# SH7612 Series Hardware Manual # **HITACHI** ADE-602-153 Rev. 0.6 03/17/98 Hitachi, Ltd. MC-Setsu ### Notice When using this document, keep the following in mind: - 1. This document may, wholly or partially, be subject to change without notice. - 2. All rights are reserved: No one is permitted to reproduce or duplicate, in any form, the whole or part of this document without Hitachi's permission. - 3. Hitachi will not be held responsible for any damage to the user that may result from accidents or any other reasons during operation of the user's unit according to this document. - 4. Circuitry and other examples described herein are meant merely to indicate the characteristics and performance of Hitachi's semiconductor products. Hitachi assumes no responsibility for any intellectual property claims or other problems that may result from applications based on the examples described herein. - 5. No license is granted by implication or otherwise under any patents or other rights of any third party or Hitachi, Ltd. - 6. MEDICAL APPLICATIONS: Hitachi's products are not authorized for use in MEDICAL APPLICATIONS without the written consent of the appropriate officer of Hitachi's sales company. Such use includes, but is not limited to, use in life support systems. Buyers of Hitachi's products are requested to notify the relevant Hitachi sales offices when planning to use the products in MEDICAL APPLICATIONS. ## Contents | Introduction | 1 | |-------------------------------------------------------------|------| | Section 1 Overview | 3 | | 1.1 Features | . 3 | | 1.2 Architecture | . 6 | | 1.3 Pin Arrangement | | | 1.4 Pin Configuration. | | | 1.5 CPU | | | 1.5.1 Fetch and Decode | | | 1.5.2 Integer Unit | | | 1.5.3 DSP Unit | | | 1.6 Peripheral Module Units | . 18 | | 1.6.1 System Controller (SYSC) | . 18 | | 1.6.2 Interrupt Controller (INTC) | | | 1.6.3 User Break Controller (UBC) | | | 1.6.4 Bus State Controller (BSC) | . 20 | | 1.6.5 Cache | 21 | | 1.6.6 Direct Memory Access Controller (DMAC) | . 21 | | 1.6.7 Division unit(DIVU) | 23 | | 1.6.8 16-bit Free-Running Timer(FRT) | . 23 | | 1.6.9 Watchdog Timer (WDT) | . 24 | | 1.6.10 Serial Communication Interface (SCI) | 25 | | 1.6.11 Smart Card Interface | . 26 | | 1.6.12 Serial Communication Interface with FIFO (SCIF) | . 26 | | 1.6.13 IrDA | . 27 | | 1.6.14 Serial I/O (SIO) | . 28 | | 1.6.15 16-bit Timer Pulse Unit (TPU) | . 28 | | 1.6.16 Hitachi User Debug Interface (H-UDI) | . 29 | | 1.6.17 Pin Function Controller | . 30 | | 1.6.18 I/O Ports | 30 | | 1.6.19 Processing States | . 30 | | Section 2 CPU | 35 | | 2.1 Register Configuration | . 35 | | 2.1.1 General Registers | | | 2.1.2 Control Registers | | | 2.1.3 System Registers | | | 2.1.4 DSP Registers | | | 2.1.5 Cautions Concerning Guard Bits and Overflow Treatment | 46 | | 2.1.6 Initial Values of Registers | 47 | |-------------------------------------------------------|-----| | 2.2 Data Formats | 48 | | 2.2.1 Data Format in Registers | 48 | | 2.2.2 Data Formats in Memory | | | 2.2.3 Immediate Data Format | | | 2.2.4 DSP Type Data Formats | 50 | | 2.2.5 DSP Type Instructions and Data Formats | 52 | | 2.3 CPU Core Instruction Features | 57 | | 2.4 Instruction Formats | 60 | | 2.4.1 CPU Instruction Addressing Modes | 60 | | 2.4.2 DSP Data Addressing | 64 | | 2.4.3 Instruction Formats for CPU Instructions | 72 | | 2.4.4 Instruction Formats for DSP Instructions | 74 | | 2.5 Instruction Set | 82 | | 2.5.1 CPU Instruction Set | 83 | | 2.5.2 DSP Data Transfer Instruction Set | 99 | | 2.5.3 DSP Operation Instruction Set | | | 2.5.4 Various Operation Instructions | 108 | | | | | Section 3 Oscillator Circuits and Operating Modes | | | 3.1 Overview | | | 3.2 On-Chip Clock Pulse Generator and Operating Modes | | | 3.2.1 Clock Pulse Generator | | | 3.2.2 Clock Operating Mode Settings | | | 3.2.3 Connecting a Crystal Oscillator | 122 | | 3.2.4 Input Method of External Clock | | | 3.2.5 Operating Frequency Selection by Register | | | 3.2.6 Operating Modes and Frequency Ranges | | | 3.2.7 Notes on Board Design | | | 3.3 Bus Width of the CS0 Area | 133 | | | | | Section 4 Exception Handling | | | 4.1 Overview | | | 4.1.1 Types of Exception Handling and Priority Order | | | 4.1.2 Exception Handling Operations | | | 4.1.3 Exception Vector Table | | | 4.2 Resets | | | 4.2.1 Types of Resets | | | 4.2.2 Power-On Reset | | | 4.2.3 Manual Reset | | | 4.3 Address Errors | | | 4.3.1 Sources of Address Errors | | | 4.3.2 Address Error Exception Handling | 144 | | 4.4 Interrupts | . 144 | |-----------------------------------------------------------------------------|-------| | 4.4.1 Interrupt Sources | . 144 | | 4.4.2 Interrupt Priority Levels | . 145 | | 4.4.3 Interrupt Exception Handling | . 145 | | 4.5 Exceptions Triggered by Instructions | . 146 | | 4.5.1 Instruction-Triggered Exception Types | . 146 | | 4.5.2 Trap Instructions | . 146 | | 4.5.3 Illegal Slot Instructions | . 147 | | 4.5.4 General Illegal Instructions | . 147 | | 4.6 When Exception Sources are Not Accepted | . 148 | | 4.6.1 Immediately after a Delayed Branch Instruction | . 148 | | 4.6.2 Immediately after an Interrupt-Disabled Instruction | . 148 | | 4.6.3 Instructions in Repeat Loops | . 148 | | 4.7 Stack Status after Exception Handling | . 150 | | 4.8 Usage Notes | . 151 | | 4.8.1 Value of Stack Pointer (SP) | . 151 | | 4.8.2 Value of Vector Base Register (VBR) | | | 4.8.3 Address Errors Caused by Stacking of Address Error Exception Handling | . 151 | | 4.8.4 Manual Reset during Register Access | . 151 | | and a first of the course | 1.50 | | Section 5 Interrupt Controller (INTC) | | | 5.1 Overview | | | 5.1.1 Features | | | 5.1.2 Block Diagram | | | 5.1.3 Pin Configuration | | | 5.1.4 Register Configuration | | | 5.2 Interrupt Sources | | | 5.2.1 NMI Interrupt | | | 5.2.2 User Break Interrupt | | | 5.2.3 Hitachi-UDI Interrupt | | | 5.2.4 IRL Interrupts | | | 5.2.5 IRQ Interrupts | | | 5.2.6 On-chip Peripheral Module Interrupts | | | 5.2.7 Interrupt Exception Vectors and Priority Order | | | 5.3 Description of Registers | | | 5.3.1 Interrupt Priority Level Setting Register A (IPRA) | | | 5.3.2 Interrupt Priority Level Setting Register B (IPRB) | | | 5.3.3 Interrupt Priority Level Setting Register C (IPRC) | | | 5.3.4 Interrupt Priority Level Setting Register D (IPRD) | | | 5.3.5 Interrupt Priority Level Setting Register E (IPRE) | | | 5.3.6 Vector Number Setting Register WDT (VCRWDT) | | | 5.3.7 Vector Number Setting Register A (VCRA) | | | 5.3.8 Vector Number Setting Register B (VCRB) | . 176 | | | 5.3.9 Vector Number Setting Register C (VCRC) | 177 | |--------|---------------------------------------------------------------|-----| | | 5.3.10 Vector Number Setting Register D (VCRD) | 178 | | | 5.3.11 Vector Number Setting Register E (VCRE) | 178 | | | 5.3.12 Vector Number Setting Register F(VCRF) | 179 | | | 5.3.13 Vector Number Setting Register G (VCRG) | 180 | | | 5.3.14 Vector Number Setting Register H (VCRH) | 180 | | | 5.3.15 Vector Number Setting Register I (VCRI) | 181 | | | 5.3.16 Vector Number Setting Register J (VCRJ) | 182 | | | 5.3.17 Vector Number Setting Register K (VCRK) | 183 | | | 5.3.18 Vector Number Setting Register L (VCRL) | 184 | | | 5.3.19 Vector Number Setting Register M (VCRM) | 185 | | | 5.3.20 Vector Number Setting Register N (VCRN) | 186 | | | 5.3.21 Vector Number Setting Register O (VCRO) | 187 | | | 5.3.22 Vector Number Setting Register P (VCRP) | 188 | | | 5.3.23 Vector Number Setting Register Q (VCRQ) | 189 | | | 5.3.24 Vector Number Setting Register R (VCRR) | 190 | | | 5.3.25 Vector Number Setting Register S (VCRS) | 191 | | | 5.3.26 Vector Number Setting Register T (VCRT) | 192 | | | 5.3.27 Vector Number Setting Register U (VCRU) | 193 | | | 5.3.28 Interrupt Control Register (ICR) | 196 | | | 5.3.29 IRQ Control/Status Register (IRQCSR) | 197 | | 5.4 In | terrupt Operation | 200 | | | 5.4.1 Interrupt Sequence | | | | 5.4.2 Stack Status after Ending Interrupt Exceptions Handling | | | 5.5 In | terrupt Response Time | 203 | | | ampling of Pins IRL3–IRL0 | | | 5.7 U | sage Notes | 205 | | | | | | | on 6 User Break Controller | | | 6.1 O | verview | | | | 6.1.1 Features | 209 | | | 6.1.2 Block Diagram | | | | 6.1.3 Register Configuration | | | 6.2 Re | egister Descriptions | | | | 6.2.1 Break Address Register A (BARA) | | | | 6.2.2 Break Address Mask Register A (BAMRA) | | | | 6.2.3 Break Bus Cycle Register A (BBRA) | | | | 6.2.4 Break Address Register B (BARB) | | | | 6.2.5 Break Address Mask Register B (BAMRB) | | | | 6.2.6 Break Data Register B (BDRB) | | | | 6.2.7 Break Data Mask Register B (BDMRB) | | | | 6.2.8 Break Bus Cycle Register B (BBRB) | 223 | | | 6.2.9 Break Control Register (BRCR) | 224 | | 6.2.10 Execution Times Break Register (BETR) | . 227 | |-----------------------------------------------------|-------| | 6.2.11 Branch Source Register (BRSR) | . 228 | | 6.2.12 Branch Destination Register (BRDR) | 229 | | 6.2.13 Branch Flag Register (BRFR) | 230 | | 6.3 Operation | . 231 | | 6.3.1 Flow of the User Break Operation | . 231 | | 6.3.2 Break on Instruction Fetch Cycle | 232 | | 6.3.3 Break on Data Access Cycle | . 232 | | 6.3.4 Program Counter (PC) Values Saved | . 233 | | 6.3.5 X Memory or Y Memory Bus Cycle Breaks | 234 | | 6.3.6 Sequential Breaks | 234 | | 6.3.7 PC Trace | 235 | | 6.3.8 Example of Use | . 237 | | 6.3.9 Usage Notes | . 241 | | | | | Section 7 Bus State Controller (BSC) | .243 | | 7.1 Overview | . 243 | | 7.1.1 Features | . 243 | | 7.1.2 Block Diagram | . 244 | | 7.1.3 Pin Configuration | 245 | | 7.1.4 Register Configuration | . 246 | | 7.1.5 Address Map | . 247 | | 7.2 Description of Registers | 250 | | 7.2.1 Bus Control Register 1 (BCR1) | 250 | | 7.2.2 Bus Control Register 2 (BCR2) | 253 | | 7.2.3 Bus Control Register 3 (BCR3) | 254 | | 7.2.4 Wait Control Register 1 (WCR1) | . 256 | | 7.2.5 Wait Control Register 2 (WCR2) | . 258 | | 7.2.6 Wait Control Register 3 (WCR3) | . 260 | | 7.2.7 Individual Memory Control Register (MCR) | 261 | | 7.2.8 Refresh Timer Control/Status Register (RTCSR) | . 266 | | 7.2.9 Refresh Timer Counter (RTCNT) | 268 | | 7.2.10 Refresh Time Constant Register (RTCOR) | | | 7.3 Access Size and Data Alignment | . 270 | | 7.3.1 Connection to Ordinary Devices | 270 | | 7.3.2 Connection to Little-Endian Devices | .271 | | 7.4 Accessing Ordinary Space | . 273 | | 7.4.1 Basic Timing | | | 7.4.2 Wait State Control | | | 7.4.3 CS Assertion Period Extension. | . 283 | | 7.5 Synchronous DRAM Interface | | | 7.5.1 Synchronous DRAM Direct Connection | 284 | | 7.5.2 Address Multiplexing | 286 | | 7.5.3 Burst Reads | 288 | |--------------------------------------------|------| | 7.5.4 Single Reads | 290 | | 7.5.5 Single Writes | 291 | | 7.5.6 Burst Write Mode | 292 | | 7.5.7 Bank Active Function | 294 | | 7.5.8 Refreshes | 301 | | 7.5.9 Power-On Sequence | 304 | | 7.6 DRAM Interface | | | 7.6.1 DRAM Direct Connection | 306 | | 7.6.2 Address Multiplexing | 307 | | 7.6.3 Basic Timing | 308 | | 7.6.4 Wait State Control | 309 | | 7.6.5 Burst Access | 310 | | 7.6.6 EDO Mode | 311 | | 7.6.7 DRAM Single Transfer | 316 | | 7.6.8 Refreshing | 317 | | 7.6.9 Power-On Sequence | 318 | | 7.7 Burst ROM Interface | 319 | | 7.8 Waits between Access Cycles | 322 | | 7.9 Bus Arbitration | 324 | | 7.9.1 Master Mode | | | 7.10 Other Topics | 327 | | 7.10.1 Resets | 327 | | 7.10.2 Access as Seen from the CPU or DMAC | 327 | | Section 8 Cache | 329 | | 8.1 Introduction | 329 | | 8.1.2 Register Configuration | 330 | | 8.2 Cache Control Register (CCR) | 331 | | 8.2.1 Cache Control Register (CCR) | | | 8.3 Address Space and the Cache | 333 | | 8.4 Cache Operation | 334 | | 8.4.1 Cache Reads | 334 | | 8.4.2 Write Access | 336 | | 8.4.3 Cache-Through Access | 339 | | 8.4.4 The TAS Instruction | 339 | | 8.4.5 Pseudo-LRU and Cache Replacement | 340 | | 8.4.6 Cache Initialization | 341 | | 8.4.7 Associative Purges | 342 | | 8.4.8 Data Array Access | | | 8.4.9 Address Array Access | 343 | | 8.5 Cache Use | 345 | | 8 5 1 Initialization | 3/15 | | 8.5.2 Purge of Specific Lines | 345 | |-----------------------------------------------------------------------------|--------| | 8.5.3 Cache Data Coherency | 346 | | 8.5.4 Two-Way Cache Mode | 347 | | 8.5.5 Usage Notes | 348 | | Section 9 Direct Memory Access Controller (DMAC) | 349 | | 9.1 Overview | | | 9.1.1 Features | | | 9.1.2 Block Diagram | | | 9.1.3 Pin Configuration | | | 9.1.4 Register Configuration | | | 9.2 Register Descriptions | | | 9.2.1 DMA Source Address Registers 0 and 1 (SAR0 and SAR1) | | | 9.2.2 DMA Destination Address Registers 0 and 1 (DAR0 and DAR1) | | | 9.2.3 DMA Transfer Count Registers 0 and 1 (TCR0 and TCR1) | | | 9.2.4 DMA Channel Control Registers 0 and 1 (CHCR0 and CHCR1) | | | 9.2.5 DMA Vector Number Registers 0 and 1 (VCRDMA0, VCRDMA1) | 361 | | 9.2.6 DMA Request/Response Selection Control Registers 0 and 1 (DRCR0, DRCF | R1)361 | | 9.2.7 DMA Operation Register (DMAOR) | | | 9.3 Operation | 366 | | 9.3.1 DMA Transfer Flow | 366 | | 9.3.2 DMA Transfer Requests | 367 | | 9.3.3 Channel Priorities | 371 | | 9.3.4 DMA Transfer Types | 374 | | 9.3.5 Number of Bus Cycles | 381 | | 9.3.6 DMA Transfer Request Acknowledge Signal Output Timing | 381 | | 9.3.7 DREQ Pin Input Detection Timing | 391 | | 9.3.8 DMA Transfer End | 399 | | 9.4 Examples of Use | 400 | | 9.4.1 DMA Transfer Between On-Chip SCI and External Memory | 400 | | 9.5 Usage Notes | 401 | | Section 10 Division Unit | 403 | | 10.1 Overview | | | 10.1.1 Features | | | 10.1.2 Block Diagram | | | 10.1.3 Register Configuration | | | 10.2 Description of Registers | | | 10.2.1 Divisor Register (DVSR) | | | 10.2.2 Dividend Register L for 32-Bit Division (DVDNT) | | | 10.2.3 Division Control Register (DVCR) | | | 10.2.4 Vector Number Setting Register DIV (VCRDIV) | | | 10.2.5 Dividend Register H (DVDNTH) | | | 10.2.6 Dividend Register L (DVDNTL) | 408 | |-----------------------------------------------------------|-----| | 10.3 Operation | 409 | | 10.3.1 64-Bit ÷ 32-Bit Operations | 409 | | 10.3.2 32-Bit ÷ 32-Bit Operations | 409 | | 10.3.3 Handling of Overflows | 409 | | 10.4 Usage Notes | 410 | | 10.4.1 Access | 410 | | 10.4.2 Overflow Flag | 410 | | Section 11 16-Bit Free-Running Timer | 413 | | 11.1 Overview | 413 | | 11.1.1 Features | 413 | | 11.1.2 Block Diagram | 414 | | 11.1.3 Pin Configuration | 415 | | 11.1.4 Register Configuration | 415 | | 11.2 Register Descriptions | 416 | | 11.2.1 Free-Running Counter (FRC) | 416 | | 11.2.2 Output Compare Registers A and B (OCRA and OCRB) | 416 | | 11.2.3 Input Capture Register (FICR) | 417 | | 11.2.4 Timer Interrupt Enable Register (TIER) | | | 11.2.5 Free-Running Timer Control/Status Register (FTCSR) | | | 11.2.6 Timer Control Register (TCR) | | | 11.2.7 Timer Output Compare Control Register (TOCR) | | | 11.3 CPU Interface | 422 | | 11.4 Operation | 425 | | 11.4.1 FRC Count Timing | | | 11.4.2 Output Timing for Output Compare | | | 11.4.3 FRC Clear Timing | 426 | | 11.4.4 Input Capture Input Timing | 427 | | 11.4.5 Input Capture Flag (ICF) Setting Timing | | | 11.4.6 Output Compare Flag (OCFA, OCFB) Setting Timing | | | 11.4.7 Timer Overflow Flag (OVF) Setting Timing | | | 11.5 Interrupt Sources | 430 | | 11.6 Example of FRT Use | 430 | | 11.7 Usage Notes | 431 | | Section 12 Watchdog Timer (WDT) | 437 | | 12.1 Overview | | | 12.1.1 Features | 437 | | 12.1.2 Block Diagram | | | 12.1.3 Pin Configuration | | | 12.1.4 Register Configuration | 439 | | 12.2 Register Descriptions | 440 | | 12.2.1 Watchdog Timer Counter (WTCNT) | 440 | |-----------------------------------------------------------------|-----| | 12.2.2 Watchdog Timer Control/Status Register (WTCSR) | 440 | | 12.2.3 Reset Control/Status Register (RSTCSR) | 442 | | 12.2.4 Notes on Register Access | 443 | | 12.3 Operation | | | 12.3.1 Operation in Watchdog Timer Mode | 445 | | 12.3.2 Operation in Interval Timer Mode | 447 | | 12.3.3 Operation when Standby Mode is Cleared | 447 | | 12.3.4 Timing of Overflow Flag (OVF) Setting | 448 | | 12.3.5 Timing of Watchdog Timer Overflow Flag (WOVF) Setting | 448 | | 12.4 Usage Notes | 449 | | 12.4.1 Contention between WTCNT Write and Increment | 449 | | 12.4.2 Changing CKS2 to CKS0 Bit Values | 449 | | 12.4.3 Switching between Watchdog Timer and Interval Timer Mode | 449 | | 12.4.4 System Reset with WDTOVF | 450 | | 12.4.5 Internal Reset in Watchdog Timer Mode | 450 | | | | | Section 13 Serial Communication Interface | 451 | | 13.1 Overview | 451 | | 13.1.1 Features | 451 | | 13.1.2 Block Diagram | | | 13.1.3 Pin Configuration | 453 | | 13.1.4 Register Configuration | | | 13.2 Register Descriptions | 454 | | 13.2.1 Receive Shift Register (RSR) | | | 13.2.2 Receive Data Register (RDR) | | | 13.2.3 Transmit Shift Register (TSR) | 454 | | 13.2.4 Transmit Data Register (TDR) | | | 13.2.5 Serial Mode Register (SMR) | | | 13.2.6 Serial Control Register (SCR) | | | 13.2.7 Serial Status Register (SSR) | 461 | | 13.2.8 Bit Rate Register (BRR) | | | 13.3 Operation | | | 13.3.1 Overview | | | 13.3.2 Operation in Asynchronous Mode | 474 | | 13.3.3 Multiprocessor Communication | | | 13.3.4 Clocked Synchronous Operation | | | 13.4 SCI Interrupt Sources and the DMAC | 501 | | 13.5 Usage Notes | 501 | | | =0= | | Section 14 Smart Card Interface | | | 14.1 Overview | | | 1/1 1 Features | 505 | | 14.1.2 Block Diagram | 506 | |--------------------------------------------------------------------|-----| | 14.1.3 Pin Configuration | 507 | | 14.1.4 Register Configuration | 507 | | 14.2 Register Descriptions | 508 | | 14.2.1 Smart Card Mode Register (SCMR) | | | 14.2.2 Serial Mode Register (SMR) | 509 | | 14.2.3 Serial Control Register (SCR) | | | 14.2.4 Serial Status Register (SSR) | | | 14.3 Operation | 513 | | 14.3.1 Overview | 513 | | 14.3.2 Pin Connections | 513 | | 14.3.3 Data Format | 515 | | 14.3.4 Register Settings | 516 | | 14.3.5 Clock | 518 | | 14.3.6 Data Transmission and Reception | 521 | | 14.4 Usage Notes | 527 | | 14.4.1 Receive Data Timing and Receive Margin in Asynchronous Mode | 527 | | 14.4.2 Retransmission (Receive and Transmit Modes) | 529 | | | | | Section 15 Serial Communication Interface with FIFO (SCIF) | 531 | | 15.1 Overview | 531 | | 15.1.1 Features | 531 | | 15.1.2 Block Diagram | 532 | | 15.1.3 Pin Configuration | 533 | | 15.1.4 Register Configuration | 534 | | 15.2 Register Descriptions | 535 | | 15.2.1 Receive Shift Register (SCRSR) | 535 | | 15.2.2 Receive FIFO Data Register (SCFRDR) | 535 | | 15.2.3 Transmit Shift Register (SCTSR) | 535 | | 15.2.4 Transmit FIFO Data Register (SCFTDR) | 536 | | 15.2.5 Serial Mode Register (SCSMR) | 536 | | 15.2.6 Serial Control Register (SCSCR) | 538 | | 15.2.7 Serial Status Register (SCSSR) | 540 | | 15.2.8 Bit Rate Register (SCBRR) | | | 15.2.9 FIFO Control Register (SCFCR) | 552 | | 15.2.10 FIFO Data Count Register (SCFDR) | 555 | | 15.3 Operation | 556 | | 15.3.1 Overview | 556 | | 15.3.2 Serial Operation | 558 | | 15.4 SCIF Interrupts | 568 | | 15.5 Usage Notes | 569 | | | | | Section 16 IrDA | 573 | | 16.1 Overview | . 573 | |-----------------------------------------------|-------| | 16.1.1 Features | . 573 | | 16.1.2 Block Diagram | . 574 | | 16.1.3 Pin Configuration | . 574 | | 16.1.4 Register Configuration | | | 16.2 Register Description | .576 | | 16.2.1 Serial Mode Register (SCSMR) | . 576 | | 16.3 Operation | . 578 | | 16.3.1 Overview | . 578 | | 16.3.2 Transmission | . 578 | | 16.3.3 Reception | . 578 | | Section 17 Serial I/O (SIO) | .581 | | 17.1 Overview | . 581 | | 17.1.1 Features | . 581 | | 17.2 Register Configuration | . 584 | | 17.2.1 Receive Shift Register (SIRSR) | . 584 | | 17.2.2 Receive Data Register (SIRDR) | | | 17.2.3 Transmit Shift Register (SITSR) | | | 17.2.4 Transmit Data Register (SITDR) | . 586 | | 17.2.5 Serial Control Registers (SICTR) | . 586 | | 17.2.6 Serial Status Register (SISTR) | . 588 | | 17.3 Operation | . 591 | | 17.3.1 Input | . 591 | | 17.3.2 Output | . 592 | | 17.4 SIO Interrupt Sources and the DMAC | . 596 | | Section 18 16-Bit Timer Pulse Unit (TPU) | .597 | | 18.1 Overview | . 597 | | 18.1.1 Features | . 597 | | 18.1.2 Block Diagram | . 601 | | 18.1.3 Pin Configuration | . 602 | | 18.1.4 Register Configuration | . 603 | | 18.2 Register Descriptions | 604 | | 18.2.1 Timer Control Register (TCR) | 604 | | 18.2.2 Timer Mode Register (TMDR) | | | 18.2.3 Timer I/O Control Register (TIOR) | . 610 | | 18.2.4 Timer Interrupt Enable Register (TIER) | | | 18.2.5 Timer Status Register (TSR) | . 620 | | 18.2.6 Timer Counter (TCNT) | 624 | | 18.2.7 Timer General Register (TGR) | 625 | | 18.2.8 Timer Start Register (TSTR) | | | 18.2.9 Timer Synchro Register (TSYR) | | | 18.3 Interface to Bus Master | 628 | |-------------------------------------------------|-----| | 18.3.1 16-Bit Registers | 628 | | 18.3.2 8-Bit Registers | 628 | | 18.4 Operation | 630 | | 18.4.1 Overview | | | 18.4.2 Basic Functions | 631 | | 18.4.3 Synchronous Operation | 637 | | 18.4.4 Buffer Operation | 639 | | 18.4.5 PWM Modes | 642 | | 18.4.6 Phase Counting Mode | 647 | | 18.5 Interrupts | 652 | | 18.5.1 Interrupt Sources and Priorities | 652 | | 18.5.2 DMAC Activation | 653 | | 18.6 Operation Timing | 654 | | 18.6.1 Input/Output Timing | 654 | | 18.6.2 Interrupt Signal Timing | 658 | | 18.7 Usage Notes | 662 | | Section 19 Hitachi User Debug Interface (H-UDI) | 671 | | 19.1.1 Features | | | 19.1.2 H-UDI Block Diagram | | | 19.1.3 Pin Configuration | | | 19.1.4 Register Configuration | | | 19.2 External Signals | | | 19.2.1 Test Clock (TCK) | | | 19.2.2 Test Mode Select (TMS) | | | 19.2.3 Test Data Input (TDI) | | | 19.2.4 Test Data Output (TDO) | | | 19.2.5 Test Reset (TRST) | | | 19.3 Registers | | | 19.3.1 Instruction Register (SDIR) | | | 19.3.2 Status Register (SDSR) | | | 19.3.3 Data Register (SDDR) | | | 19.3.4 Bypass Register (SDBPR) | | | 19.4 Operation | | | 19.4.1 H-UDI Interrupt | | | 19.4.2 Bypass Mode | | | 19.4.3 Resetting the H-UDI | | | 19.5 Precautions | 684 | | Section 20 Pin Function Controller | 685 | | | 685 | | 20.2 Register Configuration | | |------------------------------------------------------|--| | 20.3 Description of Registers | | | 20.3.1 Port A Control Register (PACR) | | | 20.3.2 Port A I/O Register (PAIOR) | | | 20.3.3 Port B Control Registers (PBCR, PBCR2)690 | | | 20.3.4 Port B I/O Register (PBIOR) | | | | | | Section 21 I/O Ports | | | 21.1 Overview | | | 21.2 Port A | | | 21.2.1 Register Configuration | | | 21.2.2 Port A Data Register (PADR) | | | 21.3 Port B | | | 21.3.1 Register Configuration | | | 21.3.2 Port B Data Register (PBDR) | | | | | | Section 22 Power-Down Modes | | | 22.1 Overview | | | 22.1.1 Power-Down Modes | | | 22.1.2 Register | | | 22.2 Register Description | | | 22.2.1 Standby Control Register 1 (SBYCR1) | | | 22.2.2 Standby Control Register 2 (SBYCR2) | | | 22.3 Sleep Mode | | | 22.3.1 Transition to Sleep Mode | | | 22.3.2 Canceling Sleep Mode | | | 22.4 Standby Mode | | | 22.4.1 Transition to Standby Mode711 | | | 22.4.2 Canceling Standby Mode | | | 22.4.3 Standby Mode Cancellation by NMI Interrupt713 | | | 22.4.4 Clock Pause Function | | | 22.4.5 Notes on Standby Mode | | | 22.5 Module Standby Function | | | 22.5.1 Transition to Module Standby Function | | | 22.5.2 Clearing the Module Standby Function | | | | | | Section 23 Electrical Characteristics | | | 23.1 Absolute Maximum Ratings | | | 23.2 DC Characteristics | | | 23.3 AC Characteristics | | | 23.3.1 Bus Timing | | | Appendix A Pin States | | | A.1 Pin States i | n Reset, Power-Down State, and Bus-Released State | . 761 | |------------------|---------------------------------------------------|-------| | Appendix B | Package Dimensions | .765 | xiv HITACHI ## Introduction SH7612 (SH-DSP) is a new-generation RISC microprocessor which integrates RISC (Reduced Instruction Set Computer) CPU required for a complete system configuration, high-performance DSP unit, and peripheral function on one chip. SH7612 also achieves low power consumption, which is indispensable for portable equipment. SH7612 has a RISC instruction set. The basic instruction is executed in one processor clock cycle, which improves the instruction execution rate. Furthermore, CPU adopts internal 32-bit architecture to expand the data processing functions. This hardware manual describes the configuration of SH7612 and details of operation. For details of the instruction, refer to the programming manual. Related Manual SH-DSP programming manual (Data No.ADJ-602-141A) For details of the development environment system, please inquire to our company's sales office. ## Section 1 Overview #### 1.1 Features The SH7612 is a single-chip device that combines the functions of a reduced instruction set computer (RISC) processor and a digital signal processing (DSP) processor. It is ideally suited for applications that require both microcontroller and DSP type processing. Traditionally, such applications have required two chips: a microcontroller and a DSP chip. The SH7612 offers an economical, one-chip solution for such applications. The single-chip solution, which the SH7612 provides, lowers development and system costs. The unified memory and single instruction stream simplify the design. A single processor removes the need to support inter-processor communication. Moreover, a single processor needs only one emulator. Power consumption can also be reduced through the special power-down states. The SH7612 is upwardly compatible with the Hitachi SH-1 and SH-2 object code. While the SH-2 processors provide basic DSP capabilities such as the multiply-accumulate function, this LSI provides a full DSP type data bus and advanced DSP operations, including single-cycle 16-bit by 16-bit signed multiplication, barrel shifting, priority encoding, rounding, and modulo addressing. The processor performs DSP operations in fixed-point arithmetic, providing guard bits to protect against overflows. The SH7612 uses a RISC architecture like that of the SH-2 family processors. By using a five-stage pipeline system, it can execute most instructions in a single processor clock cycle and provide very high performance. Its enhanced instruction set consists of all of the SH-2 instructions plus many extensions for DSP programming. These include parallel DSP instructions, which execute multiple operations simultaneously, zero-overhead loop control, modulo addressing, and dual addressing. The SH7612 uses both a standard von Neumann architecture (both instructions and data share a single bus) for the integer unit and an extended Harvard architecture (instructions and data have separate buses) for the DSP unit. The Harvard architecture allows simultaneous access to the program code and two on-chip memory spaces, called X memory and Y memory, for the efficient implementation of DSP algorithms. This manual describes all of the hardware features of the SH7612, with emphasis on interfaces to the LSI through the many on-chip peripheral modules. #### The features of the SH7612 include: - Architecture - Original Hitachi architecture - 32/40-bit internal data bus - von Neumann architecture for integer instructions and extended Harvard architecture for DSP instructions - Registers - Sixteen 32-bit general registers (R0 to R15) - Eight DSP registers: six 32-bits wide (X0, X1, Y0, Y1, M0, M1) and two 40-bits wide (A0, A1) - Four 32-bit system registers (MACH, MACL, PR, PC) - Seven 32-bit control registers: three for 16-bit integer instructions (SR, GBR, VBR) and four for 32-bit DSP instructions (RS, RE, MOD, DSR) - Address space - 4 Gbytes address space (160 Mbytes of external memory space) - On-chip memory: 16 kbytes of RAM - Modulo addressing - Indirect addressing with pointer update (increment, decrement, indexed) - Dual-addressing capability to support two memory accesses per clock cycle - Five-stage pipeline - Instruction set - Single instruction stream for both 16-bit and 32-bit instructions - Parallel instructions: 32-bit length allows up to four operations to be executed simultaneously - Load-store architecture (basic arithmetic and logic operations are performed on register values) - Delayed branches to reduce pipeline disruption (delayed branching is performed to prevent an instruction fetched into the pipeline from being discarded due to execution of a branch instruction) - Conditional DSP instruction execution - Optimized for C programming language implementation - On-chip debugging functions - Instruction execution time - One instruction/cycle for basic instructions - Zero-overhead loop control - Arithmetic operations - Two ALUs - Two shifters 4 - Arithmetic and logical barrel shifting - Most-significant bit detection (priority encoding) - Guard bits to protect against overflow - Saturation arithmetic - On-chip multipliers - DSP multiplication operations executed in one cycle (16 bits $\times$ 16 bits $\rightarrow$ 32 bits) - Integer multiplication operations execute in one to three cycles (16 bits × 16 bits → 32 bits) or two to four cycles (32 bits × 32 bits → 64 bits), and multiply-accumulate operations execute in two to three cycles (16 bits × 16 bits + 64 bits → 64 bits) or two to four cycles (32 bits × 32 bits + 64 bits → 64 bits) - On-chip peripheral modules - System controller (SYSC) - Interrupt controller (INTC) - User break controller (UBC) - Bus state controller (BSC) - Cache - Direct memory access controller (DMAC): two channels - Division unit (DIVU) - 16-bit free-running timer (FRT): one channel - Watchdog timer (WDT) - Serial communication interface (SCI): one channel - Smart card interface: one channel - Serial communication interface with FIFO (SCIF): two channels - IrDA - Serial I/O (SIO): three channels - 16-bit timer pulse unit (TPU): three channels - Hitachi user debug interface (H-UDI) - Processing states - Reset state (power-on reset and manual reset) - Exception processing state - Program execution state - Power-down states: sleep mode, standby mode, and module standby mode - Bus release state #### 1.2 Architecture Figure 1.1 shows a block diagram of the SH7612. This LSI consists of a CPU, peripheral modules, and on-chip memory linked by five different buses. Figure 1.1 SH7612 Block Diagram The CPU contains a fetch and decode unit, an integer unit, a DSP unit, and associated registers (general, DSP, control, and system). The fetch and decode unit reads instructions and controls both the integer and DSP units. The integer unit has the capabilities of an SH-2 CPU, with some features to support DSP operations. The DSP unit performs advanced DSP functions and has its own set of registers and separately addressable memory spaces called the X data and Y memories. The SH-DSP instruction set consists of the additional instructions that achieve these functions, in addition to the conventional SH-2 instructions. The CPU interfaces to external logic through the peripheral modules, as shown on the right side of figure 1.1. In addition to the external bus, the SH7612 has five internal buses: - Cache bus or C-bus (CAB, CDB): 32-bit address, 32-bit data - Internal bus or I-bus (IAB, IDB): 32-bit address, 32-bit data - X-bus (XAB, XDB): 15-bit address, 16-bit data - Y-bus (YAB, YDB): 15-bit address, 16-bit data - Peripheral bus: 16-bit data The C-bus transfers both instructions and data. The CPU can access any region of address space, including external space through the C-bus. All MOV and MOVS operations use the C-bus. MOVX operations use the X-bus, and MOVY operations use the Y-bus. The X -data and Y-data buses, XDB and YDB, can access only word data, so they are 16 bits wide. The SH7612 integer unit uses the C-bus to transfer instructions and data (von Neumann architecture). The DSP unit also uses the C-bus to transfer instructions and data, but it can also use the two additional internal buses, called the X-bus and Y-bus, to access data from the X memory and Y memory simultaneously (extended-Harvard architecture). The I-bus can be used to address any memory space, including external memory and on-chip memory. When accessing external memory, the I-bus connects to the external bus through the BSC. The DSP unit has the X-bus and Y-bus available for data transfer operations. Each of these buses consists of a 15-bit address bus, XAB or YAB, and a 16-bit data bus, XDB or YDB. The address buses are only 15 bits wide because they can access only aligned word-length data, so the least-significant bit of the 16-bit address is always zero. The CPU uses the X-bus and Y-bus to access X memory and Y memory data. The CPU accesses to the cache memory and the internal memory using the C-bus. The access to other spaces is from the C-bus via the I-bus. The DMAC allows to access to the space other than the cache memory using the I-bus. The SH7612 also has a peripheral bus for accessing peripheral modules through the BSC. This 16-bit data bus allows the CPU and DMAC to access the memory-mapped registers in the peripheral modules. The UBC monitors the C-bus, I-bus, X-bus, and Y-bus for break conditions. When a break condition is met, an interrupt is requested. ### 1.3 Pin Arrangement Figure 1.2 shows the pin arrangement. Table 1.1 lists the pins. Figure 1.2 SH7612 Pin Arrangement (FP-176) ## 1.4 Pin Configuration | Pin Number | Pin Name | Input/Output | Terminal description | |------------|-----------|--------------|----------------------------------------| | 1 | NMI | 1 | Non-maskable interrupt request | | 2 | RES | 1 | Reset | | 3 | Vcc* | I | Power | | 4 | Vss | 1 | Ground | | 5 | Vss | 1 | Ground | | 6 | Vcc (PLL) | 1 | Power for on-chip PLL | | 7 | CAP1 | 0 | External capacity terminal for PLL | | 8 | Vss (PLL) | 1 | Ground for on-chip PLL | | 9 | MD4 | 1 | Operational mode terminal | | 10 | CAP2 | 0 | External capacity terminal for PLL | | 11 | Vcc | 1 | Power | | 12 | MD3 | 1 | Operational mode terminal | | 13 | Vss | 1 | Ground | | 14 | EXTAL | 1 | Crystal oscillator connection terminal | | 15 | MD2 | 1 | Operational mode terminal | | 16 | XTAL | 0 | Crystal oscillator connection terminal | | 17 | Vss | 1 | Ground | | 18 | CKIO | Ю | System clock input- output | | 19 | Vcc | 1 | Power | | 20 | MD1 | 1 | Operational mode terminal | | 21 | Vss | 1 | Ground | | 22 | MD0 | I | Operational mode terminal | | 23 | D0 | Ю | Data bus | | 24 | D1 | Ю | Data bus | | 25 | D2 | Ю | Data bus | | 26 | Vcc | I | Power | | 27 | D3 | Ю | Data bus | | 28 | Vss | 1 | Ground | | 29 | D4 | Ю | Data bus | | 30 | D5 | Ю | Data bus | | 31 | D6 | Ю | Data bus | | 32 | D7 | Ю | Data bus | | | | | | | Pin Number | Pin Name | Input/Output | Terminal description | |------------|----------|--------------|----------------------| | 33 | D8 | Ю | Data bus | | 34 | Vcc | I | Power | | 35 | D9 | Ю | Data bus | | 36 | Vss | I | Ground | | 37 | D10 | Ю | Data bus | | 38 | D11 | Ю | Data bus | | 39 | D12 | Ю | Data bus | | 40 | D13 | Ю | Data bus | | 41 | D14 | Ю | Data bus | | 42 | Vcc | I | Power | | 43 | D15 | Ю | Data bus | | 44 | Vss | I | Ground | | 45 | D16 | Ю | Data bus | | 46 | D17 | Ю | Data bus | | 47 | D18 | Ю | Data bus | | 48 | D19 | Ю | Data bus | | 49 | D20 | Ю | Data bus | | 50 | Vcc | 1 | Power | | 51 | D21 | Ю | Data bus | | 52 | Vss | I | Ground | | 53 | D22 | Ю | Data bus | | 54 | D23 | Ю | Data bus | | 55 | D24 | Ю | Data bus | | 56 | D25 | Ю | Data bus | | 57 | D26 | Ю | Data bus | | 58 | Vcc | I | Power | | 59 | D27 | Ю | Data bus | | 60 | Vss | I | Ground | | 61 | D28 | Ю | Data bus | | 62 | D29 | Ю | Data bus | | 63 | D30 | Ю | Data bus | | 64 | D31 | Ю | Data bus | | 65 | BGR | 0 | Bus grant | | Pin Name | Input/Output | Terminal description | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BRLS | I | Bus request | | DACK0 | 0 | DMAC channel 0 acknowledge | | DACK1 | 0 | DMAC channel 1 acknowledge | | DREQ0 | I | DMAC channel 0 request | | DREQ1 | 1 | DMAC channel 1 request | | WAIT | I | Hardware weight request | | RAS | 0 | RAS for DRAM, SDRAM | | Vcc | 1 | Power | | CAS/OE | 0 | CAS for SDRAM/ OE for DRAM(EDO mode) | | Vss | I | Ground | | DQMUU/WE3 | 0 | Most significant byte selection signal for SRAM, SDRAM | | DQMUL/WE2 | 0 | 2nd byte selection signal for SRAM, SDRAM | | DQMLU/WE1 | 0 | 3rd byte selection signal for SRAM, SDRAM | | DQMLL/WE0 | 0 | Least significant byte selection signal for SRAM, SDRAM | | CAS3 | 0 | Most significant byte selection signal for DRAM | | CAS2 | 0 | 2nd byte selection signal for DRAM | | CAS1 | 0 | 3rd byte selection signal for DRAM | | CAS0 | 0 | Least significant byte selection signal for DRAM | | CKE | 0 | SDRAM clock enable control | | RD | 0 | Read pulse | | Vcc | I | Power | | REFOUT | 0 | External refresh request signal | | Vss | I | Ground | | BS | 0 | Bus cycle start | | CS0 | 0 | Chip select 0 | | CS1 | 0 | Chip select 1 | | CS2 | 0 | Chip select 2 | | CS3 | 0 | Chip select 3 | | CS4 | 0 | Chip select 4 | | RD/WR | 0 | Read/Write | | A0 | 0 | Address bus | | | BRLS DACK0 DACK1 DREQ0 DREQ1 WAIT RAS Vcc CAS/OE Vss DQMUU/WE3 DQMUL/WE2 DQMLU/WE1 DQMLL/WE0 CAS3 CAS2 CAS1 CAS0 CKE RD Vcc REFOUT Vss BS CS0 CS1 CS2 CS4 RD/WR | BRLS I DACK0 O DACK1 O DREQ0 I DREQ1 I WAIT I RAS O V∞c I CAS/OE O Vss I DQMUU/WE3 O DQMUL/WE2 O DQMLU/WE1 O DQMLL/WE0 O CAS3 O CAS2 O CAS1 O CAS2 O CAS2 O CAS3 O CKE O RD O Vcc I REFOUT O Vss I BS O CS0 O CS1 O CS2 O CS3 O CS4 O RD/WR O | | 97 | A1<br>A2<br>Vcc | 0 | Address bus | |-----|-----------------|---|-------------| | | | 0 | | | | Vcc | | Address bus | | 99 | | I | Power | | 100 | A3 | 0 | Address bus | | 101 | Vss | I | Ground | | 102 | A4 | 0 | Address bus | | 103 | A5 | 0 | Address bus | | 104 | A6 | 0 | Address bus | | 105 | A7 | 0 | Address bus | | 106 | A8 | 0 | Address bus | | 107 | Vcc | I | Power | | 108 | A9 | 0 | Address bus | | 109 | Vss | I | Ground | | 110 | A10 | 0 | Address bus | | 111 | Vcc | I | Power | | 112 | A11 | 0 | Address bus | | 113 | Vss | I | Ground | | 114 | A12 | 0 | Address bus | | 115 | A13 | 0 | Address bus | | 116 | A14 | 0 | Address bus | | 117 | Vcc | I | Power | | 118 | A15 | 0 | Address bus | | 119 | Vss | I | Ground | | 120 | A16 | 0 | Address bus | | 121 | A17 | 0 | Address bus | | 122 | A18 | 0 | Address bus | | 123 | A19 | 0 | Address bus | | 124 | A20 | 0 | Address bus | | 125 | Vcc | I | Power | | 126 | A21 | 0 | Address bus | | 127 | Vss | I | Ground | | 128 | A22 | 0 | Address bus | | 129 | A23 | 0 | Address bus | | 130 | A24 | 0 | Address bus | | Pin Number | Pin Name | Input/Output | Terminal description | |------------|----------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 131 | PB15/SRCK0<br>/SCK2 | IO/I/IO | General purpose I/O / Serial receive clock input for SIO channel 0 / Serial clock I/O for SCIF channel 2 | | 132 | PB14/SRS0/RXD2 | IO/I/I | General purpose I/O / Serial receive<br>synchronous input for SIO channel 0 / Serial<br>data input for SCIF channel 2 | | 133 | PB13/SRXD0/TXD2 | IO/I/O | General purpose I/O / Serial data input for SIO channel 0 / Serial data output for SCIF channel 2 | | 134 | PB12/STCK0/SCK1 | IO/I/IO | General purpose I/O / Serial transmit clock input for SIO channel 0 / Serial clock I/O for SCIF channel 1 | | 135 | PB11/STS0/RXD1 | IO/IO/I | General purpose I/O / Serial transmit<br>synchronization input/output for SIO channel<br>0 / Serial data input for SCIF channel 1 | | 136 | PB10/STXD0/TXD1 | 10/0/0 | General purpose I/O / Serial data output for SIO channel 0 / Serial data output for SCIF channel 1 | | 137 | PB9/SRCK1/RTS | IO/I/O | General purpose I/O / Serial receive clock input for SIO channel 1 / Request to send for SCIF channel 1 | | 138 | Vcc | 1 | Power | | 139 | PB8/SRS1/CTS | IO/I/I | General purpose I/O / Serial receive synchronous input for SIO channel 1 / Clear to send for SCIF channel 1 | | 140 | V <sub>ss</sub> | I | Ground | | 141 | PB7/SRXD1/TIOCA2 | IO/I/O | General purpose I/O / Serial data input for SIO channel 1 / Input capture/output compare match A2 of TPU channel 2 | | 142 | PB6/STCK1/TIOCB2/<br>TCLKD | IO/I/IO | General purpose I/O / Serial data transmit clock input for SIO channel 1 / Input capture/output compare match B2 of TPU channel 2/ Clock input D of TPU | | 143 | PB5/STS1/TIOCA1 | IO/IO/IO | General purpose I/O / Serial transmit<br>synchronization input/output for SIO channel<br>1 / Input capture/output compare match A1 of<br>TPU channel 1 | | 144 | PB4/STXD1/TIOCB1/<br>TCLKC | IO/O/IO | General purpose I/O / Serial data output for SIO channel 1 / Input capture/output compare match B1 of TPU channel1 / Clock input C of TPU | | Pin Number | Pin Name | Input/Output | Terminal description | |------------|----------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 145 | PB3/SRCK2/TIOCA0 | IO/I/IO | General purpose I/O / Serial receive clock input for SIO channel 2 / Input capture/ output compare match A0 of TPU channel 0 | | 146 | PB2/SRS2/TIOCB0 | IO/I/IO | General purpose I/O / Serial receive synchronous input for channel 2/ Input capture/output compare match B0 of TPU channel 0 | | 147 | PB1/SRXD2/TIOCC0<br>/TCLKA | IO/I/IO | General purpose I/O / Serial data input for SIO channel 2 / Input capture/output compare match C0 of TPU channel 0/ Clock input A of TPU | | 148 | PB0/STCK2/TIOCD0<br>/TCLKB | IO/I/IO | General purpose I/O / Serial data transmit clock input for SIO channel 2 / Input capture /output compare match D0 of TPU channel 0 / Clock input B of TPU | | 149 | TRST | 1 | Test reset input of H-UDI | | 150 | TCK/PA13 | I/IO | Test clock input of H-UDI / General purpose I/O | | 151 | Vcc | I | Power | | 152 | TMS/PA12 | I/IO | Test mode select of H-UDI/ General purpose I/O | | 153 | Vss | 1 | Ground | | 154 | TDI/PA11 | I/IO | Serial data input of H-UDI / General purpose I/O | | 155 | Vcc | 1 | Power | | 156 | TDO/PA10 | O/IO | Serial data output of H-UDI / General purpose I/O | | 157 | Vss | 1 | Ground | | 158 | PA9/STS2 | IO/IO | General purpose I/O / Serial transmit<br>synchronization input/output for SIO channel<br>2 | | 159 | PA8/STXD2 | IO/O | General purpose I/O / Serial data output for SIO channel 2 | | 160 | WDTOVF/PA7 | O/IO | Watchdog timer output / General purpose I/O | | 161 | FTCI/PA6 | I/IO | Clock input of FRT / General purpose I/O | | 162 | FTI/PA5 | I/IO | Input capture input of FRT / General purpose I/O | | 163 | FTOA/PA4 | O/IO | Output compare match A output of FRT / General purpose I/O | 14 | Pin Number | Pin Name | Input/Output | Terminal description | |------------|------------|--------------|-------------------------------------------------| | 164 | FTOB/CKPO | O/O | Output compare match B output of FRT / Pφ | | 165 | SCK/PA2 | IO/IO | Serial clock I/O of SCI / General purpose I/O | | 166 | Vcc | I | Power | | 167 | RXD/PA1 | I/IO | Serial data input of SCI / General purpose I/O | | 168 | Vss | I | Ground | | 169 | TXD/PA0 | O/IO | Serial data output of SCI / General purpose I/O | | 170 | IVECF | 0 | Interrupt vector fetch cycle | | 171 | CKPACK | 0 | Clock pause acknowledge output | | 172 | CKPREQ/CKM | I | Clock pause request input | | 173 | ĪRL3 | I | External interrupt source input | | 174 | ĪRL2 | I | External interrupt source input | | 175 | ĪRL1 | I | External interrupt source input | | 176 | ĪRL0 | I | External interrupt source input | Note: \* If the debug is performed by E10 emulator(Series type E10), be sure to design the board so that the mode can be changed with this terminal. #### 1.5 **CPU** #### 1.5.1 Fetch and Decode The SH7612 supports a mixed 16-bit/32-bit instruction stream. There are no restrictions on the order or sequence of instructions in the mixed 16-bit/32-bit instruction stream. #### 1.5.2 Integer Unit The integer unit of the SH7612 is an enhanced version of the SH-2 CPU core that supports DSP operations. It can execute all the SH-1 and SH-2 object code, but it is not upwardly compatible with SH-3 object code. Compared with the SH-2 CPU core, the SH-DSP integer unit offers the following additional features: **Dual-Addressing Capability:** The SH7612 supports the simultaneous access to two on-chip memories by using the main integer unit (ALU) to calculate the X memory address and a separate 16-bit ALU called the Pointer Arithmetic Unit (PAU) to calculate the Y memory address. **Index Addressing with Pointer Update:** The SH7612 supports index addressing with automatic updating the address pointer. The address pointer is automatically incremented or decremented by 2 or 4 when sequential words or longwords in memory are accessed, or incremented by a specified index amount after each memory is accessed. **Modulo Addressing:** Modulo addressing is useful for implementing circular buffers. The starting and ending modulo addresses are specified in the MOD control register. When the address register is incremented to the ending address, it is automatically reset to the starting address. **Zero-Overhead Loop Control:** The SH7612 supports zero-overhead program loops, automatically performing loop counter increment and loop end determination. These loops are important for high-speed DSP applications. To set up such a loop, special-purpose registers are used to specify the repeat count, the starting address, and the ending address of the instruction loop. Then, the processor automatically executes the loop for the specified number of times. #### **1.5.3 DSP Unit** The SH7612 has a powerful DSP unit that can execute up to two operations in parallel, providing faster DSP performance than conventional multiply-accumulate (MAC) units. The DSP unit offers the following features: **Parallel Operations:** The DSP unit can execute up to two independent operations simultaneously: one addition or subtraction operation and one multiply operation. Simultaneously when the DSP unit executes these operations, the integer unit can also execute up to two load or store operations at a time concerning X memory or Y memory. A single 32-bit instruction specifies these two operations and two transfers. **32/40 Bit Data Registers:** The DSP unit uses a set of eight data registers: two 40-bit registers and six 32-bit registers. The upper eight bits of the 40-bit registers serve as guard bits to accommodate overflow results during operations. **Fixed-Point Arithmetic Operations:** Most of the 32-bit instructions executed by the DSP use fixed-point data with the binary point fixed between bits 30 and 31. All 16-bit instructions executed by the integer unit use integer data with the binary point fixed to the right of bit 0. **Single-Cycle Multiply Operations:** The DSP unit executes a 16-bit by 16-bit multiply instruction in a single processor clock cycle. The SH-DSP can also execute all of the multiply operations supported by the SH-2 family with the same performance. See the *SH-DSP Programming Manual* for details. **Barrel-Shift Operations:** These perform both arithmetic and logical barrel shifting of data in DSP registers. The shift amount and the shift direction can be specified with the register or immediate value. **Conditional-Instruction Execution:** The SH-DSP instruction set allows conditional execution of ALU and shift operations in the DSP unit. The conditions reflect such situations as negative data, data equal to zero, or the occurrence of a carry/borrow. **Valid Most-Significant Bit Detection (Priority Encoding):** The SH-DSP provides an instruction to locate the most-significant bit of the data. The result of this operation can be combined with an arithmetic shift to normalize a value. **Saturation Arithmetic:** The DSP fixed-point arithmetic and SH-2 multiply-accumulate operations can use saturation arithmetic to prevent overflows and underflows. Any result that exceeds the register width is set to the largest magnitude that the register can accommodate with the appropriate sign. CPU is described in Section 2. #### 1.6 Peripheral Module Units The LSI chip provides peripheral module units that are useful in many DSP applications: - System controller (SYSC) - Interrupt controller (INTC) - User break interface (UBC) - Bus state controller (BSC) - · Cache memory - Direct memory access controller (DMAC): two channels - Division unit (DIVU) - 16-bit free-running timer (FRT): one channel - Watchdog timer (WDT): one channel - Serial communication interface (SCI): one channel - Smart card interface: one channel - Serial communication interface with FIFO(SCIF): two channels - IrDA - Serial I/O (SIO): three channels - 16-bit timer pulse unit (TPU): three channels - Hitachi user debug interface (H-UDI) - Pin function controller (PFC) - I/O port #### 1.6.1 System Controller (SYSC) The system controller generates and controls the clock signals for all on-chip modules and the external bus. The SYSC functions in one of seven clock operating modes and one of three power-down modes: - Operating modes: - Control the method of clock generation (PLL ON/OFF, etc.) and clock division ratio. - Power-down modes: - Sleep mode halts CPU function; standby mode halts all functions; module standby function selectively halts operation such as FRT, SCIF, SIO, DMAC, UBC, DSP, DIVU, TPU, and SCI. #### **1.6.2** Interrupt Controller (INTC) The interrupt controller(INTC) determines the priority of interrupt sources, and controls interrupt requests to the CPU. The INTC has the following features: - Setting the interrupt priority at 16 levels is possible The INTC can set the on-chip peripheral module interrupt priority up to 16 levels according to the request source by five interrupt priority level setting registers. - Setting the on-chip peripheral module interrupt vector number is possible The INTC can set the on-chip peripheral module interrupt vector number with 0 to 127 according to the interrupt source by 22 of vector number setting registers. - Selecting the IRL interrupt vector number setting mode is possible There are the auto-vector mode which uses internal vector number and the external vector mode in which the vector number is set from the external pin. One of these modes can be selected by setting the register. - IRQ interrupt setting available(detection at the low level, the rising edge, the falling edge, or both edges). INTC is described in Section 5. #### 1.6.3 User Break Controller (UBC) UBC can facilitate program debugging. The UBC has the following features: The following break conditions can be set: - Number of break channels: two channels (channels A and B) User break interrupt is requested for channel A and channel B independently or sequentially(sequential break is set from channel A to channel B). - Address: 32-bit mask enabled with settings for each address (cache bus, CPU), internal bus (DMAC), or X/Y bus - Data (channel B only): 32-bit mask enabled with settings for each address (cache bus, CPU), internal bus (DMAC), or X/Y bus - Bus master: CPU cycle/DMA cycle - Bus cycle: Instruction fetch/data access - Read/write - Operand cycle: Byte/word/long word - User break interrupt occurs when break conditions are satisfied. User break interrupt exception routines created by the user can be executed. - Fetch cycle can be selected to stop before or after instruction execution. - Break specifying the number of executions (channel B only) Maximum number of executions that can be specified: 2<sup>12</sup>-1 (4095 executions) #### PC trace function Branch source and branch destination addresses can be traced when branch instruction is fetched (to a maximum of 4 pairs, 8 addresses) UBC is described in Chapter 6. #### 1.6.4 Bus State Controller (BSC) The bus state controller (BSC) manages the address space and outputs a control signal to provide optimum memory access to the five spaces. The BSC has the following features: - Dividing of address space into five spaces - Memory spaces CS0 to CS4 are provided, with maximum space of linear 32Mbytes each - Memory types such as DRAM, synchronous DRAM and burst ROM specified for each space - 8-bit, 16-bit, or 32-bit bus width selectable for each space - Control of insertion of wait states for each space - Output of control signals corresponding to each space - Cache - Cache area and cache-through area can be selected by access address - When a cache access misses, 16 bytes are read consecutively in 4-byte units(because of cache fill); write-through and write-back mode can be selected. - Cache-through accesses are performed by the access size. - Refresh function - CAS-before-RAS refresh(auto-refresh) and self-refresh - Refresh counter and clock select can be used to set the refresh interval - Direct interface to DRAM - Multiplexed output of row addresses and column addresses - Burst transfer when read, high speed page mode for consecutive access - TP cycle generation to maintain RAS precharge time - Synchronous DRAM direct interface - Multiplexed output of row addresses and column addresses - Burst reading, single writing - Bank active mode - Bus arbitration - All resources are shared with another CPU; when a bus release request is received from an external source, a bus right signal is output. BSC is described in Chapter 7. #### 1.6.5 Cache Cache memory uses space/time locality of memory access to provide high-speed memory access. Cache memory has the following features: - · 4-way cache memory with 4kbyte instruction and data - 64-entry, 4-way set-associative, and 16-byte line length - Write-through or write-back mode can be selected for data writing - LRU replacement algorithm - Can be used as 2kbyte cache and 2kbyte internal RAM - 16-byte write-back buffer Cache is described in Chapter 8. ## **1.6.6 Direct Memory Access Controller (DMAC)** The Direct Memory Access Controller (DMAC) substitutes for the CPU to provide high-speed data transfer among external devices with DACK (a transfer request receive signal), external memory, internal memory, memory-mapped external devices and internal peripheral modules (except DMAC, BSC, UBC and cache memory). DMAC has the following features: - Number of channels: two channels - Address space: 4Gbyte architecture - Selection of data transfer units: Byte, word (two bytes), long word (four bytes) or 16-byte units (In 16-byte transfer, long word writing is performed four times after long-word reading is performed four times) - Maximum number of transfers: 16,777,216 (16M) times - When the cache is hit, parallel execution of CPU instruction processing and DMA operation is enabled. - Single address mode transfers: Either the transfer source or transfer destination(peripheral device) is accessed by a DACK signal(selectable) while the other one is accessed by address. One transfer unit of data is transferred in each bus cycle. - Devices that can be used for transfer: External device with DACK and memory-mapped external devices(including external memory) Dual addressing mode transfer: Both the transfer source and transfer destination can be accessed by address. One unit of data is transferred in two bus cycles. Devices that can be used for transfer: Two external memory External memory and memory-mapped external device Two memory-mapped external devices External memory and on-chip peripheral modules(except DMAC, BSC, UBC and cache memory) Memory-mapped external device and on-chip peripheral module(except DMAC, BSC, UBC, and cache memory) $Two\ on\mbox{-}chip\ peripheral\ modules (except\ DMAC,\ BSC,\ UBC,\ and$ cache memory)(Access size permitted by the register of the transfer source and destination on-chip peripheral modules) On-chip memory and memory-mapped external device Two on-chip memories On-chip memory and on-chip peripheral module(except DMAC, BSC, UBC, and cache memory) On-chip memory and external memory - Transfer request - External request (from the DREQ pin. Detection at edge, level, and active low, or active high). - On-chip peripheral module request (serial communication interface (SCI), serial communication interface with FIFO (SCIF), 16 bit timer pulse unit (TPU), or serial I/O (SIO)) - Auto request (transfer request is automatically generated within DMAC) - Bus mode can be selected - Cycle steal mode - Burst mode - Channel priority level can be selected - Fixed mode - Round-robin mode - An interrupt request can be generated to CPU when data transfer ends DMAC is described in Chapter 9. #### 1.6.7 Division unit(DIVU) The division unit(DIVU) divides 64 bits by 32 bits and 32 bits by 32 bits. The DIVU has the following features: - Performs the signed division of 64 bits by 32 bits and 32 bits by 32 bits - Quotient 32 bits, remainder 32 bits - Number of operation execution cycles: 39 - Enables or disables overflow interrupts - Parallel processing of instructions which do not access DIVU can be performed even during execution of division processing DIVU is described in Chapter 10. ## 1.6.8 16-bit Free-Running Timer(FRT) The 16-bit free-running timer (FRT) can output two types of independent waveforms using the 16-bit free-running counter (FRC). It can also measure the input pulse width and external clock cycle. The FRT has the following features: - Four types of input counter clock can be selected The input counter clock can be selected from among three types of internal clock (Pφ/ 8, Pφ / 32, and Pφ / 128) and one external clock. - Two independent comparators Two types of waveform can be output. - Input capture Input capture at the rising edge or the falling edge can be selected. - Counter can be cleared Counter value can be cleared by compare match A. - Four types of interrupt sources Two compare match sources, one input capture source and one overflow source are available as an interrupt source and can be requested independently. FRT is described in Chapter 11. ## 1.6.9 Watchdog Timer (WDT) The watchdog timer (WDT) is a one-channel timer which can be used to monitor the system. WDT has the following features. - Timer mode can be selected between watchdog timer mode and interval timer mode. - WDTOVF is output in watchdog timer mode. When the counter overflows, the WDTOVF signal is output externally. Whether an LSI internal reset is simultaneously performed or not can be selected at this time. Power-on reset or manual reset can be selected for this internal reset. - Interrupt is generated during interval timer mode. When the counter overflows, an interval timer interrupt is generated. - WDT is used when standby mode is canceled, when clock frequency is changed and in clock pose mode. - Counter input clock can be selected from among eight types. WDT is described in Chapter 12. #### 1.6.10 Serial Communication Interface (SCI) The serial communication interface (SCI) can perform serial communication in either asynchronous mode or clocked synchronous mode. SCI has the following features. - Serial communication mode can be selected from among asynchronous mode and clocked synchronous mode. - Asynchronous mode Serial data communication is synchronized one character at a time. The SCI can communicate with a Universal Asynchronous Receiver/Transmitter (UART), Asynchronous Communication Interface Adapter (ACIA), or any other chip that employs a standard asynchronous serial communication. It can also communicate with two or more other processors using the multiprocessor communication function. There are twelve selectable serial data communication formats. Serial data communication format can be selected from among 12 formats. Data length: 7 or 8 bits Stop bit length: 1 or 2 bits Parity: Even, odd, or none Multiprocessor bit: 1 or 0 Receive error detection: Parity error, over-run error, or flaming error detection Clocked synchronous mode In clocked synchronous mode, serial data communication is synchronized with the clock. This enables serial data communication with another LSI which has a clocked synchronous communication function. One serial data communication format is provided. Data length: 8 bits Receive error detection: Over-run error detection • Full duplex communication The transmit and receive sections are independent, and the SCI can transmit and receive simultaneously. Both sections are double-buffed, thus serial data can be transmitted and received continuously. - Selectable bit rates with the internal baud rate generator. - Internal or external transmit/receive clock resource: From either baud rate generator (internal clock) or SCK pin (external clock) - Four interrupt sources - Four interrupt sources are available: transfer data empty, transfer end, receive data full and receive error. Each source can be requested independently. Transfer data empty interrupt and receive data full interrupt can be used to start the DMA controller (DMAC) to transfer data. SCI is described in Chapter 13. #### 1.6.11 Smart Card Interface The serial communication interface (SCI) supports the following extension functions: ISO/IEC7816-3 (Identification Card) data transfer protocol format t=0; and an IC card (smart card) interface conforming to the asynchronous duplexed character transfer protocol. The smart card interface has the following features: - Asynchronous mode - Data length: 8 bits - Generation and checking of parity bit - Transfer of an error signal (parity error) in receive mode - When the error signal is detected in transmit mode, data is automatically re-transmitted. - Both direct convention and inverse convention are supported. - Internal baud rate generator can be used to select any bit rate - Three interrupt sources Three interrupt sources are available: transmit data empty, receive data full, and transmit or receive error. Each source can be requested independently. The smart card interface is described in Chapter 14. #### **1.6.12** Serial Communication Interface with FIFO (SCIF) The SH7612 has a two-channel serial communication interface with FIFO (SCIF) that supports asynchronous serial communication. It also has 16-stage FIFO registers for both transmit and receive that enables efficient, high-speed, continuous communication. The SCIF has the following features: - Asynchronous serial communication: - Serial data communication is synchronized one character at a time. 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 communication system. There are eight selectable serial data communication formats. - Data length: 7 or 8 bits - Stop bit length: 1 or 2 bits - Parity: Even, odd, or none - Receive error detection: Parity and framing errors - Break detection: Break is detected when the receive data following the generated framing error is the space 0 level, including a framing error. It is also detected by reading the RxD pin level directly from the port data register (PBDR) when a framing error occurs - Full duplex communication: The transmit and receive sections are independent, so the SCIF can transmit and receive simultaneously. Both sections are 16-stage FIFO buffered, so highspeed continuous data transfer is possible in both the transmit and receive directions. - Selectable bit rates with internal baud rate generator - Internal or external transmit/receive clock source: From either baud rate generator (internal clock) or SCK pin (external clock) - Four interrupt sources: Transmit-FIFO-data-empty, break, receive-FIFO-data-full, and receive-error interrupts are requested independently. A transmit-FIFO-data-empty or receive-FIFO-data-full interrupt can start the direct memory access controller (DMAC) to transfer data. - When the SCIF is not in use, it can be stopped by halting the clock supplied to it, saving the power consumption. - On-chip modem control signals, $\overline{RTS}$ and $\overline{CTS}$ (one of the two channels has these signals) - The quantity of data in the transmit and receive FIFO registers and the number of errors of the receive data in the receive FIFO register can be detected. - A time-out error (DR) can be detected in receiving. SCIF is described in Chapter 15. #### 1.6.13 IrDA The SH7612 has an on-chip Infrared Data Association (IrDA) interface which conforms to on the IrDA 1.0 system and can perform infrared communication. It can also be used as the SCIF with register settings. IrDA has the following features: - Conforms to the IrDA 1.0 system - Asynchronous serial communication - Data length: eight bits - Stop bit length: one bit - Parity bit: None - Internal 16-stage FIFO buffers for both transmit and receive - Internal baud rate generator with selectable bit rates - Protects the receiver during transfer - While the IrDA is not in use, the clock supply is stopped to reduce the power consumption. IrDA is described in Chapter 16. #### 1.6.14 Serial I/O (SIO) The serial I/O (SIO) functions mainly as an interface between this LSI and the analog front ends of CODEC and MODEM. The SIO has the following features: - Full- duplex communication Independent transmit and receive register and independent transmit and receive clock - Transmit and receive port with double buffers Data can be transmitted and received continuously. - Interval transfer mode and continuous transfer mode - Memory-mapped receive register, transmit register, control register and status register Except for SIRSR and SITSR, these registers are memory-mapped and accessible using the MOV instruction. - 8-bit or 16-bit data length can be selected. - Data can be transmitted or received using polling or interrupt. - Data transfer can be monitored by polling the receive data register full flag (RDRF) and transfer data register empty flag (TDRF) of the serial data register. - When the receive interrupt request flag and transfer interrupt request flag are set and data is transferred, an interrupt request can be generated. - Data is transferred to data I/O in order from MSB. SIO is described in Chapter 17. #### 1.6.15 16-bit Timer Pulse Unit (TPU) The SH7612 has a 16-bit timer pulse unit (TPU) consisting of a 3-channel 16-bit timer. The TPU has the following features: - Up to eight pulses can be output - Incorporates four timer general registers (TGR) on channel 0 and two general registers each on channels 1 and 2 for a total of eight TGRs. Output compare or input capture registers can be set independently in each channel. - Waveform output using compare match: 0 output, 1 output, or toggle output can be selected - Input capture function: Detection at the rising edge, falling edge, or both edges - Counter clear: clear by compare match or input capture - Synchronous operation: Simultaneous writing to multiple timer counters (TCNT) is enabled Simultaneous clearing can be performed using compare match or input capture. Synchronous input to each register is enabled using synchronous operation of counters. — PWM mode: PWM output of any duty is enabled. The PWM output of the maximum of seven phases is possible in combination with the synchronous operation. - Buffer operation can be specified in channel 0 - Double buffer configuration of the input capture register can be performed. - Automatic overwrite of the output compare register can be performed. - Channels 1 and 2 can be independently specified as phase counting mode. - Up-down counting of 2-phase encoder pulse can be performed. - High-speed access using internal 16-bit bus - High-speed access using 16-bit bus interface. - 13 interrupt sources - Four compare match/input capture interrupts and one overflow interrupt can be independently requested on channel 0 - Two compare match/input capture interrupts, one overflow interrupt, and one underflow interrupt can be independently requested on channels 1 and 2 - · Automatic data transfer of register . - Block transfer, one-word data transfer or 1-byte data transfer can be performed by activating the direct memory access controller (DMAC). TPU is described in Chapter 18. ## 1.6.16 Hitachi User Debug Interface (H-UDI) The Hitachi User Debug Interface (H-UDI) provides data transfer and interrupt request functions. The H-UDI performs serial data transfer using external signal control. - The H-UDI has the following features conforming to IEEE standard 1149.1. - Five test signals (TCK, TDI, TDO, TMS and TRST) - TAP controller - Instruction register - Data register - Bypass register - The H-UDI has two instructions. - BYPASS mode - Test mode conforming to IEEE standard 1149.1 - H-UDI interrupt - H-UDI interrupt request to INTC H-UDI is described in Chapter 19. #### 1.6.17 Pin Function Controller The pin function controller (PFC) consists of registers which are used to select the functions of multiplexed pins and their I/O direction. Each pin and its I/O direction can be selected individually regardless of the operation mode of this LSI. PFC is described in Chapter 20. #### 1.6.18 I/O Ports Two I/O ports, A and B are provided. Port A is a 14-bit I/O port, and port B is a 16-bit I/O port. Each port is a multiplexed pin that is used as general I/O and other functions (the pin function controller (PFC) is used to select the functions of the multiplexed pins). Both Ports A and B have one data register each to store pin data. The I/O ports are described in Chapter 21. ## 1.6.19 Processing States • State Transition The CPU has five states: reset state, exception processing state, bus right release state, program execution state and low power consumption state. Transition between these states is illustrated in figure 1.3. Figure 1.3 State Transition #### - Reset state In this state, the CPU is reset. When the $\overline{RES}$ pin changes to a low level, the SH7612 enters the reset state. When the NMI pin is high, this LSI enters the power-on reset state. When the NMI pin is low, it enters the manual reset state. ## - Exception processing state This is a transitional state in which the CPU changes the flow of processing states due to exception processing sources such as reset and interrupt. At reset, the execution start address, which is the initial value of the program counter (PC) taken from the exception processing vector table, and the initial value of the stack pointer (SP) are fetched and stored. Branching is then executed to the start address to start program execution. At interrupt, SP is referenced, and the PC and status register (SR) are saved to the stack area. The start address of the exception service routine is fetched from the exception processing vector table, and branching is executed to that address to start program execution. The subsequent processing state is program execution. ## - Program execution state This is the state in which the CPU executes program in order. ## — Low power consumption state This is the state in which CPU operation is stopped and consumption power is low. The SH7612 enters the low power consumption state by the SLEEP instruction. In this state, the sleep mode, standby mode, and the module standby function are available. ## — Bus right release state In this state, the CPU releases the bus to a device which requests the bus access right. #### • Low power consumption state In addition to the normal program execution state, there is the state in which CPU operation is stopped and power consumption is lowered. The low power consumption state includes sleep mode, standby mode, and the module standby function. # - Sleep mode When the standby bit (SBY) of standby control register 1 (SBYCR1) is cleared to 0 and the SLEEP instruction is executed, the CPU enters sleep mode. In sleep mode, CPU operation is stopped but the contents of the CPU's internal register, its on-chip cache memory and on-chip RAM are maintained. The functions of on-chip peripheral modules other than CPU are not stopped. Sleep mode is canceled by reset, all interrupts and a DMA address error. The state changes first to the exception processing state and then to the normal program execution state. #### — Standby mode When SBY of SBYCR1 is set to 1 and the SLEEP instruction is executed, the CPU enters standby mode. In standby mode, all functions of the CPU, internal modules and oscillator are stopped. When entering standby mode, set the DMA master enable bit of DMAC to 0. Data in cache and in on-chip RAM is not maintained. Recovery from standby mode is done by reset and external NMI interrupt. At reset, after the oscillation stabilization period elapses, the state changes first to the exception processing state and then to the normal program execution state. At NMI interrupt, after the oscillation stabilization period elapses, the state changes first to the exception processing state and then to the normal program execution state. Before entering standby mode, turn the cache off. Also, when the clock pause function is used to enter standby mode, the input clock frequency to the CKIO pin can be changed or the clock itself can be stopped. When SBY of SBYCR is set to 1 to apply a low level to the $\overline{CKPREQ}/CKM$ pin, the SH7612 enters standby mode and a low level is output from the $\overline{CKPACK}$ pin. At this time the clock can be stopped or the frequency can be changed. The state of each on-chip peripheral module and the pin states are the same as in the normal standby mode entered using the SLEEP instruction. High level is applied to $\overline{\text{CKPREQ}}/\text{CKM}$ to enter the program execution state. In this mode, the oscillator is stopped, so power consumption is significantly decreased. #### — Module standby function A module standby function is provided for on-chip peripheral modules: direct memory access controller (DMAC), DSP, division unit (DIVU), 16-bit free-running timer (FRT) serial communication interface (SCI), serial communication interface with FIFO (SCIF), serial I/O (SIO), user break controller (UBC) and timer pulse unit (TPU). By setting 1 to the module stop bits 4 to 0 (MSTP4 to MSTP0) of the standby control register (SBYCR1/2), clock supply to each of the on-chip peripheral modules corresponding to these bits can be stopped. This function can be used to reduce power consumption. The module standby function can be canceled by clearing the corresponding MSTP bit to 0. When setting DSP to the module standby state, do not execute a DSP instruction. When using the module standby function of DMAC, the DMA master enable bit of DMAC must be 0. **Table 1.1 Power-Down State** | | | State | | | | | | | |-------------------------------|--------------------------------------------------------------------------------|-------|--------------------|---------------------------------------------------------------------------------------------------------|-----------------|----------------------------|----|---------------------------------------------------------| | Mode | Transition<br>Condition | Clock | CPU | On-chip<br>peripheral<br>module | CPU<br>register | On-chip<br>cache or<br>RAM | | inceling<br>ocedure | | Sleep<br>mode | Executes<br>SLEEP<br>instruction<br>with SBY bit<br>cleared to 0 in<br>SBYCR 1 | Run | Halt | | Held | Held | 2. | Interrupt DMA address error Power-on reset Manual reset | | Standby<br>mode | Executes<br>SLEEP<br>instruction<br>with SBY bit<br>set to 1 in<br>SBYCR 1 | Halt | Halt | Halt and initialized*1 | Held | Undefined | 2. | NMI interrupt Power-on reset Manual reset | | Module<br>standby<br>function | Sets the<br>MSTP bits<br>corresponding<br>to each<br>module | Run | Run (DSP<br>halts) | Clock<br>supply halts<br>to the<br>specified<br>modules<br>and these<br>modules<br>are<br>initialized*2 | Held | Held | 2. | MSTP bit clear<br>Power-on<br>reset<br>Manual Reset | Note 1. It is different depending on each peripheral module and pin. 2. The set value is held in each register of DMAC, DSP, DIV, and interrupt vectors of the specified modules. # Section 2 CPU # 2.1 Register Configuration The LSI register set consists of sixteen 32-bit general registers, six 32-bit control registers and ten 32-bit system registers. The LSI is upwardly compatible with the SH-1, SH-2 and on the object code level. For this reason, several registers have been added to the previous SuperH microcontroller registers. The added registers are the three control registers: repeat start register (RS), repeat end register (RE), and modulo register (MOD) and the six system registers: DSP status register (DSR), and A0, X0, X1, Y0 and Y1 among the DSP data registers. The general registers are used in the same manner as the SH-1, SH-2 with regard to SuperH microcontroller-type instructions. With regard to DSP type instructions, they are used as address and index registers for accessing memory. ### 2.1.1 General Registers There are 16 general registers (Rn) numbered R0–R15, which are 32 bits in length. General registers are used for data processing and address calculation. In the instruction of Super H microcomputer type R0 is also used as an index register. Several instructions are limited to use of R0 only. R15 is used as the stack pointer (SP). Saving and recovering the status register (SR) and program counter (PC) in exception processing is accomplished by referencing the stack using R15. With DSP type instructions, eight of the 16 general registers are used for the addressing of X, Y data memory and data memory (single data) using the I bus. R4, R5 are used as an X address register (Ax) for X memory accesses, and R8 is used as an X index register (Ix). R6, R7 are used as a Y address register (Ay) for Y memory accesses, and R9 is used as a Y index register (Iy). R2, R3, R4, R5 are used as a single data address register (As) for accessing single data using the I bus, and R8 is used as a single data index register (Is). DSP type instructions can simultaneously access X and Y data memory. There are two groups of address pointers for designating X and Y data memory addresses. Figure 2.1 shows the general registers. - Notes: 1. R0 functions as an index register in the indirect indexed register addressing mode and indirect indexed GBR addressing mode. In some instructions, R0 functions as a source register or destination register. - 2. R15 functions as a hardware stack pointer (SP) during exception processing. - 3. Used as memory address registers, memory index registers with DSP type instructions. Figure 2.1 General Register Configuration With the assembler, symbol names are used for R2, R3, ..., so use a different register name (alias) when wishing to use names making clear a register allocation for DSP type instructions. This is written in the following manner for the assembler. Ix: .REG (R8) The name Ix is an alias for R8. The other aliases are assigned as follows: ``` Ax0: .REG (R4) .REG (R5) Ax1: Ix: .REG (R8) .REG (R6) Ay0: Ay1: .REG (R7) .REG (R9) Iy: .REG (R4) defined when an alias is required for single data transfer As0: .REG (R5) defined when an alias is required for single data transfer As1: .REG (R2) defined when an alias is required for single data transfer As2: .REG (R3) defined when an alias is required for single data transfer As3: .REG (R8) defined when an alias is required for single data transfer Is: ``` #### 2.1.2 Control Registers The six 32-bit control registers consist of the status register (SR), repeat start register (RS), repeat end register (RE), global base register (GBR), vector base register (VBR), and modulo register (MOD). The SR register indicates processing states. The GBR register functions as a base address for the indirect GBR addressing mode, and is used for such as on-chip peripheral module register data transfers. The VBR register functions as the base address of the exception processing vector area (including interrupts). The RS and RE registers are used for program repeat (loop) control. The repeat count is designated in the SR register repeat counter (RC), the repeat start address in the RS register, and the repeat end address in the RE register. However, the address values stored in the RS and RE registers are not necessarily always the same as the physical start and end address values of the repeat. The MOD register is used for modulo addressing to buffer the repeat data. The modulo addressing designation is made by DMX or DMY, the modulo end address (ME) is designated in the upper 16 bits of the MOD register, and the modulo start address (MS) is designated in the lower 16 bits. Note that the DMX and DMY bits cannot simultaneously designate modulo addressing. Modulo addressing is possible with X and Y data transfer instructions (MOVX, MOVY). It is not possible with single data transfer instructions (MOVS). Figure 2.2 shows the control registers. Table 2.1 indicates the SR register bits. Figure 2.2 Control Register Configuration Table 2.1 SR Register Bits | Bit | Name (Abbreviation) | Function | |----------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------| | 27–16 | Repeat counter (RC) | Designate the repeat count (2–4095) for repeat (loop) control | | 11 | Y pointer usage modulo addressing designation (DMY) | 1: modulo addressing mode becomes valid for Y memory address pointer, Ay (R6, R7) | | 10 | X pointer usage modulo addressing designation (DMX) | 1: modulo addressing mode becomes valid for X memory address pointer, Ax (R4, R5) | | 9 | M bit | Used by the DIV0S/U, DIV1 instructions | | 8 | Q bit | Used by the DIV0S/U, DIV1 instructions | | 7–4 | Interrupt request mask (13 to 10) | Indicate the receive level of an interrupt request (0 to 15) | | 3–2 | Repeat flags (RF1, RF0) | Used in zero overhead repeat (loop) control. Set as below for an SETRC instruction. | | | | For 1 step repeat 00 RE—RS=-4 | | | | For 2 step repeat 01 RE—RS=-2 | | | | For 3 step repeat 11 RE—RS=0 | | | | For 4 steps or more 10 RE—RS>0 | | 1 | Saturation arithmetic bit | Used with MAC instructions and DSP instructions | | | (S) | 1: Designates saturation arithmetic (prevents overflows) | | 0 | T bit | For MOVT, CMP/cond, TAS, TST, BT, BF, SETT, CLRT and DT instructions, | | | | 0: represents false | | | | 1: represents true | | | | For ADDV/ADDC, SUBV/SUBC, DIV0U/DIV0S, DIV1, NEGC, SHAR/SHAL, SHLR/SHLL, ROTR/ROTL and ROTCR/ROTCL instructions, | | | | 1: represents occurrence of carry, borrow, overflow or underflow | | 31–28<br>15–12 | 0 bit | 0: 0 is always read out; write a 0 | There are dedicated load/store instructions for accessing the RS, RE and MOD registers. For example, the RS register is accessed as follows. ``` LDC Rm,RS; Rm\rightarrowRS LDC.L @Rm+,RS; (Rm)\rightarrowRS,Rm+4\rightarrowRm STC RS,Rn; RS\rightarrowRn STC.L RS,@-Rn; Rn-4\rightarrowRn,RS\rightarrow(Rn) ``` The following instructions set addresses in the RS, RE registers for zero overhead repeat control: ``` LDRS @(disp,PC); disp\times2 + PC\rightarrowRS LDRE @(disp,PC); disp\times2 + PC\rightarrowRE ``` The GBR register and VBR register are the same as the previous SuperH microprocessor registers. An RC counter and four control bits (DMX bit, DMY bit, RF1 bit, RF0 bit) have been added to the SR register. The RS, RE and MOD registers are new also registers. ## 2.1.3 System Registers System registers consist of four 32-bit registers: high and low multiply and accumulate registers (MACH and MACL), the procedure register (PR), and the program counter (PC). The MACH and MACL registers store the results of multiplication or multiply and accumulate operations. The PR register stores the return address from the subroutine procedure. The PC counter indicates the address of the program in execution; it controls the flow of the processing. The PC counter indicates the fourth byte after the instruction currently being executed. These registers are the same as those in the SuperH microprocessor. Figure 2.3 System Register Configuration Additionally, from among the LSI unit usage registers (DSP registers) described later, the DSP status register (DSR) and the five registers A0, X0, X1, Y0 and Y1 from among the eight data registers are treated as system registers. Among these, the A0 is a 40-bit register, but when data is output from the A0 register, the guard bit section (A0G) is disregarded; when data is input to the A0 register, the MSB of the data is copied into the guard bit section (A0G). #### 2.1.4 DSP Registers The DSP unit has eight data registers and one control register as its DSP registers. The DSP data registers are comprised of the two 40-bit registers A0 and A1, and the six 32-bit registers M0, M1, X0, X1, Y0 and Y1. The A0 and A1 registers have the 8-bit guard bits A0G and A1G, respectively. The DSP data registers are used for the transfer and/or processing of the DSP data of DSP instruction operands. There are three types of instructions that access DSP data registers: those for DSP data processing, and those for X or Y data transfer processing. The control register is the 32-bit DSP status register (DSR) that represents operation results. The DSR register has bits that represent operation results, a signed greater than bit (GT), a zero bit (Z), a negative value bit (N), an overflow bit (V), a DSP status bit (DC: DSP condition), and a status selection bit (CS: condition select) for controlling DC bit setting. The DC bit represents one type of status flag and is very similar to the SuperH microprocessor CPU core T bit. For conditional DSP type instructions, control of DSP data processing is executed in accordance with the DC bit. This control is related to execution in the DSP unit only, and only DSP registers are updated. It bears no relation to address calculation or such SuperH microprocessor CPU core execution instructions as load/store instructions. The control bits CS (bits 2 to 0) designate the status for setting the DC bit. DSP type instructions are comprised of unconditional DSP type instructions and conditional DSP type instructions. The status and DC bits are updated in unconditional DSP type data processing, with the exception of the PMULS, PWAD, PWSB, MOVX, MOVY and MOVS instructions. Conditional DSP type instructions are executed according to the status of the DC bit, but regardless of whether or not they are executed, the DSR register is not updated. Figure 2.4 shows the DSP registers. The DSR register bit functions are indicated in table 2.2. Figure 2.4 DSP Register Configuration Table 2.2 DSR Register Bits | Bit | Name (Abbreviation) | Function | | |------|---------------------------------------|------------------------------------------------------------------------------------------------------------|--| | 31–8 | Reserved bits | 0: Always read out; always use 0 as a write value | | | 7 | Signed greater than bit (GT) | Indicates that the operation result is positive (excepting 0), or that operand 1 is greater than operand 2 | | | | | 1: Operation result is positive, or operand 1 is greater | | | 6 | Zero bit (Z) | Indicates that the operation result is zero (0), or that operand 1 is equal to operand 2 | | | | | 1: Operation result is zero (0), or equivalence | | | 5 | Negative bit (N) | Indicates that the operation result is negative, or that operand 1 is smaller than operand 2 | | | | | 1: Operation result is negative, or operand 1 is smaller | | | 4 | Overflow bit (V) | Indicates that the operation result has overflowed | | | | | 1: Operation result has overflowed | | | 3–1 | Status selection bits (CS) | Designate the mode for selecting the operation result status set in the DC bit | | | | | Do not set either 110 or 111 | | | | | 000: Carry/borrow mode | | | | | 001: Negative value mode | | | | | 010: Zero mode | | | | | 011: Overflow mode | | | | | 100: Signed greater mode | | | | | 101: Signed above mode | | | 0 | DSP status bit (DC) | Sets the status of the operation result in the mode designated by the CS bits | | | | | 0: Designated mode status not realized (unrealized) | | | | | 1: Designated mode status realized | | | | · · · · · · · · · · · · · · · · · · · | | | The DSR register is treated as a system register by CPU core instructions. The following load/store instructions are for data transfers concerning the DSR register. STS DSR,Rm; STS.L DSR,@-Rn; LDS Rn,DSR; LDS.L @Rn+,DSR; The A0, X0, X1, Y0 and Y1 registers are also treated as system registers by CPU core instructions. The following load/store instructions are for data transfers concerning each of these registers. ``` STS Dm,Rn; STS.L Dm,@-Rn; LDS Rn,Dm; LDS.L @Rn+,Dm; ``` (Dm: any one of the A0, X0, X1, Y0 or Y1) # 2.1.5 Cautions Concerning Guard Bits and Overflow Treatment DSP unit data operations are fundamentally performed as 32-bit, but during these operations the execution is always with the 40-bit length including the 8-bit guard bit section. When the guard bit section does not match the value of the 32-bit section MSB, the operation result is treated as an overflow. In this case, the N bit indicates the correct status of the operation result regardless of the existence or not of an overflow. This is so even if the destination operand is a 32-bit length register. The 8-bit section guard bits are always presupposed and each status flag is updated. When place overflows occur so that the correct result cannot be displayed even when the guard bits are used, the N flag cannot indicate the correct status. # 2.1.6 Initial Values of Registers Table 2.3 lists the values of the registers after reset. **Table 2.3** Initial Values of Registers | Classification | Register | Initial Value | |-------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------| | General registers | R0-R14 | Undefined | | | R15 (SP) | Value of the SP in the vector address table | | Control registers | SR | Bits I3–I0 are 1111 (H'F), the reserved bits RC, DMY, and DMX are 0, and other bits are undefined | | | RS | Undefined | | | RE | | | | GBR | Undefined | | | VBR | H'00000000 | | | MOD | Undefined | | System registers | MACH, MACL, PR | Undefined | | | PC | Value of the PC in the vector address table | | DSP registers | A0, A0G, A1, A1G, M0,<br>M1, X0, X1, Y0, Y1 | Undefined | | | DSR | H'00000000 | ## 2.2 Data Formats ## 2.2.1 Data Format in Registers Register operand data size is always longword (32 bits). When loading data from memory into a register, if the memory operand is a byte (8 bits) or a word (16 bits), it is sign-extended into a longword, then loaded into the register. Figure 2.5 Register Data Format # 2.2.2 Data Formats in Memory These formats are classified into bytes, words, and longwords. Place byte data in any address, word data from 2n addresses, and longword data from 4n addresses. An address error will occur if accesses are made from any other boundary. In such cases, the access results cannot be guaranteed. In particular, the stack area referred to by the stack pointer (SP, R15) stores the program counter (PC) and status register (SR) as longwords, so establish the stack pointer so that a 4n value will always result. Figure 2.6 Data Formats in Memory #### 2.2.3 Immediate Data Format Byte immediate data is placed in an instruction code. With the MOV, ADD, and CMP/EQ instructions, immediate data 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. Word or longword immediate data is not located in the instruction code; it should be placed in a memory table. Use an immediate data transfer instruction (MOV) to reference the memory table using the PC relative addressing mode with displacement. # 2.2.4 DSP Type Data Formats The LSI has three different types of data format that correspond to various instructions. These are the fixed-point data format, the integer data format, and the logical data format. The DSP type fixed-point data format has a binary point fixed between bits 31 and 30. There are three types: with guard bits, without guard bits, and multiplication input; each with different valid bit lengths and expressible value ranges. The DSP type integer data format has a binary point fixed between bits 16 and 15. There are three types: with guard bits, without guard bits, and shift amount; each with different valid bit lengths and expressible value ranges. The shift amount of the arithmetic shift (PSHA) has a 7 bit range and can express values from -64 to +63, but the actual valid values are from -32 to +32. In the same manner, the shift amount of the logical shift has a 6 bit range, but the actual valid values are from -16 to +16. The DSP type logical data format does not have a decimal point. The data format and valid data length are determined by the instructions and DSP registers. Figure 2.7 shows the three DSP type data formats and binary point positions. The SuperH type data format is also shown for reference. Figure 2.7 DSP Type Data Formats #### 2.2.5 DSP Type Instructions and Data Formats The DSP data format and valid data length are determined by DSP type instructions and DSP registers. There are three types of instructions that access DSP data registers, namely, DSP data processing, X, Y data transfer processing, and single data transfer processing instructions. **DSP Data Processing:** The guard bits (bits 39–32) are valid when the A0 and A1 registers are used as source registers in DSP fixed-point data processing. When any registers other than A0, A1 (M0, M1, X0, X1, Y0, Y1 registers) are used as source registers, the sign-extended part of that register data becomes the bits 39 to 32 data. When the A0 and A1 registers are used as destination registers, the guard bits (bits 39–32) are valid. When any registers other than A0, A1 are used as destination registers, bits 39 to 32 of the result data are disregarded. Processing for DSP integer data is the same as the DSP fixed-point data processing. However, the lower word (the lower 16 bits, bits 15–0) of the source register is disregarded. The lower word of the destination register is cleared to 0. In DSP logical data processing, the upper word (the upper 16 bits, bits 31–16) of the source register is valid. The lower word and the guard bits of the A0, A1 registers are disregarded. The upper word of the destination register is valid. The lower word and the guard bits of the A0, A1 registers are cleared to 0. **X, Y Data Transfers:** The MOVX.W and MOVY.W instructions access X, Y memory via the 16-bit X, Y data buses. The data loaded into registers and data stored from registers is always the upper word (the upper 16 bits, bits 31–16). When loading, the MOVX.W instruction loads X memory, with the X0 and X1 registers as the destination registers. The MOVY.W instruction loads Y memory, with the Y0 and Y1 registers as the destination registers. Data is stored in the upper word of the register; the lower word is cleared to 0. The upper word data of the A0, A1 registers can be stored in X or Y memory with these data transfer instructions, but storing is not possible from any other registers. The guard bits and the lower word of the A0, A1 registers are disregarded. **Single Data Transfers:** The MOVS.W and MOVS.L instructions can access any memory via the instruction data bus (IDB). All DSP registers are connected to the IDB bus, and they can become source or destination registers during data transfers. The two data transfer modes are word and longword (double-length word). In word mode, the load is to, and the store is from, the upper word of the DSP register, with the exception of the A0G, A1G registers. In longword mode, the load is to, and the store is from, the 32 bits of the DSP register, with the exception of the A0G, A1G registers. The A0G, A1G registers can be treated as independent registers during single data transfers. The load/store data length for the A0G, A1G registers is 8 bits. If DSP registers are used as source registers in word mode, when data is stored from any registers other than A0G, A1G, the upper word of the register is transferred. In the case of the A0, A1 registers, the guard bits are disregarded. When the A0G, A1G registers are the source registers in word mode, only 8 bits of the data are stored from the registers; the upper bits are sign-extended. If the DSP registers are used as destination registers in word mode, the load is to the upper word of the register, with the exception of A0G, A1G. When data is loaded to any register other than A0G, A1G, the lower word of the register is cleared to 0. In the case of the A0, A1 registers, the data sign is extended and stored in the guard bits; the lower word is cleared to 0. When the A0G, A1G registers are the destination registers in word mode, the least significant 8 bits of the data are loaded into the registers; the A0, A1 registers are not zero cleared but retain their previous values. If the DSP registers are used as source registers in longword mode, when data is stored from any registers other than A0G, A1G, the 32 bits of the register are transferred. When the A0, A1 registers are used as the source registers the guard bits are disregarded. When the A0G, A1G registers are the source registers in longword mode, only 8 bits of the data are stored from the registers; the upper bits are sign-extended. If the DSP registers are used as destination registers in longword mode, the load is to the 32 bits of the register, with the exception of A0G, A1G. In the case of the A0, A1 registers, the data sign is extended and stored in the guard bits. When the A0G, A1G registers are the destination registers in longword mode, the least significant 8 bits of the data are loaded into the registers; the A0, A1 registers are not zero cleared but retain their previous values. Tables 2.4 and 2.5 indicate the register data formats for DSP instructions. Some registers cannot be accessed by certain instructions. For example, the PMULS instruction can designate the A1 register as a source register but cannot designate A0 as such. Refer to the instruction explanations for details. Figure 2.8 shows the relationship between the buses and the DSP registers during transfers. Table 2.4 Source Register Data Formats for DSP Instructions | | Instruction | | Guard Bits | Regis | Register Bits | | | |---------------------------|------------------|----------------------------------|-------------|-------------|---------------|--|--| | Register | | | 39–32 | 31–16 | 15–0 | | | | A0, A1 | DSP<br>operation | Fixed decimal,<br>PDMSB,<br>PSHA | 40-bit data | | | | | | | | Integer | 24-bit data | | | | | | | | Logic, PSHL,<br>PMULS | _ | 16-bit data | | | | | | Data<br>transfer | MOVX.W,<br>MOVY.W,<br>MOVS.W | - | | | | | | | | MOVS.L | = | 32-bit data | | | | | A0G, A1G | Data | MOVS.W | Data | _ | _ | | | | | transfer | MOVS.L | Data | | | | | | X0, X1, Y0,<br>Y1, M0, M1 | DSP<br>operation | Fixed decimal,<br>PDMSB,<br>PSHA | Sign* | 32-bit data | | | | | | | Integer | - | 16-bit data | _ | | | | | | Logic, PSHL,<br>PMULS | _ | | | | | | | Data<br>transfer | MOVS.W | - | | | | | | | | MOVS.L | - | 32-bit data | | | | Note: The sign is extended and stored in the ALU's guard bits. Table 2.5 Destination Register Data Formats for DSP Instructions | | | | Guard Bits | Register Bits | | | |---------------------------|------------------|-------------------------------------|---------------|---------------|----------------|--| | Register | Instr | uction | 39–32 | 31–16 | 15–0 | | | A0, A1 | DSP<br>operation | Fixed<br>decimal,<br>PSHA,<br>PMULS | (Sign extend) | 40-bit result | | | | | | Integer,<br>PDMSB | (Sign extend) | 24-bit result | Clear to 0 | | | | | Logic, PSHL | Clear to 0 | 16-bit result | _ | | | | Data transfer | MOVS.W | Sign extend | 16-bit data | _ | | | | | MOVS.L | Sign extend | 32-bit data | | | | A0G, A1G | Data transfer | MOVS.W | Data | Not updated | Not<br>updated | | | | | MOVS.L | Data | Not updated | <del>_</del> | | | X0, X1, Y0,<br>Y1, M0, M1 | DSP<br>operation | Fixed<br>decimal,<br>PSHA,<br>PMULS | _ | 32-bit result | | | | | | Integer, logic,<br>PDMSB,<br>PSHL | - | 16-bit result | Clear to 0 | | | | Data transfer | MOVX.W,<br>MOVY.W,<br>MOVS.W | - | 16-bit data | _ | | | | | MOVS.L | <del>-</del> | 32-bit data | | | Figure 2.8 DSP Register-Bus Relationship during Data Transfers #### 2.3 CPU Core Instruction Features The CPU core instructions are RISC type. The characteristics are as follow. **16-Bit Fixed Length:** All instructions are 16 bits long, increasing program code efficiency. One Instruction per Cycle: The microprocessor can execute basic instructions in one cycle using the pipeline system. One state equals 16.7 ns when operating at 60 MHz. **Data Length:** Longword is the basic data length for all operations. Memory can be accessed in bytes, words, or longwords. Byte or word data accessed from memory is sign-extended and handled as longword data. Immediate data is sign-extended for arithmetic operations or zero-extended for logic operations. It also is handled as longword data. Table 2.6 Sign Extension of Word Data | SH-DSP CPU | | Description | Example of Conventional CPU | | |------------|---------------|------------------------------------------------|-----------------------------|------------| | MOV.W | @(disp,PC),R1 | 9 | 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. **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. **Delayed Branches:** Such instructions as unconditional branches are executed as the delayed branch. In the case of delayed branch instructions, the branch occurs after execution of the instruction immediately following the delayed branch instruction (slot instruction). This reduces pipeline disruption during branching. The branching operation of the delay branch occurs after execution of the slot instruction. However, with the exception of such branch operations as register updating, execution of instructions is performed with the order of delayed branch instruction, then delayed slot instruction. For example, even if the contents of a register storing a branch destination address are modified by a delayed slot, the branch destination address will still be the contents of the register before the modification. **Table 2.7 Delayed Branch Instructions** | SH7612 CPU | | Description | Example of Conventional CPU | | |------------|-------|------------------------|-----------------------------|--| | BRA | TRGET | Executes an ADD before | ADD.W R1,R0 | | | ADD | R1,R0 | branching to TRGET | BRA TRGET | | **Multiplication/Multiply-Accumulate Operation:** $16 \times 16 \rightarrow 32$ multiplications execute in one to two cycles, and $16 \times 16 + 64 \rightarrow 64$ multiply-accumulate operations execute in two to three cycles. $32 \times 32 \rightarrow 64$ multiplications and $32 \times 32 + 64 \rightarrow 64$ multiply-accumulate operations execute in two to four cycles. **T Bit:** The T bit in the status register (SR) changes according to the result of a comparison, and conditional branches occur in accordance with its true or false status. The number of instructions modifying the T bit is kept to a minimum to improve the processing speed. Table 2.8 T Bit | SH7612 CPU | | Description | <b>Example of Conventional CPL</b> | | |------------|--------|------------------------------------------------------------------------------------------|------------------------------------|--------| | CMP/GE | R1,R0 | T bit is set when R0 <sup>3</sup> R1. The | CMP.W | R1,R0 | | BT | TRGET0 | program branches to TRGET0 when R0 <sup>3</sup> R1 and to TRGET1 | BGE | TRGET0 | | BF | TRGET1 | when R0 < R1. | BLT | TRGET1 | | ADD | #–1,R0 | T bit is not changed by ADD. T bit is set when R0 = 0. The program branches when R0 = 0. | SUB.W | #1,R0 | | CMP/EQ | #0,R0 | | BEQ | TRGET | | ВТ | TRGET | bidiffiles when No = 0. | | | **Immediate Data:** Byte immediate data resides in instruction code. Word or longword immediate data is not input via instruction codes but is stored in a memory table. An immediate data transfer instruction (MOV) accesses the memory table using the PC relative addressing mode with displacement. Table 2.9 Immediate Data Accessing | Classification | SH-DSP CPU | Example of Conventional CPU | |------------------|---------------------|-----------------------------| | 8-bit immediate | MOV #H'12,R0 | MOV.B #H'12,R0 | | 16-bit immediate | MOV.W @(disp,PC),R0 | MOV.W #H'1234,R0 | | | | | | | .DATA.W H'1234 | | | 32-bit immediate | MOV.L @(disp,PC),R0 | MOV.L #H'12345678,R0 | | | | | | | .DATA.L H'12345678 | | Note: @(disp, PC) accesses the immediate data. **Absolute Address:** When data is accessed by absolute address, the value already in the absolute address is placed in the memory table. Loading the immediate data when the instruction is executed transfers that value to the register and the data is accessed in the indirect register addressing mode. Table 2.10 Absolute Address Accessing | Classification | SH-DSP CPU | Example of Conventional CPU | |------------------|---------------------|-----------------------------| | Absolute address | MOV.L @(disp,PC),R1 | MOV.B @H'12345678,R0 | | | MOV.B @R1,R0 | | | | | | | | .DATA.L H'12345678 | | **16-Bit/32-Bit Displacement:** When data is accessed by 16-bit or 32-bit displacement, the pre-existing displacement value is placed in the memory table. Loading the immediate data when the instruction is executed transfers that value to the register and the data is accessed in the indirect indexed register addressing mode. **Table 2.11 Displacement Accessing** | Classification | SH-DSP CPU | Example of Conventional CPU | |---------------------|---------------------|-----------------------------| | 16-bit displacement | MOV.W @(disp,PC),R0 | MOV.W @(H'1234,R1),R2 | | | MOV.W @(R0,R1),R2 | | | | | | | | .DATA.W H'1234 | | # 2.4 Instruction Formats ## 2.4.1 CPU Instruction Addressing Modes The addressing modes and effective address calculation for instructions executed by the CPU core are listed in table 2.12. Table 2.12 CPU Instruction Addressing Modes and Effective Addresses | Addressing<br>Mode | Instruction<br>Format | n<br>Effective Addresses Calculation | Equation | |----------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------| | Direct register addressing | Rn | The effective address is register Rn. (The operand is the contents of register Rn.) | _ | | Indirect register addressing | @Rn | The effective address is the content of register Rn. Rn Rn | Rn | | Post-increment indirect register | @Rn+ | The effective address is the content of register Rn. A constant is added to the content of Rn | Rn | | addressing | | after the instruction is executed. 1 is added for a byte operation, 2 for a word operation, and 4 for a longword operation. | (After the instruction executes) | | | | | Byte: $Rn + 1 \rightarrow Rn$ | | | | Rn Rn | Word: $Rn + 2 \rightarrow Rn$ | | | | 1/2/4 + | Longword: Rn + 4<br>→ Rn | | Pre-decrement indirect register | @-Rn | The effective address is the value obtained by subtracting a constant from Rn. 1 is subtracted | Byte: $Rn - 1 \rightarrow Rn$ | | addressing | | for a byte operation, 2 for a word operation, and 4 for a longword operation. | Word: $Rn - 2 \rightarrow Rn$ | | | | Rn - 1/2/4 - Rn - 1/2/4 | Longword: Rn – 4<br>→ Rn (Instruction<br>executed with Rn<br>after calculation) | 60 Table 2.12 CPU Instruction Addressing Modes and Effective Addresses (cont) Table 2.12 CPU Instruction Addressing Modes and Effective Addresses (cont) | Addressing<br>Mode | Instruction<br>Format | n<br>Effective Addresses Calculation | Equation | |------------------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------| | Indirect<br>indexed GBR<br>addressing | @(R0,<br>GBR) | The effective address is the GBR value plus the R0. GBR GBR + R0 | GBR + R0 | | PC relative addressing with displacement | @(disp:8,<br>PC) | The effective address is the PC value plus an 8-bit displacement (disp). The value of disp is zero-extended, and remains the same for a byte operation, is doubled for a word operation, and is quadrupled for a longword operation. For a longword operation, the lowest two bits of the PC value are masked. PC | Word: PC + disp × 2 Longword: PC & H'FFFFFFC + disp × 4 | Table 2.12 CPU Instruction Addressing Modes and Effective Addresses (cont) PC relative addressing disp:8 The effective address is the PC value sign-extended PC + disp $\times$ 2 with an 8-bit displacement (disp), doubled, and added to the PC value. disp:12 The effective address is the PC value sign-extended PC + disp $\times$ 2 with a 12-bit displacement (disp), doubled, and added to the PC value. Rn The effective address is the register PC value plus PC + Rn Rn. Immediate addressing #imm:8 The 8-bit immediate data (imm) for the TST, AND, OR, and XOR instructions are zero-extended. #imm:8 The 8-bit immediate data (imm) for the MOV, ADD, and CMP/EQ instructions are sign-extended. #imm:8 The 8-bit immediate data (imm) for the TRAPA instruction is zero-extended and is quadrupled. ## 2.4.2 DSP Data Addressing There are two different kinds of memory accesses with DSP instructions. One type is with the X, Y data transfer instructions (MOVX.W, MOVY.W), and the other is with the single data transfer instructions (MOVS.W, MOVS.L). The data addressing differs between these two types of instructions. Table 2.13 shows a summary of the data transfer instructions. **Table 2.13 Overview of Data Transfer Instructions** | Classification | X, Y Data Transfer Processing (MOVX.W, MOVY.W) | Single Data Transfer Processing (MOVS.W, MOVS.L) | |-----------------------|------------------------------------------------|--------------------------------------------------| | Address registers | Ax: R4, R5; Ay: R6, R7 | As: R2, R3, R4, R5 | | Index registers | lx: R8, ly: R9 | Is: R8 | | Addressing | Nop/Inc(+2)/index addition: post-<br>update | Nop/Inc(+2,+4)/index addition: post-update | | Addressing | _ | Dec(-2,-4): pre-update | | Modulo addressing | Possible | Not possible | | Data bus | XDB, YDB | IDB | | Data length | 16 bit (word) | 16 bit/32 bit (word/longword) | | Bus contention | None | Yes | | Memory | X, Y data memory | All memory spaces | | Source registers | Dx, Dy: A0, A1 | Ds: A0/A1, M0/M1, X0/X1, Y0/Y1, A0G, A1G | | Destination registers | Dx: X0/X1; Dy: Y0/Y1 | Ds: A0/A1, M0/M1, X0/X1, Y0/Y1, A0G, A1G | **X, Y Data Addressing:** From among the DSP instructions, the SH-DSP can use the MOVX.W and MOVY.W instructions to simultaneously access X, Y data memory. The DSP instructions have two address pointers for simultaneous accessing of X, Y data memory. Only pointer addressing is possible with DSP instructions; there is no immediate addressing. The address registers are divided into two; the R4, R5 registers become the X memory address register (Ax), and the R6, R7 registers become the Y memory address register (Ay). The following three types of addressing exist with X, Y data transfer instructions. - 1. Non-updated address registers: The Ax, Ay registers are address pointers. They are not updated. - 2. Add index registers: The Ax, Ay registers are address pointers. The Ix, Iy register values are added to them, respectively, after the data transfer (post-update). - 3. Increment address registers: The Ax, Ay registers are address pointers. The value +2 is added to each of them after the data transfer (post-update). Each of the address pointers has an index register. The R8 register becomes the index register (Ix) of the X memory address register (Ax), and the R9 register becomes the index register (Iy) of the Y memory address register (Ay). The X, Y data transfer instructions are processed in word lengths. X, Y data memory is accessed in 16 bit lengths. This is why the increment processing adds 2 to the address registers. In order to decrement, set -2 in the index register and designate add index register addressing. During X, Y data addressing, only bits 1 to 15 of the address pointer are valid. Always write a 0 to bit 0 of the address pointer and the index register during X, Y data addressing. Figure 2.9 shows the X, Y data transfer addressing. Figure 2.9 X, Y Data Transfer Addressing **Single Data Addressing:** From among the DSP instructions, the SH-DSP uses the single data transfer instructions (MOVS.W and MOVS.L) to either load data into DSP registers or to store it from them. With these instructions, the registers R2 to R5 are used as address registers (As) for the single data transfers. The four following data addressing instructions exist for single data transfer instructions. - 1. Non-updated address registers: The As registers are address pointers. They are not updated. - 2. Add index registers: The As registers are address pointers. The Is register values are added to them after the data transfer (post-update). - 3. Increment address registers: The As registers are address pointers. The value +2 or +4 is added after the data transfer (post-update). - 4. Decrement address registers: The As registers are address pointers. The value –2 or –4 is added (+2 or +4 is subtracted) before the data transfer (pre-update). The address pointer (As) uses the R8 register as an index register (Is). Figure 2.10 shows the single data transfer addressing. Figure 2.10 Single Data Transfer Addressing **Modulo Addressing:** The LSI has modulo addressing, just as other DSP do. Address registers are updated in the same manner as with other modes. When the address pointer value becomes the same as a previously established modulo end address, the address pointer becomes the modulo start address. Modulo addressing is valid only with X, Y data transfer instructions (MOVX.W, MOVY.W). When the DMX bit of the SR register is set, the X address register enters modulo addressing mode; when the DMY bit of the SR register is set, the Y address register does so. Modulo addressing is valid only for either the X or the Y address register; it is not possible to make them both modulo addressing mode at the same time. Therefore, do not simultaneously set the DMX and DMY. If they happen to be set at the same time, only the DMY side is valid. The MOD register is used to designate the start and end addresses of the modulo address area; it stores the MS (modulo start) and ME (modulo end). An example of MOD register (MS, ME) usage is indicated below. MOV.L ModAddr,Rn; Rn=ModEnd, ModStart LDC Rn, MOD; ME=ModEnd, MS=ModStart Lower 8bit of ModEnd ModAddr: .DATA.W mEnd; .DATA.W mStart; Lower 8bit of ModStart ModStart: .DATA : ModEnd: .DATA Designate the start and end addresses in MS and ME, and then set the DMX or DMY bit to 1. The contents of the address register are compared with ME. If they match ME, the start address MS is stored in the address register. The lower 16 bits of the address register are compared with ME. The maximum modulo size is 64 kbytes. This is sufficient for X, Y data memory accesses. Figure 2.11 shows a block diagram of modulo addressing. Figure 2.11 Modulo Addressing An example of modulo addressing is indicated below: ``` MS=H'08; ME=H'0C; R4=H'C008; ``` DMX=1; DMY=0; (sets modulo addressing for address register Ax (R4, R5)) The R4 register changes as follows due to the above settings. R4: H'C008 Inc. R4: H'C00A Inc. R4: H'C00C Inc. R4: H'C008 (becomes the modulo start address because the modulo end address occurred) Data is placed so that the upper 16 bits of the modulo start and end addresses become identical. This is so because the modulo start address replaces only the lower 15 bits of the address register, excepting bit 0. Note: When using add index with DSP data addressing, there are cases where the value is exceeded without the address pointer matching the ME. In such cases, the address pointer does not return to the modulo start address. Bit 0 is disregarded not only for modulo addressing, but also during X, Y data addressing, so always write 0 to the 0 bits of the address pointer, index register, MS, and ME. **DSP Addressing Operation:** The DSP addressing operation in the item stage (EX) of the pipeline, including modulo addressing, is indicated below. 70 HITACHI ``` if ( Operation is MOVX.W MOVY.W ) { ABx=Ax; ABy=Ay; /* memory access cycle uses ABx and ABy. The addresses to be used have not been updated */ /* Ax is one of R4,5 */ if ( DMX==0 | | DMX==1 && DMY==1 )} Ax=Ax+(+2 \text{ or } R8[Ix] \text{ or } +0); /* Inc,Index,Not-Update */ else if (!not-update) Ax=modulo( Ax, (+2 or R8[Ix]) ); /* Ay is one of R6,7 */ if ( DMY==0 ) Ay=Ay+(+2 or R9[Iy] or +0; /* Inc, Index, Not-Update*/ else if (! not-update) Ay=modulo( Ay, (+2 or R9[Iy]) ); else if ( Operation is MOVS.W or MOVS.L ) { if ( Addressing is Nop, Inc, Add-index-reg ) { MAB=As; /* memory access cycle uses MAB. The address to be used has not been updated */ /* As is one of R2-5 */ As=As+(+2 or +4 or R8[Is] or +0); /* Inc.Index,Not-Update */ else { /* Decrement, Pre-update */ /* As is one of R2-5 */ As=As+(-2 \text{ or } -4); MAB=As; /st memory access cycle uses MAB. The address to be used has been updated */ } /* The value to be added to the address register depends on addressing operations. For example, (+2 or R8[Ix] or +0) means that +2: if operation is increment R8[Ix}: if operation is add-index-reg if operation is not-update * / function modulo ( AddrReg, Index ) { ``` ``` if ( AdrReg[15:0]==ME ) AdrReg[15:0]==MS; else AdrReg=AdrReg+Index; return AddrReg; } ``` #### 2.4.3 Instruction Formats for CPU Instructions The instruction format of instructions executed by the CPU core and the meanings of the source and destination operands are indicated below. The meaning of the operand depends on the instruction code. The symbols are used as follows: xxxx: Instruction code mmmm: Source register nnnn: Destination register iiii: Immediate data dddd: Displacement **Table 2.14 Instruction Formats for CPU Instructions** | Instruction Formats | Source Operand | Destination Operand | Example | |-------------------------------------|----------------------------------------|-------------------------------------------|---------------| | 0 format 15 0 xxxx xxxx xxxx xxxx | _ | _ | NOP | | n format 15 0 xxxx nnnn xxxx xxxx | _ | nnnn: Direct register | MOVT Rn | | | Control register or system register | nnnn: Direct register | STS MACH,Rn | | | Control register or system register | nnnn: Indirect pre-<br>decrement register | STC.L SR,@-Rn | | m format 15 0 xxxxx mmmm xxxx xxxx | mmmm: Direct register | Control register or system register | LDC Rm,SR | | | mmmm: Indirect post increment register | -Control register or system register | LDC.L @Rm+,SR | | | mmmm: Indirect register | _ | JMP @Rm | | | mmmm: PC relative using Rm | _ | BRAF Rm | **Table 2.14** Instruction Formats for CPU Instructions (cont) | Instruction Formats | Source Operand | Destination<br>Operand | Example | |---------------------------|-------------------------------------------------------------------------|-------------------------------------------|------------------------| | nm format | mmmm: Direct register | nnnn: Direct register | ADD Rm,Rn | | 15 0 xxxx nnnn mmmm xxxx | mmmm: Direct register | nnnn: Indirect<br>register | MOV.L Rm,@Rn | | | mmmm: Indirect post increment register (multiply/ accumulate) | -MACH, MACL | MAC.W<br>@Rm+,@Rn+ | | | nnnn: Indirect post<br>increment register<br>(multiply/<br>accumulate)* | - | | | | mmmm: Indirect post-<br>increment register | | MOV.L @Rm+,Rn | | | mmmm: Direct register | nnnn: Indirect pre-<br>decrement register | MOV.L Rm,@-Rn | | | mmmm: Direct register | nnnn: Indirect indexed register | MOV.L<br>Rm,@(R0,Rn) | | md format | | R0 (Direct register) | | | 15 0 | register with displacement | | @(disp,Rm),R0 | | xxxx xxxx mmmm dddd | displacement | | | | nd4 format | R0 (Direct register) | nnnndddd: Indirect | :MOV.B | | 15 0 | | register with | R0,@(disp,Rn) | | xxxx xxxx nnnn dddd | | displacement | | | nmd format | mmmm: Direct | nnnndddd: Indirect | :MOV.L | | 15 0 xxxx nnnn mmmm xxxx | register | register with displacement | Rm,@(disp,Rn) | | | mmmmdddd: Indirect<br>register<br>with displacement | tnnnn: Direct<br>register | MOV.L<br>@(disp,Rm),Rn | **Table 2.14 Instruction Formats for CPU Instructions (cont)** | Instruction Formats | Source Operand | <b>Destination Operand</b> | Example | |--------------------------------------------|-----------------------------------------------|-----------------------------------------------|------------------------------| | d format 15 0 xxxx xxxx dddd dddd | ddddddd: Indirect<br>GBR with<br>displacement | R0 (Direct register) | MOV.L<br>@(disp,GBR),R0 | | | R0(Direct register) | ddddddd: Indirect<br>GBR with<br>displacement | MOV.L<br>R0,@(disp,GBR) | | | ddddddd: PC relative with displacement | R0 (Direct register) | MOVA<br>@(disp,PC),R0 | | | dddddddd: PC relative | <del>e_</del> | BF label | | d12 format 15 0 | dddddddddd:<br>PC relative | _ | BRA label<br>(label=disp+PC) | | nd8 format 15 0 xxxx nnnn dddd dddd | ddddddd: PC relative with displacement | nnnn: Direct register | MOV.L<br>@(disp,PC),Rn | | i format 15 0 xxxx xxxx iiii iiii | iiiiiiii:<br>Immediate | Indirect indexed GBR | AND.B<br>#imm,@(R0,GBR) | | | iiiiiiii: Immediate | R0 (Direct register) | AND #imm,R0 | | | iiiiiiii:<br>Immediate | _ | TRAPA #imm | | ni format 15 0 xxxxx nnnn iiii iiii | iiiiiiii: Immediate | ennnn: Direct<br>register | ADD #imm,Rn | Note: In multiply/accumulate instructions, nnnn is the source register. ### 2.4.4 Instruction Formats for DSP Instructions New instructions have been added to the SH-DSP for digital signal processing. The new instructions are divided into the two following types. - 1. Memory and DSP register double, single data transfer instructions (16 bit length) - 2. Parallel processing instructions processed by the DSP unit (32 bit length) Figure 2.12 shows each of the instruction formats. **Figure 2.12 Instruction Formats for DSP Instructions** **Double, Single Data Transfer Instructions:** Table 2.15 indicates the data formats for double data transfer instructions, and table 2.16 indicates the data formats for single data transfer instructions. **Table 2.15 Instruction Formats for Double Data Transfers** | Category | Mnemonic | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-------------------------|-----------------------------------------------------|----|----|----|----|----|----|----|----| | X memory data transfers | NOPX | 1 | 1 | 1 | 1 | 0 | 0 | 0 | | | | MOVX.W @Ax,Dx<br>MOVX.W @Ax+,Dx<br>MOVX.W @Ax+Ix,Dx | | | | | | | Ax | | | | MOVX.W Da,@Ax<br>MOVX.W Da,@Ax+<br>MOVX.W Da,@Ax+Ix | | | | | | | _ | | | Y memory data transfers | NOPY | 1 | 1 | 1 | 1 | 0 | 0 | | 0 | | | MOVY.W @Ay,Dy<br>MOVY.W @Ay+,Dy<br>MOVY.W @Ay+Iy,Dy | | | | | | | | Ay | | | MOVY.W Da,@Ay<br>MOVY.W Da,@Ay+<br>MOVY.W Da,@Ay+Iy | | | | | | | | | Table 2.15 Instruction Formats for Double Data Transfers (cont) | Category | Mnemonic | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------------------|------------------|----|----|---|---|---|---|---|---| | X memory data transfers | NOPX | 0 | | 0 | | 0 | 0 | | | | | MOVX.W @Ax,Dx | Dx | | 0 | | 0 | 1 | | | | | MOVX.W @Ax+,Dx | | | | | 1 | 0 | | | | | MOVX.W@Ax+Ix,Dx | | | | | 1 | 1 | | | | | MOVX.W Da,@Ax | Da | | 1 | | 0 | 1 | | | | | MOVX.W Da,@Ax+ | | | | | 1 | 0 | | | | | MOVX.W Da,@Ax+Ix | | | | | 1 | 1 | | | | Y memory data transfers | NOPY | | 0 | | 0 | | | 0 | 0 | | | MOVY.W @Ay,Dy | | Dy | | 0 | | | 0 | 1 | | | MOVY.W @Ay+,Dy | | - | | | | | 1 | 0 | | | MOVY.W@Ay+Iy,Dy | | | | | | | 1 | 1 | | | MOVY.W Da,@Ay | | Da | | 1 | | | 0 | 1 | | | MOVY.W Da,@Ay+ | | | | | | | 1 | 0 | | | MOVY.W Da,@Ay+Iy | | | | | | | 1 | 1 | Ax: 0=R4, 1=R5 Ay: 0=R6, 1=R7 Dx: 0=X0, 1=X1 Dy: 0=Y0, 1=Y1 Da: 0=A0, 1=A1 Table 2.16 Instruction Formats for Single Data Transfers | Category | Mnemonic | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------------|-----------------------------------------------------------------------|----|----|----|----|----|----|---|-------------------------------| | Single data transfer | MOVS.W @-As,Ds<br>MOVS.W @As,Ds<br>MOVS.W @As+,Ds<br>MOVS.W @As+Ix,Ds | 1 | 1 | 1 | 1 | 0 | 1 | | As<br>0: R4<br>1: R5<br>2: R2 | | | MOVS.W Ds,@A-s<br>MOVS.W Ds,@As<br>MOVS.W Ds,@As+<br>MOVS.W Ds,@As+Ix | | | | | | | | 3: R3 | | | MOVS.L@-As,Ds MOVS.L@As,Ds MOVS.L@As+,Ds MOVS.L@As+Ix,Ds | | | | | | | | | | | MOVS.L Ds,@A-s<br>MOVS.L Ds,@As<br>MOVS.L Ds,@As+<br>MOVS.L Ds,@As+Ix | | | | | | | | | Table 2.16 Instruction Formats for Single Data Transfers (cont) | Category | Mnemonic | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|------------------|---|----|----|-------|---|---|---|---| | Single data | MOVS.W@-As,Ds | | Ds | 0 | : (*) | 0 | 0 | 0 | 0 | | transfer | MOVS.W @As,Ds | | | 1 | : (*) | 0 | 1 | | | | | MOVS.W @As+,Ds | | | 2 | : (*) | 1 | 0 | | | | | MOVS.W@As+Ix,Ds | | | | : (*) | 1 | 1 | | | | | MOVS.W Ds,@A-s | | | 4 | : (*) | 0 | 0 | | 1 | | | MOVS.W Ds,@As | | | 5 | : A1 | 0 | 1 | | | | | MOVS.W Ds,@As+ | | | 6 | : (*) | 1 | 0 | | | | | MOVS.W Ds,@As+Ix | | | 7 | : A0 | 1 | 1 | | | | | MOVS.L@-As,Ds | | | 8 | : X0 | 0 | 0 | | 0 | | | MOVS.L @As,Ds | | | 9 | : X1 | 0 | 1 | | | | | MOVS.L @As+,Ds | | | Α | : Y0 | 1 | 0 | | | | | MOVS.L@As+Ix,Ds | | | В | : Y1 | 1 | 1 | | | | | MOVS.L Ds,@A-s | | | С | : M0 | 0 | 0 | | 1 | | | MOVS.L Ds,@As | | | D: | A1G | 0 | 1 | | | | | MOVS.L Ds,@As+ | | | Е | :M1 | 1 | 0 | | | | | MOVS.L Ds,@As+Ix | | | F: | A0G | 1 | 1 | | | Note: System reserved code **Parallel Processing Instructions:** The parallel processing instructions allow for more efficient execution of digital signal processing using the DSP unit. They are 32 bit length, allowing simultaneously in four processes, ALU operations, multiplications or 2 data transfers. The parallel processing instructions are divided into A fields and B fields. The A field defines data transfer instructions; the B field defines ALU operation instructions and multiplication instructions. These instructions can be defined independently, the processes can be independent, and furthermore, they can be executed simultaneously in parallel. Table 2.17 indicates the A field parallel data transfer instructions, and table 2.18 indicates the B field ALU operation instructions and multiplication instructions. **Table 2.17 Field A Parallel Data Transfer Instructions** | Category | Mnemonic | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | |-------------------------------|-----------------------------------------------------|----|----|----|----|----|----|----|----|----| | X memory<br>data<br>transfers | NOPX | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | 0 | | | MOVX.W @Ax,Dx<br>MOVX.W @Ax+,Dx<br>MOVX.W @Ax+Ix,Dx | _ | | | | | | Ax | | Dx | | | MOVX.W Da,@Ax<br>MOVX.W Da,@Ax+<br>MOVX.W Da,@Ax+Ix | | | | | | | | | Da | | Y memory<br>data<br>transfers | NOPY | | | | | | | | 0 | | | | MOVY.W @Ay,Dy<br>MOVY.W @Ay+,Dy | | | | | | | | Ау | | | | MOVY.W@Ay+Iy,Dy | | | | | | | | | | | | MOVY W Da , @Ay | | | | | | | | | | | | MOVY.W Da,@Ay+<br>MOVY.W Da,@Ay+Iy | | | | | | | | | | Table 2.17 Field A Parallel Data Transfer Instructions (cont) | Category | Mnemonic | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15–0 | |-------------------------------|------------------|----|----|----|----|----|----|----|--------------| | X memory<br>data<br>transfers | NOPX | | 0 | | 0 | 0 | | | Field B | | | MOVX.W @Ax,Dx | | 0 | _ | 0 | 1 | _ | | | | | MOVX.W @Ax+,Dx | | | | 1 | 0 | | | | | | MOVX.W@Ax+Ix,Dx | | | | 1 | 1 | | | | | | MOVX.W Da,@Ax | | 1 | _ | 0 | 1 | _ | | | | | MOVX.W Da,@Ax+ | | | | 1 | 0 | | | | | | MOVX.W Da,@Ax+Ix | | | | 1 | 1 | | | | | Y memory<br>data<br>transfers | NOPY | 0 | | 0 | | | 0 | 0 | _ | | | MOVY.W @Ay,Dy | Dy | _ | 0 | _ | | 0 | 1 | <del>_</del> | | | MOVY.W @Ay+,Dy | | | | | | 1 | 0 | | | | MOVY.W@Ay+Iy,Dy | | | | | | 1 | 1 | | | | MOVY.W Da,@Ay | Da | _ | 1 | _ | | 0 | 1 | | | | MOVY.W Da,@Ay+ | | | | | | 1 | 0 | | | | MOVY.W Da,@Ay+Iy | | | | | | 1 | 1 | | Ax: 0=R4, 1=R5 Ay: 0=R6, 1=R7 Dx: 0=X0, 1=X1 Dy: 0=Y0, 1=Y1 Da: 0=A0, 1=A1 Table 2.18 Field B ALU Operation Instructions, Multiplication Instructions | Cotogony | | 04 07 | | 05.40 | 4544 | 40 4 | ٦ | 44 40 | 0 0 | 7 0 | - 4 | | 4 0 | |----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------|------------------|-------------------|------|-----------------------------------------------------------------------------------------|--------------|------------------|-----|--------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------| | Category | Mnemonic | 31–27<br>1 | 26<br>0 | 25–16<br>Field A | | | | | 9 8<br>16 ≤ lm | | | 3 2<br>D | | | Imm. shift | PSHL #Imm, Dz<br>PSHA #Imm, Dz | ' | U | i icia / t | 0 0 | - 1 | 1 | | 32 ≤ In | | | | _ | | Six | Reserved PMULS Se, Sf, Dg | | | | 0 0<br>0 0<br>0 1 | | | 1<br>Se | Sf | Sx | Sy | Dg | Du | | operand<br>parallel | Reserved | | | | 0 1 | 0 1 | 1 | 0:X0<br>1:X1 | | | 0:Y0<br>1:Y1 | | | | instruction | PSUB Sx, Sy, Du<br>PMULS Se, Sf, Dg<br>PADD Sx, Sy, Du<br>PMULS Se, Sf, Dg | | | | 0 1 | | | 2:Y0<br>3:A1 | | | 2:M0<br>3:M1 | | | | Three operand instructions | Reserved PSUBC Sx, Sy, Dz PADDC Sx, Sy, Dz PCMP Sx, Sy Reserved PWSB Sx, Sy, Dz PWAD Sx, Sy, Dz PABS Sx, Dz PRND Sx, Dz PABS Sy, Dz PABS Sy, Dz PRND Sy, Dz RRND Sy, Dz RRND Sy, Dz RRND Sy, Dz | | | | 1 0 | 0 | 1 0 0 1 0 0 1 0 0 1 1 0 0 1 1 0 0 1 1 0 0 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0 0 1 | 0 0 | | | 2: (<br>3: (<br>5: /<br>6: (<br>7: /<br>8: 2<br>9: 2<br>A: B: C:<br>D: E: | (*3)<br>(*3)<br>(*3)<br>(*3)<br>(*3)<br>(*3)<br>A1<br>(*3)<br>A0<br>X0<br>X1<br>Y0<br>Y1<br>M0<br>(*3) | | A | B | | © | ) | | (0 | 9) | | | | (E) | | | 80 HITACHI Table 2.18 Field B ALU Operation Instructions, Multiplication Instructions (cont) 3. System reserved code ## 2.5 Instruction Set The SH-DSP instructions are divided into three groups. These are: CPU instructions executed by the CPU core, DSP data transfer instructions executed by the DSP unit, and DSP operation instructions. There are a number of CPU instructions for supporting the DSP functions. The instruction set is explained below in terms of each of the three groups. 82 HITACHI ## 2.5.1 CPU Instruction Set Table 2.19 lists the CPU instructions by classification. **Table 2.19 Classification of CPU Instructions** | Classification | Types | Operation Code | r<br>Function | No. of<br>Instructions | |-----------------------|-------|----------------|--------------------------------------------------------------------------------------------------|------------------------| | Data transfer | 5 | MOV | Data transfer, immediate data transfer, peripheral module data transfer, structure data transfer | 39 | | | | MOVA | Effective address transfer | | | | | MOVT | T bit transfer | | | | | SWAP | Swap of upper and lower bytes | | | | | XTRCT | Extraction of the middle of registers connected | | | Arithmetic operations | 21 | ADD | Binary addition | 33 | | | | ADDC | Binary addition with carry | | | | | ADDV | Binary addition with overflow | | | | | CMP/cond | Comparison | | | | | DIV1 | Division | | | | | DIV0S | Initialization of signed division | | | | | DIV0U | Initialization of unsigned division | | | | | DMULS | Signed double-length multiplication | | | | | DMULU | Unsigned double-length multiplication | | | | | DT | Decrement and test | | | | | EXTS | Sign extension | | | | | EXTU | Zero extension | | | | | MAC | Multiply/accumulate, double-length multiply/accumulate operation | | | | | MUL | Double-length multiply operation | | | | | 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 | | **Table 2.19 Classification of CPU Instructions (cont)** | Classification | Types | Operation Code | Function | No. of<br>Instructions | |------------------|-------|----------------|--------------------------------------------------------------------------|------------------------| | Logic operations | 6 | AND | Logical AND | 14 | | | | NOT | Bit inversion | _ | | | | OR | Logical OR | = | | | | TAS | Memory test and bit set | = | | | | TST | Logical AND and T bit set | = | | | | XOR | Exclusive OR | = | | Shift | 10 | ROTCL | One-bit left rotation with T bit | 14 | | | | ROTCR | One-bit right rotation with T bit | = | | | | ROTL | One-bit left rotation | = | | | | ROTR | One-bit right rotation | = | | | | SHAL | One-bit arithmetic left shift | = | | | | SHAR | One-bit arithmetic right shift | = | | | | SHLL | One-bit logical left shift | <del>-</del> | | | | SHLLn | n-bit logical left shift | = | | | | SHLR | One-bit logical right shift | = | | | | SHLRn | n-bit logical right shift | <del>-</del> | | Branch | 9 | BF | Conditional branch, conditional branch with delay (Branch when $T=0$ ) | 11 | | | | ВТ | Conditional branch, conditional branch with delay (Branch when $T = 1$ ) | <del>-</del> | | | | BRA | Unconditional branch | _ | | | | BRAF | Unconditional branch | = | | | | BSR | Branch to subroutine procedure | = | | | | BSRF | Branch to subroutine procedure | _ | | | | JMP | Unconditional branch | _ | | | | JSR | Branch to subroutine procedure | _ | | | | RTS | Return from subroutine procedure | <del>-</del> | 84 **Table 2.19 Classification of CPU Instructions (cont)** | Classification | Types | Operation Code | Function | No. of<br>Instructions | |----------------|-------|----------------|----------------------------------|------------------------| | System control | 14 | CLRMAC | MAC register clear | 71 | | | | CLRT | T bit clear | | | | | LDC | Load to control register | | | | | LDRE | Load to repeat end register | | | | | LDRS | Load to repeat start register | | | | | LDS | Load to system register | | | | | NOP | No operation | | | | | RTE | Return from exception processing | | | | | SETRC | Repeat count setting | | | | | SETT | T bit set | | | | | SLEEP | Shift into power-down mode | | | | | STC | Storing control register data | | | | | STS | Storing system register data | | | | | TRAPA | Trap exception handling | | | Total: | 65 | | | 182 | The instruction codes, operation, and execution states of the CPU instructions are listed by classification with the formats listed in table 2.20. **Table 2.20 Instruction Code Formats** | Item | Format | Explanation | |-------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------| | Instruction<br>mnemonic | OP.Sz SRC,DEST | OP: Operation code Sz: Size SRC: Source DEST: Destination Rm: Source register Rn: Destination register imm: Immediate data disp: Displacement*2 | | Instruction code | $MSB \leftrightarrow LSB$ | mmmm: Source register<br>nnnn: Destination register<br>0000: R0<br>0001: R1 | | | | 1111: R15 iiii: Immediate data dddd: Displacement | | Operation summary | $\rightarrow$ , $\leftarrow$ | Direction of transfer | | | (xx) | Memory operand | | | M/Q/T | Flag bits in the SR | | | & | Logical AND of each bit | | | T | Logical OR of each bit | | | ٨ | Exclusive OR of each bit | | | ~ | Logical NOT of each bit | | | < <n< td=""><td>n-bit left shift</td></n<> | n-bit left shift | | | >>n | n-bit right shift | | Execution cycle | _ | Value when no wait states are inserted*1 | | T bit | _ | Value of T bit after instruction is executed. An em-dash (— ) in the column means no change. | Notes: 1. Instruction execution cycles: The execution cycles shown in the table are minimums. The actual number of cycles may be increased when (1) contention occurs between instruction fetches and data access, or (2) when the destination register of the load instruction (memory → register) and the register used by the next instruction are the same. 2. Depending on the instruction's operand size, scaling is $\times 1$ , $\times 2$ , or $\times 4$ . For details, see the SH-DSP Programming Manual. **Table 2.21 Data Transfer Instructions** | Instruc | tion | Instruction Code | Operation | Cycles | T<br>Bit | |---------|---------------|------------------|--------------------------------------------------------------------------|--------|----------| | MOV | #imm,Rn | 1110nnnniiiiiiii | #imm $\rightarrow$ Sign extension $\rightarrow$ Rn | 1 | _ | | MOV.W | @(disp,PC),Rn | 1001nnnndddddddd | $(disp \times 2 + PC) \rightarrow Sign$<br>extension $\rightarrow Rn$ | 1 | _ | | MOV.L | @(disp,PC),Rn | 1101nnnndddddddd | $(disp \times 4 + PC) \to Rn$ | 1 | _ | | MOV | Rm,Rn | 0110nnnnmmmm0011 | $Rm \to Rn$ | 1 | _ | | MOV.B | Rm,@Rn | 0010nnnnmmmm0000 | $Rm \rightarrow (Rn)$ | 1 | _ | | MOV.W | Rm,@Rn | 0010nnnnmmmm0001 | $Rm \rightarrow (Rn)$ | 1 | | | MOV.L | Rm,@Rn | 0010nnnnmmmm0010 | $Rm \rightarrow (Rn)$ | 1 | _ | | MOV.B | @Rm,Rn | 0110nnnnmmmm0000 | $(Rm) \rightarrow Sign \ extension \rightarrow Rn$ | 1 | _ | | MOV.W | @Rm,Rn | 0110nnnnmmmm0001 | $(Rm) \rightarrow Sign \ extension \rightarrow Rn$ | 1 | _ | | MOV.L | @Rm,Rn | 0110nnnnmmmm0010 | $(Rm) \rightarrow Rn$ | 1 | _ | | MOV.B | Rm,@-Rn | 0010nnnnmmmm0100 | $Rn-1 \rightarrow Rn, Rm \rightarrow (Rn)$ | 1 | _ | | MOV.W | Rm,@-Rn | 0010nnnnmmmm0101 | $Rn-2 \rightarrow Rn, Rm \rightarrow (Rn)$ | 1 | _ | | MOV.L | Rm,@-Rn | 0010nnnnmmmm0110 | $Rn-4 \rightarrow Rn, Rm \rightarrow (Rn)$ | 1 | _ | | MOV.B | @Rm+,Rn | 0110nnnnmmmm0100 | $(Rm) \rightarrow Sign \ extension \rightarrow Rn,Rm + 1 \rightarrow Rm$ | 1 | _ | | MOV.W | @Rm+,Rn | 0110nnnnmmmm0101 | $(Rm) \rightarrow Sign \ extension \rightarrow Rn,Rm + 2 \rightarrow Rm$ | 1 | _ | | MOV.L | @Rm+,Rn | 0110nnnnmmmm0110 | $(Rm) \rightarrow Rn, Rm + 4 \rightarrow Rm$ | 1 | _ | | MOV.B | R0,@(disp,Rn) | 10000000nnnndddd | $R0 \rightarrow (disp + Rn)$ | 1 | _ | | MOV.W | R0,@(disp,Rn) | 10000001nnnndddd | $R0 \rightarrow (disp \times 2 + Rn)$ | 1 | _ | | MOV.L | Rm,@(disp,Rn) | 0001nnnnmmmmdddd | $Rm \rightarrow (disp \times 4 + Rn)$ | 1 | | | MOV.B | @(disp,Rm),R0 | 10000100mmmmdddd | | 1 | _ | | MOV.W | @(disp,Rm),R0 | 10000101mmmmdddd | $(disp \times 2 + Rm) \rightarrow Sign$<br>extension $\rightarrow R0$ | 1 | _ | | MOV.L | @(disp,Rm),Rn | 0101nnnnmmmmdddd | $(disp \times 4 + Rm) \rightarrow Rn$ | 1 | _ | | MOV.B | Rm,@(R0,Rn) | 0000nnnnmmmm0100 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | | MOV.W | Rm,@(R0,Rn) | 0000nnnnmmmm0101 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | **Table 2.21 Data Transfer Instructions (cont)** | Instruc | tion | Instruction Code | Operation | Cycles | T<br>Bit | |---------|----------------|------------------|---------------------------------------------------------------------------------------------------------------------------|--------|----------| | MOV.L | Rm,@(R0,Rn) | 0000nnnnmmmm0110 | $Rm \rightarrow (R0 + Rn)$ | 1 | _ | | MOV.B | @(R0,Rm),Rn | 0000nnnnmmm1100 | $(R0 + Rm) \rightarrow Sign$<br>extension $\rightarrow Rn$ | 1 | _ | | MOV.W | @(R0,Rm),Rn | 0000nnnnmmm1101 | $ \begin{array}{l} (R0 + Rm) \to Sign \\ extension \to Rn \end{array} $ | 1 | _ | | MOV.L | @(R0,Rm),Rn | 0000nnnnmmm1110 | $(R0 + Rm) \rightarrow Rn$ | 1 | | | MOV.B | R0,@(disp,GBR) | 11000000dddddddd | $R0 \to (disp + GBR)$ | 1 | _ | | MOV.W | R0,@(disp,GBR) | 11000001dddddddd | $R0 \to (disp \times 2 + GBR)$ | 1 | | | MOV.L | R0,@(disp,GBR) | 11000010dddddddd | $R0 \to (disp \times 4 + GBR)$ | 1 | _ | | MOV.B | @(disp,GBR),R0 | 11000100dddddddd | | 1 | _ | | MOV.W | @(disp,GBR),R0 | 11000101dddddddd | | 1 | | | MOV.L | @(disp,GBR),R0 | 11000110dddddddd | $(disp \times 4 + GBR) \to R0$ | 1 | _ | | MOVA | @(disp,PC),R0 | 11000111dddddddd | $disp \times 4 + PC \to R0$ | 1 | _ | | MOVT | Rn | 0000nnnn00101001 | $T \rightarrow Rn$ | 1 | _ | | SWAP.E | 3 Rm,Rn | 0110nnnnmmmm1000 | $\begin{array}{c} \text{Rm} \rightarrow \text{Swap the} \\ \text{bottom two bytes} \rightarrow \text{Rn} \end{array}$ | 1 | _ | | SWAP.V | √Rm,Rn | 0110nnnnmmmm1001 | $\begin{array}{c} \text{Rm} \rightarrow \text{Swap two} \\ \text{consecutive words} \rightarrow \\ \text{Rn} \end{array}$ | 1 | _ | | XTRCT | Rm,Rn | 0010nnnnmmmm1101 | Rm: Middle 32 bits of $Rn \rightarrow Rn$ | 1 | | **Table 2.22 Arithmetic Instructions** | Instruction | | Instruction Code | Operation | Cycles | T Bit | |-------------|---------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------------------| | ADD | Rm,Rn | 0011nnnnmmmm1100 | $Rn + Rm \rightarrow Rn$ | 1 | _ | | ADD | #imm,Rn | 0111nnnniiiiiiii | $Rn + imm \rightarrow Rn$ | 1 | _ | | ADDC | Rm,Rn | 0011nnnnmmmm1110 | $Rn + Rm + T \rightarrow Rn,$ $Carry \rightarrow T$ | 1 | Carry | | ADDV | Rm,Rn | 0011nnnnmmmm1111 | $\begin{array}{c} Rn + Rm \rightarrow Rn, \\ Overflow \rightarrow T \end{array}$ | 1 | Overflow | | CMP/EQ | #imm,R0 | 10001000iiiiiiii | If R0 = imm, $1 \rightarrow T$ | 1 | Comparison result | | CMP/EQ | Rm,Rn | 0011nnnnmmmm0000 | If Rn = Rm, $1 \rightarrow T$ | 1 | Comparison result | | CMP/HS | Rm,Rn | 0011nnnnmmmm0010 | If Rn³Rm with unsigned data, $1 \rightarrow T$ | 1 | Comparison result | | CMP/GE | Rm,Rn | 0011nnnnmmmm0011 | If Rn ³ Rm with signed data, 1 → T | 1 | Comparison result | | CMP/HI | Rm,Rn | 0011nnnnmmmm0110 | If Rn > Rm with unsigned data, $1 \rightarrow T$ | 1 | Comparison result | | CMP/GT | Rm,Rn | 0011nnnnmmmm0111 | If Rn > Rm with signed data, $1 \rightarrow T$ | 1 | Comparison result | | CMP/PL | Rn | 0100nnnn00010101 | If Rn > 0, 1 $\rightarrow$ T | 1 | Comparison result | | CMP/PZ | Rn | 0100nnnn00010001 | If Rn <sup>3</sup> 0, 1 → T | 1 | Comparison result | | CMP/STR | Rm,Rn | 0010nnnnmmm1100 | If Rn and Rm have an equivalent byte, $1 \rightarrow T$ | 1 | Comparison result | | DIV1 | Rm,Rn | 0011nnnnmmmm0100 | Single-step division (Rn/Rm) | 1 | Calculation result | | DIVOS | Rm,Rn | 0010nnnnmmmm0111 | $\begin{array}{l} \text{MSB of Rn} \rightarrow \text{Q}, \\ \text{MSB of Rm} \rightarrow \text{M}, \\ \text{M} \land \text{Q} \rightarrow \text{T} \end{array}$ | 1 | Calculation result | | DIV0U | | 000000000011001 | $0 \rightarrow M/Q/T$ | 1 | 0 | **Table 2.22 Arithmetic Instructions (cont)** | Instructio | n | Instruction Code | Operation | Cycles | T Bit | |------------|-----------|------------------|-----------------------------------------------------------------------------------------------------------------|----------------|-------------------| | DMULS.L | Rm,Rn | 0011nnnnmmmm1101 | Signed operation of $Rn \times Rm \rightarrow MACH$ , MACL $32 \times 32 \rightarrow 64$ bit | 2 to 4* | _ | | DMULU.L | Rm,Rn | 0011nnnnmmmm0101 | Unsigned operation of Rn $\times$ Rm $\rightarrow$ MACH, MACL 32 $\times$ 32 $\rightarrow$ 64 bit | 2 to 4* | _ | | DT | Rn | 0100nnnn00010000 | $Rn - 1 \rightarrow Rn$ , when Rn is 0, 1 $\rightarrow$ T. When Rn is nonzero, 0 $\rightarrow$ T | 1 | Comparison result | | EXTS.B | Rm,Rn | 0110nnnnmmmm1110 | A byte in Rm is signextended $\rightarrow$ Rn | 1 | _ | | EXTS.W | Rm,Rn | 0110nnnnmmmm1111 | A word in Rm is sign-extended $\rightarrow$ Rn | 1 | _ | | EXTU.B | Rm,Rn | 0110nnnnmmmm1100 | A byte in Rm is zero-<br>extended $\rightarrow$ Rn | 1 | _ | | EXTU.W | Rm,Rn | 0110nnnnmmmm1101 | A word in Rm is zero-extended $\rightarrow$ Rn | 1 | _ | | MAC.L | @Rm+,@Rn+ | 0000nnnnmmmm1111 | Signed operation of $(Rn) \times (Rm) + MAC$<br>$\rightarrow MAC 32 \times 32 \rightarrow$<br>64 bit | 3/(2 to<br>4)* | _ | | MAC.W | @Rm+,@Rn+ | 0100nnnnmmmm1111 | Signed operation of $(Rn) \times (Rm) + MAC$<br>$\rightarrow MAC \ 16 \times 16 + 64$<br>$\rightarrow 64 \ bit$ | 3/(2)* | _ | | MUL.L | Rm,Rn | 0000nnnnmmmm0111 | $\begin{array}{c} Rn \times Rm \rightarrow MACL, \\ 32 \times 32 \rightarrow 32 \ bit \end{array}$ | 2 to 4* | _ | | MULS.W | Rm,Rn | 0010nnnnmmmm1111 | Signed operation of Rn $\times$ Rm $\rightarrow$ MAC 16 $\times$ 16 $\rightarrow$ 32 bit | 1 to 3* | _ | | MULU.W | Rm,Rn | 0010nnnnmmmm1110 | Unsigned operation of Rn $\times$ Rm $\rightarrow$ MAC 16 $\times$ 16 $\rightarrow$ 32 bit | 1 to 3* | _ | | NEG | Rm,Rn | 0110nnnnmmm1011 | $0-Rm \rightarrow Rn$ | 1 | | | NEGC | Rm,Rn | 0110nnnnmmmm1010 | $\begin{array}{c} \text{0RmT} \rightarrow \text{Rn,} \\ \text{Borrow} \rightarrow \text{T} \end{array}$ | 1 | Borrow | 90 HITACHI **Table 2.22 Arithmetic Instructions (cont)** | Instruction | | Instruction Code | Operation | Cycles | T Bit | |-------------|-------|------------------|------------------------------------------------------------------------------|--------|-----------| | SUB | Rm,Rn | 0011nnnnmmmm1000 | $RnRm \to Rn$ | 1 | _ | | SUBC | Rm,Rn | 0011nnnnmmmm1010 | $\begin{array}{l} RnRmT \rightarrow Rn, \\ Borrow \rightarrow T \end{array}$ | 1 | Borrow | | SUBV | Rm,Rn | 0011nnnnmmmm1011 | $Rn-Rm \rightarrow Rn,$<br>Underflow $\rightarrow T$ | 1 | Underflow | Note: The normal number of execution cycles. (The number in parentheses is the number of cycles when there is contention with following instructions.) **Table 2.23 Logic Operation Instructions** | Instruc | tion | Instruction Code | Operation | Cycles | T Bit | |---------|----------------|--------------------|-----------------------------------------------------------------------------------------------------|--------|----------------| | AND | Rm,Rn | 0010nnnnmmmm1001 | $Rn \& Rm \rightarrow Rn$ | 1 | _ | | AND | #imm,R0 | 11001001iiiiiiii | R0 & imm $\rightarrow$ R0 | 1 | _ | | AND.B | #imm,@(R0,GBR) | 11001101iiiiiiii | $ \begin{array}{c} (\text{R0 + GBR}) \& \text{imm} \rightarrow \\ (\text{R0 + GBR}) \end{array} $ | 3 | _ | | NOT | Rm,Rn | 0110nnnnmmmm0111 | $\sim\!$ Rm $\to$ Rn | 1 | _ | | OR | Rm,Rn | 0010nnnnmmmm1011 | $Rn\mid Rm\to Rn$ | 1 | _ | | OR | #imm,R0 | 11001011iiiiiii | $R0\mid imm \rightarrow R0$ | 1 | _ | | OR.B | #imm,@(R0,GBR) | 110011111111111111 | $ \begin{array}{c} (\text{R0 + GBR}) \mid \text{imm} \rightarrow \\ (\text{R0 + GBR}) \end{array} $ | 3 | _ | | TAS.B | @Rn | 0100nnnn00011011 | If (Rn) is 0, 1 $\rightarrow$ T; 1 $\rightarrow$ MSB of (Rn) | 4 | Test<br>result | | TST | Rm,Rn | 0010nnnnmmmm1000 | Rn & Rm; if the result is $0, 1 \rightarrow T$ | 1 | Test<br>result | | TST | #imm,R0 | 11001000iiiiiiii | R0 & imm; if the result is $0, 1 \rightarrow T$ | 1 | Test<br>result | | TST.B | #imm,@(R0,GBR) | 11001100iiiiiiii | (R0 + GBR) & imm; if the result is 0, 1 $\rightarrow$ T | 3 | Test<br>result | | XOR | Rm,Rn | 0010nnnnmmmm1010 | $Rn \wedge Rm \rightarrow Rn$ | 1 | _ | | XOR | #imm,R0 | 11001010iiiiiiii | R0 ^ imm $\rightarrow$ R0 | 1 | _ | | XOR.B | #imm,@(R0,GBR) | 11001110iiiiiiii | $\begin{array}{l} (\text{R0 + GBR}) \land \text{imm} \rightarrow \\ (\text{R0 + GBR}) \end{array}$ | 3 | _ | **Table 2.24 Shift Instructions** | Instruction | | Instruction Code | Operation | Cycles | T Bit | |-------------|------|------------------|----------------------------------|--------|-------| | ROTL | Rn | 0100nnnn00000100 | $T \leftarrow Rn \leftarrow MSB$ | 1 | MSB | | ROTR | Rn | 0100nnnn00000101 | $LSB \to Rn \to T$ | 1 | LSB | | ROTCL | Rn | 0100nnnn00100100 | $T \leftarrow Rn \leftarrow T$ | 1 | MSB | | ROTCR | Rn | 0100nnnn00100101 | $T \to Rn \to T$ | 1 | LSB | | SHAL | Rn | 0100nnnn00100000 | $T \leftarrow Rn \leftarrow 0$ | 1 | MSB | | SHAR | Rn | 0100nnnn00100001 | $MSB \to Rn \to T$ | 1 | LSB | | SHLL | Rn | 0100nnnn00000000 | $T \leftarrow Rn \leftarrow 0$ | 1 | MSB | | SHLR | Rn | 0100nnnn00000001 | $0 \to Rn \to T$ | 1 | LSB | | SHLL2 | Rn | 0100nnnn00001000 | $Rn << 2 \rightarrow Rn$ | 1 | _ | | SHLR2 | Rn | 0100nnnn00001001 | $Rn>>2 \rightarrow Rn$ | 1 | | | SHLL8 | Rn | 0100nnnn00011000 | $Rn << 8 \rightarrow Rn$ | 1 | | | SHLR8 | Rn | 0100nnnn00011001 | $Rn>>8 \rightarrow Rn$ | 1 | _ | | SHLL16 | 5 Rn | 0100nnnn00101000 | $Rn << 16 \rightarrow Rn$ | 1 | _ | | SHLR16 | 5 Rn | 0100nnnn00101001 | $Rn >> 16 \rightarrow Rn$ | 1 | | 92 HITACHI **Table 2.25 Branch Instructions** | | | | | | T | |---------|-------|------------------|--------------------------------------------------------------------------------|------------------|-----| | Instruc | tion | Instruction Code | Operation | Cycles | Bit | | BF | label | 10001011dddddddd | If T = 0, disp $\times$ 2 + PC $\rightarrow$ PC;<br>if T = 1, nop | 3/1* | _ | | BF/S | label | 10001111dddddddd | Delayed branch, if T = 0, disp $\times$ 2 + PC $\rightarrow$ PC; if T = 1, nop | 2/1* | _ | | BT | label | 10001001dddddddd | Delayed branch, if T = 1, disp $\times$ 2 + PC $\rightarrow$ PC; if T = 0, nop | 3/1 <sup>*</sup> | _ | | BT/S | label | 10001101dddddddd | If T = 1, disp $\times$ 2 + PC $\rightarrow$ PC; if T = 0, nop | 2/1* | _ | | BRA | label | 1010dddddddddddd | Delayed branch, disp $\times$ 2 + PC $\rightarrow$ PC | 2 | _ | | BRAF | Rm | 0000nnnn00100011 | Delayed branch, Rm + PC $\rightarrow$ PC | 2 | _ | | BSR | label | 1011dddddddddddd | Delayed branch, PC $\rightarrow$ PR, disp $\times$ 2 + PC $\rightarrow$ PC | 2 | _ | | BSRF | Rm | 0000nnnn00000011 | Delayed branch, $PC \rightarrow PR$ , $Rm + PC \rightarrow PC$ | 2 | _ | | JMP | @Rm | 0100nnnn00101011 | Delayed branch, $Rm \rightarrow PC$ | 2 | | | JSR | @Rm | 0100nnnn00001011 | Delayed branch, $PC \rightarrow PR$ , $Rm \rightarrow PC$ | 2 | _ | | RTS | | 0000000000001011 | Delayed branch, $PR \rightarrow PC$ | 2 | _ | Note: One state when it does not branch. **Table 2.26 System Control Instructions** | Instruction | | Instruction Code | Operation | Cycles | T<br>Bit | |-------------|------------|------------------|--------------------------------------------------------------------------------------------------------------|--------|----------| | CLRMAC | 2 | 000000000101000 | $0 \rightarrow MACH$ , MACL | 1 | _ | | CLRT | | 000000000001000 | $0 \rightarrow T$ | 1 | 0 | | LDC | Rm,SR | 0100mmmm00001110 | $Rm \to SR$ | 1 | LSB | | LDC | Rm,GBR | 0100mmmm00011110 | $Rm \to GBR$ | 1 | _ | | LDC | Rm,VBR | 0100mmmm00101110 | $Rm \to VBR$ | 1 | _ | | LDC | Rm,MOD | 0100mmmm01011110 | $Rm \to MOD$ | 1 | _ | | LDC | Rm,RE | 0100mmmm01111110 | $Rm \to RE$ | 1 | _ | | LDC | Rm,RS | 0100mmmm01101110 | $Rm \to RS$ | 1 | _ | | LDC.L | @Rm+,SR | 0100mmmm00000111 | $(Rm) \rightarrow SR, Rm + 4 \rightarrow Rm$ | 3 | LSB | | LDC.L | @Rm+,GBR | 0100mmmm00010111 | $(Rm) \rightarrow GBR, Rm + 4 \rightarrow Rm$ | 3 | _ | | LDC.L | @Rm+,VBR | 0100mmmm00100111 | $(Rm) \rightarrow VBR, Rm + 4 \rightarrow Rm$ | 3 | _ | | LDC.L | @Rm+,MOD | 0100mmmm01010111 | $(Rm) \rightarrow MOD, Rm + 4 \rightarrow Rm$ | 3 | _ | | LDC.L | @Rm+,RE | 0100mmmm01110111 | $(Rm) \rightarrow RE, Rm + 4 \rightarrow Rm$ | 3 | _ | | LDC.L | @Rm+,RS | 0100mmmm01100111 | $(Rm) \rightarrow RS, Rm + 4 \rightarrow Rm$ | 3 | _ | | LDRE | @(disp,PC) | 10001110dddddddd | $disp \times 2 + PC \to RE$ | 1 | _ | | LDRS | @(disp,PC) | 10001100dddddddd | $disp \times 2 + PC \to RS$ | 1 | _ | | LDS | Rm,MACH | 0100mmmm00001010 | $Rm \to MACH$ | 1 | _ | | LDS | Rm,MACL | 0100mmmm00011010 | $Rm \to MACL$ | 1 | _ | | LDS | Rm,PR | 0100mmmm00101010 | $Rm \to PR$ | 1 | _ | | LDS | Rm,DSR | 0100mmmm01101010 | $Rm \to DSR$ | 1 | _ | | LDS | Rm,A0 | 0100mmmm01111010 | $Rm \rightarrow A0$ | 1 | _ | | LDS | Rm,X0 | 0100mmmm10001010 | $Rm \to X0$ | 1 | _ | | LDS | Rm,X1 | 0100mmmm10011010 | $Rm \to X1$ | 1 | _ | | LDS | Rm,Y0 | 0100mmmm10101010 | $Rm \rightarrow Y0$ | 1 | _ | | LDS | Rm,Y1 | 0100mmmm10111010 | $Rm \rightarrow Y1$ | 1 | _ | | LDS.L | @Rm+,MACH | 0100mmmm00000110 | $ \begin{array}{l} (\text{Rm}) \rightarrow \text{MACH}, \\ \text{Rm} + 4 \rightarrow \text{Rm} \end{array} $ | 1 | _ | | LDS.L | @Rm+,MACL | 0100mmmm00010110 | $ \begin{array}{l} (\text{Rm}) \rightarrow \text{MACL}, \\ \text{Rm} + 4 \rightarrow \text{Rm} \end{array} $ | 1 | _ | | LDS.L | @Rm+,PR | 0100mmmm00100110 | $(Rm) \rightarrow PR, Rm + 4 \rightarrow Rm$ | 1 | _ | **Table 2.26 System Control Instructions (cont)** | Instruc | tion | Instruction Code | Operation | Cycles | T<br>Bit | |---------|----------|------------------|--------------------------------------------------------------------------------------------------------------------|--------|----------| | LDS.L | @Rm+,DSR | 0100mmmm01100110 | $(Rm) \to DSR, \ Rm + 4 \to Rm$ | 1 | _ | | LDS.L | @Rm+,A0 | 0100mmmm01110110 | $(Rm) \rightarrow A0, Rm + 4 \rightarrow Rm$ | 1 | _ | | LDS.L | @Rm+,X0 | 0100mmmm10000110 | $(Rm) \rightarrow X0, Rm + 4 \rightarrow Rm$ | 1 | _ | | LDS.L | @Rm+,X1 | 0100mmmm10010110 | $(Rm) \rightarrow X1, Rm + 4 \rightarrow Rm$ | 1 | _ | | LDS.L | @Rm+,Y0 | 0100mmmm10100110 | $(Rm) \rightarrow Y0, Rm + 4 \rightarrow Rm$ | 1 | _ | | LDS.L | @Rm+,Y1 | 0100mmmm10110110 | $(Rm) \rightarrow Y1, Rm + 4 \rightarrow Rm$ | 1 | _ | | NOP | | 0000000000001001 | No operation | 1 | _ | | RTE | | 000000000101011 | Delayed branch,<br>stack area → PC/SR | 4 | _ | | SETRC | Rm | 0100mmmm00010100 | RE–RS operation result (repeat status) → RF1, RF0 | 1 | _ | | | | | $Rm[11:0] \rightarrow RC \; (SR[27:16])$ | | | | SETRC | #imm | 10000010iiiiiiii | RE–RS operation result (repeat status) $\rightarrow$ RF1, RF0 | 1 | _ | | | | | $\begin{array}{l} \text{imm} \rightarrow \text{RC (SR[23:16]), zeros} \\ \rightarrow \text{SR[27:24]} \end{array}$ | | | | SETT | | 000000000011000 | 1 → T | 1 | 1 | | SLEEP | | 000000000011011 | Sleep | 3* | _ | | STC | SR,Rn | 0000nnnn00000010 | $SR \to Rn$ | 1 | _ | | STC | GBR,Rn | 0000nnnn00010010 | $GBR \to Rn$ | 1 | _ | | STC | VBR,Rn | 0000nnnn00100010 | $VBR \to Rn$ | 1 | _ | | STC | MOD,Rn | 0000nnnn01010010 | $MOD \to Rn$ | 1 | _ | | STC | RE,Rn | 0000nnnn01110010 | $RE \rightarrow Rn$ | 1 | _ | | STC | RS,Rn | 0000nnnn01100010 | $RS \rightarrow Rn$ | 1 | _ | | STC.L | SR,@-Rn | 0100nnnn00000011 | $Rn-4 \rightarrow Rn, SR \rightarrow (Rn)$ | 2 | _ | | STC.L | GBR,@-Rn | 0100nnnn00010011 | $Rn-4 \rightarrow Rn, \ GBR \rightarrow (Rn)$ | 2 | _ | | STC.L | VBR,@-Rn | 0100nnnn00100011 | $Rn-4 \rightarrow Rn, VBR \rightarrow (Rn)$ | 2 | _ | | STC.L | MOD,@-Rn | 0100nnnn01010011 | $Rn-4 \rightarrow Rn, MOD \rightarrow (Rn)$ | 2 | _ | | STC.L | RE,@-Rn | 0100nnnn01110011 | $Rn-4 \rightarrow Rn, RE \rightarrow (Rn)$ | 2 | _ | | STC.L | RS,@-Rn | 0100nnnn01100011 | $Rn-4 \rightarrow Rn, RS \rightarrow (Rn)$ | 2 | _ | **Table 2.26 System Control Instructions (cont)** | | | | | | T | |---------|-----------|------------------|---------------------------------------------------------------------|--------|-----| | Instruc | tion | Instruction Code | Operation | Cycles | Bit | | STS | MACH,Rn | 0000nnnn00001010 | $MACH \to Rn$ | 1 | _ | | STS | MACL,Rn | 0000nnnn00011010 | $MACL \to Rn$ | 1 | _ | | STS | PR,Rn | 0000nnnn00101010 | $PR \to Rn$ | 1 | _ | | STS | DSR,Rn | 0000nnnn01101010 | $DSR \to Rn$ | 1 | _ | | STS | A0,Rn | 0000nnnn01111010 | $A0 \rightarrow Rn$ | 1 | _ | | STS | X0,Rn | 0000nnnn10001010 | $X0 \rightarrow Rn$ | 1 | _ | | STS | X1,Rn | 0000nnnn10011010 | $X1 \rightarrow Rn$ | 1 | _ | | STS | Y0,Rn | 0000nnnn10101010 | $Y0 \rightarrow Rn$ | 1 | _ | | STS | Y1,Rn | 0000nnnn10111010 | $Y1 \rightarrow Rn$ | 1 | _ | | STS.L | MACH,@-Rn | 0100nnnn00000010 | $Rn-4 \rightarrow Rn, MACH \rightarrow (Rn)$ | 1 | _ | | STS.L | MACL,@-Rn | 0100nnnn00010010 | $Rn-4 \rightarrow Rn, MACL \rightarrow (Rn)$ | 1 | _ | | STS.L | PR,@-Rn | 0100nnnn00100010 | $Rn-4 \rightarrow Rn, PR \rightarrow (Rn)$ | 1 | _ | | STS.L | DSR,@-Rn | 0100nnnn01100010 | $Rn-4 \rightarrow Rn, DSR \rightarrow (Rn)$ | 1 | _ | | STS.L | A0,@-Rn | 0100nnnn01110010 | $Rn-4 \rightarrow Rn, A0 \rightarrow (Rn)$ | 1 | _ | | STS.L | X0,@-Rn | 0100nnnn10000010 | $Rn-4 \rightarrow Rn, X0 \rightarrow (Rn)$ | 1 | _ | | STS.L | X1,@-Rn | 0100nnnn10010010 | $Rn-4 \rightarrow Rn, X1 \rightarrow (Rn)$ | 1 | _ | | STS.L | Y0,@-Rn | 0100nnnn10100010 | $Rn-4 \rightarrow Rn, Y0 \rightarrow (Rn)$ | 1 | _ | | STS.L | Y1,@-Rn | 0100nnnn10110010 | $Rn-4 \rightarrow Rn, Y1 \rightarrow (Rn)$ | 1 | _ | | TRAPA | #imm | 11000011iiiiiii | $PC/SR \rightarrow stack area, (imm \times 4 + VBR) \rightarrow PC$ | 8 | _ | Note: The number of execution cycles (3) before the chip enters sleep mode. 96 **Precautions Concerning the Number of Instruction Execution Cycles:** The execution cycles listed in the tables are minimum values. In practice, the number of execution cycles increases under such conditions as 1) when the instruction fetch is in contention with a data access, 2) when the destination register of a load instruction (memory $\rightarrow$ register) is the same as the register used by the next instruction, 3) when the branch destination address of a branch instruction is a 4n + 2 address. **CPU Instructions That Support DSP Functions:** A number of system control instructions have been added to the CPU core instructions to support DSP functions. The RS, RE and MOD registers have been added to support repeat control and modulo addressing, and the RC counter has been added to the SR register. The LDC and STC instructions have been added in order to access the aforementioned. The LDS and STS instructions have been added in order to access the DSP registers DSR, A0, X0, X1, Y0 and Y1. The SETRC instruction has been added to set the repeat counter (RC, bits 27 to 16) and repeat flags (RF1, RF0, bits 3 and 2) of the SR register. When the SETRC instruction operand is immediate, the 8-bit immediate data is stored in bits 23 to 16 of the SR register and bits 27 to 24 are 0 cleared. When the operand is a register, bits 11 to 0 of the register (12 bits) are stored in bits 27 to 16 of the SR register. Additionally, the status of 1 step repeat (00), 2 step repeat (01), 3 step repeat (11) or 4 step or greater repeat (10) is set from the RS, RE established values. In addition to the LDC instruction, the LDRS and LDRE instructions have been added for establishing the repeat start and repeat end addresses in the RS and RE registers. The added instructions are listed in table 2.27. **Table 2.27 Added CPU Instructions** | Instruction | | Operation | Code | Cycles | T<br>Bit | |-------------|----------|------------------|------------------|--------|----------| | LDC | Rm,MOD | Rm→MOD | 0100mmmm01011110 | 1 | _ | | LDC | Rm,RE | Rm→RE | 0100mmmm01111110 | 1 | _ | | LDC | Rm,RS | Rm→RS | 0100mmmm01101110 | 1 | _ | | LDC.L | @Rm+,MOD | (Rm)→MOD,Rm+4→Rm | 0100mmmm01010111 | 3 | _ | | LDC.L | @Rm+,RE | (Rm)→RE,Rm+4→Rm | 0100mmmm01110111 | 3 | _ | | LDC.L | @Rm+,RS | (Rm)→RS,Rm+4→Rm | 0100mmmm01100111 | 3 | _ | | STC | MOD,Rn | MOD→Rn | 0000nnnn01010010 | 1 | _ | | STC | RE,Rn | RE→Rn | 0000nnnn01110010 | 1 | _ | | STC | RS,Rn | RS→Rn | 0000nnnn01100010 | 1 | _ | | STC.L | MOD,@-Rn | Rn–4→Rn,MOD→(Rn) | 0100nnnn01010011 | 2 | _ | | STC.L | RE,@-Rn | Rn–4→Rn,RE→(Rn) | 0100nnnn01110011 | 2 | _ | | STC.L | RS,@-Rn | Rn–4→Rn,RS→(Rn) | 0100nnnn01100011 | 2 | _ | | LDS | Rm,DSR | Rm→DSR | 0100mmmm01101010 | 1 | _ | | LDS.L | @Rm+,DSR | (Rm)→DSR,Rm+4→Rm | 0100mmmm01100110 | 1 | _ | | LDS | Rm+,A0 | (Rm)→A0 | 0100mmmm01110110 | 1 | _ | | LDS.L | @Rm+,A0 | (Rm)→A0,Rm+4→Rm | 0100mmmm01110110 | 1 | _ | | LDS | Rm+,X0 | (Rm)→X0 | 0100mmmm01110110 | 1 | _ | | LDS.L | @Rm+,X0 | (Rm)→X0,Rm+4→Rm | 0100mmmm01100110 | 1 | _ | | LDS | Rm+,X1 | (Rm)→X1 | 0100mmmm01110110 | 1 | _ | | LDS.L | @Rm+,X1 | (Rm)→X1,Rm+4→Rm | 0100mmmm01100110 | 1 | _ | | LDS | Rm+,Y0 | (Rm)→Y0 | 0100mmmm01110110 | 1 | _ | | LDS.L | @Rm+,Y0 | (Rm)→Y0,Rm+4→Rm | 0100mmmm01100110 | 1 | _ | | LDS | Rm+,Y1 | (Rm)→Y1,Rm+4→Rm | 0100mmmm01110110 | 1 | _ | | STS | DSR,Rn | DSR→Rn | 0000nnnn01101010 | 1 | _ | | STS.L | DSR,@-Rn | Rn–4→Rn,DSR→(Rn) | 0100nnnn01100010 | 1 | _ | | STS | A0,Rn | A0→Rn | 0000nnnn01111010 | 1 | _ | | STS.L | A0,@-Rn | Rn–4→Rn,A0→(Rn) | 0100nnnn01110010 | 1 | | | STS | X0,Rn | X0→Rn | 0000nnnn10001010 | 1 | _ | | STS.L | X0,@-Rn | Rn–4→Rn,X0→(Rn) | 0100nnnn01110010 | 1 | | | STS | X1,Rn | X1→Rn | 0000nnnn01111010 | 1 | _ | | STS.L | X1,@-Rn | Rn–4→Rn,X1→(Rn) | 0100nnnn01110010 | 1 | _ | **Table 2.27 Added CPU Instructions (cont)** | Instruction | | Operation | Code | Cycles | T<br>Bit | |-------------|------------|----------------------------------------------------------------|------------------|--------|----------| | STS | Y0,Rn | Y0→Rn | 0000nnnn10101010 | 1 | _ | | STS.L | Y0,@-Rn | $Rn-4\rightarrow Rn, Y0\rightarrow (Rn)$ | 0100nnnn10100010 | 1 | _ | | STS | Y1,Rn | Y1→Rn | 0000nnnn10111010 | 1 | _ | | STS.L | Y1,@-Rn | Rn–4→Rn,Y1→(Rn) | 0100nnnn10110010 | 1 | _ | | SETRC | Rm | Rm[11:0]→RC (SR[27:16]) | 0100mmmm00010100 | 1 | _ | | SETRC | #imm | imm $\rightarrow$ RC(SR[23:16]),zero s $\rightarrow$ SR[27:24] | 10000010iiiiiiii | 1 | _ | | LDRS | @(disp,PC) | $disp \times 2 \text{+PC} {\rightarrow} RS$ | 10001100dddddddd | 1 | _ | | LDRE | @(disp,PC) | $disp \times 2 \texttt{+PC} {\rightarrow} RE$ | 10001110dddddddd | 1 | _ | #### 2.5.2 DSP Data Transfer Instruction Set Table 2.28 lists the DSP data transfer instructions by classification. **Table 2.28 Classification of DSP Data Transfer Instructions** | Classification | Types | Operation Code | n<br>Function | No. of<br>Instructions | |-----------------------------------|----------|----------------|------------------------|------------------------| | Double data transfer instructions | 4 | NOPX | X memory no operation | 14 | | | | MOVX | X memory data transfer | | | | | NOPY | Y memory no operation | <u> </u> | | | | MOVY | Y memory data transfer | | | Single data transfer instructions | 1 | MOVS | Single data transfer | 16 | | | Total: 5 | ; | | Total: 30 | The data transfer instructions are divided into two groups, namely, double data transfers and single data transfers. Double data transfers can be combined with DSP operation instructions to perform DSP parallel processing. The parallel processing instructions are 32 bit length, and the double data transfer instructions are incorporated into their A fields. Double data transfers that are not parallel processing instructions are 16 bit length, as are the single data transfer instructions. The X memory and Y memory can be accessed simultaneously in parallel in double data transfers. One instruction each is designated from among the X and Y memory data accesses. The Ax pointer is used to access X memory; the Ay pointer is used to access Y memory. Double data transfers can only access X, Y memory. Single data transfers can be accessed from any area. Single data transfers use the Ax pointer and two other pointers as an As pointer. **Table 2.29 Double Data Transfer Instructions (X Memory Data)** | Instruction | Operation | Code | Cycles | T Bit | |---------------------|-------------------------------------------------------------------------------|------------------|--------|-------| | NOPX | No Operation | 1111000*0*0*00** | 1 | _ | | MOVX.W<br>@Ax,Dx | (Ax)→MSW of Dx,0→LSW of Dx | 111100A*D*0*01** | 1 | _ | | MOVX.W<br>@Ax+,Dx | (Ax) $\rightarrow$ MSW of Dx,0 $\rightarrow$ LSW of Dx,Ax+2 $\rightarrow$ Ax | 111100A*D*0*10** | 1 | _ | | MOVX.W<br>@Ax+Ix,Dx | (Ax) $\rightarrow$ MSW of Dx,0 $\rightarrow$ LSW of Dx,Ax+Ix $\rightarrow$ Ax | 111100A*D*0*11** | 1 | _ | | MOVX.W<br>Da,@Ax | MSW of Da→(Ax) | 111100A*D*1*01** | 1 | _ | | MOVX.W<br>Da,@Ax+ | MSW of Da→(Ax),Ax+2→Ax | 111100A*D*1*10** | 1 | _ | | MOVX.W<br>Da,@Ax+Ix | MSW of Da→(Ax),Ax+Ix→Ax | 111100A*D*1*11** | 1 | _ | Table 2.30 Double Data Transfer Instructions (Y Memory Data) | Instruction | Operation | Code | Cycles | T Bit | |---------------------|-----------------------------------------|----------------------|--------|-------| | NOPY | No Operation | 111100*0*0*0**0<br>0 | 1 | _ | | MOVY.W<br>@Ay,Dy | (Ay)→MSW of Dy,0→LSW of Dy | 111100*A*D*0**0<br>1 | 1 | _ | | MOVY.W<br>@Ay+,Dy | (Ay)→MSW of Dy,0→LSW of<br>Dy, Ay+2→Ay | 111100*A*D*0**1<br>0 | 1 | _ | | MOVY.W<br>@Ay+Iy,Dy | (Ay)→MSW of Dy,0→LSW of<br>Dy, Ay+Iy→Ay | 111100*A*D*0**1<br>1 | 1 | _ | | MOVY.W<br>Da,@Ay | MSW of Da→(Ay) | 111100*A*D*1**0<br>1 | 1 | _ | | MOVY.W<br>Da,@Ay+ | MSW of Da→(Ay),Ay+2→Ay | 111100*A*D*1**1<br>0 | 1 | _ | | MOVY.W<br>Da,@Ay+Iy | MSW of Da→(Ay),Ay+Iy→Ay | 111100*A*D*1**1<br>1 | 1 | _ | **Table 2.31 Single Data Transfer Instructions** | Instruction | Operation | Code | Cycles | T<br>Bit | |---------------------|--------------------------------------------------------------------------------|-------------------|--------|----------| | MOVS.W<br>@-As,Ds | As–2→As,(As)→MSW of Ds,0→LSW of Ds | 111101AADDDD0000 | 1 | _ | | MOVS.W<br>@As,Ds | (As)→MSW of Ds,0→LSW of Ds | 111101AADDDD0100 | 1 | _ | | MOVS.W<br>@As+,Ds | (As) $\rightarrow$ MSW of Ds,0 $\rightarrow$ LSW of Ds, As+2 $\rightarrow$ As | 111101AADDDD1000 | 1 | _ | | MOVS.W<br>@As+Ix,Ds | (As) $\rightarrow$ MSW of Ds,0 $\rightarrow$ LSW of Ds, As+Ix $\rightarrow$ As | 111101AADDDD1100 | 1 | _ | | MOVS.W<br>Ds,@-As | As–2→As,MSW of Ds→(As)* | 111101AADDDD0001 | 1 | _ | | MOVS.W<br>Ds,@As | MSW of Ds→(As)* | 111101AADDDD0101 | 1 | _ | | MOVS.W<br>Ds,@As+ | MSW of Ds→(As),As+2→As* | 111101AADDDD1001 | 1 | _ | | MOVS.W<br>Ds,@As+Is | MSW of<br>Ds→(As),As+Is→As* | 111101AADDDD1101 | 1 | _ | | MOVS.L<br>@-As,Ds | As–4→As,(As)→Ds | 111101AADDDD0010 | 1 | _ | | MOVS.L<br>@As,Ds | (As)→Ds | 111101AADDDD0110 | 1 | _ | | MOVS.L<br>@As+,Ds | (As)→Ds,As+4→As | 111101AADDDD1010 | 1 | _ | | MOVS.L<br>@As+Is,Ds | (As)→Ds,As+Is→As | 111101AADDDD11110 | 1 | _ | | MOVS.L Ds,<br>@-As | As–4→As,Ds→(As) | 111101AADDDD0011 | 1 | _ | | MOVS.L<br>Ds,@As | Ds→(As) | 111101AADDDD0111 | 1 | _ | | MOVS.L<br>Ds,@As+ | Ds→(As),As+4→As | 111101AADDDD1011 | 1 | _ | | MOVS.L<br>Ds,@As+Is | Ds→(As),As+Is→As | 111101AADDDD1111 | 1 | _ | Note: When guard bit registers A0G and A1G are specified for the source operand Ds, data is output to the IDB[7:0] bus and the sign bit is copied to the top bits [31:8]. Table 2.32 shows the correspondence between the DSP data transfer operands and registers. CPU core registers are used as pointer addresses indicating memory addresses. Table 2.32 Correspondence between DSP Data Transfer Operands and Registers # SuperH (CPU Core) Registers | Oper-<br>and | R0 | R1 | R2<br>(As2) | R3<br>(As3) | R4<br>(Ax0)<br>(As0) | R5<br>(Ax1)<br>(Ax0) | R6<br>(Ay0) | R7<br>(Ay1) | R8<br>(lx) | R9<br>(ly) | |--------------|----|----|-------------|-------------|----------------------|----------------------|-------------|-------------|------------|------------| | Ax | _ | _ | _ | _ | Yes | Yes | _ | _ | _ | _ | | lx (ls) | _ | _ | _ | _ | _ | _ | _ | _ | Yes | _ | | Dx | _ | _ | _ | _ | _ | _ | _ | _ | _ | | | Ay | _ | _ | _ | _ | _ | _ | Yes | Yes | _ | _ | | ly | _ | _ | _ | _ | _ | _ | _ | _ | _ | Yes | | Dy | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Da | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | As | _ | _ | Yes | Yes | Yes | Yes | _ | _ | _ | _ | | Ds | | | _ | _ | _ | | _ | _ | _ | _ | # **DSP Registers** | Operand | X0 | <b>X1</b> | Y0 | Y1 | MO | M1 | A0 | A1 | A0G | A1G | |---------|-----|-----------|-----|-----|-----|-----|-----|-----|-----|-----| | Ax | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | lx (ls) | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Dx | Yes | Yes | _ | _ | _ | _ | _ | _ | _ | | | Ay | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | ly | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Dy | _ | _ | Yes | Yes | _ | _ | _ | _ | _ | _ | | Da | _ | _ | _ | _ | _ | _ | Yes | Yes | _ | _ | | As | _ | _ | _ | _ | _ | _ | _ | _ | _ | _ | | Ds | Yes Note: Yes indicates that the register can be set. #### 2.5.3 DSP Operation Instruction Set DSP operation instructions are digital signal processing instructions processed by the DSP unit. These instructions are 32 bit length instruction codes, and they execute multiple instructions in parallel. The instruction codes are divided into an A field and a B field; parallel data transfer instructions are designated in the A field, and single or double data operation instructions are designated in the B field. Instructions can be independently designated and execution can also be independently in parallel. A parallel data transfer instruction designated in the A field is exactly the same as a double data transfer instruction. The B field data operation instructions are divided into three groups: double data operation instructions, conditional single data operation instructions, and unconditional single data operation instructions. Table 2.33 lists the instruction formats of the DSP operation instructions. Each of the operands can be independently selected from the DSP registers. Table 2.34 shows the correspondence between the DSP operation instruction operands and registers. **Table 2.33 DSP Operation Instruction Formats** | Classification | | Instruction Forms | Instruction | |-------------------------------------|---------------------------|--------------------------|----------------------------------| | Double data operation | instructions (6 operands) | ALUop. Sx, Sy, | PADD PMULS, | | | | Du | PSUB PMULS | | | | MLTop. Se, Sf,<br>Dg | | | Conditional single data operation | 3 operands | ALUop. Sx, Sy, | PADD, PAND, POR,<br>PSHA, PSHL, | | instructions | | DCT ALUop. Sx,<br>Sy, Dz | PSUB, PXOR | | | | DCF ALUop. Sx,<br>Sy, Dz | | | | 2 operands | ALUop. Sx, Dz | PCOPY, PDEC, | | | | DCT ALUop. Sx, | PDMSB, PINC,<br>PLDS, PSTS, PNEG | | | | DCF ALUop. Sx, | | | | | ALUop. Sy, Dz | | | | | DCT ALUop. Sy,<br>Dz | | | | | DCF ALUop. Sy,<br>Dz | | | | 1 operand | ALUop. Dz | PCLR, PSHA #imm, | | | | DCT ALUop. Dz | PSHL #imm | | | | DCF ALUop. Dz | | | Unconditional single data operation | 3 operands | ALUop. Sx, Sy,<br>Du | PADDC, PSUBC,<br>PWADD, PWSB, | | instructions | | MLTop. Se, Sf,<br>Dg | PMULS | | | 2 operands | ALUop. Sx, Dz | PCMP, PABS, PRND | | | | ALUop. Sy, Dz | | Table 2.34 Correspondence between DSP Instruction Operands and Registers | | ALU and BPU Instructions | | | Multi | plication In | structions | | |----------|--------------------------|-----|-----|-------|--------------|------------|-----| | Register | Sx | Sy | Dz | Du | Se | Sf | Dg | | A0 | Yes | _ | Yes | Yes | _ | _ | Yes | | A1 | Yes | _ | Yes | Yes | Yes | Yes | Yes | | MO | _ | Yes | Yes | _ | _ | _ | Yes | | M1 | _ | Yes | Yes | _ | _ | _ | Yes | | X0 | Yes | _ | Yes | Yes | Yes | Yes | _ | | X1 | Yes | _ | Yes | _ | Yes | _ | _ | | Y0 | _ | Yes | Yes | Yes | Yes | Yes | _ | | Y1 | _ | Yes | Yes | _ | _ | Yes | _ | When writing parallel instructions, write the B field instructions first, then write the A field instructions: | PADD A0,M0,A0 PMULS X0,Y0,M0 | MOVX.W @R4+,X0 | MOVY.W @R6+,Y0[;] | |------------------------------|------------------|-------------------| | DCF PINC X1,A1 | MOVX.W A0,@R5+R8 | MOVY.W@R7+,Y0[;] | | PCMP X1,M0 | MOVX.W @R4 | [NOPY][;] | Text in brackets ([]) can be omitted. The no operation instructions NOPX and NOPY can be omitted. Semicolons (;) are used to demarcate instruction lines, but can be omitted. If semicolons are used, the space after the semicolon can be used for comments. The individual status codes (DC, N, Z, V, GT) of the DSR register is always updated by unconditional ALU operation instructions and shift operation instructions. Conditional instructions do not update the status codes, even if the conditions have been met. Multiplication instructions also do not update the status codes. DC bit definitions are determined by the specifications of the CS bits in the DSR register. Table 2.35 lists the DSP operation instructions by classification. Table 2.35 Classification of CPU Instructions | Classifica | tion | Instruction<br>Types | Operation Code | Function | No. of In-<br>structions | |----------------------------------|------------------------------------------------|----------------------|----------------|---------------------------------------|--------------------------| | ALU arith-<br>metic<br>operation | ALU fixed decimal point operation instructions | 11 | PABS | Absolute value operation | 28 | | | | | PADD | Addition | = | | | | | PADD | Addition and signed | =' | | | | | PMULS | multiplication | _ | | instruc- | | | PADDC | Addition with carry | | | tions | | | PCLR | Clear | - | | | | | PCMP | Compare | - | | | | | PCOPY | Сору | _ | | | | | PNEG | Invert sign | _ | | | | | PSUB | Subtraction | _ | | | | | PSUB<br>PMULS | Subtraction and signed multiplication | | | | | | PSUBC | Subtraction with borrow | - | | | ALU integer operation instructions | 2 | PDEC | Decrement | 12 | | | | | PINC | Increment | - | | | MSB detection instruction | 1 | PDMSB | MSB detection | 6 | | | Rounding operation instruction | 1 | PRND | Rounding | 2 | | ALU logica | I operation instructions | 3 | PAND | Logical AND | - | | | | | POR | Logical OR | 9 | | | | | PXOR | Logical exclusive OR | | | Fixed decir<br>instruction | mal point multiplication | 1 | PMULS | Signed multiplication | 1 | | Shift | Arithmetic shift operation instruction | 1 | PSHA | Arithmetic shift | 4 | | | Logical shift operation instruction | 1 | PSHL | Logical shift | 4 | | System co | ntrol instructions | 2 | PLDS | System register load | 12 | | | | | PSTS | Store from system register | - | | | | Total 23 | | | Total 78 | | | | | | | | # 2.5.4 Various Operation Instructions Tables 2.36–2.45 list various operation instructions. **Table 2.36 ALU Fixed Point Operation Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |--------------------|------------------------------|-----------------------------------|--------|---------| | PABS Sx,Dz | If Sx³0,Sx→Dz | 111110****** | 1 | Update | | | If $Sx<0,0-Sx\rightarrow Dz$ | 10001000xx00zzzz | | | | PABS Sy,Dz | If Sy³0,Sy→Dz | 111110****** | 1 | Update | | | If Sy<0,0−Sy→Dz | 1010100000yyzzzz | | | | PADD | Sx+Sy→Dz | 111110****** | 1 | Update | | Sx,Sy,Dz | | 10110001xxyyzzzz | | | | DCT PADD | if DC=1,Sx+Sy→Dz if | 111110******* | 1 | _ | | Sx,Sy,Dz | 0,nop | 10110010xxyyzzzz | | | | DCF PADD | if DC=0,Sx+Sy→Dz if | 111110****** | 1 | _ | | Sx,Sy,Dz | 1,nop | 10110011xxyyzzzz | | | | PADD | Sx+Sy→Du | 111110******* | 1 | Update | | Sx,Sy,Du | MSW of Se $\times$ MSW of | 0111eeffxxyygguu | | | | PMULS | Sf→Dg | | | | | Se,Sf,Dg PADDC | Sx+Sy+DC→Dz | 111110****** | 1 | Update | | Sx,Sy,Dz | ЗхтЭутЬС⇒Ь2 | 101100000xxyyzzzz | 1 | Opuale | | PCLR Dz | H'00000000→Dz | 111110****** | 1 | Update | | PCLR DZ | 11000000000→D2 | 100011010000zzzz | 1 | Opuale | | DCT PCLR Dz | if DC=1,H'00000000→Dz | 111110****** | 1 | | | DCI PCLR D2 | if 0,nop | 100011100000zzzz | 1 | _ | | DCF PCLR Dz | if DC=0,H'00000000→Dz | 111110******* | 1 | | | DCF PCLR D2 | if 1,nop | 100011110000zzzz | 1 | _ | | DOMP G G | <u> </u> | 111110****** | 1 | Lindata | | PCMP Sx,Sy | Sx–Sy | | ı | Update | | DOODY G D- | Sv .D-7 | 10000100xxyy0000<br>111110******* | 1 | Undota | | PCOPY Sx,Dz | Sx→Dz | | 1 | Update | | DGODY G D | Cv · D- | 11011001xx00zzzz | 1 | Undoto | | PCOPY Sy,Dz | Sy→Dz | 111110******* | 1 | Update | | | #D0 40: D #0 | 1111100100yyzzzz | | | | DCT PCOPY<br>Sx,Dz | if DC=1,Sx→Dz if 0,nop | 111110******* | 1 | _ | | | | 11011010xx00zzzz | | | **Table 2.36 ALU Fixed Point Operation Instructions (cont)** | Instruction | Operation | Code | Cycles | DC Bit | |-------------------|---------------------------|------------------|--------|-------------| | DCT PCOPY | if DC=1,Sy→Dz if 0,nop | 111110****** | 1 | | | Sy,Dz | | 1111101000yyzzzz | | | | DCF PCOPY | if DC=0,Sx→Dz if 1,nop | 111110****** | 1 | | | Sx,Dz | | 11011011xx00zzzz | | | | DCF PCOPY | if DC=0,Sy→Dz if 1,nop | 111110****** | 1 | | | Sy,Dz | | 1111101100yyzzzz | | | | PNEG Sx,Dz | 0–Sx→Dz | 111110****** | 1 | Update | | | | 11001001xx00zzzz | | | | PNEG Sy,Dz | 0–Sy→Dz | 111110****** | 1 | Update | | | | 1110100100yyzzzz | | | | DCT PNEG | if DC=1,0-Sx→Dz | 111110****** | 1 | _ | | Sx,Dz | if 0,nop | 11001010xx00zzzz | | | | DCT PNEG | if DC=1,0-Sy→Dz | 111110****** | 1 | <del></del> | | Sy,Dz | if 0,nop | 1110101000yyzzzz | | | | DCF PNEG | if DC=0,0−Sx→Dz | 111110****** | 1 | _ | | Sx,Dz | if 1,nop | 11001011xx00zzzz | | | | DCF PNEG | if DC=0,0-Sy→Dz | 111110****** | 1 | | | Sy,Dz | if 1,nop | 1110101100yyzzzz | | | | PSUB | Sx–Sy→Dz | 111110****** | 1 | Update | | Sx,Sy,Dz | | 10100001xxyyzzzz | | | | DCT PSUB | if DC=1,Sx−Sy→Dz if | 111110****** | 1 | _ | | Sx,Sy,Dz | 0,nop | 10100010xxyyzzzz | | | | DCF PSUB | if DC=0,Sx-Sy→Dz if | 111110****** | 1 | | | Sx,Sy,Dz | 1,nop | 10100011xxyyzzzz | | | | PSUB | Sx–Sy→Du | 111110****** | 1 | Update | | Sx,Sy,Du | MSW of Se $\times$ MSW of | 0110eeffxxyygguu | | | | PMULS<br>Se,Sf,Dg | Sf→Dg | | | | | PSUBC | Sx–Sy–DC→Dz | 111110****** | 1 | Update | | Sx,Sy,Dz | 0x-0y-00→02 | | ı | Opuale | | | | 10100000xxyyzzzz | | | Table 2.37 ALU Integer Operation Instructions | Instruction | Operation | Code | Cycles | DC Bit | |-------------|---------------------------------------|------------------|--------|--------| | PDEC Sx,Dz | MSW of $Sx - 1 \rightarrow MSW$ of | 111110******* | 1 | Update | | | Dz, clear LSW of Dz | 10001001xx00zzzz | | | | PDEC Sy,Dz | MSW of Sy $-1 \rightarrow$ MSW of | 111110****** | 1 | Update | | | Dz, clear LSW of Dz | 10101001xx00zzzz | | | | DCT PDEC | If DC=1, MSW of Sx – 1 $\rightarrow$ | 111110******* | 1 | _ | | Sx,Dz | MSW of Dz, clear LSW of Dz; if 0, nop | 10001010xx00zzzz | | | | DCT PDEC | If DC=1, MSW of Sy – 1 $\rightarrow$ | 111110******* | 1 | _ | | Sy,Dz | MSW of Dz, clear LSW of Dz; if 0, nop | 10101010xx00zzzz | | | | DCF PDEC | If DC=0, MSW of Sx – 1 $\rightarrow$ | 111110******* | 1 | _ | | Sx,Dz | MSW of Dz, clear LSW of Dz; if 1, nop | 10001011xx00zzzz | | | | DCF PDEC | If DC=0, MSW of Sy – 1 $\rightarrow$ | 111110******* | 1 | _ | | Sy,Dz | MSW of Dz, clear LSW of Dz; if 1, nop | 10101011xx00zzzz | | | | PINC Sx,Dz | MSW of Sx + 1 $\rightarrow$ MSW of | 111110******* | 1 | Update | | | Dz, clear LSW of Dz | 10011001xx00zzzz | | | | PINC Sy,Dz | MSW of Sy + 1 $\rightarrow$ MSW of | 111110******* | 1 | Update | | | Dz, clear LSW of Dz | 1011100100yyzzzz | | | | DCT PINC | If DC=1, MSW of Sx + 1 $\rightarrow$ | 111110****** | 1 | _ | | Sx,Dz | MSW of Dz, clear LSW of Dz; if 0, nop | 10011010xx00zzzz | | | | DCT PINC | If DC=1, MSW of Sy + 1 $\rightarrow$ | 111110******* | 1 | _ | | Sy,Dz | MSW of Dz, clear LSW of Dz; if 0, nop | 1011101000yyzzzz | | | | DCF PINC | If DC=0, MSW of Sx + 1 $\rightarrow$ | 111110******* | 1 | _ | | Sx,Dz | MSW of Dz, clear LSW of Dz; if 1, nop | 10011011xx00zzzz | | | | DCF PINC | If DC=0, MSW of Sy + 1 $\rightarrow$ | 111110******* | 1 | _ | | Sy,Dz | MSW of Dz, clear LSW of Dz; if 1, nop | 1011101100yyzzzz | | | **Table 2.38 MSB Detection Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |-------------|--------------------------------------------------------------|-------------------|--------|--------| | PDMSB Sx,Dz | Sx data MSB position $\rightarrow$ | 111110******* | 1 | Update | | | MSW of Dz, clear LSW of<br>Dz | 10011101xx00zzzz | | | | PDMSB Sy,Dz | Sy data MSB position $\rightarrow$ | 111110******* | 1 | Update | | | MSW of Dz, clear LSW of<br>Dz | 1011110100yyzzzz | | | | DCT PDMSB | If DC=1, Sx data MSB | 111110******* | 1 | _ | | Sx,Dz | position $\rightarrow$ MSW of Dz, clear LSW of Dz; if 0, nop | 10011110xx00zzzz | | | | DCT PDMSB | If DC=1, Sy data MSB | 111110******* | 1 | _ | | Sy,Dz | position $\rightarrow$ MSW of Dz, clear LSW of Dz; if 0, nop | 10111111000yyzzzz | | | | DCF PDMSB | If DC=0, Sx data MSB | 111110******* | 1 | _ | | Sx,Dz | position $\rightarrow$ MSW of Dz, clear LSW of Dz; if 1, nop | 100111111xx00zzzz | | | | DCF PDMSB | If DC=0, Sy data MSB | 111110******* | 1 | | | Sy,Dz | position $\rightarrow$ MSW of Dz, clear LSW of Dz; if 1, nop | 10111111100yyzzzz | | | **Table 2.39 Rounding Operation Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |-------------|------------------|------------------|--------|--------| | PRND Sx,Dz | Sx+H'00008000→Dz | 111110******* | 1 | Update | | | clear LSW of Dz | 10011000xx00zzzz | | | | PRND Sy,Dz | Sy+H'00008000→Dz | 111110******* | 1 | Update | | | clear LSW of Dz | 1011100000yyzzzz | | | **Table 2.40 ALU Logical Operation Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |--------------|---------------------------------------------------------------|------------------|--------|--------| | PAND | Sx & Sy $\rightarrow$ Dz, clear LSW | 111110******* | 1 | Update | | Sx,Sy,Dz | of Dz | 10010101xxyyzzzz | | | | DCT PAND | If DC=1, Sx & Sy $\rightarrow$ Dz, | 111110******* | 1 | _ | | Sx,Sy,Dz | clear LSW of Dz; if 0, nop | 10010110xxyyzzzz | | | | DCF PAND | If DC=0, Sx & Sy $\rightarrow$ Dz, | 111110******* | 1 | | | Sx,Sy,Dz | clear LSW of Dz; if 1, nop | 10010111xxyyzzzz | | | | POR Sx,Sy,Dz | $Sx \mid Sy \rightarrow Dz$ , clear LSW | 111110******* | 1 | Update | | | of Dz | 10110101xxyyzzzz | | | | DCT POR | If DC=1, Sx Sy $\rightarrow$ Dz, clear LSW of Dz; if 0, nop | 111110******* | 1 | | | Sx,Sy,Dz | | 10110110xxyyzzzz | | | | DCF POR | If DC=0, Sx Sy $\rightarrow$ Dz, | 111110******* | 1 | | | Sx,Sy,Dz | clear LSW of Dz; if 1, nop | 10110111xxyyzzzz | | | | PXOR | $Sx \land Sy \rightarrow Dz$ , clear LSW | 111110******* | 1 | Update | | Sx,Sy,Dz | of Dz | 10100101xxyyzzzz | | | | DCT PXOR | If DC=1, $Sx \land Sy \rightarrow Dz$ , | 111110******* | 1 | | | Sx,Sy,Dz | clear LSW of Dz; if 0, nop | 10100110xxyyzzzz | | | | DCF PXOR | If DC=0, $Sx \land Sy \rightarrow Dz$ , | 111110******* | 1 | | | Sx,Sy,Dz | clear LSW of Dz; if 1, nop | 10100111xxyyzzzz | | | **Table 2.41 Fixed Point Multiplication Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |-------------|---------------------------|------------------|--------|--------| | PMULS | MSW of Se $\times$ MSW of | 111110******* | 1 | _ | | Se,Sf,Dg | Sf→Dg | 0100eeff0000gg00 | | | **Table 2.42 Arithmetic Shift Operation Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |--------------|---------------------------------------------------------------------------------------|------------------|--------|--------| | PSHA | if Sy³0,Sx< <sy→dz< td=""><td>111110*******</td><td>1</td><td>Update</td></sy→dz<> | 111110******* | 1 | Update | | Sx,Sy,Dz | if Sy<0,Sx>>Sy $\rightarrow$ Dz | 10010001xxyyzzzz | | | | DCT PSHA | if DC=1 & | 111110******* | 1 | _ | | Sx,Sy,Dz | Sy³0,Sx< <sy→dz< td=""><td>10010010xxyyzzzz</td><td></td><td></td></sy→dz<> | 10010010xxyyzzzz | | | | | if DC=1 & | | | | | | $Sy<0,Sx>>Sy\rightarrow Dz$ | | | | | | if DC=0,nop | | | | | DCF PSHA | if DC=0 & | 111110******* | 1 | _ | | Sx,Sy,Dz | Sy³0,Sx< <sy→dz< td=""><td>10010011xxyyzzzz</td><td></td><td></td></sy→dz<> | 10010011xxyyzzzz | | | | | if DC=0 & | | | | | | Sy<0,Sx>>Sy→Dz | | | | | | if DC=1,nop | | | | | PSHA #imm,Dz | if imm³0,Dz< <imm→dz< td=""><td>111110*******</td><td>1</td><td>Update</td></imm→dz<> | 111110******* | 1 | Update | | | if imm<0,Dz>>imm $\rightarrow$ Dz | 00000iiiiiiizzzz | | | Table 2.43 Logical Shift Operation Instructions | Instruction | Operation | Code | Cycles | DC Bit | |-------------|----------------------------------------------------------------------------------------------|------------------|--------|--------| | PSHL | if Sy³0,Sx< <sy→dz, clear<="" td=""><td>111110*******</td><td>1</td><td>Update</td></sy→dz,> | 111110******* | 1 | Update | | Sx,Sy,Dz | LSW of Dz | 10000001xxyyzzzz | | | | | if Sy<0,Sx>>Sy→Dz, clear<br>LSW of Dz | | | | | DCT PSHL | if DC=1 & | 111110******* | 1 | _ | | Sx,Sy,Dz | Sy³0,Sx< <sy→dz, clear<br="">LSW of Dz</sy→dz,> | 10000010xxyyzzzz | | | | | if DC=1 &<br>Sy<0,Sx>>Sy→Dz, clear<br>LSW of Dz | | | | | | if DC=0,nop | | | | | DCF PSHL | if DC=0 & | 111110******* | 1 | _ | | Sx,Sy,Dz | Sy³0,Sx< <sy→dz, clear<br="">LSW of Dz</sy→dz,> | 10000011xxyyzzzz | | | | | if DC=0 &<br>Sy<0,Sx>>Sy→Dz, clear<br>LSW of Dz | | | | | | if DC=1,nop | | | | | PSHL | if imm³0,Dz< <imm→dz,< td=""><td>111110*******</td><td>1</td><td>Update</td></imm→dz,<> | 111110******* | 1 | Update | | #imm,Dz | clear LSW of Dz | 00010iiiiiiizzzz | | | | | if imm<0,Dz>>imm→Dz,<br>clear LSW of Dz | | | | 114 **Table 2.44 System Control Instructions** | Instruction | Operation | Code | Cycles | DC Bit | |-------------|-----------------|-------------------|--------|--------| | PLDS | Dz→MACH | 111110****** | 1 | | | Dz,MACH | | 111011010000zzzz | | | | PLDS | Dz→MACL | 111110****** | 1 | _ | | Dz,MACL | | 111111010000zzzz | | | | DCT PLDS | if DC=1,Dz→MACH | 111110****** | 1 | _ | | Dz,MACH | if 0,nop | 111011100000zzzz | | | | DCT PLDS | if DC=1,Dz→MACL | 111110****** | 1 | | | Dz,MACL | if 0,nop | 111111100000zzzz | | | | DCF PLDS | if DC=0,Dz→MACH | 111110******* | 1 | _ | | Dz,MACH | if 1,nop | 1110111110000zzzz | | | | DCF PLDS | if DC=0,Dz→MACL | 111110******* | 1 | _ | | Dz,MACL | if 1,nop | 111111110000zzzz | | | | PSTS | MACH→Dz | 111110****** | 1 | _ | | MACH,Dz | | 110011010000zzzz | | | | PSTS | MACL→Dz | 111110****** | 1 | _ | | MACL,Dz | | 110111010000zzzz | | | | DCT PSTS | if DC=1,MACH→Dz | 111110******* | 1 | _ | | MACH,Dz | if 0,nop | 110011100000zzzz | | | | DCT PSTS | if DC=1,MACL→Dz | 111110******* | 1 | _ | | MACL,Dz | if 0,nop | 110111100000zzzz | | | | DCF PSTS | if DC=0,MACH→Dz | 111110****** | 1 | _ | | MACH,Dz | if 1,nop | 110011110000zzzz | | | | DCF PSTS | if DC=0,MACL→Dz | 111110****** | 1 | _ | | MACL,Dz | if 1,nop | 110111110000zzzz | | | When there are no data transfer instructions being processed simultaneously in parallel with DSP operation instructions, it is possible to either write NOPX, NOPY instructions or to omit the instructions. The instruction codes are the same regardless of whether the NOPX, NOPY instructions are written or omitted. Table 2.45 gives some examples of NOPX and NOPY instruction codes. Table 2.45 NOPX and NOPY Instruction Code Examples | Instruction | Code | |---------------------------------------------------|------------------| | PADD X0, Y0, A0 MOVX.W @R4+, X0 MOVY.W @R6+R9, Y0 | 1111100010110000 | | | 100000010100000 | | PADD X0, Y0, A0 NOPX MOVY.W @R6+R9, Y0 | 1111100000110000 | | | 100000010100000 | | PADD X0, Y0, A0 NOPX NOPY | 1111100000000000 | | | 100000010100000 | | PADD X0, Y0, A0 NOPX | <u>-</u> | | PADD X0, Y0, A0 | _ | | MOVX.W @R4+, X0 MOVY.W @R6+R9, Y0 | 1111000010110000 | | MOVX.W @R4+, X0 NOPY | 1111000010000000 | | MOVS.W @R4+, X0 | 1111011010000000 | | NOPX MOVY.W @R6+R9, Y0 | 1111000000110000 | | MOVY.W @R6+R9, Y0 | _ | | NOPX NOPY | 1111000000000000 | | NOP | 000000000001001 | # Section 3 Oscillator Circuits and Operating Modes # 3.1 Overview Operation of the on-chip clock pulse generator, CS0 area bus width specification, and switching between master and slave modes are controlled by the operating mode pins. A crystal oscillator or external clock can be selected as the clock source. # 3.2 On-Chip Clock Pulse Generator and Operating Modes #### 3.2.1 Clock Pulse Generator A block diagram of the on-chip clock pulse generator circuit is shown in figure 3.1. Figure 3.1 Block Diagram of Clock Pulse Generator Circuit **Pin Configuration:** Table 3.1 lists the functions relating to the pins relating to the oscillator circuit. **Table 3.1 Pin Functions** | Pin Name | I/O | Function | |------------|-----|---------------------------------------------------------------------------------------------| | CKIO | I/O | External clock input pin or internal clock output pin. | | XTAL | 0 | Connects to the crystal oscillator. | | EXTAL | I | Connects to the crystal oscillator or to the external clock input when using PLL circuit 2. | | CAP1 | I | Connects to capacitance for operating PLL circuit 1. | | CAP2 | ı | Connects to capacitance for operating PLL circuit 2. | | MD0 | I | The level applied to these pins specifies the clock mode. | | MD1 | I | _ | | MD2 | I | _ | | CKPREQ/CKM | I | Used as the clock pause request pin, or specifies operation of the crystal oscillator. | **PLL Circuit 1:** PLL circuit 1 eliminates phase differences between external clocks and clocks supplied internally within the chip. In high-speed operation, the phase difference between the reference clocks and operating clocks in the chip directly affects the interface margin with peripheral devices. On-chip PLL circuit 1 is provided to eliminate this effect. **PLL Circuit 2:** PLL circuit 2 either leaves unchanged, doubles, or quadruples the frequency of clocks provided from the crystal oscillator or the EXTAL pin external clock input for the chip operating frequency. The frequency modification register sets the clock frequency multiplication factor. #### 3.2.2 Clock Operating Mode Settings Table 3.2 lists the functions and operation of clock modes 0 to 6. **Table 3.2** Operating Modes | Clock Mode | Function/Operation | Clock Source | | | | | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--|--| | 0 | The PLL circuit 1 and the PLL circuit 2 operate. At this time, the internal clock ( $I\phi$ , $E\phi$ , $P\phi$ and the same phase clock ( $E\phi$ oscillator/external clock input | | | | | | | | The operation/stop of the PLL circuit 1 and the PLL circuit 2 can be switched by the control bit of the frequency change register (FMR). And also, the CKIO terminal is possible to make the HiZ condition. | | | | | | | 1 | The PLL circuit 1 and the PLL circuit 2 operate. At this time, the internal Eφ clock which 1/4φ was shifted against the LSI internal system clock is output from the CKIO terminal. | | | | | | | | The operation/stop of the PLL circuit 1 and the PLL circuit 2 can be switched bythe control bit of FMR. And also, it is possible to make the CKIO terminal in the HiZ condition. | | | | | | | 2 | The PLL circuit 2 operates. At this time, from the CKIO terminal, the clock from the PLL circuit 2 is output (It is the same frequency as the internal Εφ clock). The phase adjustment is not performed because the PLL circuit 1 always stops. | _ | | | | | | | The operation/stop of the PLL circuit 2 can be switched by<br>the control bit of FMR. And also, it is possible to make the<br>CKIO terminal in the HiZ condition. | | | | | | | 3 | The PLL circuit 2 operates. At this time, the CKIO terminal is always in the high impedance condition. | <del>-</del> | | | | | | | The operation/stop of the PLL circuit 2 can be switched by the control bit of FMR. | | | | | | | 4 | The PLL circuit 1 operates. Let the PLL circuit 1 operate when the phase with the input clock from the CKIO terminal and the LSI internal clock( $l\phi$ , $E\phi$ , $P\phi$ ) is adjusted and operated. PLL circuit2 always stops. | External clock input | | | | | | | The operation/stop of the PLL circuit 1 can be switched by the control bit of FMR | | | | | | | 5 | The PLL circuit 1 operates. Let the PLL circuit 1 operate when the input clock from the CKIO terminal and the LSI internal clock ( $l\phi$ , $E\phi$ , $P\phi$ ) operate with $1/4\phi$ cycle shifting against the system clock $\phi$ . The PLL circuit 2 always stops. | - | | | | | | | The operation/stop of the PLL circuit 1 can be switched by the control bit of FMR. | | | | | | | 6 | The PLL circuit 1 and the PLL circuit 2 always stop together. Set the mode 6 when letting operate with the same frequency clock as the input clock from the CKIO terminal. | External clock input | | | | | The internal clock frequency can be switched by each clock mode. (Refer to 3.2.5 Selection of operation frequency by the register). Frequency change of the input clock from CKIO pin and the stop of clock can be performed in the clock modes 4~6. (Refer to 22.4.4 clock pause function) Table 3.3 lists the relationship between pins MD2 to MD0 and the clock operating mode. Do not switch the MD2–MD0 pins while they are operating. Switching will cause operating errors. Table 3.3 Clock Mode Pin Settings and States | Pin*1 | |-------| |-------| | Clock<br>Mode | MD2 | MD1 | MD0 | CKPREQ/<br>CKM | EXTAL | XTAL | CKIO | | |---------------|-----|-----|---------------------|---------------------|---------------------|---------------------|-----------------------|--| | 0 | 0 | 0 | 0 | 0 | Clock input | Open | Output/high | | | | | | Crystal oscillation | Crystal oscillation | impedance | | | | | 1 | 0 | 0 | 1 | 0 | Clock input | Open | Output/high | | | | | | | 1 | Crystal oscillation | Crystal oscillation | impedance | | | 2 | 0 | 1 | 0 | 0 | Clock input | Open | Output/high impedance | | | | | | | 1 | Crystal oscillation | Crystal oscillation | | | | 3 | 0 | 1 | 1 | 0 | Clock input | Open | High | | | | | | | 1 | Crystal oscillation | Crystal oscillation | impedance | | | 4 | 1 | 0 | 0 | *2 | Open | Open | Clock input | | | 5 | 1 | 0 | 1 | <del>_</del> | Open | Open | Clock input | | | 6 | 1 | 1 | 0 | <del>_</del> | Open | Open | Clock input | | | | | | | | | | | | Notes: 1. Do not use in combinations other than those listed. <sup>2.</sup> In clock modes 4, 5, and 6, CKPREQ/CKM functions as the clock pause request pin. #### 3.2.3 Connecting a Crystal Oscillator **Connecting a Crystal Oscillator:** Figure 3.2 shows how to connect a crystal oscillator. Use the value shown in table 3.4 for the damping resistance Rd. The crystal oscillator should be an AT-cut parallel-resonance type. Be sure to connect load capacitors (CL1, CL2) as shown in the figure. Figure 3.2 Example of Crystal Oscillator Connection **Table 3.4 Damping Resistance (Reference Values)** | Frequency (MHz) | T.B.D. | T.B.D. | T.B.D. | |-----------------|--------|--------|--------| | Rd (?) | T.B.D. | T.B.D. | T.B.D. | **Crystal Oscillator**: Figure 3.3 shows a crystal oscillator equivalent circuit. Use a crystal oscillator that has the characteristics shown in table 3.5. Figure 3.3 Crystal Oscillator Equivalent Circuit Table 3.5 Crystal Oscillator Characteristics (Reference Values) # Frequency (MHz) | Parameters | T.B.D. | T.B.D. | T.B.D. | | |-------------|--------|--------|--------|--| | Rs max (?) | T.B.D. | T.B.D. | T.B.D. | | | Co max (pF) | T.B.D. | T.B.D. | T.B.D. | | # 3.2.4 Input Method of External Clock The external clock input is input from EXTAL pin or CKIO pin by the clock mode. **Clock input from EXTAL pin**: It can be used by the clock mode 0,1,2,3. Figure 3.4 External Clock Input Method **Clock Input from CKIO Pin:** It can be used by the clock mode4,5,6. Figure 3.5 External Clock Input Method ## 3.2.5 Operating Frequency Selection by Register Using the frequency modification register (FMR), it is possible to specify the operating frequency division ratio for the internal clocks ( $I\phi$ , $E\phi$ , $P\phi$ ). The internal clock frequency is determined under the control of PLL circuits 1 and 2 and dividers DIVM, DIVE, and DIVP. **Frequency Modification Register:** The frequency modification register is initialized only when power-on from $\overline{RES}$ pin is reset, but it is not initialized with the internal reset due to overflow of the WDT. And also, the initial value of the frequency modification register is different depending on the setting of MD2 to 0 pin. The relations of combination of MD 2 to 0 pin and the frequency modification register initial value are shown in table 3.6. Table 3.6 Relationship between Clock Mode Pin Settings and Initial Value of Frequency Modification Register | Clock Mode | MD2 | MD1 | MD0 | Initial Value | | |------------|-----|-----|-----|---------------|--| | Mode 0 | 0 | 0 | 0 | H'00 | | | Mode 1 | 0 | 0 | 1 | | | | Mode 2 | 0 | 1 | 0 | H'40 | | | Mode 3 | 0 | 1 | 1 | H'60 | | | Mode 4 | 1 | 0 | 0 | H'A6 | | | Mode 5 | 1 | 0 | 1 | | | | Mode 6 | 1 | 1 | 0 | H'E0 | | Register configuration is shown in table 3.7. **Table 3.7 Register Configuration** | Name | Abbreviated name | R/W | Initial value | Address | |---------------------------------------|------------------|-----|---------------|-----------| | Frequency<br>modification<br>register | FMR | R/W | * | H'FFFFE90 | [Notes] \* Refer to the table 3.6. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------|--------|--------|--------|---|-----|-----|-----|-----| | | PLL2ST | PLL1ST | CKIOST | _ | FR3 | FR2 | FR1 | FR0 | | Reset: | _ | _ | _ | 0 | 0 | _ | _ | 0 | | R/W: | R/W | R/W | R/W | R | R/W | R/W | R/W | R/W | ## Bit 7—PLL2ST Switching possible in mode 0-3. PLL circuit 2 cannot be used in modes 4–6. In these modes, this bit always reads 1. Bits 7 | PLL2ST | Description | | |--------|---------------------------|----------| | 0 | PLL circuit 2 used value) | (Initial | | 1 | PLL circuit 2 not used | | Switching Possible in Mode 0-3 #### Bit 6—PLL1ST Switching possible in modes 0, 1, 4, 5. PLL circuit 1 cannot be used in modes 2, 3, and 6. In these modes, this bit always reads 1. Bits 6 | PLL1ST | Description | | |--------|---------------------------|----------| | 0 | PLL circuit 1 used value) | (Initial | | 1 | PLL circuit 1 not used | | Bit 6: PLL1ST #### Bit 5—CKIOST Setting possible in modes 0–3. In modes 4–6, CKIO is an input pin. In these modes, this bit always reads 1. Bits 5 | CKIOST | Description | |--------|----------------------------------------------------------------------------------------------------------------| | 0 | CKIO pin outputs the Eφ clock (Initial value) | | 1 | CKIO pin is high-impedance (Do not place $\phi$ O in the high-impedance state when PLL circuit 1 is operating) | #### Bit 4—Reserved bits Bits 4 is the reserved bits. These bits always read 0. The write value should always be 0. #### Bits 3-0—FR3-0 The internal clock frequency and CKIO output frequency (modes 0–2) can be set by frequency setting bits FR3–FR0. The values that can be set in bits FR3–FR0 depend on the mode and whether PLL circuit 1 and PLL circuit 2 are operating or halted. The following tables show the values that can be set in FR3–FR0, and the internal clock and CKIO output frequency ratios, taking the external input clock frequency as 1. • Modes 0 and 1 PLL circuits 1 and 2 operating EXTAL input or crystal oscillator used | FR3 | FR2 | FR1 | FR0 | Ιφ | Еф | Рф | CKIO | |-----|-----|-----|-----|----|----|----|------| | 0 | 0 | 0 | 0 | ×1 | ×1 | ×1 | Еф | | 0 | 1 | 0 | 0 | ×2 | ×1 | ×1 | Еф | | 0 | 1 | 0 | 1 | ×2 | ×2 | ×1 | Еф | | 0 | 1 | 1 | 0 | ×2 | ×2 | ×2 | Еф | | 1 | 0 | 0 | 0 | ×4 | ×1 | ×1 | Еф | | 1 | 0 | 0 | 1 | ×4 | ×2 | ×1 | Еф | | 1 | 0 | 1 | 0 | ×4 | ×2 | ×2 | Еф | | 1 | 1 | 0 | 0 | ×4 | ×4 | ×1 | Еф | | 1 | 1 | 1 | 0 | ×4 | ×4 | ×2 | Еф | Do not use combinations other than those shown above. Modes 0 to 3 PLL circuit 1 halted, PLL circuit 2 operating EXTAL input or crystal oscillator used | FR3 | FR2 | FR1 | FR0 | lφ | Еф | Рф | CKIO | |-----|-----|-----|-----|----|----|----|------| | 0 | 0 | 0 | 0 | ×1 | ×1 | ×1 | Еф | | 0 | 1 | 0 | 1 | ×2 | ×2 | ×1 | Еф | | 0 | 1 | 1 | 0 | ×2 | ×2 | ×2 | Еф | | 1 | 1 | 0 | 0 | ×4 | ×4 | ×1 | Еф | | 1 | 1 | 1 | 0 | ×4 | ×4 | ×2 | Еф | Do not use combinations other than those shown above. Modes 0 and 1 PLL circuit 1 operating, PLL circuit 2 halted EXTAL input or crystal oscillator used | FR3 | FR2 | FR1 | FR0 | lφ | Еф | Рф | CKIO | |-----|-----|-----|-----|----|----|----|------| | 0 | 0 | 0 | 0 | ×1 | ×1 | ×1 | Еф | | 0 | 1 | 0 | 0 | ×2 | ×1 | ×1 | Еф | | 1 | 0 | 0 | 0 | ×4 | ×1 | ×1 | Еф | Do not use combinations other than those shown above. Modes 4 and 5 PLL circuit 1 operating, PLL circuit 2 halted CKIO input | FR3 | FR2 | FR1 | FR0 | lφ | Еф | Рф | CKIO | |-----|-----|-----|-----|----|----|------|------| | 0 | 1 | 0 | 1 | ×1 | ×1 | ×1/2 | Еф | | 0 | 1 | 1 | 0 | ×1 | ×1 | ×1 | Еф | | 1 | 0 | 0 | 1 | ×2 | ×1 | ×1/2 | Еф | | 1 | 0 | 1 | 0 | ×2 | ×1 | ×1 | Еф | Do not use combinations other than those shown above. • Modes 0–6 PLL circuits 1 and 2 halted EXTAL input or crystal oscillator used (modes 0–3) CKIO input (modes 4,6) | FR3 | FR2 | FR1 | FR0 | lφ | Еф | Рф | CKIO | |-----|-----|-----|-----|------|------|------|------| | 0 | 0 | 0 | 0 | ×1/4 | ×1/4 | ×1/4 | ×1 | | 0 | 1 | 0 | 0 | ×1/2 | ×1/4 | ×1/4 | ×1 | | 0 | 1 | 0 | 1 | ×1/2 | ×1/2 | ×1/4 | ×1 | | 0 | 1 | 1 | 0 | ×1/2 | ×1/2 | ×1/2 | ×1 | | 1 | 0 | 0 | 0 | ×1/1 | ×1/4 | ×1/4 | ×1 | | 1 | 0 | 0 | 1 | ×1/1 | ×1/2 | ×1/4 | ×1 | | 1 | 0 | 1 | 0 | ×1/1 | ×1/2 | ×1/2 | ×1 | | 1 | 1 | 0 | 0 | ×1/1 | ×1/1 | ×1/4 | ×1 | | 1 | 1 | 1 | 0 | ×1/1 | ×1/1 | ×1/2 | ×1 | | 1 | 1 | 1 | 1 | ×1/1 | ×1/1 | ×1/1 | ×1 | Do not use combinations other than those shown above. **Method of Changing Frequency:** When PLL circuit 1 or PLL circuit 2 becomes operational after modifying the frequency modification register (including frequency modification register modification in the operating state), access the frequency modification register using the following procedure, and noting the cautions listed below. #### Frequency change procedure - Set the on-chip watchdog timer (WDT) overflow time to secure the PLL circuit oscillation settling time (CKS[2:0] bits in WTCSR). - Clear the TME bit to 0 in WTCSR. - Perform a read anywhere in an external memory area 0–4 cache-through area. - Change the frequency modification register to the target frequency, or change the operating/halted state of the PLL circuits 1 and 2 (the clocks will stop temporarily inside the chip). - The oscillation circuits operate, and the clock is supplied to the WDT. This clock increments the WDT. - On WDT overflow, supply of a clock with the frequency set in frequency setting bits FR3–FR0 begins. #### **Cautions** - The read from the external memory space 0–4 cache-through area and the write to the frequency modification register should be performed in on-chip X/Y memory. After reading from the external memory space 0–4 cache-through area, do not perform any write operations in external memory spaces 0–4 until the write to the frequency modification register. - When the write access to the frequency modification register is executed, the WDT starts automatically. - Do not turn off the CKIO output when PLL circuit 1 is in the operating state. - The CKIO output will be unstable until the PLL circuit stabilizes. If PLL circuit 1 or PLL circuit 2 does not become operational after modifying the frequency modification register (including modification in the operating state), it means that the above procedure or cautions have not been properly observed. In this case, the WDT will not operate even though the frequency modification register is modified. ## 3.2.6 Operating Modes and Frequency Ranges The following table shows the operating modes and the associated frequency ranges for input clocks. | | Clock Input | | PLL Circuit | | Internal Clock*2 | | | | | |------|------------------|-----------------------------------|-------------|--------------|------------------|-------------|-------------|-------------------------|--| | Mode | Pin | Input<br>Frequency<br>Range (MHz) | PLL1 | PLL2 | Ιφ<br>(MHz) | Εφ<br>(MHz) | Pφ<br>(MHz) | CKIO<br>Output<br>(MHz) | | | 0, 1 | EXTAL or crystal | 8–15 | On | On | 8–60 | 8–60 | 8–30 | 8–60 | | | | oscillator*1 | | Off | On | 8–60 | 8–60 | 8–30 | 8–60 | | | | | | On | Off | 8–60 | 8–15 | 8–15 | 8–15 | | | | | 1–30 | Off | Off | 1–30 | 1–30 | 1–30 | 1–30 | | | 2 | _ | 8–15 | Off | On | 8–60 | 8–60 | 8–30 | 8–60 | | | | | 1–30 | | Off | 1–30 | 1–30 | 1–30 | 1–30 | | | 3 | _ | 8–15 | | On | 8–60 | 8–60 | 8–30 | | | | | | 1–30 | | Off | 1–30 | 1–30 | 1–30 | | | | 4, 5 | CKIO | 16–30 | On | Off | 16–60 | 16–30 | 16–30 | _ | | | | | 1–30 | Off | <del>_</del> | 1–30 | 1–30 | 1–30 | | | | 6 | _ | 1–30 | Off | _ | 1–30 | 1–30 | 1–30 | | | Notes: 1. When a crystal oscillator is used, set the frequency in the range of 2 to 20 MHz. <sup>2.</sup> Set the frequency modification register so that the frequency of all internal clocks is 1 MHz or higher. ## 3.2.7 Notes on Board Design When Using a Crystal Oscillator: Place the crystal oscillator and capacitors as close to the EXTAL and XTAL pins as possible. Do not let the pins' signal lines cross other signal lines. If they do, induction may prevent proper oscillation. Figure 3.6 Design Considerations when Using a Crystal Oscillator When Using PLL Oscillation Circuits: Place oscillation settling capacitors C1 and C2 and resistors R1 and R2 near the CAP1 and CAP2 pins, and do not cross signal lines. The C1 and C2 grounds should be supplied from PLL- $V_{ss}$ . PLL- $V_{cc}$ and PLL- $V_{ss}$ should also be isolated from other $V_{cc}$ and $V_{ss}$ lines away from the board's power supply sources, and bypass capacitors CPB and CB should be inserted near the pins. In clock mode 6, in which no PLLs are used, connect PLL- $V_{cc}$ to $V_{cc}$ and PLL- $V_{ss}$ to $V_{ss}$ . **Table 3.8** Connected Resistance and Capacitance Reference Values | Mode Setting | | | | | | | | |--------------------------|--------|--------|---------------|---------------|---------------|---------------|---------------| | Resistance/Capacitance | 0 | 1 | 2 | 3 | 4 | 5 | 6 | | R1 = T.B.D<br>C1 = T.B.D | Needed | Needed | Not<br>needed | Not<br>needed | Needed | Needed | Not<br>needed | | R2 = T.B.D<br>C2 = T.B.D | Needed | Needed | Needed | Needed | Not<br>needed | Not<br>needed | Not<br>needed | When the PLL circuits are off, CAP1 and CAP2 should be left open or used as shown in the recommended example. Figure 3.7 Design Considerations when Using PLL Oscillation Circuits ## 3.3 Bus Width of the CS0 Area Pins MD3 and MD4 are used to specify the bus width of the CS0 area. The pin combination and functions are listed in table 3.8. Do not switch the MD4 and MD3 pins while they are operating. Switching them will cause operating errors. Table 3.9 Bus Width of the CS0 Area | MD4 | MD3 | Function | |-----|-----|---------------------------| | 0 | 0 | 8-bit bus width selected | | 0 | 1 | 16-bit bus width selected | | 1 | 0 | 32-bit bus width selected | | 1 | 1 | Setting inhibited | # Section 4 Exception Handling ## 4.1 Overview ## 4.1.1 Types of Exception Handling and Priority Order Exception handling is initiated by four sources: resets, address errors, interrupts, and instructions (table 4.1). When several exception sources occur simultaneously, they are accepted and processed according to the priority order shown in table 4.1. Table 4.1 Types of Exception Handling and Priority Order | Exception | Source | | Priority | | | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------|--|--|--| | Reset | Power-on reset | | | | | | | | Manual reset | | | | | | | Address<br>error | CPU address error | | _ | | | | | | DMA address error | | _ | | | | | Interrupt | NMI | | _ | | | | | | User break | | _ | | | | | | Hitachi user debug interface (H-UDI) | | | | | | | | External interrupts (IRL1–IRL15, IRQ0–IRQ3 (set with IRL3, IRL2, IRL1 IRL0 pins)) | | | | | | | | On-chip peripheral modules Division unit (DIVU) | | | | | | | | | Direct memory access controller (DMAC) | | | | | | | | Watchdog timer (WDT) | | | | | | | | Compare match interrupt (part of the bus state controller) | | | | | | | | Serial communication interface (SCI) | _ | | | | | | | 16-bit free-running timer (FRT) | | | | | | | | Serial communication interface with FIFO (SCIF) | | | | | | | | 16-bit timer pulse unit (TPU) | | | | | | | | Serial I/O (SIO) | _ | | | | | Instructions | Trap instruction (TRAPA) | | | | | | | | General illegal instructions (undefined code) | | | | | | | | Illegal slot instructions (undefined code placed directly following a delayed branch instruction*1 or instructions that rewrite the PC*2) | | | | | | 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 ## 4.1.2 Exception Handling Operations Exception handling sources are detected, and exception handling started, according to the timing shown in table 4.2. Table 4.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 NMI pin is high and the $\overline{\text{RES}}$ pin changes from low to high. | | | | | | | Manual reset | Starts when the NMI pin is low and the $\overline{\text{RES}}$ pin changes from low to high. | | | | | | 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. | | | | | | Instructions | Trap instruction | Starts from the execution of a TRAPA instruction. | | | | | | | General illegal instructions | Starts from the decoding of undefined code anytime except after a delayed branch instruction (delay slot). | | | | | | | Illegal slot<br>instructions | Starts from the decoding of undefined code placed following a delayed branch instruction (delay slot) or of an instruction that rewrites the PC. | | | | | 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 vector table (PC and SP are respectively addresses H'00000000 and H'00000004 for a power-on reset and addresses H'00000008 and H'0000000C addresses for a manual reset). See section 4.1.3, Exception Vector Table, for more information. 0 is then written to the vector base register (VBR) and 1111 is written to the interrupt mask bits (I3–I0) of the status register. The program begins running from the PC address fetched from the exception vector table. 2. Exception handling triggered by address errors, interrupts, and instructions SR and PC are saved to the stack address indicated by R15. For interrupt exception handling, the interrupt priority level is written to the SR's interrupt mask bits (I3–I0). For address error and instruction exception handling, the I3–I0 bits are not affected. The start address is then fetched from the exception vector table and the program begins running from that address. ## 4.1.3 Exception Vector Table Before exception handling begins, the exception vector table must be written in memory. The exception vector table stores the start addresses of exception service routines. (The reset exception 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 vector table. Table 4.3 lists the vector numbers and vector table address offsets. Table 4.4 shows vector table address calculations. Table 4.3 (a) Exception Vector Table | Exception Source | | Vector<br>Number | Vector Table Address<br>Offset | Vector Address | |--------------------------|------------|------------------|--------------------------------|---------------------------| | Power-on reset PC | | 0 | H'00000000-H'00000003 | Vector number × 4 | | | SP | 1 | H'00000004-H'00000007 | | | Manual reset | PC | 2 | H'00000008-H'0000000B | | | | SP | 3 | H'000000C-H'0000000F | <del>_</del> | | General illegal instru | ction | 4 | H'00000010-H'00000013 | VBR + (vector number × 4) | | (Reserved by system | n) | 5 | H'00000014-H'00000017 | | | Slot illegal instruction | า | 6 | H'00000018-H'0000001B | | | (Reserved by system | n) | 7 | H'0000001C-H'0000001F | <del>_</del> | | | | 8 | H'00000020-H'00000023 | <del>_</del> | | CPU address error | | 9 | H'00000024-H'00000027 | | | DMA address error | | 10 | H'00000028-H'0000002B | | | Interrupt | NMI | 11 | H'0000002C-H'0000002F | <u> </u> | | | User break | 12 | H'00000030-H'00000033 | | | | H-UDI | 13 | H'00000034-H'00000037 | | | (Reserved by syster | n) | 14 | H'00000038-H'0000003B | | | | | : | : | | | | | 31 | H'0000007C-H'0000007F | | | Trap instruction (use | er vector) | 32 | H'00000080-H'00000083 | | | | | : | : | | | | | 63 | H'000000FC-H'000000FF | | Table 4.3 (b) Exception Processing Vector Table (IRQ mode) | Exception Source | | Vector<br>Number | Vector Table Address<br>Offset | Vector Addresses | |------------------|----------------------|-------------------|--------------------------------|------------------| | Interrupt | IRQ0 | 64 <sup>*2</sup> | H'00000100-H'00000103 | _ | | | IRQ1 | 65 <sup>*2</sup> | H'00000104-H'00000107 | _ | | | IRQ2 | 66 <sup>*2</sup> | H'00000108-H'0000010B | _ | | | IRQ3 | 67 <sup>*2</sup> | H'0000010C-H'0000010F | _ | | | On-chip | 0 | H'00000000-H'00000003 | _ | | | peripheral<br>module | : | : | | | | module | 255 <sup>*4</sup> | H'000003FC-H'000003FF | | Table 4.3 (c) Exception Processing Vector Table (IRL mode) | Exception Source | | Vector<br>Number | Vector Table Address<br>Offset | Vector Addresses | |------------------|------------------------|-------------------|--------------------------------|---------------------------| | Interrupt | IRL1*1 | 64 <sup>*2</sup> | H'00000100-H'00000103 | VBR + (vector number × 4) | | | IRL2*1 | 65 <sup>*2</sup> | H'00000104-H'00000107 | <del>_</del> | | | IRL3*1 | _ | | | | | IRL4*1 | 66 <sup>*2</sup> | H'00000108-H'0000010B | <del>_</del> | | | IRL5*1 | _ | | | | | IRL6*1 | 67 <sup>*2</sup> | H'0000010C-H'0000010F | <del>_</del> | | | IRL7*1 | _ | | | | | IRL8*1 | 68 <sup>*2</sup> | H'00000110-H'00000113 | <del>_</del> | | | IRL9*1 | _ | | | | | IRL10*1 | 69 <sup>*2</sup> | H'00000114-H'00000117 | <del>_</del> | | | IRL11*1 | _ | | | | | IRL12*1 | 70 <sup>*2</sup> | H'00000118-H'0000011B | <del>_</del> | | | IRL13*1 | _ | | | | | IRL14*1 | 71 <sup>*2</sup> | H'0000011C-H'0000011F | <del>_</del> | | | IRL15*1 | _ | | | | | On-chip | 0*4 | H'00000000-H'00000003 | <del>_</del> | | | peripheral<br>module*3 | • | : | | | | module | 255 <sup>*4</sup> | H'000003FC-H'000003FF | | Notes: 1. When 1110 is input to the IRL3, IRL2, IRL1, and IRL0 pins, an IRL1 interrupt results. When 0000 is input, an IRL15 interrupt results. - 2. External vector number fetches can be performed without using the auto-vector numbers in this table. - 3. The vector numbers and vector table address offsets for each on-chip peripheral module interrupt are given in section 5, Interrupt Controller (INTC), and table 5.4, Interrupt Exception Vectors and Priorities. - 4. Vector numbers are set in the on-chip vector number register. See section 5.3, Description of Registers, in section 5, Interrupt Controller (INTC), section 9, Direct Memory Access Controller (DMAC), and section 10, Division Unit (DIVU), for more information. **Table 4.4 Calculating Exception Vector Table Addresses** | Exception Source | Vector Table Address Calculation | |--------------------------|------------------------------------------------------------------------------------------| | Power-on reset | (Vector table address) = (vector table address offset) | | Manual reset | $= (vector number) \times 4$ | | Other exception handling | (Vector table address) = VBR + (vector table address offset) = VBR + (vector number) × 4 | Note: VBR: Vector base register Vector table address offset: See table 4.3. Vector number: See table 4.3. #### 4.2 Resets ## 4.2.1 Types of Resets Resets have the highest priority of any exception source. There are two types of resets: manual resets and power-on resets. As table 4.5 shows, both types of resets initialize the internal status of the CPU. In power-on resets, all registers of the on-chip peripheral modules are initialized; in manual resets, registers of all on-chip peripheral modules except the bus state controller (BSC), user break controller (UBC), pin function controller (PFC), and frequency modification register (FMR) are initialized. (Use the power-on reset when turning the power on.) **Table 4.5** Types of Resets | | | ditions for to Reset Status | Internal Status | | | |----------------|---------|-----------------------------|-----------------|---------------------------------------------------------------------------------|--| | Туре | NMI Pin | RES Pin | CPU | On-Chip Peripheral Modules | | | Power-on reset | High | Low | Initialized | Initialized | | | Manual reset | Low | Low | Initialized | Initialized except for BSC, UBC, PFC, and frequency modification register (FMR) | | #### 4.2.2 Power-On Reset When the NMI pin is high and the $\overline{RES}$ pin is driven low, the device performs a power-on reset. For a reliable reset, the $\overline{RES}$ pin should be kept low for at least the duration of the oscillation settling time (when the PLL circuit is halted) or for $20t_{cyc}$ (when the PLL circuit is running). During a power-on reset, the CPU's internal state and all on-chip peripheral module registers are initialized. See appendix A, Pin States, for the state of individual pins in the power-on reset state. In a power-on reset, power-on reset exception handling starts when the NMI pin is kept high and the $\overline{RES}$ pin is first driven low for a set period of time and then returned to high. The CPU will then operate as follows: - 1. The initial value (execution start address) of the program counter (PC) is fetched from the exception vector table. - 2. The initial value of the stack pointer (SP) is fetched from the exception vector table. - 3. The vector base register (VBR) is cleared to H'00000000 and the interrupt mask bits (I3–I0) of the status register (SR) are set to H'F (1111). - 4. The values fetched from the exception vector table are set in the PC and SP, and the program begins executing. ## 4.2.3 Manual Reset When the NMI pin is low and the $\overline{RES}$ pin is driven low, the device executes a manual reset. For a reliable reset, the $\overline{RES}$ pin should be kept low for at least 20 clock cycles. During a manual reset, the CPU's internal state is initialized. Registers of the bus state controller (BSC), user break controller (UBC), and pin function controller (PFC) on-chip peripheral modules, and the frequency modification register (FMR), are initialized. When the chip enters the manual reset state in the middle of a bus cycle, manual reset exception handling does not start until the bus cycle has ended. Thus, manual resets do not abort bus cycles. See appendix A, Pin States, for the state of individual pins in the manual reset state. In a manual reset, manual reset exception handling starts when the NMI pin is kept low and the $\overline{RES}$ pin is first kept low for a set period of time and then returned to high. The CPU will then operate in the same way as for a power-on reset. ## 4.3 Address Errors #### 4.3.1 Sources of Address Errors Address errors occur when instructions are fetched or data read or written, as shown in table 4.6. Table 4.6 Bus Cycles and Address Errors ## **Bus Cycle** | Bus Cycle | | | | |--------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | Туре | Bus<br>Master | Bus Cycle Description | Address Errors | | Instruction fetch | CPU | Instruction fetched from even address | None (normal) | | | | Instruction fetched from odd address | Address error occurs | | | | Instruction fetched from other than on-chip peripheral module space | None (normal) | | | | Instruction fetched from on-chip peripheral module space | Address error occurs | | Data<br>read/write | CPU or<br>DMAC | Word data accessed from even address | None (normal) | | | | 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 longword boundary | Address error occurs | | | | Access of cache purge space, address array read/<br>write space or on-chip I/O space by PC-relative<br>addressing | Address error occurs | | | | Access of cache purge space, address array read/<br>write space, data array read/write space or on-chip<br>I/O space by a TAS.B instruction | Address error occurs | | | | The address accesses to bytes, words and longword data of the built-in peripheral module space of H'FFFFFC00 to H'FFFFFFCFF. | None (normal) | | | | Longword data accessed in on-chip peripheral module space at addresses H'FFFFFE00 to H'FFFFFEFF | Address error occurs | | | | Word or byte data accessed in on-chip peripheral module space at addresses H'FFFFE00 to H'FFFFEFF | None (normal) | | | | The address accesses to the byte data of the on-chip peripheral module space of H'FFFFFF00 to H'FFFFFFF. | Address error occurs | | | | Word or longword data accessed in on-chip peripheral module space at addresses H'FFFFF00 to H'FFFFFFF | None (normal) | Notes: 1. Address errors do not occur during the synchronous DRAM mode register write cycle. <sup>2. 16-</sup>byte DMAC transfers use longword accesses. ## 4.3.2 Address Error Exception Handling When an address error occurs, address error exception handling begins after the end of the bus cycle in which the error occurred and completion of the executing instruction. The CPU operates as follows: - 1. The status register (SR) is saved to the stack. - 2. 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 instruction executed . - 3. The exception service routine start address is fetched from the exception vector table entry that corresponds to the address error that occurred, and the program starts executing from that address. The jump that occurs is not a delayed branch. ## 4.4 Interrupts ## 4.4.1 Interrupt Sources Table 4.7 shows the sources that initiate interrupt exception handling. These are divided into NMI, user breaks, H-UDI, IRL/IRQ, and on-chip peripheral modules. Each interrupt source is allocated a different vector number and vector table address offset. Table 4.7 Types of Interrupt Sources | NMI pin (external input) | 1 | |-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | User break controller | 1 | | Hitachi user debug interface (H-UDI) | 1 | | IRL1–IRL15 (external input) | 15 | | IRQ0-IRQ3 (external input) | 4 | | Direct memory access controller (DMAC) | 2 | | Division unit (DIVU) | 1 | | Serial communication interface (SCI) | 4 | | Free-running timer (FRT) | 3 | | Watchdog timer (WDT) | 1 | | Bus state controller (BSC) | 1 | | Serial I/O (SIO) | 4 | | Serial communication interface with FIFO (SCIF) | 4 | | 16-bit timer pulse unit (TPU) | 13 | | | User break controller Hitachi user debug interface (H-UDI) IRL1–IRL15 (external input) IRQ0–IRQ3 (external input) Direct memory access controller (DMAC) Division unit (DIVU) Serial communication interface (SCI) Free-running timer (FRT) Watchdog timer (WDT) Bus state controller (BSC) Serial I/O (SIO) Serial communication interface with FIFO (SCIF) | In each interrupt factor, respective different vector number and vector table address offset are allocated. For vector number and vector table address offset, refer to Table 5.4 Interrupt exception handling vector and priority of 5. Interrupt controller (INTC). #### 4.4.2 Interrupt Priority Levels The interrupt priority order is predetermined. When multiple interrupts occur simultaneously, the interrupt controller (INTC) determines their relative priorities and begins exception handling accordingly. The priority order of interrupts is expressed as priority levels 0–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 priority level is 15 and IRL interrupts have priorities of 1–15. On-chip peripheral module interrupt priority levels can be set freely using the INTC's interrupt priority level setting registers A–E (IPRA–IPRE) as shown in table 4.8. The priority levels that can be set are 0–15. Level 16 cannot be set. For more information on IPRA–IPRE, see sections 5.3.1, Interrupt Priority Level Setting Register A (IPRA), to 5.3.5, Interrupt Priority Level Setting Register E (IPRE). **Table 4.8** Interrupt Priority Order | Туре | <b>Priority Level</b> | Comment | |---------------------------|-----------------------|---------------------------------------------------------------------------------------------| | NMI | 16 | Fixed priority level. Cannot be masked. | | User break | 15 | Fixed priority level. | | H-UDI | 15 | Fixed priority level. | | IRL | 1–15 | Set with IRL3-IRL0 pins. | | IRQ | 0–15 | Set with interrupt priority level setting register C (IPRC) | | On-chip peripheral module | 0–15 | Set with interrupt priority level setting registers A, B, D, and E (IPRA, IPRB, IPRD, IPRE) | #### 4.4.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 bits (I3–I0) of the status register (SR). When an interrupt is accepted, exception handling begins. In interrupt exception handling, the CPU saves SR and the program counter (PC) to the stack. The priority level value of the accepted interrupt is written to SR bits I3–I0. For NMI, however, the priority level is 16, but the value set in I3–I0 is H'F (level 15). Next, the start address of the exception service routine is fetched from the exception vector table for the accepted interrupt, that address is jumped to and execution begins. For more information about interrupt exception handling, see section 5.4, Interrupt Operation. ## 4.5 Exceptions Triggered by Instructions ## 4.5.1 Instruction-Triggered Exception Types Exception handling can be triggered by a trap instruction, general illegal instruction or illegal slot instruction, as shown in table 4.9. **Table 4.9** Types of Exceptions Triggered by Instructions | Туре | Source Instruction | Comment | | | |-------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--| | Trap instruction | TRAPA | _ | | | | branch instruction (delay sle | immediately after a delayed branch instruction (delay slot) | Delayed branch instructions: JMP, JSR, BRA, BSR, RTS, RTE, BF/S, BT/S, BSRF, BRAF | | | | | and instructions that rewrite the PC | Instructions that rewrite the PC: JMP, JSR, BRA, BSR, RTS, RTE, BT, BF, TRAPA, BF/S, BT/S, BSRF, BRAF | | | | General illegal instruction | Undefined code anywhere besides in a delay slot | _ | | | #### 4.5.2 Trap Instructions When a TRAPA instruction is executed, trap instruction exception handling starts. The CPU operates as follows: - 1. The status register (SR) is saved to the stack. - 2. 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. - 3. The exception service routine start address is fetched from the exception vector table entry that corresponds to the vector number specified by the TRAPA instruction. That address is jumped to and the program starts executing. The jump that occurs is not a delayed branch. #### 4.5.3 Illegal Slot Instructions An instruction placed immediately after a delayed branch instruction is said to be placed in a delay slot. If the instruction placed in the delay slot is undefined code, illegal slot exception handling begins when the undefined code is decoded. Illegal slot exception handling also starts up when an instruction that rewrites the program counter (PC) is placed in a delay slot. The exception handling starts when the instruction is decoded. The CPU handles an illegal slot instruction as follows: - 1. The status register (SR) is saved to the stack. - 2. 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 or the instruction that rewrites the PC. - 3. The exception service routine start address is fetched from the exception vector table entry that corresponds to the exception that occurred. That address is jumped to and the program starts executing. The jump that occurs is not a delayed branch. ## 4.5.4 General Illegal Instructions When undefined code placed anywhere other than immediately after a delayed branch instruction (i.e., in a delay slot) is decoded, general illegal instruction exception handling starts. The CPU handles general illegal instructions in the same way as illegal slot instructions. Unlike processing of illegal slot instructions, however, the program counter value stored is the start address of the undefined code. ## 4.6 When Exception Sources are Not Accepted When an address error or interrupt is generated after a delayed branch instruction or interruptdisabled instruction, it is sometimes not immediately accepted but is stored instead, as described in table 4.10. When this happens, it will be accepted when an instruction for which exception acceptance is possible is decoded. Table 4.10 Exception Source Generation Immediately after a Delayed Branch Instruction or Interrupt-Disabled Instruction | | Exception Source | | | | |----------------------------------------------------------------------------------------------------|------------------|--------------|--|--| | Point of Occurrence | Address Error | Interrupt | | | | Immediately after a delayed branch instruction*1 | Not accepted | Not accepted | | | | Immediately after an interrupt-disabled instruction*2 | Accepted | Not accepted | | | | A repeat loop comprising up to three instructions (instruction fetch cycle not generated) | Not accepted | Not accepted | | | | First instruction or last three instructions in a repeat loop containing four or more instructions | | | | | | Fourth from last instruction in a repeat loop containing four or more instructions | Accepted | Not accepted | | | Notes: 1. Delayed branch instructions: JMP, JSR, BRA, BSR, RTS, RTE, BF/S, BT/S, BSRF, BRAF 2. Interrupt-disabled instructions: LDC, LDC.L, STC, STC.L, LDS, LDS.L, STS, STS.L #### 4.6.1 Immediately after a Delayed Branch Instruction When an instruction placed immediately after a delayed branch instruction (delay slot) is decoded, neither address errors nor interrupts are accepted. The delayed branch instruction and the instruction located immediately after it (delay slot) are always executed consecutively, so no exception handling occurs between the two. #### 4.6.2 Immediately after an Interrupt-Disabled Instruction When an instruction immediately following an interrupt-disabled instruction is decoded, interrupts are not accepted. Address errors are accepted. ## 4.6.3 Instructions in Repeat Loops If a repeat loop comprises up to three instructions, neither exceptions nor interrupts are accepted. If a repeat loop contains four or more instructions, neither exceptions nor interrupts are accepted during the execution cycle of the first instruction or the last three instructions. If a repeat loop contains four or more instructions, address errors only are accepted during the execution cycle of the fourth from last instruction. For more information, see the SH-DSP Programming Manual. ``` A. All interrupts and address errors are accepted. B. Address errors only are accepted. C. No interrupts or address errors are accepted. When RC ≥ 1 (1) One instruction (2) Two instructions (3) Three instructions (4) Four or more instructions instr0 \leftarrow A or C (on return from instr n) Start:instr1 : : \begin{array}{ccc} \cdot & \leftarrow & A \\ \text{instr } & \text{n-3} & \leftarrow & B \end{array} \begin{array}{c} \leftarrow B \\ \text{instr } n-2 \\ \leftarrow C \\ \text{instr } n-1 \\ \leftarrow C \end{array} End: instr n \( \leftarrow C instr n+1 \leftarrow A When RC = 0 All interrupts and address errors are accepted. ``` Figure 4.1 Interrupt Acceptance Restrictions in Repeat Mode ## 4.7 Stack Status after Exception Handling The status of the stack after exception handling ends is as shown in table 4.11. Table 4.11 Stack Status after Exception Handling | Туре | Stack | Status | | |-----------------------------|----------|--------------------------------------------------------|---------| | Address error | $SP \to$ | Address of instruction after executed instruction | 32 bits | | | | SR | 32 bits | | Trap instruction | $SP \to$ | Address of instruction after TRAPA instruction | 32 bits | | | | SR | 32 bits | | General illegal instruction | $SP \to$ | Start address of illegal instruction | 32 bits | | | | SR | 32 bits | | Interrupt | $SP \to$ | Address of instruction after executed instruction | 32 bits | | | | SR | 32 bits | | Illegal slot instruction | $SP \to$ | Jump destination address of delayed branch instruction | 32 bits | | | | SR | 32 bits | ## 4.8 Usage Notes #### 4.8.1 Value of Stack Pointer (SP) The value of the stack pointer must always be a multiple of four, otherwise an address error will occur when the stack is accessed during exception handling. #### 4.8.2 Value of Vector Base Register (VBR) The value of the vector base register must always be a multiple of four, otherwise an address error will occur when the vector table is accessed during exception handling. #### 4.8.3 Address Errors Caused by Stacking of Address Error Exception Handling If the stack pointer value is not a multiple of four, an address error will occur during stacking of the exception handling (interrupts, etc.). Address error exception handling will begin as soon as the first exception handling is ended, but address errors will continue to occur. 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 handling to be carried out. When an address error occurs during exception handling stacking, the stacking bus cycle (write) is executed. In 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 that the write data stacked will be undefined. #### 4.8.4 Manual Reset during Register Access Do not initiate a manual reset during access of a bus state controller (BSC), user break controller (UBC), or pin function controller (PFC) register, or the frequency modification register (FMR), otherwise a write error may result. ## Section 5 Interrupt Controller (INTC) ## 5.1 Overview The interrupt controller (INTC) ascertains the priority of interrupt sources and controls interrupt requests to the CPU. The INTC has registers for setting the priority of each interrupt which allow the user to set the order of priority in which interrupt requests are handled. #### 5.1.1 Features The INTC has the following features: - 16 interrupt priority levels: By setting the five interrupt-priority level registers, the priorities of on-chip peripheral module interrupts can be set at 16 levels for different request sources. - Settable vector numbers for on-chip peripheral module interrupts: 22 vector number setting registers enable on-chip peripheral module interrupt vector numbers to be set in the range 0–127 by interrupt source. - The IRL interrupt vector number setting method can be selected: Either of two modes can be selected by a register setting: auto-vector mode in which vector numbers are determined internally, and external vector mode in which vector numbers are set externally. - Settable IRQ interrupt (low-level, rising/falling/both-edge detection) ## 5.1.2 Block Diagram Figure 5.1 shows a block diagram of the INTC. Figure 5.1 INTC Block Diagram ## **5.1.3** Pin Configuration Table 5.1 shows the INTC pin configuration. **Table 5.1 Pin Configuration** | Name | Abbreviation | I/O | Function | |----------------------------------------|--------------|-----|-------------------------------------------------------------------------------------------------| | Nonmaskable interrupt input pin | NMI | I | Input of nonmaskable interrupt request signal | | Level request interrupt input pins | ĪRL3–ĪRL0 | I | Input of maskable interrupt request signals | | Interrupt acceptance level output pins | A3–A0 | 0 | In external vector mode, output an interrupt level signal when an IRL/IRQ interrupt is accepted | | External vector fetch pin | ĪVECF | 0 | Indicates external vector read cycle | | External vector number input pins | D7-D0 | ļ | Input external vector number | | | | | | ## 5.1.4 Register Configuration The INTC has the 29 registers shown in table 5.2. These registers perform various INTC functions including setting interrupt priority, and controlling external interrupt input signal detection. **Table 5.2 Register Configuration** | Name | Abbr. | R/W | Initial<br>Value | Address | Access<br>Size | |------------------------------------------------|-------|-----|------------------|------------|----------------| | Interrupt priority register setting register A | IPRA | R/W | H'0000 | H'FFFFFEE2 | 8, 16 | | Interrupt priority register setting register B | IPRB | R/W | H'0000 | H'FFFFFE60 | 8, 16 | | Interrupt priority register setting register C | IPRC | R/W | H'0000 | H'FFFFFEE6 | 8, 16 | | Interrupt priority register setting register D | IPRD | R/W | H'0000 | H'FFFFFE40 | 8, 16 | | Interrupt priority register setting register E | IPRE | R/W | H'0000 | H'FFFFFEC0 | 8, 16 | | Vector number setting register A | VCRA | R/W | H'0000 | H'FFFFFE62 | 8, 16 | | Vector number setting register B | VCRB | R/W | H'0000 | H'FFFFFE64 | 8, 16 | | Vector number setting register C | VCRC | R/W | H'0000 | H'FFFFFE66 | 8, 16 | | Vector number setting register D | VCRD | R/W | H'0000 | H'FFFFFE68 | 8, 16 | | Vector number setting register E | VCRE | R/W | H'0000 | H'FFFFFE42 | 8, 16 | | Vector number setting register F | VCRF | R/W | H'0000 | H'FFFFFE44 | 8, 16 | | Vector number setting register G | VCRG | R/W | H'0000 | H'FFFFFE46 | 8, 16 | **Table 5.2** Register Configuration (cont) | Name | Abbr. | R/W | Initial<br>Value | Address | Access<br>Size | |--------------------------------------|---------|-----|---------------------|-------------|----------------| | Vector number setting register H | VCRH | R/W | H'0000 | H'FFFFFE48 | 8, 16 | | Vector number setting register I | VCRI | R/W | H'0000 | H'FFFFFE4A | 8, 16 | | Vector number setting register J | VCRJ | R/W | H'0000 | H'FFFFFE4C | 8, 16 | | Vector number setting register K | VCRK | R/W | H'0000 | H'FFFFFE4E | 8, 16 | | Vector number setting register L | VCRL | R/W | H'0000 | H'FFFFFE 50 | 8, 16 | | Vector number setting register M | VCRM | R/W | H'0000 | H'FFFFFE52 | 8, 16 | | Vector number setting register N | VCRN | R/W | H'0000 | H'FFFFFE54 | 8, 16 | | Vector number setting register O | VCRO | R/W | H'0000 | H'FFFFFE56 | 8, 16 | | Vector number setting register P | VCRP | R/W | H'0000 | H'FFFFFEC2 | 8, 16 | | Vector number setting register Q | VCRQ | R/W | H'0000 | H'FFFFFEC4 | 8, 16 | | Vector number setting register R | VCRR | R/W | H'0000 | H'FFFFEC6 | 8, 16 | | Vector number setting register S | VCRS | R/W | H'0000 | H'FFFFEC8 | 8, 16 | | Vector number setting register T | VCRT | R/W | H'0000 | H'FFFFFECA | 8, 16 | | Vector number setting register U | VCRU | R/W | H'0000 | H'FFFFFECC | 8, 16 | | Vector number setting register WDT | VCRWDT | R/W | H'0000 | H'FFFFFEE4 | 8, 16 | | Vector number setting register DIV | VCRDIV | R/W | Undefined | H'FFFFF0C | 32 | | Vector number setting register DMAC0 | VCRDMA0 | R/W | Undefined | H'FFFFFA0 | 32 | | Vector number setting register DMAC1 | VCRDMA1 | R/W | Undefined | H'FFFFFA8 | 32 | | Interrupt control register | ICR | R/W | H'8000/<br>H'0000*1 | H'FFFFFEE0 | 8, 16 | | IRQ control/status register | IRQCSR | R/W | *2 | H'FFFFFEE8 | 8, 16 | Notes: 1. The value when the NMI pin is high is H'8000; when the NMI pin is low, it is H'0000. See sections 9, Direct Memory Access Controller (DMAC), and 10, Division Unit (DIVU), for more information on VCRDIV, VCRDMA0, and VCRDMA1. 2. When pins IRL3–IRL0 are high, bits 7–4 in IRQCSR are set to 1. When pins IRL3–IRL0 are low, bits 7–4 in IRQCSR are cleared to 0. The initial value of bits other than 7–4 is 0. 156 ## 5.2 Interrupt Sources There are five types of interrupt sources: NMI, user breaks, H-UDI, IRL/IRQ and on-chip peripheral modules. Each interrupt has a priority expressed as a priority level (0 to 16, with 0 the lowest and 16 the highest). Giving an interrupt a priority level of 0 masks it. #### 5.2.1 NMI Interrupt The NMI interrupt has priority 16 and is always accepted. Input at the NMI pin is detected by edge. Use the NMI edge select bit (NMIE) in the interrupt control register (ICR) to select either the rising or falling edge. NMI interrupt exception handling sets the interrupt mask level bits (I3–I0) in the status register (SR) to level 15. ## 5.2.2 User Break Interrupt A user break interrupt has priority level 15 and occurs when the break condition set in the user break controller (UBC) is satisfied. User break interrupt exception handling sets the interrupt mask level bits (I3–I0) in the status register (SR) to level 15. For more information about the user break interrupt, see section 6, User Break Controller (UBC). #### 5.2.3 Hitachi-UDI Interrupt The H-UDI has the priority level 15, when the instruction of H-UDI interrupt is input in serial, it occurs. Hitachi-UDI interrupt exception processing sets the interrupt mask bits (I3–I0) in the status register (SR) to level 15. See section 18, Hitachi User Debug Interface, for details of the Hitachi-UDI interrupt (H-UDI). #### 5.2.4 IRL Interrupts IRL interrupts are requested by input from pins IRL3–IRL0. Fifteen interrupts, IRL15–IRL1, can be input externally via pins IRL3–IRL0. The priority levels of interrupts IRL15–IRL0 are 15–1, respectively, and their vector numbers are 71–64. Set the vector numbers with the interrupt vector mode select (VECMD) bit of the interrupt control register (ICR) to enable external input. External input of vector numbers consists of vector numbers 0–127 from the external vector input pins (D7–D0). When an external vector is used, 0 is input to D7. Internal vectors are called auto-vectors and vectors input externally are called external vectors. Table 5.3 lists IRL priority levels and auto vector numbers. When an IRL interrupt is accepted in external vector mode, the IRL interrupt level is output from the interrupt acceptance level output pins (A3–A0). The external vector fetch pin (IVECF) is also asserted. The external vector number is read from pins D7–D0 at this time. IRL interrupt exception processing sets the interrupt mask level bits (I3 to I0) in the status register (SR) to the priority level value of the IRL interrupt that was accepted. ## 5.2.5 IRQ Interrupts An IRQ interrupt is requested when the external interrupt vector mode select bit (EXIMD) of the interrupt control register (ICR) is set to 1. An IRQ interrupt corresponds to input at one of pins $\overline{IRL3}$ – $\overline{IRL0}$ . Low-level sensing or rising/falling/both-edge sensing can be selected independently for each pin by the IRQ sense select bits (IRQ00S–IRQ31S) in the IRQ control/status register (IRQCSR), and a priority level of 0 to 15 can be selected independently for each pin by means of interrupt priority register C (IPRC). Set the interrupt vector mode select bit (VECMFD) of the interrupt control register (ICR) to enable external input of vector numbers. External vector numbers are 0 to 127, and are input to the external vector input pins (D7–D0) during the interrupt vector fetch bus cycle. When an external vector is used, 0 is input to D7. When an IRQ interrupt is accepted in external vector mode, the IRQ interrupt priority level is output from the interrupt acceptance level output pins (A3–A0). The external vector fetch signal (IVECF) is also asserted. The external vector number is read from signals D7–D0 at this time. IRQ interrupt exception processing sets the interrupt mask bits (I3–I0) in the status register (SR) to the priority level value of the IRQ interrupt that was accepted. Table 5.3 IRL Interrupt Priority Levels and Auto-Vector Numbers Pin | ĪRL3 | ĪRL2 | ĪRL1 | ĪRL0 | Priority Level | Vector Number | |------|------|------|------|----------------|---------------| | 0 | 0 | 0 | 0 | 15 | 71 | | 0 | 0 | 0 | 1 | 14 | | | 0 | 0 | 1 | 0 | 13 | 70 | | 0 | 0 | 1 | 1 | 12 | <del>_</del> | | 0 | 1 | 0 | 0 | 11 | 69 | | 0 | 1 | 0 | 1 | 10 | | | 0 | 1 | 1 | 0 | 9 | 68 | | 0 | 1 | 1 | 1 | 8 | | | 1 | 0 | 0 | 0 | 7 | 67 | | 1 | 0 | 0 | 1 | 6 | | | 1 | 0 | 1 | 0 | 5 | 66 | | 1 | 0 | 1 | 1 | 4 | <del>_</del> | | 1 | 1 | 0 | 0 | 3 | 65 | | 1 | 1 | 0 | 1 | 2 | <u> </u> | | 1 | 1 | 1 | 0 | 1 | 64 | An example of connections for external vector mode interrupts is shown in figure 5.2, and an example of connections for auto-vector mode interrupts in figure 5.3. Figure 5.2 Example of Connections for External Vector Mode Interrupts Figure 5.3 Example of Connections for Auto-Vector Mode Interrupts Figures 5.4 to 5.7 show the interrupt fetch cycle for the external vector mode. During this cycle, $\overline{\text{CS0}}$ – $\overline{\text{CS4}}$ stay high. A24–A4 output undefined values. The $\overline{\text{WAIT}}$ pin is sampled, but programmable waits are not valid. Figure 5.4 External Vector Fetch ( $\mathbf{I}\phi : \mathbf{E}\phi = 1 : 1$ ) Figure 5.5 External Vector Fetch $(I\phi : E\phi = 1 : 2)$ Figure 5.6 External Vector Fetch ( $\mathbf{I}\phi : \mathbf{E}\phi = 1 : 1 \text{ (}\overline{\mathbf{WAIT}}\mathbf{Input))$ Figure 5.7 External Vector Fetch ( $\mathbf{I}\phi : \mathbf{E}\phi = 1 : 2 \text{ (}\overline{\mathbf{WAIT}}\text{ Input)}\text{)}$ ## 5.2.6 On-chip Peripheral Module Interrupts On-chip peripheral module interrupts are interrupts generated by the following 9 on-chip peripheral modules: - Division unit (DIVU) - Direct memory access controller (DMAC) - Serial communication interface (SCI) - Bus state controller (BSC) - Watchdog timer (WDT) - Free-running timer (FRT) - 16-bit timer pulse unit (TPU) - Serial communication interface with FIFO (SCIF) - Serial I/O (SIO) A different interrupt vector is assigned to each interrupt source, so the exception service routine does not have to decide which interrupt has occurred. Priority levels between 0 and 15 can be assigned to individual on-chip peripheral modules in interrupt priority registers A–E (IPRA–IPRE). On-chip peripheral module interrupt exception handling sets the interrupt mask level bits (I3–I0) in the status register (SR) to the priority level value of the on-chip peripheral module interrupt that was accepted. #### 5.2.7 Interrupt Exception Vectors and Priority Order Table 5.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 vector numbers and vector table address offsets. In interrupt exception handling, the exception service routine start address is fetched from the vector table entry indicated by the vector table address. See table 4.4, Calculating Exception Vector Table Addresses, in section 4, Exception Handling, for more information on this calculation. IRL interrupts IRL15–IRL1 have interrupt priority levels of 15–1, respectively. IRQ interrupt and on-chip peripheral module interrupt priorities can be set freely between 0 and 15 for each module by setting interrupt priority registers A–E (IPRA–IPRE). The ranking of interrupt sources for IPRA–IPRE, however, must be the order listed under Priority Within IPR Setting Unit in table 5.4 and cannot be changed. A reset assigns priority level 0 to 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, their priority order is the default priority order indicated at the right in table 5.4. Table 5.4 (a) Interrupt Exception Vectors and Priority Order | | | Ve | ectors | _ | | | | | |-----------|-----------------|------------------|----------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interrupt | Source | Vector<br>No. | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | NMI | | 11 | VBR + (vector No. × 4) | 16 | _ | _ | _ | High | | User brea | ık | 12 | _ | 15 | _ | _ | _ | <u> </u> | | H-UDI | | 13 | _ | 15 | _ | _ | _ | _ | | IRL15*4 | | 71* <sup>1</sup> | _ | 15 | _ | _ | _ | _ | | IRL14*4 | | <del>-</del> | | 14 | _ | _ | _ | _ | | IRL13*4 | | 70* <sup>1</sup> | _ | 13 | _ | _ | _ | _ | | IRL12*4 | | <del>-</del> | | 12 | _ | _ | _ | _ | | IRL11*4 | | 69* <sup>1</sup> | _ | 11 | _ | _ | _ | _ | | IRL10*4 | | _ | | 10 | _ | _ | _ | _ | | IRL9*4 | | 68* <sup>1</sup> | _ | 9 | _ | _ | _ | _ | | IRL8*4 | | _ | | 8 | _ | _ | _ | _ | | IRL7*4 | | 67* <sup>1</sup> | _ | 7 | _ | _ | _ | _ | | IRL6*⁴ | | _ | | 6 | _ | _ | _ | _ | | IRL5*4 | | 66*1 | _ | 5 | _ | _ | _ | _ | | IRL4*4 | | _ | | 4 | _ | _ | _ | _ | | IRL3*4 | | 65*1 | _ | 3 | _ | _ | _ | <u>-</u> | | IRL2*4 | | | _ | 2 | _ | _ | _ | _ | | IRL1*4 | | 64*1 | _ | 1 | _ | _ | _ | _ | | DIVU | OVFI | 0–127*2 | | 15–0 (0) | IPRA<br>(15–12) | High<br>↑<br>↓<br>Low | VCRDIV<br>(6-0) | | | DMAC0 | Transfer<br>end | 0-127*2 | - | 15–0 (0) | IPRA<br>(11–8) | High<br>↑<br>↓<br>Low | VCRDMA0<br>(6-0) | - | | DMAC1 | Transfer<br>end | 0-127*2 | - | 15–0 (0) | - | High ↑ ↓ Low | VCRDMA1<br>(6-0) | ↓<br>Low | Table 5.4 (a) Interrupt Exception Vectors and Priority Order (cont) | | | Ve | ctors | | | | | | |-------------------|-------|---------------|----------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interru<br>Source | • | Vector<br>No. | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | WDT | ITI | 0–127*2 | VBR + (vector No. × 4) | 15–0 (0) | IPRA(7-4) | High<br>↑<br>↓<br>Low | VCRWDT (14–<br>8) | High<br>↑ | | REF*3 | CMI | 0–127*2 | - | 15-0 (0) | - | High ↑ Low | VCRWDT<br>(6-0) | - | | SCI | ERI | 0-127*2 | - | 15–0 (0) | IPRB<br>(15–12) | High | VCRA (14-8) | - | | | RXI | 0-127*2 | _ | | , | $\uparrow$ | VCRA (6-0) | _ | | | TXI | 0-127*2 | _ | | | $\downarrow$ | VCRB (14-8) | _ | | | TEI | 0-127*2 | - | | | Low | VCRB (6-0) | - | | FRT | ICI | 0-127*2 | - | 15–0 (0) | IPRB (11-8) | High | VCRC (14-8) | - | | | OCI | 0-127*2 | _ | | | $\uparrow$ | VCRC (6-0) | _ | | | OVI | 0-127*2 | - | | | $\downarrow$ | VCRD (14-8) | _ | | | | | _ | | | Low | | _ | | TPU0 | TGI0A | 0-127*2 | | 15–0 (0) | IPRD<br>(15–12) | High | VCRE (14-8) | | | | TGI0B | 0-127*2 | _ | | | $\uparrow$ | VCRE (6-0) | _ | | | TGI0C | 0-127*2 | _ | | | | VCRF (14-8) | | | | TGI0D | 0-127*2 | _ | | | $\downarrow$ | VCRF (6-0) | <u>-</u> | | | TCI0V | 0-127*2 | _ | | | Low | VCRG (14-8) | _ | | TPU1 | TGI1A | 0-127*2 | _ | 15–0 (0) | IPRD (11-8) | High | VCRH (14-8) | _ | | | TGI1B | 0-127*2 | _ | | | $\uparrow$ | VCRH (6-0) | _ | | | TCI1V | 0-127*2 | _ | | | $\downarrow$ | VCRI (14-8) | _ | | | TCI1U | 0-127*2 | _ | | | Low | VCRI (6-0) | _ | | TPU2 | TGI2A | 0-127*2 | _ | 15–0 (0) | IPRD (7-4) | High | VCRJ (14-8) | _ | | | | 0-127*2 | _ | | | $\uparrow$ | VCRJ (6-0) | _ | | | TCI2V | 0-127*2 | _ | | | $\downarrow$ | VCRK (14-8) | _ ↓ | | | TCI2U | 0-127*2 | | | | Low | VCRK (6-0) | Low | Table 5.4 (a) Interrupt Exception Vectors and Priority Order (cont) | | | Ve | ctors | | | | | | |----------------------|-------|---------------|------------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interru <sub> </sub> | • | Vector<br>No. | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | SCIF1 | ERI1 | 0-127*2 | VBR +<br>(vector<br>No. × 4) | 15–0 (0) | IPRD (3-0) | High | VCRL (14-8) | High | | | RXI1 | 0-127*2 | - | | | $\uparrow$ | VCRL (6-0) | _ | | | BRI1 | 0-127*2 | - | | | $\downarrow$ | VCRM (14-8) | _ | | | TXI1 | 0-127*2 | - | | | Low | VCRM (6-0) | _ | | SCIF2 | ERI2 | 0-127*2 | - | 15–0 (0) | IPRE<br>(15–12) | High | VCRN (14-8) | _ | | | RXI2 | 0-127*2 | • | | | $\uparrow$ | VCRN (6-0) | _ | | | BRI2 | 0-127*2 | • | | | $\downarrow$ | VCRO (14-8) | _ | | | TXI2 | 0-127*2 | • | | | Low | VCRO (6-0) | _ | | SIO0 | RERI0 | 0-127*2 | • | 15–0 (0) | IPRE(11-8) | High | VCRP (14-8) | _ | | | TERI0 | 0-127*2 | - | | | $\uparrow$ | VCRP (6-0) | _ | | | RDFI0 | 0-127*2 | - | | | $\downarrow$ | VCRQ (14-8) | _ | | | TDEI0 | 0-127*2 | - | | | Low | VCRQ (6-0) | _ | | SIO1 | RERI1 | 0-127*2 | = | 15–0 (0) | IPRE (7-4) | High | VCRR (14-8) | _ | | | TERI1 | 0-127*2 | = | | | $\uparrow$ | VCRR (6-0) | _ | | | RDFI1 | 0-127*2 | • | | | $\downarrow$ | VCRS (14-8) | _ | | | TDEI1 | 0-127*2 | • | | | Low | VCRS (6-0) | _ | | SIO2 | RERI2 | 0-127*2 | • | 15–0 (0) | IPRE (3-0) | High | VCRT (14-8) | _ | | | TERI2 | 0-127*2 | • | | | $\uparrow$ | VCRT (6-0) | _ | | | RDFI2 | 0-127*2 | • | | | $\downarrow$ | VCRU (14-8) | _ | | | TDEI2 | 0-127*2 | <del>-</del> | | | Low | VCRU (6-0) | _ ↓ | | Reserv<br>ed | | 128–<br>255 | _ | _ | _ | _ | _ | Low | Notes: 1. An external vector number fetch can be performed without using the auto-vector numbers shown in this table. The external vector numbers are 0–127. - 2. Vector numbers are set in the on-chip vector number register. - 3. REF is the refresh control unit within the bus state controller. - 4. Set to IRL1–IRL15 or IRQ0–IRQ3 by the EXIMD bit in ICR. Table 5.4 (b) Interrupt Exception Vectors and Priority Order | | | Ve | ectors | | | | | | |-----------|-----------------|------------------|----------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interrupt | Source | Vector<br>No. | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | NMI | | 11 | VBR + (vector No. × 4) | 16 | _ | _ | _ | High | | User brea | ak | 12 | - | 15 | _ | _ | | | | H-UDI | | 13 | - | 15 | _ | _ | _ | _ | | IRQ0*4 | | 64*1 | - | 15–0 (0) | IPRC<br>(15–12) | _ | _ | _ | | IRQ1*4 | | 65* <sup>1</sup> | - | 15–0 (0) | IPRC<br>(11–8) | _ | _ | _ | | IRQ2*4 | | 66*1 | - | 15–0 (0) | IPRC<br>(7–4) | _ | _ | _ | | IRQ3*4 | | 67*1 | _ | 15–0 (0) | IPRC<br>(3-0) | _ | _ | _ | | DIVU | OVFI | 0–127*2 | | 15–0 (0) | IPRA<br>(15–12) | High<br>↑<br>↓<br>Low | VCRDIV<br>(6-0) | | | DMAC0 | Transfer<br>end | 0-127*2 | - | 15–0 (0) | IPRA<br>(11–8) | High<br>↑<br>↓<br>Low | VCRDMA0<br>(6-0) | - | | DMAC1 | Transfer<br>end | 0-127*2 | - | 15–0 (0) | - | High ↑ ↓ Low | VCRDMA1<br>(6-0) | - | | WDT | ITI | 0-127*2 | - | 15–0 (0) | IPRA(7-4) | High<br>↑<br>↓<br>Low | VCRWDT<br>(14–8) | _ | | REF*3 | CMI | 0-127*2 | - | 15–0 (0) | - | High ↑ ↓ Low | VCRWDT<br>(6-0) | ↓<br>Low | Table 5.4 (b) Interrupt Exception Vectors and Priority Order (cont) | | | Ve | ctors | _ | | | | | |-------------------|-------|---------|----------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interru<br>Source | • | Vector | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | SCI | ERI | 0-127*2 | | 15–0 (0) | IPRB (15–12) | High | VCRA (14–8) | High | | | | | (vector No. $\times$ 4) | (-) | ( - , | 3 | - ( - , | 3 | | | RXI | 0-127*2 | -" | | | $\uparrow$ | VCRA (6-0) | $\uparrow$ | | | TXI | 0-127*2 | | | | $\downarrow$ | VCRB (14-8) | <u>-</u> | | | TEI | 0-127*2 | | | | Low | VCRB (6-0) | _ | | FRT | ICI | 0-127*2 | _, | 15–0 (0) | IPRB (11-8) | High | VCRC (14-8) | _ | | | OCI | 0-127*2 | _, | | | $\uparrow$ | VCRC (6-0) | _ | | | OVI | 0-127*2 | | | | $\downarrow$ | VCRD (14-8) | | | | | | _ | | | Low | | _ | | TPU0 | _ | 0-127*2 | _ | 15–0 (0) | IPRD | High | VCRE (14-8) | _ | | | | 0-127*2 | - | | (15–12) | <b>↑</b> | VCRE (6-0) | _ | | | _ | 0-127*2 | _ | | | | VCRF (14-8) | _ | | | | 0-127*2 | _ | | | $\downarrow$ | VCRF (6-0) | _ | | | TCI0V | | <b>=</b> ∙ | | | Low | VCRG (14-8) | _ | | TPU1 | | 0-127*2 | _ | 15–0 (0) | IPRD (11–8) | High | VCRH (14-8) | _ | | | | 0-127*2 | <b>=</b> ∙ | | | <b>↑</b> | VCRH (6-0) | _ | | | TCI1V | | <b>=</b> ∙ | | | $\downarrow$ | VCRI (14-8) | _ | | | | 0-127*2 | <b>=</b> ∙ | | | Low | VCRI (6-0) | _ | | TPU2 | _ | 0-127*2 | <b>=</b> ∙ | 15–0 (0) | IPRD (7-4) | High | VCRJ (14-8) | - | | | | 0-127*2 | <u>-</u> | | | 1 | VCRJ (6-0) | _ | | | TCI2V | | - | | | $\downarrow$ | VCRK (14-8) | _ | | | | 0-127*2 | - | | | Low | VCRK (6-0) | _ | | SCIF1 | ERI1 | 0-127*2 | - | 15–0 (0) | IPRD (3-0) | High | VCRL (14-8) | - | | | RXI1 | 0-127*2 | - | | | <b>↑</b> | VCRL (6-0) | _ | | | BRI1 | 0-127*2 | - | | | $\downarrow$ | VCRM (14-8) | _ | | | TXI1 | 0-127*2 | - | | | Low | VCRM (6-0) | _ | | SCIF2 | ERI2 | 0-127*2 | - | 15–0 (0) | IPRE (15-12) | High | VCRN (14-8) | - | | | RXI2 | 0-127*2 | <u>-</u> | | | <b>↑</b> | VCRN (6-0) | - | | | BRI2 | 0-127*2 | <u>-</u> | | | $\downarrow$ | VCRO (14-8) | _ | | | TXI2 | 0-127*2 | | | | Low | VCRO (6-0) | Low | Table 5.4 (b) Interrupt Exception Vectors and Priority Order (cont) | | | Vec | ctors | _ | | | | | |--------------|--------|---------------|----------------------------|------------------------------------------------------|----------------------|----------------------------------------------|----------------------|---------------------| | Interrupt \$ | Source | Vector<br>No. | Vector<br>Table<br>Address | Interrupt<br>Priority<br>Order<br>(Initial<br>Value) | IPR (Bit<br>Numbers) | Priority<br>within<br>IPR<br>Setting<br>Unit | VCR (Bit<br>Numbers) | Default<br>Priority | | SIO0 | RERI0 | 0-127*2 | VBR + (vector No. × 4) | 15-0 (0) | IPRE<br>(11–8) | High | VCRP (14-8) | High | | | TERI0 | 0-127*2 | - | | | $\uparrow$ | VCRP (6-0) | 1 | | | RDFI0 | 0-127*2 | - | | | $\downarrow$ | VCRQ (14-8) | - | | | TDEI0 | 0-127*2 | - | | | Low | VCRQ (6-0) | - | | SIO1 | RERI1 | 0-127*2 | - | 15–0 (0) | IPRE<br>(7–4) | High | VCRR (14-8) | • | | | TERI1 | 0-127*2 | - | | | $\uparrow$ | VCRR (6-0) | - | | | RDFI1 | 0-127*2 | - | | | $\downarrow$ | VCRS (14-8) | - | | | TDEI1 | 0-127*2 | =" | | | Low | VCRS (6-0) | = | | SIO2 | RERI2 | 0-127*2 | • | 15-0 (0) | IPRE<br>(3–0) | High | VCRT (14-8) | • | | | TERI2 | 0-127*2 | - | | | $\uparrow$ | VCRT (6-0) | - | | | RDFI2 | 0-127*2 | - | | | $\downarrow$ | VCRU (14-8) | - | | | TDEI2 | 0-127*2 | - | | | Low | VCRU (6-0) | $\downarrow$ | | Reserved | | 128–<br>255 | _ | _ | _ | _ | _ | Low | Notes: 1. An external vector number fetch can be performed without using the auto-vector numbers shown in this table. The external vector numbers are 0–127. <sup>2.</sup> Vector numbers are set in the on-chip vector number register. <sup>3.</sup> REF is the refresh control unit within the bus state controller. <sup>4.</sup> Set to IRL1-IRL15 or IRQ0-IRQ3 by the EXIMD bit in ICR. ## **5.3** Description of Registers ## 5.3.1 Interrupt Priority Level Setting Register A (IPRA) Interrupt priority level setting register A (IPRA) is a 16-bit read/write register that assigns priority levels from 0 to 15 to on-chip peripheral module interrupts. IPRA is initialized to H'0000 by a reset. It is not initialized in standby mode. Unless otherwise specified, 'reset' refers to both power-on and manual resets throughout this manual. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | Bit name: | DIVU<br>IP3 | DIVU<br>IP2 | DIVU<br>IP1 | DIVU<br>IP0 | DMAC<br>IP3 | DMAC<br>IP2 | DMAC<br>IP1 | DMAC<br>IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | WDT | WDT | WDT | WDT | _ | _ | _ | _ | | | IP3 | IP2 | IP1 | IP0 | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R | R | R | Bits 15 to 12—Division Unit (DIVU) Interrupt Priority Level 3–0 (DIVUIP3–DIVUIP0): These bits set the division unit (DIVU) interrupt priority level. There are four bits, so levels 0–15 can be set. Bits 11 to 8—DMA Controller Interrupt Priority Level 3–0 (DMACIP3–DMACIP0): These bits set the DMA controller (DMAC) interrupt priority level. There are four bits, so levels 0–15 can be set. The same level is set for both DMAC channels. When interrupts occur simultaneously, channel 0 has priority. Bits 7 to 4—Watchdog Timer (WDT) Interrupt Priority Level 3–0 (WDTIP3–WDTIP0): These bits set the watchdog timer (WDT) interrupt priority level and bus state controller (BSC) interrupt priority level. There are four bits, so levels 0–15 can be set. When WDT and BSC interrupts occur simultaneously, the WDT interrupt has priority. Bits 3 to 0—Reserved: These bits always read 0. The write value should always be 0. ## 5.3.2 Interrupt Priority Level Setting Register B (IPRB) Interrupt priority level setting register B (IPRB) is a 16-bit read/write register that assigns priority levels from 0 to 15 to on-chip peripheral module interrupts. IPRB is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | SCIIP3 | SCIIP2 | SCIIP1 | SCIIP0 | FRTIP3 | FRTIP2 | FRTIP1 | FRTIP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | Bits 15 to 12—Serial Communication Interface (SCI) Interrupt Priority Level 3–0 (SCIIP3–SCIIP0): These bits set the serial communication interface (SCI) interrupt priority level. There are four bits, so levels 0–15 can be set. Bits 11 to 8—Free-Running Timer (FRT) Interrupt Priority Level 3–0 (FRTIP3–FRTIP0): These bits set the free-running timer (FRT) interrupt priority level. There are four bits, so levels 0–15 can be set. Bits 7 to 0—Reserved: These bits always read 0. The write value should always be 0. ## 5.3.3 Interrupt Priority Level Setting Register C (IPRC) Interrupt priority level setting register C (IPRC) is a 16-bit read/write register that sets the priority levels (0–15) of IRQ0–IRQ3 interrupts. IPRC is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|---------|---------|---------|---------|---------|---------|---------|---------| | Bit name: | IRQ0IP3 | IRQ0IP2 | IRQ0IP1 | IRQ0IP0 | IRQ1IP3 | IRQ1IP2 | IRQ1IP1 | IRQ1IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | IRQ2IP3 | IRQ2IP2 | IRQ2IP1 | IRQ2IP0 | IRQ3IP3 | IRQ3IP2 | IRQ3IP1 | IRQ3IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 to 0–IRQ0 to IRQ3 Interrupt Level 3 to 0 (IRQnIP3–IRQnIP0, n = 0–3): These bits set the IRQ0–IRQ3 interrupt priority levels. There are four bits for each interrupt, so the value can be set between 0 and 15. ## 5.3.4 Interrupt Priority Level Setting Register D (IPRD) Interrupt priority level setting register D (IPRD) is a 16-bit read/write register that sets the priority levels (0–15) of on-chip peripheral module interrupts. IPRD is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|---------|---------|---------|---------|---------|---------|---------|---------| | Bit name: | TPU0IP3 | TPU0IP2 | TPU0IP1 | TPU0IP0 | TPU1IP3 | TPU1IP2 | TPU1IP1 | TPU1IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | TPU2IP3 | TPU2IP2 | TPU2IP1 | TPU2IP0 | SCF1IP3 | SCF1IP2 | SCF1IP1 | SCF1IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 to 4—Timer Pulse Unit 0 to 2 (TPU0–TPU2) Interrupt Priority Level 3 to 0 (TPUnIP3–TPUnIP0, n = 0-2): These bits set the timer pulse unit 0-2 (TPU0–TPU2) interrupt priority levels. There are four bits for each interrupt, so the value can be set between 0 and 15. Bits 3 to 0—Serial Communication Interface with FIFO (SCIF1) Interrupt Priority Level 3 to 0 (SCF1IP3–SCF1IP0): These bits set the serial communication interface with FIFO (SCIF1) interrupt priority level. There are four bits, so the value can be set between 0 and 15. ## 5.3.5 Interrupt Priority Level Setting Register E (IPRE) Interrupt priority level setting register E (IPRE) is a 16-bit read/write register that sets the priority levels (0–15) of on-chip peripheral module interrupts. IPRE is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|---------|---------|---------|---------|---------|---------|---------|---------| | Bit name: | SCF2IP3 | SCF2IP2 | SCF2IP1 | SCF2IP0 | SIO0IP3 | SIO0IP2 | SIO0IP1 | SIO0IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | SIO1IP3 | SIO1IP2 | SIO1IP1 | SIO1IP0 | SIO2IP3 | SIO2IP2 | SIO2IP1 | SIO2IP0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 to 12—Serial Communication Interface with FIFO (SCIF2) Interrupt Priority Level 3 to 0 (SCF2IP3–SCF2IP0) These bits set the serial communication interface with FIFO (SCIF2) interrupt priority level. There are four bits, so the value can be set between 0 and 15. Bits 11 to 0—Serial I/O 0 to 2 (SIO0–SIO2) Interrupt Priority Level 3 to 0 (SIOnIP3–SIOnIP0, n = 0–2): These bits set the serial I/O 0–2 (SIO0–SIO2) interrupt priority levels. There are four bits for each interrupt, so the value can be set between 0 and 15. Table 5.5 shows the relationship between on-chip peripheral module interrupts and interrupt priority level setting registers. Table 5.5 Interrupt Request Sources and IPRA-IPRE | Register | Bits 15 to 12 | Bits 11 to 8 | Bits 7 to 4 | Bits 3 to 0 | |---------------------------------------------|---------------|-----------------|-------------|-------------| | Interrupt priority level setting register A | DIVU | DMAC0,<br>DMAC1 | WDT, REF | Reserved | | Interrupt priority level setting register B | SCI | FRT | Reserved | Reserved | | Interrupt priority level setting register C | IRQ0 | IRQ1 | IRQ2 | IRQ3 | | Interrupt priority level setting register D | TPU0 | TPU1 | TPU2 | SCIF1 | | Interrupt priority level setting register E | SCIF2 | SIO0 | SIO1 | SIO2 | As table 5.5 shows, between two to four on-chip peripheral modules are assigned to each interrupt priority level setting register. Set the priority levels by setting the corresponding 4-bit groups with values in the range of H'0 (0000) to H'F (1111). H'0 is interrupt priority level 0 (the lowest); H'F is level 15 (the highest). When two on-chip peripheral modules are assigned to the same bits (DMAC0 and DMAC1, or WDT and DRAM refresh control unit), those two modules have the same priority. A reset initializes IPRA-IPRE to H'0000. They are not initialized in standby mode. ## 5.3.6 Vector Number Setting Register WDT (VCRWDT) Vector number setting register WDT (VCRWDT) is a 16-bit read/write register that sets the WDT interval interrupt and BSC compare match interrupt vector numbers (0–127). VCRWDT is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | WITV6 | WITV5 | WITV4 | WITV3 | WITV2 | WITV1 | WITV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | BCMV6 | BCMV5 | BCMV4 | BCMV3 | BCMV2 | BCMV1 | BCMV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15, 7—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 8—Watchdog Timer (WDT) Interval Interrupt Vector Number 6–0 (WITV6–WITV0): These bits set the vector number for the interval interrupt (ITI) of the watchdog timer (WDT). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Bus State Controller (BSC) Compare Match Interrupt Vector Number 6–0 (BCMV6–BCMV0): These bits set the vector number for the compare match interrupt (CMI) of the bus state controller (BSC). There are seven bits, so the value can be set between 0 and 127. #### 5.3.7 Vector Number Setting Register A (VCRA) Vector number setting register A (VCRA) is a 16-bit read/write register that sets the SCI receive-error interrupt and receive-data-full interrupt vector numbers (0–127). VCRA is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | SERV6 | SERV5 | SERV4 | SERV3 | SERV2 | SERV1 | SERV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | SRXV6 | SRXV5 | SRXV4 | SRXV3 | SRXV2 | SRXV1 | SRXV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15, 7—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 8—Serial Communication Interface (SCI) Receive-Error Interrupt Vector Number 6–0 (SERV6–SERV0): These bits set the vector number for the serial communication interface (SCI) receive-error interrupt (ERI). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Serial Communication Interface (SCI) Receive-Data-Full Interrupt Vector Number 6–0 (SRXV6–SRXV0): These bits set the vector number for the serial communication interface (SCI) receive-data-full interrupt (RXI). There are seven bits, so the value can be set between 0 and 127. ## 5.3.8 Vector Number Setting Register B (VCRB) Vector number setting register B (VCRB) is a 16-bit read/write register that sets the SCI transmit-data-empty interrupt and transmit-end interrupt vector numbers (0–127). VCRB is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | STXV6 | STXV5 | STXV4 | STXV3 | STXV2 | STXV1 | STXV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | STEV6 | STEV5 | STEV4 | STEV3 | STEV2 | STEV1 | STEV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15, 7—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 8—Serial Communication Interface (SCI) Transmit-Data-Empty Interrupt Vector Number 6–0 (STXV6–STXV0): These bits set the vector number for the serial communication interface (SCI) transmit-data-empty interrupt (TXI). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Serial Communication Interface (SCI) Transmit-End Interrupt Vector Number 6–0 (STEV6–STEV0): These bits set the vector number for the serial communication interface (SCI) transmit-end interrupt (TEI). There are seven bits, so the value can be set between 0 and 127. ## **5.3.9** Vector Number Setting Register C (VCRC) Vector number setting register C (VCRC) is a 16-bit read/write register that sets the free-funning timer (FRT) input-capture interrupt and output-compare interrupt vector numbers (0–127). VCRC is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | FICV6 | FICV5 | FICV4 | FICV3 | FICV2 | FICV1 | FICV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | FOCV6 | FOCV5 | FOCV4 | FOCV3 | FOCV2 | FOCV1 | FOCV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15, 7—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 8—Free-Running Timer (FRT) Input-Capture Interrupt Vector Number 6–0 (FICV6–FICV0): These bits set the vector number for the free-running timer (FRT) input-capture interrupt (ICI). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Free-Running Timer (FRT) Output-Compare Interrupt Vector Number 6–0 (FOCV6–FOCV0): These bits set the vector number for the free-running timer (FRT) output-compare interrupt (OCI). There are seven bits, so the value can be set between 0 and 127. ## **5.3.10** Vector Number Setting Register D (VCRD) Vector number setting register D (VCRD) is a 16-bit read/write register that sets the free-running timer (FRT) overflow interrupt vector number (0–127). VCRD is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | FOVV6 | FOVV5 | FOVV4 | FOVV3 | FOVV2 | FOVV1 | FOVV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | Bits 15, 7–0—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 8—Free-Running Timer (FRT) Overflow Interrupt Vector Number 6–0 (FOVV6–FOVV0): These bits set the vector number for the free-running timer (FRT) overflow interrupt (OVI). There are seven bits, so the value can be set between 0 and 127. # 5.3.11 Vector Number Setting Register E (VCRE) Vector number setting register E (VCRE) is a 16-bit read/write register that sets the timer pulse unit 0 (TPU0) TGR0A and TGR0B input capture/compare match interrupt vector numbers (0–127). | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | TG0AV6 | TG0AV5 | TG0AV4 | TG0AV3 | TG0AV2 | TG0AV1 | TG0AV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TG0BV6 | TG0BV5 | TG0BV4 | TG0BV3 | TG0BV2 | TG0BV1 | TG0BV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved. These bits always read 0. The write value should always be 0. Bits 14 to 8—Timer pulse unit 0 (TPU0) TGR0A Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG0AV6–TG0AV0): These bits set the vector number for the timer pulse unit 0 (TPU0) TGR0A input capture/compare match interrupt. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Timer pulse unit 0 (TPU0) TGR0B Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG0BV6–TG0BV0): These bits set the vector number for the timer pulse unit 0 (TPU0) TGR0B input capture/compare match interrupt. There are seven bits, so the value can be set between 0 and 127. #### **5.3.12** Vector Number Setting Register F(VCRF) Vector number setting register F(VCRF) is a 16-bit read/write register that sets TGR0 of the timer pulse unit 0 (TPU0) and the vector number(0~127) of TGR0D input capture/compare match interrupts. VCRF is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | TG0CV6 | TG0CV5 | TG0CV4 | TG0CV3 | TG0CV2 | TG0CV1 | TG0CV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TG0DV6 | TG0DV5 | TG0DV4 | TG0DV3 | TG0DV2 | TG0DV1 | TG0DV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG0CV6-TG0CV0) of Timer Pulse Unit 0 (TPU0). These bits set the input capture/compare match interrupt vector number of the timer pulse unit 0 (TPU0) TGR0C. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG0DV6-TG0DV0) of Timer Pulse Unit 0 (TPU0) TGR0D. These bits set the input capture/compare match interrupt vector number of the timer pulse unit 0 (TPU0) TGR0D. There are seven bits , so the value can be set between 0 and 127. ## 5.3.13 Vector Number Setting Register G (VCRG) Vector number setting register G (VCRG) is a 16-bit read/write register that sets the overflow interrupt vector number (0~127) of TCNT0 of the timer pulse unit 0(TPU0). VCRG is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | | TC0VV6 | TC0VV5 | TC0VV4 | TC0VV3 | TC0VV2 | TC0VV1 | TC0VV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | Bits 15, 7 to 0—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Overflow Interrupt Vector Number 6~0 (TC0VV6~TC0VV0) of Timer Pulse Unit 0 (TPU0) TCNT0. These bits set the overflow interrupt vector number of the timer pulse unit 0 (TPU0) TCNT0. There are seven bits, so the value can be set between 0 and 127. ## 5.3.14 Vector Number Setting Register H (VCRH) Vector number setting register H (VCRH) is a 16-bit read/write register that sets TGR1A of the timer pulse unit 1 (TPU1) and the input capture/compare match interrupt vector number (0-127) of TGR1B. VCRH is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | | TG1AV6 | TG1AV5 | TG1AV4 | TG1AV3 | TG1AV2 | TG1AV1 | TG1AV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | TG1BV6 | TG1BV5 | TG1BV4 | TG1BV3 | TG1BV2 | TG1BV1 | TG1BV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG1AV6-TG1AV0) of Timer Pulse Unit 1 (TPU1) TGR1A. These bits set the input capture/compare match interrupt vector number of the timer pulse unit 1 (TPU1) TGR1A. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Input Capture/Compare Match Interrupt Vector Number $6\sim0$ (TG1BV6 $\sim$ TG1BV0) of Timer Pulse Unit 1 (TPU1) TGR1B. These bits set the input capture/compare match interrupt vector number of the timer pulse unit 1 (TPU1) TGR1B. There are seven bits , so the value can be set between 0 and 127. #### 5.3.15 Vector Number Setting Register I (VCRI) Vector number setting register I(VCRI) is a 16-bit read/write register that sets the overflow/underflow interrupt vector number (0~127) of TCNT1 of the timer pulse unit 1 (TPU1). VCR1 is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | TC1VV6 | TC1VV5 | TC1VV4 | TC1VV3 | TC1VV2 | TC1VV1 | TC1VV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TC1UV6 | TC1UV5 | TC1UV4 | TC1UV3 | TC1UV2 | TC1UV1 | TC1UV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Overflow Interrupt Vector Number 6 to 0 (TC1VV6-TC1VV0) of Timer. Pulse Unit 1 (TPU1) TCNT1. These bits set the overflow interrupt vector number of the timer pulse unit 1. (TPU1) TCNT1. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Underflow Interrupt Vector Number 6 to 0 (TC1UV6-TC1UV0) of Timer Pulse Unit 1 (TPU1) TCNT1. These bits set the underflow interrupt vector number of the timer pulse unit 1. (TPU1) TCNT1. There are seven bits, so the value can be set between 0 and 127. ## 5.3.16 Vector Number Setting Register J (VCRJ) Vector number setting register J (VCRJ) is a 16-bit read/write register that sets TGR2A of the timer pulse unit 2 (TPU2) and the input capture/compare match interrupt vector number (0-127) of TGR2B. VCRJ is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | | TG2AV6 | TG2AV5 | TG2AV4 | TG2AV3 | TG2AV2 | TG2AV1 | TG2AV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TG2BV6 | TG2BV5 | TG2BV4 | TG2BV3 | TG2BV2 | TG2BV1 | TG2BV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved: These bits always read 0. The write value should always be 0. Bits 14 to 6—Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG2AV6-TG2AV0) of Timer Pulse Unit 2 (TPU2) TGR2A. These bits set the input capture/compare match interrupt number of the time pulse unit 2 (TPU2) TGR2A. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Input Capture/Compare Match Interrupt Vector Number 6 to 0 (TG2BV6-TG2BV0) of Timer Pulse Unit 2 (TPU2) TGR2B. These bits set the input capture/compare match interrupt vector number of the timer pulse unit 2 (TPU2) TGR2B. There are seven bits, so the value can be set between 0 and 127. ## 5.3.17 Vector Number Setting Register K (VCRK) Vector number setting register K (VCRK) is a 16-bit read/write register that sets the overflow/underflow interrupt vector number (0-127) of TCNT2 of the timer pulse unit 2 (TPU2). VCRK is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | TC2VV6 | TC2VV5 | TC2VV4 | TC2VV3 | TC2VV2 | TC2VV1 | TC2VV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TC2UV6 | TC2UV5 | TC2UV4 | TC2UV3 | TC2UV2 | TC2UV1 | TC2UV0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Overflow Interrupt Vector Number 6 to 0 (TC2VV6-TC2VV0) of Timer Pulse Unit 2 (TPU2) TCNT2 These bits set the overflow interrupt vector number of the timer pulse unit 2 (TPU2) TCNT2. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Underflow Interrupt Vector Number 6 to 0 (TC2UV6-TC2UV0) of Timer Pulse Unit 2 (TPU2) TCNT2 These bits set the underflow interrupt vector number of the timer pulse unit 2 (TPU2) TCNT2. There are seven bits, so the value can be set between 0 and 127. ## 5.3.18 Vector Number Setting Register L (VCRL) Vector number setting register L (VCRL) is a 16-bit read/write register that sets the receive error interrupt of the serial communication interface 1 (SCIF1) with FIFO and the vector number (0~127) of the receive- data- full/data ready interrupt. VCRL is initialized to H'0000 by a reset. It is not initialized in standby mode. $Å\dot{E}\ddot{l}$ | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | SER1V6 | SER1V5 | SER1V4 | SER1V3 | SER1V2 | SER1V1 | SER1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | SRX1V6 | SRX1V5 | SRX1V4 | SRX1V3 | SRX1V2 | SRX1V1 | SRX1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Receive Error Interrupt Vector Number 6 to 0 (SER1V6-SER1V0) of Serial Communication Interface 1 (SCIF1) with FIFO. These bits set the receive error interrupt vector number of the serial communication interface (SCIP1) with FIFO. There are seven bits, so the value can be set between 0 and 127. Bits 7 to 0—Receive-Data-Full/Data Ready Interrupt Vector Number 6 to 0 (SRX1V6-SRX1V0) of Serial Communication Interface1 (SCIF1) with FIFO. These bits set the receive-data-full/data ready interrupt vector number of the serial communication interface 1 (SCIF1) with FIFO. There are seven bits, so the value can be set between 0 and 127. ## 5.3.19 Vector Number Setting Register M (VCRM) The vector number setting register M (VCRM) is a 16-bit read/write register thatsets the break interrupt of the serial communication interface 1 (SCIF1) with FIFO and the vector number (0~127) of the transmit data empty interrupt. VCRM is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | SBR1V6 | SBR1V5 | SBR1V4 | SBR1V3 | SBR1V2 | SBR1V1 | SBR1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | STX1V6 | STX1V5 | STX1V4 | STX1V3 | STX1V2 | STX1V1 | STX1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Break Interrupt Vector Number 6 to 0 (SBR1V6-SBR1V0) of Serial Communication Interface 1 (SCIF1) with FIFO. These bits set the break interrupt vector number of the serial communication interface 1 (SCIF1) with FIFO. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Data Empty Interrupt Vector Number 6 to 0 (STE1V6-STE1V0) of Serial Communication Interface 1 (SCIF1) with FIFO. These bits set the transmit data empty interrupt vector number of the serial communication interface 1 (SCIF1) with FIFO. There are seven bits, so the value can be set between 0 and 127. ## **5.3.20** Vector Number Setting Register N (VCRN) Vector number setting register N (VCRN) is a 16-bit read/write register that sets the receive error interrupt of the serial communication interface 2 (SCIF2) withFIFO and the vector number (0~127) of the receive-data-full/data ready interrupt. VCRN is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | | SER2V6 | SER2V5 | SER2V4 | SER2V3 | SER2V2 | SER2V1 | SER2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | SRX2V6 | SRX2V5 | SRX2V4 | SRX2V3 | SRX2V2 | SRX2V1 | SRX2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Receive Error Interrupt Vector Number 6 to 0 (SER2V6-SER2V0) of Serial Communication Interface 2 (SCIF2) with FIFO. These bits set the receive error interrupt vector number of the serial communication interface 2 (SCIF2) with FIFO. There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Receive-Data-Full/Data Ready Interrupt Vector Number 6 to 0 (SRX2V6-SRX2V0) of Serial Communication Interface 2 (SCIF2) with FIFO. These bits set the receive-data-full/data ready interrupt vector number of the serial communication interface 2 (SCIF2) with FIFO. There are seven bits, so the value can be set between 0 and 127. ## **5.3.21** Vector Number Setting Register O (VCRO) Vector number setting register O (VCRO) is a 16-bit read/write register that sets the break interrupt of the serial communication interface 2 (SCIF2) with FIFO and the vector number(0~127) of the transmit data empty interrupt. VCRO is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | SBR2V6 | SBR2V5 | SBR2V4 | SBR2V3 | SBR2V2 | SBR2V1 | SBR2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | STX2V6 | STX2V5 | STX2V4 | STX2V3 | STX2V2 | STX2V1 | STX2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Break Interrupt Vector Number 6 to 0 (SBR2V6-SBR2V0) of Serial Communication Interface 2 (SCIF2) with FIFO. These bits set the break interrupt vector number of the serial communication interface 2 (SCIF2) with FIFO. Bits 6 to 0—Transmit Data Empty Interrupt Vector Number 6 to 0 (STE2V6-STE2V0) of Serial Communication Interface 2 (SCIF2) with FIFO. These bits set the transmit empty interrupt vector number of the serial communication interface 2 (SCIF2) with FIFO. There are seven bits, so the value can be set between 0 and 127. ## **5.3.22** Vector Number Setting Register P (VCRP) Vector number setting register P (VCRP) is a 16-bit read/write register that sets the receive overrun error interrupt of the serial I/O0 (SIO0) and the vector number (0~127) of the transmit overrun error interrupt. VCRP is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RER0V6 | RER0V5 | RER0V4 | RER0V3 | RER0V2 | RER0V1 | RER0V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TER0V6 | TER0V5 | TER0V4 | TER0V3 | TER0V2 | TER0V1 | TER0V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8: Receive Overrun Error Interrupt Vector Number 6 to 0 (RER0V6-RER0V0) of Serial I/O0 (SIO0). These bits set the receive overrun error interrupt vector number of the serial I/O0(SIO0). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Overrun Error Interrupt Vector Number 6 to 0(TER0V6-TER0V0) of Serial I/O0 (SIO0). These bits set the transmit overrun error interrupt vector number of the serial I/O0 (SIO0). There are seven bits, so the value can be set between 0 and 127. ## 5.3.23 Vector Number Setting Register Q (VCRQ) Vector number setting register Q (VCRQ) is a 16-bit read/write register that sets the receive-data-full of the serial I/O0 (SIO0) and the vector number(0~127) of the transmit data empty interrupt. VCRQ is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RDF0V6 | RDF0V5 | RDF0V4 | RDF0V3 | RDF0V2 | RDF0V1 | RDF0V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TDE0V6 | TDE0V5 | TDE0V4 | TDE0V3 | TDE0V2 | TDE0V1 | TDE0V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always 0. Bits 14 to 8—Receive-Data-Full Interrupt Vector Number 6 to 0(RDF0V8-RDF0V0) of Serial I/O0(SIO0) These bits set the receive-data-full interrupt vector number of the serial I/O0 (SIO0). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Data Empty Interrupt Vector Number 6 to 0 (TDE0V6-TDE0V0) of Serial I/O0 (SIO0). These bits set the transmit data empty interrupt vector number of the serial I/O0 (SIO0). There are seven bits, so the value can be set between 0 and 127. ## 5.3.24 Vector Number Setting Register R (VCRR) Vector number setting register R (VCRR) is a 16-bit read/write register that sets the receive overrun error interrupt of the serial I/O1 (SIO1) and the transmit overrun error interrupt vector number(0~127). VCRR is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RER1V6 | RER1V5 | RER1V4 | RER1V3 | RER1V2 | RER1V1 | RER1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | TER1V6 | TER1V5 | TER1V4 | TER1V3 | TER1V2 | TER1V1 | TER1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Receive Overrun Error Interrupt Vector Number 6 to 0(RER1V6-RER1V0) of Serial I/O1 (SIO1). These bits set the receive overrun interrupt vector number of the serial I/O1 (SIO1). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Overrun Error Interrupt Vector Number 6 to 0(TER1V6-TER1V0). These bits set the transmit overrun error interrupt vector number of the serial I/O1(SIO1). These are seven bits, and the value can be set between 0 and 127. ## 5.3.25 Vector Number Setting Register S (VCRS) Vector number setting register S (VCRS) is a 16-bit read/write register that sets the receive-datafull interrupt of the serial I/O1 (SIO1) and the transmit data empty interrupt vector number(0~127). VCRS is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RDF1V6 | RDF1V5 | RDF1V4 | RDF1V3 | RDF1V2 | RDF1V1 | RDF1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TDE1V6 | TDE1V5 | TDE1V4 | TDE1V3 | TDE1V2 | TDE1V1 | TDE1V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Receive-Data-Full Interrupt Vector Number 6 to 0(RDF1V6-RDF1V0) of Serial I/O1 (SIO1). These bits set the receive-data-full interrupt vector number of the serial I/O1 (SIO1). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Data Empty Interrupt Vector Number 6 to 0(TDE1V6-TDE1V0) of Serial I/O1 (SIO1). These bits set the transmit data empty interrupt vector number of the serial I/O1 (SIO1). There are seven bits, so the value can be set between 0 and 127. ## **5.3.26** Vector Number Setting Register T (VCRT) Vector number setting register T (VCRT) is a 16-bit read/write register that sets the receive overrun error interrupt of the serial I/O2 (SIO2) and the transmit overrun error interrupt vector number(0~127). VCRT is initialized to H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RER2V6 | RER2V5 | RER2V4 | RER2V3 | RER2V2 | RER2V1 | RER2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TER2V6 | TER2V5 | TER2V4 | TER2V3 | TER2V2 | TER2V1 | TER2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved bits. These bits always read 0. The write value should always be 0. Bits 14 to 8—Receive Overrun Error Interrupt Vector Number 6 to 0 (RER2V6-RER2V0) of Serial I/O2 (SIO2). These bits set the receive overrun error interrupt vector number of the serial I/O2 (SIO2). There are seven bits, so the value can be set between 0 and 127. Bits 6 to 0—Transmit Overrun Error Interrupt Vector Number 6 to 0 (TER2V6-TER2V0) of Serial I/O2 (SIO2). These bits set the transmit overrun interrupt vector number of the serial I/O2 (SIO2). There are seven bits, so the value can be set between 0 and 127. ## 5.3.27 Vector Number Setting Register U (VCRU) Vector number setting register U (VCRU) is a 16-bit read/write register that sets the serial I/O 2 (SIO2) receive-data-full interrupt and transmit-data-empty interrupt vector numbers (0–127). | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | RDF2V6 | RDF2V5 | RDF2V4 | RDF2V3 | RDF2V2 | RDF2V1 | RDF2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | TDE2V6 | TDE2V5 | TDE2V4 | TDE2V3 | TDE2V2 | TDE2V1 | TDE2V0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W Bits 15 and 7—Reserved. These bits always read 0. The write value should always be 0. Bits 14 to 8—Serial I/O 2 (SIO2) Receive-Data-Full Interrupt Vector Number 6 to 0 (RDF2V6–RDF2V0): These bits set the vector number for the serial I/O 2 (SIO2) receive-data-full interrupt. There are seven bits, so the value can be set between 0 and 127. Bits 7 to 0—Serial I/O 2 (SIO2) Transmit-Data-Empty Interrupt Vector Number 6 to 0 (TDE2V6–TDE2V0): These bits set the vector number for the serial I/O 2 (SIO2) transmit-data-empty interrupt. There are seven bits, so the value can be set between 0 and 127. Tables 5.6 and 5.7 show the relationship between on-chip peripheral module interrupts and interrupt vector number setting registers. Table 5.6 Interrupt Request Sources and Vector Number Setting Registers (1) Bits | | Bito | | |------------------------------------|----------------------------------------------------|----------------------------------------------------| | Register | 14–8 | 6–0 | | Vector number setting register WDT | Interval interrupt (WDT) | Compare-match interrupt (BSC) | | Vector number setting register A | Receive-error interrupt (SCI) | Receive-data-full interrupt (SCI) | | Vector number setting register B | Transmit-data-empty interrupt (SCI) | Transmit-end interrupt (SCI) | | Vector number setting register C | Input-capture interrupt (FRT) | Output-compare interrupt (FRT) | | Vector number setting register D | Overflow interrupt (FRT) | Reserved | | Vector number setting register E | Input capture/compare match interrupt (TPU0/TGR0A) | Input capture/compare match interrupt (TPU0/TGR0B) | | Vector number setting register F | Input capture/compare match interrupt (TPU0/TGR0C) | Input capture/compare match interrupt (TPU0/TGR0D) | | Vector number setting register G | Overflow interrupt (TPU0/TCNT0) | Reserved | | Vector number setting register H | Input capture/compare match interrupt (TPU1/TGR1A) | Input capture/compare match interrupt (TPU1/TGR1B) | | Vector number setting register I | Overflow interrupt (TPU1/TCNT1) | Underflow interrupt<br>(TPU1/TCNT1) | | Vector number setting register J | Input capture/compare match interrupt (TPU2/TGR2A) | Input capture/compare match interrupt (TPU2/TGR2B) | | Vector number setting register K | Overflow interrupt<br>(TPU2/TCNT2) | Underflow interrupt<br>(TPU2/TCNT2) | | Vector number setting register L | Receive-error interrupt (SCIF1) | Receive-data-full/data-ready interrupt (SCIF1) | | Vector number setting register M | Break interrupt (SCIF1) | Transmit-data-empty interrupt (SCIF2) | | Vector number setting register N | Receive-error interrupt (SCIF2) | Receive-data-full/data-ready interrupt (SCIF2) | | Vector number setting register O | Break interrupt (SCIF2) | Transmit-data-empty interrupt (SCIF2) | | Vector number setting register P | Receive overrun error interrupt (SIO0) | Transmit overrun error interrupt (SIO0) | | Vector number setting register Q | Receive-data-full interrupt (SIO0) | Transmit-data-empty interrupt (SIO0) | | - | | | Table 5.6 Interrupt Request Sources and Vector Number Setting Registers (1) (cont) **Bits** Register 14-8 6-0 Vector number setting register R Receive overrun error interrupt Transmit overrun error interrupt (SIO1) (SIO1) Receive-data-full interrupt Transmit-data-empty interrupt Vector number setting register S (SIO1) (SIO1) Vector number setting register T Receive overrun error interrupt Transmit overrun error (SIO2) interrupt (SIO2) Vector number setting register U Receive-data-full interrupt Transmit-data-empty interrupt (SIO2) (SIO2) As table 5.6 shows, two on-chip peripheral module interrupts are assigned to each register. Set the vector numbers by setting the corresponding 7-bit groups (bits 14 to 8 and bits 6 to 0) with values in the range of H'00 (0000000) to H'7F (1111111). H'00 is vector number 0 (the lowest); H'7F is vector number 127 (the highest). The vector table address is calculated by the following equation. Vector table address = VBR + (vector number $\times$ 4) A reset initializes a vector number setting register to H'0000. They are not initialized in standby mode. As shown in table 5.7, the vector number for divider overflow interrupts is set in VCRDIV, and the vector numbers for direct memory access controller transfer-end interrupts are set in VCRDMA0 and VCRDMA1. See sections 9, Direct Memory Access Controller (DMAC), and 10, Division Unit (DIVU), for more details. Table 5.7 Interrupt Request Sources and Vector Number Setting Registers (2) | Register | Setting Function | |------------------------------------------------|-------------------------------------------| | Vector number setting register DIV (VCRDIV) | Overflow interrupts for DIVU | | Vector number setting register DMAC0 (VCRDMA0) | Channel 0 transfer end interrupt for DMAC | | Vector number setting register DMAC1 (VCRDMA1) | Channel 1 transfer end interrupt for DMAC | ## 5.3.28 Interrupt Control Register (ICR) ICR is a 16-bit register that sets the input signal detection mode of external interrupt input pin NMI and indicates the input signal level at the NMI pin. It can also specify IRQ or IRL mode by means of external interrupt mode. IRQ/IRL interrupt vector number can select to set in accordance with either the vector mode or the external mode by the interrupt vector mode select. ICR is initialized to H'8000 or H'0000 by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|----|----|----|----|----|-------|-------| | Bit name: | NMIL | _ | _ | | _ | _ | _ | NMIE | | Initial value: | 0/1* | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | | _ | _ | EXIMD | VECMD | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | Note: When NMI input is high: 1; when NMI input is low: 0 Bit 15—NMI Input Level (NMIL): Sets the level of the signal input at the NMI pin. This bit can be read to determine the NMI pin level. This bit cannot be modified. | Bit 15: NMIL | Description | | |--------------|-------------------------|--| | 0 | NMI input level is low | | | 1 | NMI input level is high | | Bits 14 to 9—Reserved: These bits always read 0. The write value should always be 0. Bit 8—NMI Edge Select (NMIE): Selects whether the falling or rising edge of the interrupt request signal to the NMI pin is detected. | Bit 8: NMIE | Description | |-------------|----------------------------------------------------------------------------| | 0 | Interrupt request is detected on falling edge of NMI input (Initial value) | | 1 | Interrupt request is detected on rising edge of NMI input | Bits 7 to 2—Reserved: These bits always read 0. The write value should always be 0. Bit 1—External Interrupt Vector Mode Select (EXMID): This bit selects IRQ mode or IRL mode. In IRQ mode, each of signals $\overline{1RL3}$ to $\overline{1RL0}$ functions as a separate interrupt source. In IRL mode, these signals can specify interrupt priority levels 1 to 15. | Bit 1: EXIMD | Description | | |--------------|-------------|-----------------| | 0 | IRL mode | (Initial value) | | 1 | IRQ mode | _ | Bit 0—IRL Interrupt Vector Mode Select (VECMD): This bit selects auto-vector mode or external vector mode for IRL interrupt vector number setting. In auto-vector mode, an internally determined vector number is set. The IRL15 and IRL14 interrupt vector numbers are set to 71 and the IRL1 vector number is set to 64. In external vector mode, a value between 0 and 127 can be input as the vector number from the external vector number input pins (D7–D0). | Bit 0: VECMD | Description | | |----------------------------------------------------------------|-----------------------------------------------------------|--| | 0 Auto vector mode, vector number automatically set internally | | | | | (Initial value) | | | 1 | External vector mode, vector number set by external input | | # 5.3.29 IRQ Control/Status Register (IRQCSR) The IRQ control/status register (IRQCSR) is a 16-bit register that sets the $\overline{IRL3}$ – $\overline{IRL0}$ input signal detection mode, indicates the input signal levels at pins $\overline{IRL3}$ – $\overline{IRL0}$ , and also indicates the IRQ interrupt status. IRQCSR is initialized by a reset. It is not initialized in standby mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | IRQ31S | IRQ30S | IRQ21S | IRQ20S | IRQ11S | IRQ10S | IRQ01S | IRQ00S | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | IRL3PS | IRL2PS | IRL1PS | IRL0PS | IRQ3F | IRQ2F | IRQ1F | IRQ0F | | Initial value: | 0/1 | 0/1 | 0/1 | 0/1 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/(W) | R/(W) | R/(W) | R/(W) | Bits 15 to 8—IRQ Sense Select Bits (IRQ31S–IRQ00S): These bits set the IRQ detection mode for $\overline{IRL3}$ – $\overline{IRL0}$ . | Bits 15–8:<br>IRQn1S | Bits 15–8:<br>IRQn0S | Description | |----------------------|----------------------|------------------------| | 0 | 0 | Low-level detection | | | 1 | Falling-edge detection | | 1 | 0 | Rising-edge detection | | | 1 | Both-edge detection | n = 0 to 3 Bits 7 to 4—IRL Pin Status Bits (IRL3PS–IRL0PS): These bits indicate the $\overline{IRL3}$ – $\overline{IRL0}$ pin status. The $\overline{IRL3}$ – $\overline{IRL0}$ pin levels can be ascertained by reading these bits. These bits cannot be modified. | Bits 7-4: IRLnPS | Description | | |------------------|---------------------------------------|--| | 0 | Low level is being input to pin IRLn | | | 1 | High level is being input to pin IRLn | | | - O4- 2 | | | n = 0 to 3 Bits 3 to 0:IRQ3 to IRQ0 Flags (IRQ3F–IRQ0F): These bits indicate the IRQ3–IRQ0 interrupt request status. Bits 3-0: | IRQ3F-IRQ0F | <b>Detection Setting</b> | Description | |-------------|--------------------------|-----------------------------------------------------| | 0 | Level detection | There is no IRQn interrupt request | | | | [Clearing condition] | | | | When IRLn input is high | | | Edge detection | An IRQn interrupt request has not been detected | | | | [Clearing conditions] | | | | 1. When 0 is written to IRQnF after reading IRQnF = | | | | 1 | | | | 2. When an IRQn interrupt is accepted | | 1 | Level detection | There is an IRQn interrupt request | | | | [Setting condition] | | | | When IRLn input is low | | | Edge detection | An IRQn interrupt request has been detected | | | | [Setting condition] | | | | When an IRLn input edge is detected | n = 0 to 3 # 5.4 Interrupt Operation #### **5.4.1** Interrupt Sequence The sequence of operations in interrupt generation is described below and illustrated in figure 5.5. - 1. The interrupt request sources send interrupt request signals to the interrupt controller. - 2. The interrupt controller selects the highest-priority interrupt among the interrupt requests sent, according to the priority levels set in interrupt priority level setting registers A–E (IPRA–IPRE). Lower-priority interrupts are held pending. If two of these interrupts have the same priority level or if multiple interrupts occur within a single module, the interrupt with the highest default priority or the highest priority within its IPR setting unit (as indicated in table 5.4) is selected. - 3. The interrupt controller compares the priority level of the selected interrupt request with the interrupt mask bits (I3–I0) in the CPU's status register (SR). If the request priority level is equal to or less than the level set in I3–I0, the request is held pending. If the request priority level is higher than the level in bits I3–I0, the interrupt controller accepts the interrupt and sends an interrupt request signal to the CPU. - 4. The CPU detects the interrupt request sent from the interrupt controller when it decodes the next instruction to be executed. Instead of executing the decoded instruction, the CPU starts interrupt exception handling. - 5. Status register (SR) and program counter (PC) are saved onto the stack. - 6. The priority level of the accepted interrupt is copied to the interrupt mask level bits (I3 to I0) in the status register (SR). - 7. When external vector mode is specified for the IRL/IRQ interrupt, the vector number is read from the external vector number input pins (D7–D0). - 8. The CPU reads the start address of the exception service routine from the exception vector table entry for the accepted interrupt, jumps to that address, and starts executing the program there. This jump is not a delayed branch. **Figure 5.8 Interrupt Sequence Flowchart** # 5.4.2 Stack Status after Ending Interrupt Exceptions Handling The stack status after ending the interrupt exceptions handling is shown in Figure 5.9. Figure 5.9 Stack Status after Ending Interrupt Exceptions Handling # 5.5 Interrupt Response Time Table 5.8 shows the interrupt response time, which is the time from the occurrence of an interrupt request until interrupt exception handling starts and fetching of the first instruction of the interrupt service routine begins. **Table 5.8** Interrupt Response Time | | Number of Sta | ites | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Peripheral Mod | dule | _ | | Item | NMI | IRL/IRQ | A | В | Notes | | Compare identified interrupt priority with SR mask level | 2.0 × lcyc | 0.5 × lcyc<br>+ 1.0 × Ecyc<br>+ 1.5 × Pcyc | 0.5 × lcyc<br>+ 1.0 × Pcyc | 1.0 × Pcyc | | | Wait for completion of sequence currently being executed by CPU | X (= 0) | X (= 0) | X (= 0) | X (= 0) | The longest sequence is for interrupt or address-error exception handling (X = 4.0 × lcyc + m1 + m2 + m3 + m4). If an interrupt-making instruction follows, however, the time may be even longer during repeat instruction execution. | | Time from interrupt exception handling (SR and PC saves and vector address fetch) until fetch of first instruction exception service routine starts | + m1 + m2<br>+ m3 | 5.0 × lcyc<br>+ m1 + m2<br>+ m3 | 5.0 × lcyc<br>+ m1 + m2<br>+ m3 | 5.0 × lcyc<br>+ m1 + m2<br>+ m3 | | | Response time Total: | X + 7.0 × lcyc<br>+ m1 + m2<br>+ m3 | X + 5.5 × lcyc<br>+ 1.0 × Ecyc<br>+ 1.5 × Pcyc<br>+ m1 + m2<br>+ m3 | X + 5.5 × lcyc<br>+ 1.0 × Pcyc<br>+ m1 + m2<br>+ m3 | X + 5.0 × lcyc<br>+ 1.0 × Pcyc<br>+ m1 + m2<br>+ m3 | | | Minimum: | 10 | 11 | 9.5 | 9 | $I\phi:E\phi:P\phi=1:1:1$ | | Maximum: | 11 + 2 (m1<br>+ m2 + m3)<br>+ m4 | 19.5 + 2 (m1<br>+ m2 + m3)<br>+ m4 | 13.5 + 2 (m1<br>+ m2 + m3)<br>+ m4 | 13.0 + 2 (m1<br>+ m2 + m3)<br>+ m4 | $I\phi:E\phi:P\phi = 1:1/4:1/4$ | Note: m1-m4 are the number of states needed for the following memory accesses m1: SR save (longword write)m2: PC save (longword write) m3: Vector address read (longword read) m4: Fetch of first instruction of interrupt service routine Icyc: I $\phi$ cycle time Ecyc: E $\phi$ cycle time Pcyc: P $\phi$ cycle time Peripheral modules A: DIVU, DMAC, REF (BSC) Peripheral modules B: WDT, SCI, FRT, TPU, SCIF, SIO # 5.6 Sampling of Pins IRL3-IRL0 Signals on interrupt pins $\overline{IRL3}$ to $\overline{IRL0}$ pass through the noise canceler before being sent by the interrupt controller to the CPU as interrupt requests, as shown in figure 5.9. The noise canceler cancels noise that changes in short cycles. The CPU samples the interrupt requests between executing instructions. During this period, the noise canceler output changes according to the noise-eliminated pin level, so the pin level must be held until the CPU samples it. This means that interrupt sources generally must not be cleared inside interrupt routines. When an external vector is fetched, the interrupt source can also be cleared when the external vector fetch cycle is detected. Figure 5.10 IRL3-IRL0 Pin Sampling ## 5.7 Usage Notes - 1. Do not execute module standby for modules that have the module standby function when the possibility remains that an interrupt request may be output. - 2. Notes on Clear of Interrupt Factor - In the case of clearing the external interrupt factor - If the clear of the interrupt factor is performed by write against the I/O address(external), the next instruction is executed before completion of write operation by the effect of write buffer. When performing read from the same address followingwrite in order that the next instruction is executed after the write operation has been completed, it is synchronized. - In the case of returning from the interrupt processing by RTE instruction As shown in fig. 5.10, when returning from the interrupt processing by RTE instruction, examine the write instruction for synchronization and the cycle inserted between RTE instructions by the set clock ratio(Iφ:Eφ:Pφ) and the external bus cycle. In IRL3-IRL0, negate it before more than 0.5Icyc + 1.0Ecyc +1.5Pcyc until the interrupt acceptance become available. - If the clock ratio is $I\phi : E\phi : P\phi = 4 : 2 : 2$ , arrange so that more than 5.5 Leyc can be inserted. - In the case of changing the level during the interrupt processing Even if the another interrupt allows to apply multiple after changing SR value by the LDC instruction, examine the inserted cycle between the synchronization instruction and the LDC instruction as shown in fig.5.11 from the set clock ratio (Iφ: Εφ: Pφ) and the external bus cycle. - In IRL3-IRL0, negate it before more than 0.5Icyc + 1.0Ecyc + 1.5Pcyc until the interrupt acceptance becomes available. - If the clock ratio is $I\phi$ : $E\phi$ : $P\phi=4$ : 2: 2, arrange so that more than 5.5Icyccan be inserted. Figure 5.11 Pipe line operation in return by RTE instruction Figure 5.12 Pipe line operation when interrupt is allowed by changing SR If the clear of the interrupt factor is performed by the program, the pipe line operation is necessary to consider in order that the same interrupt will not work once again. - In the case of clearing the built-in interrupt The pipe line is necessary to consider in order that the same interrupt will not work once again even if the interrupt factor comes from the internal peripheral factor. 0.5Icyc + 1.0Pcyc is necessary until the interrupt from the internal peripheral module is recognized by CPU. Similarly, 0.5Icyc + 1.0Pcyc is necessary to be transmitted that the interrupt request was not available. - In the case of returning from the interrupt processing by RTE instruction As shown in fig.5.12, when returning from the interrupt processing by RTE, examine the inserted cycle between the write instruction and RTE instruction for synchronization by the set clock ratio ( $I\phi$ : $E\phi$ : $P\phi$ ). - Negate the internal peripheral interrupt signal before more than 0.5 Icyc + 1.0 Pcyc until the interrupt acceptance becomes available. - If the clock ratio is $I\phi : E\phi : P\phi = 4 : 2 : 2$ , arrange so that more than 2.5 Icyc can be inserted. - In the case of changing the level during the interrupt processing Even if the another interrupt allows to apply multiple after changing SR value by the LDC instruction, examine the inserted cycle between the synchronization instruction and LDC instruction as shown in fig.5.13 by the set clock ratio (Iφ:Εφ:Pφ). Negate the internal peripheral interrupt signal before more than 0.5Icyc + 1.0Pcyc until the interrupt acceptance becomes available. If the clock ratio is I $\phi$ : E $\phi$ : P $\phi$ = 4 : 2 : 2, arrange so that more than 2.5Icyc can be inserted. Figure 5.13 Pipe line operation in return by RTE instruction Figure 5.14 Pipe line operation when interrupt is allowed by changing SR In the above diagram, since SH-DSP can not specify the stage which the instruction fetch occurs due to DSP instruction mixing, F of the instruction fetch is almost omitted during the pipe line operation. # Section 6 User Break Controller #### 6.1 Overview The user break controller (UBC) provides functions that simplify program debugging. Break conditions are set in the UBC and a user break interrupt is generated according to the conditions of the bus cycle generated by the CPU and on-chip DMAC. This function makes it easy to design an effective self-monitoring debugger, enabling the chip to debug programs without using an in-circuit emulator. #### 6.1.1 Features The features of the user break controller are listed below: - The following break compare conditions can be set: Two break channels (channel A, channel B). User break interrupts can be requested using either independent or sequential condition for the two channels (sequential breaks are channel A, then channel B). - Address: 32-bit maskable, individual address setting possible (cache bus (CPU), internal bus (DMAC), X/Y bus) - Data (channel B only): 32-bit maskable, individual address setting possible (cache bus (CPU), internal bus (DMAC), X/Y bus) - Bus master: CPU cycle/DMAC cycle/external bus cycle - Bus cycle: instruction fetch/data access - Read or write - Operand size: byte/word/longword - User break interrupt generated upon satisfying break conditions. A user-designed user break interrupt exception handling routine can be run. - If the instruction fetch cycle is a condition, either the interrupt is generated before instruction is executed or (the stop interrupt processing is generated after the instruction is executed) is selectable. - Execution times specification break (channel B only) Settable number of times: max. 2<sup>12</sup> – 1 (4095) - PC trace function Tracing of branch source/branch destination addresses in branch instruction execution (max. eight addresses (four pairs)) ## 6.1.2 Block Diagram Figure 6.1 User Break Controller Block Diagram # 6.1.3 Register Configuration **Table 6.1** Register Configuration | Name | Abbr. | R/W | Initial<br>Value* <sup>1</sup> | Address | Access | s Size*² | |--------------------------------|--------|-----|--------------------------------|------------|--------|----------| | Break address register AH | BARAH | R/W | H'0000 | H'FFFFFF40 | 16 | 32 | | Break address register AL | BARAL | R/W | H'0000 | H'FFFFFF42 | 16 | _ | | Break address mask register AH | BAMRAH | R/W | H'0000 | H'FFFFFF44 | 16 | 32 | | Break address mask register AL | BAMRAL | R/W | H'0000 | H'FFFFFF46 | 16 | _ | | Break bus cycle register A | BBRA | R/W | H'0000 | H'FFFFFF48 | 16, 32 | | | Break address register BH | BARBH | R/W | H'0000 | H'FFFFFF60 | 16 | 32 | | Break address register BL | BARBL | R/W | H'0000 | H'FFFFF62 | 16 | _ | | Break address mask register BH | BAMRBH | R/W | H'0000 | H'FFFFFF64 | 16 | 32 | | Break address mask register BL | BAMRBL | R/W | H'0000 | H'FFFFF66 | 16 | _ | | Break data register BH | BDRBH | R/W | H'0000 | H'FFFFFF70 | 16 | 32 | | Break data register BL | BDRBL | R/W | H'0000 | H'FFFFFF72 | 16 | _ | | Break data mask register BH | BDMRBH | R/W | H'0000 | H'FFFFFF74 | 16 | 32 | | Break data mask register BL | BDMRBL | R/W | H'0000 | H'FFFFFF76 | 16 | _ | | Break bus cycle register B | BBRB | R/W | H'0000 | H'FFFFF68 | 16, 32 | | | Break control register | BRCR | R/W | H'0000 | H'FFFFFF78 | 16, 32 | | | Execution count break register | BETR | R/W | H'0000 | H'FFFFFF4C | 16, 32 | | | Branch flag register | BRFR | R | *3 | H'FFFFF50 | 16, 32 | | | Branch source register | BRSR | R | Unde-<br>fined | H'FFFFFF54 | 16, 32 | | | Branch destination register | BRDR | R | Unde-<br>fined | H'FFFFFF58 | 16, 32 | | Notes: 1. Initialized by a power-on reset. Values held in standby mode. Value undefined after a manual reset. <sup>2.</sup> Byte access not permitted. <sup>3.</sup> Bits SVF and DVF in BRFR are initialized by a power-on reset, but the other bits in BRFR are not. # **6.2** Register Descriptions ## 6.2.1 Break Address Register A (BARA) #### **BARAH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | BAA31 | BAA30 | BAA29 | BAA28 | BAA27 | BAA26 | BAA25 | BAA24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAA23 | BAA22 | BAA21 | BAA20 | BAA19 | BAA18 | BAA17 | BAA16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **BARAL:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|------|------|------| | Bit name: | BAA15 | BAA14 | BAA13 | BAA12 | BAA11 | BA10 | BAA9 | BAA8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAA7 | BAA6 | BAA5 | BAA4 | BAA3 | BAA2 | BAA1 | BAA0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break address registers A—break address register AH (BARAH) and break address register AL (BARAL)—together form a single group. Both are 16-bit read/write registers. BARAH stores the upper bits (bits 31 to 16) of the address of the channel A break condition, while BARAL stores the lower bits (bits 15 to 0). A power-on reset initializes both BARAH and BARAL to H'0000. Their values are undefined after a manual reset. BARAH Bits 15 to 0—Break Address A 31 to 16 (BAA31 to BAA16): These bits store the upper bit values (bits 31 to 16) of the address of the channel A break condition. BARAL Bits 15 to 0—Break Address A 15 to 0 (BAA15 to BAA0): These bits store the lower bit values (bits 15 to 0) of the address of the channel A break condition. ## 6.2.2 Break Address Mask Register A (BAMRA) #### **BAMRAH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | BAMA31 | BAMA30 | BAMA29 | BAMA28 | BAMA27 | BAMA26 | BAMA25 | BAMA24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAMA23 | BAMA22 | BAMA21 | BAMA20 | BAMA19 | BAMA18 | BAMA17 | BAMA16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **BAMRAL:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|-------|-------| | Bit name: | BAMA15 | BAMA14 | BAMA13 | BAMA12 | BAMA11 | BAMA10 | BAMA9 | BAMA8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAMA7 | BAMA6 | BAMA5 | BAMA4 | BAMA3 | BAMA2 | BAMA1 | BAMA0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break address mask registers A (BAMRA)—break address mask register AH (BAMRAH) and break address mask register AL (BAMRAL)—together form a single group. Both are 16-bit read/write registers. BAMRAH determines which of the bits in the break address set in BARAH are masked. BAMRAL determines which of the bits in the break address set in BARAL are masked. A power-on reset initializes BAMRAH and BAMRAL to H'0000. Their values are undefined after a manual reset. BAMRAH Bits 15 to 0—Break Address Mask A 31 to 16 (BAMA31 to BAMA16): These bits specify whether bits 31–16 (BAA31 to BAA16) of the channel A break address set in BARAH are masked. BAMRAL Bits 15 to 0—Break Address Mask A 15 to 0 (BAMA15 to BAMA0): These bits specify whether bits 15–0 (BAA15 to BAA0) of the channel A break address set in BARAL are masked. | Bits 31-0: BAMAn | Description | |------------------|-------------------------------------------------------------------------------------------| | 0 | Channel A break address BAAn is included in the break conditions (Initial | | | value) | | 1 | Channel A break address BAAn is masked and therefore not included in the break conditions | n = 31 to 0 # 6.2.3 Break Bus Cycle Register A (BBRA) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|------|------|------|------|------|------|------| | Bit name: | _ | _ | _ | _ | | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | CPA1 | CPA0 | IDA1 | IDA0 | RWA1 | RWA0 | SZA1 | SZA0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The break bus cycle register A (BBRA) is a 16-bit read/write register that selects the following four channel A break conditions: - 1. CPU cycle/DMAC cycle - 2. Instruction fetch/data access - 3. Read/write - 4. Operand size A power-on reset initializes BBRA to H'0000. Its value is undefined after a manual reset. Bits 15 to 8—Reserved: These bits always read 0. The write value should always be 0. Bits 7 and 6—CPU Cycle/DMAC Cycle Select A (CPA1, CPA0): These bits select whether to break channel A on a CPU and/or DMAC bus cycle. When the DMAC cycle setting is made, on-chip DMAC cycles are always included in the break conditions. | Bit 7: CPA1 | Bit 6: CPA0 | Description | | |-------------|-------------|-------------------------------------------------|----------| | 0 | 0 | No channel A user break interrupt occurs value) | (Initial | | | 1 | Break only on CPU cycles | | | 1 | 0 | Break only on DMAC cycles | | | | 1 | Break on both CPU and DMAC cycles | | Bits 5 and 4—Instruction Fetch/Data Access Select A (IDA1, IDA0): These bits select whether to break channel A on instruction fetch and/or data access cycles. | Bit 5: IDA1 | Bit 4: IDA0 | Description | | | | | |-------------|-------------|----------------------------------------------------------|--|--|--|--| | 0 | 0 | No channel A user break interrupt occurs (Initial value) | | | | | | | 1 | Break only on instruction fetch cycles | | | | | | 1 | 0 | Break only on data access cycles | | | | | | | 1 | Break on both instruction fetch and data access cycles | | | | | Bits 3 and 2—Read/Write Select A (RWA1, RWA0): These bits select whether to break channel A on read and/or write cycles. | Bit 3: RWA1 | Bit 2: RWA0 | Description | | |-------------|-------------|-------------------------------------------------|----------| | 0 | 0 | No channel A user break interrupt occurs value) | (Initial | | | 1 | Break only on read cycles | | | 1 | 0 | Break only on write cycles | | | | 1 | Break on both read and write cycles | | Bits 1 and 0—Operand Size Select A (SZA1, SZA0): These bits select bus cycle operand size as a channel A break condition. | Bit 1: SZA1 | Bit 0: SZA0 | Description | | |-------------|-------------|----------------------------------------------|----------| | 0 | 0 | Operand size is not a break condition value) | (Initial | | | 1 | Break on byte access | | | 1 | 0 | Break on word access | | | | 1 | Break on longword access | | Note: When breaking on an instruction fetch, set the SZA0 bit to 0. All instructions are considered to be word-size accesses (instruction fetches are always longword). Operand size is word for instructions or determined by the operand size specified for the CPU/DMAC data access. It is not determined by the bus width of the space being accessed. ## 6.2.4 Break Address Register B (BARB) ## **BARBH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | BAB31 | BAB30 | BAB29 | BAB28 | BAB27 | BAB26 | BAB25 | BAB24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAB23 | BAB22 | BAB21 | BAB20 | BAB19 | BAB18 | BAB17 | BAB16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **BARBL:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|------|------| | Bit name: | BAB15 | BAB14 | BAB13 | BAB12 | BAB11 | BAB10 | BAB9 | BAB8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAB7 | BAB6 | BAB5 | BAB4 | BAB3 | BAB2 | BAB1 | BAB0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break address registers B—break address register BH (BARBH) and break address register BL (BARBL)—together form a single group. Both are 16-bit read/write registers. BARBH stores the upper bits (bits 31 to 16) of the address of the channel B break condition, while BARBL stores the lower bits (bits 15 to 0). In addition, the address bus connected to X/Y memory can also be specified as a break condition by means of XYE bit/XYS bit settings in break bus cycle register B (BBRB). When XYE = 0, BAB31–BAB0 specify the address; when XYE = 1, the upper 16 bits of BARB (bits BAB31–BAB16) specify the X address bus, and the lower 16 bits (bits BAB15–BAB0) specify the Y address bus. A power-on reset initializes both BARBH and BARBL to H'0000. Their values are undefined after a manual reset. #### **BARB** configuration | | | Upper 16 bits<br>(BAB31–BAB16) | Lower 16 bits<br>(BAB15–BAB0) | |-------------------------------------|-----------------------------|--------------------------------|-------------------------------| | XYE = 0 | Address | Upper 16 bits of address bus | Lower 16 bits of address bus | | XYE = 1 X address<br>(when XYS = 0) | | X address (XAB15–XAB1)* | _ | | | Y address<br>(when XYS = 1) | _ | Y address (YAB15–YAB1)* | Note: As X/Y bus accesses are always word accesses, the values of XAB0 and YAB0 are not included in the break conditions. # 6.2.5 Break Address Mask Register B (BAMRB) #### **BAMRBH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | BAMB31 | BAMB30 | BAMB29 | BAMB28 | BAMB27 | BAMB26 | BAMB25 | BAMB24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAMB23 | BAMB22 | BAMB21 | BAMB20 | BAMB19 | BAMB18 | BAMB17 | BAMB16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **BAMRBL:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|-------|-------| | Bit name: | BAMB15 | BAMB14 | BAMB13 | BAMB12 | BAMB11 | BAMB10 | BAMB9 | BAMB8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BAMB7 | BAMB6 | BAMB5 | BAMB4 | BAMB3 | BAMB2 | BAMB1 | BAMB0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break address mask registers B (BAMR)—break address mask register BH (BAMRBH) and break address mask register BL (BAMRBL)—together form a single group. Both are 16-bit read/write registers. BAMRBH determines which of the bits in the break address set in BARBH are masked. BAMRBL determines which of the bits in the break address set in BARBL are masked. The function of these registers is affected by bits XYE and XYS in break bus cycle register B (BBRB) as shown below. # **BAMRB** configuration | | | Upper 16 bits<br>(BAMB31–BAMB16) | Lower 16 bits<br>(BAMB15–BAMB0) | |---------|-----------------------------|----------------------------------|---------------------------------| | XYE = 0 | Address | Upper 16 bits maskable | Lower 16 bits maskable | | XYE = 1 | X address<br>(when XYS = 0) | Maskable | _ | | | Y address<br>(when XYS = 1) | _ | Maskable | | Bits 31-0: BAMBn | Description | |------------------|-------------------------------------------------------------------------------------------| | 0 | Channel B break address BABn is included in the break conditions | | 1 | Channel B break address BABn is masked and therefore not included in the break conditions | n = 31 to 0 ## 6.2.6 Break Data Register B (BDRB) #### **BDRBH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | BDB31 | BDB30 | BDB29 | BDB28 | BDB27 | BDB26 | BDB25 | BDB24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BDB23 | BDB22 | BDB21 | BDB20 | BDB19 | BDB18 | BDB17 | BDB16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **BDRBL**: | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|------|------| | Bit name: | BDB15 | BDB14 | BDB13 | BDB12 | BDB11 | BDB10 | BDB9 | BDB8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BDB7 | BDB6 | BDB5 | BDB4 | BDB3 | BDB2 | BDB1 | BDB0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break data registers B (BDRB)—break data register BH (BDRBH) and break data register BL (BDRBL)—together form a single group. Both are 16-bit read/write registers. BDRBH specifies the upper half (bits 31–16) of the data that is the break condition for channel B, while BDRBL specifies the lower half (bits 15–0). In addition, the data bus connected to X/Y memory can also be specified as a break condition by means of XYE bit/XYS bit settings in break bus cycle register B (BBRB). When XYE = 1, the upper 16 bits of BDRB (bits BDB31–BDB16) specify the X data bus, and the lower 16 bits (bits BDB15–BDB0) specify the Y data bus. # **BDRB** configuration | | | Upper 16 bits<br>(BDB31–BDB16) | Lower 16 bits<br>(BDB15–BDB0) | |---------|--------------------------|--------------------------------|-------------------------------| | XYE = 0 | Data | Upper 16 bits of data bus | Lower 16 bits of data bus | | XYE = 1 | X data<br>(when XYS = 0) | X data (XDB15–XDB0) | _ | | | Y data<br>(when XYS = 1) | _ | Y data (YDB15-YDB0)* | # 6.2.7 Break Data Mask Register B (BDMRB) # **BDMRBH:** | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | BDMB31 | BDMB30 | BDMB29 | BDMB28 | BDMB27 | BDMB26 | BDMB25 | BDMB24 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BDMB23 | BDMB22 | BDMB21 | BDMB20 | BDMB19 | BDMB18 | BDMB17 | BDMB16 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W # BDMRBL: | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|-------|-------| | Bit name: | BDMB15 | BDMB14 | BDMB13 | BDMB12 | BDMB11 | BDMB10 | BDMB9 | BDMB8 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BDMB7 | BDMB6 | BDMB5 | BDMB4 | BDMB3 | BDMB2 | BDMB1 | BDMB0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The two break data mask registers B (BDMRB)—break data mask register BH (BDMRBH) and break data mask register BL (BDMRBL)—together form a single group. Both are 16-bit read/write registers. BDMRBH determines which of the bits in the break address set in BDRBH are masked. BDMRBL determines which of the bits in the break address set in BDRBL are masked. The function of these registers is affected by bits XYE and XYS in break bus cycle register B (BBRB) as shown below. A power-on reset initializes BDMRBH and BDMRBL to H'0000. Their values are undefined after a manual reset. ### **BDMRB** configuration | | | Upper 16 bits<br>(BDMB31–BDMB16) | Lower 16 bits<br>(BDMB15–BDMB0) | |---------|--------------------------|----------------------------------|---------------------------------| | XYE = 0 | Data | Upper 16 bits maskable | Lower 16 bits maskable | | XYE = 1 | X data<br>(when XYS = 0) | Maskable | _ | | | Y data<br>(when XYS = 1) | _ | Maskable | | Bits 31-0: BDMBn | Description | |------------------|----------------------------------------------------------------------------------------------| | 0 | Channel B break address bit BDBn is included in the break condition | | 1 | Channel B break address bit BDBn is masked and therefore not included in the break condition | n = 31 to 0 Notes: 1. When the data bus value is included in the break conditions, specify the operand size. 2. When byte-size is specified and odd-address data is used as a break condition, set the value in bits 7–0 of BDRB and BDMRB. When even-address data is used as a break condition, set the value in bits 15–8. Unused bits do not affect the break conditions. ## 6.2.8 Break Bus Cycle Register B (BBRB) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|------|------|------|------|------|------|------| | Bit name: | _ | _ | _ | _ | | _ | XYE | XYS | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | CPB1 | CPB0 | IDB1 | IDB0 | RWB1 | RWB0 | SZB1 | SZB0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Break bus cycle register B (BBRB) is a 16-bit read/write register that selects the following five channel B break conditions: - 1. Internal bus (C bus, I bus)/X memory/Y memory bus - 2. CPU cycle/DMAC cycle - 3. Instruction fetch/data access - 4. Read/write - 5. Operand size A power-on reset initializes BBRB to H'0000. Its value is undefined after a manual reset. Bits 15 to 10—Reserved: These bits always read 0. The write value should always be 0. Bit 9—X/Y Memory Bus Enable (XYE): Selects whether the X/Y bus is used for channel B break conditions. | Bit 9: XYE | Description | |------------|-------------------------------------------------------------------| | 0 | Cache bus or internal bus is condition for channel B address/data | | 1 | X/Y bus is condition for channel B address/data | Bit 8—X Bus/Y Bus Select (XYS): Selects whether the X bus or Y bus is used for channel B break conditions. This bit is only valid when the XYE bit is set to 1. | Bit 8: XYS | Description | |------------|---------------------------------------------| | 0 | X bus is used for channel B break condition | | 1 | Y bus is used for channel B break condition | Bits 7–0 have the same configuration as in BBRA. ## 6.2.9 Break Control Register (BRCR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|------|-----|------|------|---|---| | Bit name: | CMFCA | CMFPA | EBBE | UMD | PCTE | PCBA | | _ | | 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 | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | CMFCB | CMFPB | ETBE | SEQ | DBEB | PCBB | _ | _ | | 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 | ## The BRCR register: - 1. Determines whether to use channels A and B as two independent channels or as sequential conditions. - 2. Selects whether to break before or after instruction execution during the instruction fetch cycle. - 3. Selects whether to include the data bus in channel B comparison conditions. - 4. Selects whether the execution times break setting is executed. - 5. Selects whether a PC trace is executed. It also has a flag that is set when conditions match. A power-on reset initializes BRCR to H'0000. Its value is undefined after a manual reset. Bit 15—CPU Condition-Match Flag A (CMFCA): Set to 1 when CPU bus cycle conditions included in the break conditions set for channel A are met. Not cleared to 0. If the flag set is confirmed again after once it is set, clear it by write. | Bit 15: CMFCA | Description | |---------------|------------------------------------------------------------------------------------------------| | 0 | Channel A CPU cycle conditions do not match, no user break interrupt generated (Initial value) | | 1 | Channel A CPU cycle conditions have matched, user break interrupt generated | Bit 14—DMAC Condition-Match Flag A (CMFPA): Set to 1 when DMAC bus cycle conditions included in the break conditions set for channel A are met. Not cleared to 0. If the flag set is confirmed again after once it is set, clear it by write. | Bit 14: CMFPA | Description | | |---------------|--------------------------------------------------------------------------------|-----------------------| | 0 | Channel A DMAC cycle conditions do not match, no us interrupt generated value) | ser break<br>(Initial | | 1 | Channel A DMAC cycle conditions have matched, use generated | r break interrupt | Bit 13—External Bus Break Enable (EBBE): In the SH7064, this bit monitors the external bus master's address bus when the bus is released, and includes the external bus master's bus cycle in the bus cycle select conditions (CPA1, CPB1). However, this bit is not supported in the LSI. Bit 12—UBC Mode (UMD): In the SH7064, this bit selects SH7000 series-compatible mode or SH7064 mode as the operating mode. However, this bit is not supported in the LSI. Bit 11—PC Trace Enable (PCTE): Selects whether a PC trace is executed. | Bit 11: PCTE | Description | | |--------------|---------------------------------|----------| | 0 | PC trace is not executed value) | (Initial | | 1 | PC trace is executed | | Bit 10—PC Break Select A (PCBA): Selects whether to place the channel A break in the instruction fetch cycle before or after instruction execution. | Bit 10: PCBA | Description | | |--------------|-----------------------------------------------------------------------------------|---------------------| | 0 | Places the channel A instruction fetch cycle break before insexecution (Ir value) | struction<br>nitial | | 1 | Places the channel A instruction fetch cycle break after instruction | uction | Bits 9 and 8—Reserved: These bits always read 0. The write value should always be 0. Bit 7—CPU Condition-Match Flag B (CMFCB): Set to 1 when CPU bus cycle conditions included in the break conditions set for channel B are met. Not cleared to 0 (once set, it must be cleared by a write before it can be used again). | Bit 7: CMFCB | Description | |--------------|------------------------------------------------------------------------------------------------| | 0 | Channel B CPU cycle conditions do not match, no user break interrupt generated (Initial value) | | 1 | Channel B CPU cycle conditions have matched, user break interrupt generated | Bit 6—DMAC Condition-Match Flag B (CMFPB): Set to 1 when DMAC bus cycle conditions included in the break conditions set for channel B are met. Not cleared to 0 (once set, it must be cleared by a write before it can be used again). | Bit 6: CMFPB | Description | | |--------------|--------------------------------------------------------------------------|---------------------------| | 0 | Channel B DMAC cycle conditions do not match, interrupt generated value) | no user break<br>(Initial | | 1 | Channel B DMAC cycle conditions have matched, generated | user break interrupt | Bit 5—Execution Times Specification Break Enable (ETBE): Enables the execution times break conditions (channel B only). When this bit is set to 1, a user break interrupt is requested when the number of break condition occurrences equals the execution times setting in the execution times break register (BETR). | Bit 5: ETBE | Description | | |-------------|----------------------------------------------------------------------|---| | 0 | Channel B execution time break condition is disabled (Initial value) | _ | | 1 | Channel B execution time break condition is enabled | | Bit 4—Sequence Condition Select (SEQ): Selects whether to handle the channel A and B conditions independently or sequentially. | Bit 4: SEQ | Description | |------------|------------------------------------------------------------------------------| | 0 | Channel A and B conditions compared independently (Initial value) | | 1 | Channel A and B conditions compared sequentially (channel A, then channel B) | Bit 3—Data Break Enable B (DBEB): Selects whether to include data bus conditions in the channel B break conditions. | Bit 3: DBEB | Description | |-------------|--------------------------------------------------------------| | 0 | Data bus conditions not included in the channel B conditions | | | (Initial | | | value) | | 1 | Data bus conditions included in the channel B conditions | Bit 2—Instruction Break Select (PCBB): Selects whether to place the channel B instruction fetch cycle break before or after instruction execution. | Bit 2: PCBB | Description | | |-------------|----------------------------------------------------------------------------------------------|-------| | 0 | Places the channel B instruction fetch cycle break before instruction execution (Init value) | | | 1 | Places the channel B instruction fetch cycle break after instruction | ction | Bits 1 and 0—Reserved: These bits always read 0. The write value should always be 0. ## **6.2.10** Execution Times Break Register (BETR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | _ | | _ | _ | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The execution times break register (BETR) is a 16-bit register that specifies the number of occurrences of channel B break conditions before a user break interrupt is requested after channel B execution times break conditions are enabled (by setting bit ETBE in BRCR). The maximum value is $2^{12} - 1$ . A power-on reset initializes BETR to H'0000. BETR is decremented by 1 each time a channel B break condition is satisfied. After BETR reaches H'0001, an interrupt is requested when a break condition is satisfied. Exceptions and interrupts are not accepted for instructions in a repeat loop comprising up to three instructions (see section 4.6). Therefore, BETR is not decremented by a break condition match for an instruction in a repeat loop comprising up to three instructions. Bits 15 to 12 – Reserved bits: These bits always read 0, and the write value to these bits should always be 0. #### 6.2.11 Branch Source Register (BRSR) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | BSA31 | BSA30 | BSA29 | BSA28 | BSA27 | BSA26 | BSA25 | BSA24 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | Bit name: | BSA23 | BSA22 | BSA21 | BSA20 | BSA19 | BSA18 | BSA17 | BSA16 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Bit name: | BSA15 | BSA14 | BSA13 | BSA12 | BSA11 | BSA10 | BSA9 | BSA8 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BSA7 | BSA6 | BSA5 | BSA4 | BSA3 | BSA2 | BSA1 | BSA0 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | The branch source register (BRSR) comprises a set of four 32-bit read-only registers that store the last address fetched before the previous branch. These values are used to calculate the address of the last instruction executed before a branch when a PC trace is performed. BRSR has a FIFO (first-in-first-out) queue structure for PC trace use. The queue shifts on each branch. BRSR is not initialized by a reset. ## **6.2.12** Branch Destination Register (BRDR) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | BDA31 | BDA30 | BDA29 | BDA28 | BDA27 | BDA26 | BDA25 | BDA24 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | Bit name: | BDA23 | BDA22 | BDA21 | BDA20 | BDA19 | BDA18 | BDA17 | BDA16 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Bit name: | BDA15 | BDA14 | BDA13 | BDA12 | BDA11 | BDA10 | BDA9 | BDA8 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | BDA7 | BDA6 | BDA5 | BDA4 | BDA3 | BDA2 | BDA1 | BDA0 | | Initial value: | * | * | * | * | * | * | * | * | | R/W: | R | R | R | R | R | R | R | R | The branch destination register (BRDR) comprises a set of four 32-bit read-only registers that store branch destination fetch addresses to be used in a PC trace. BRDR has a FIFO (first-infirst-out) queue structure for PC trace use. The queue shifts on each branch. BRDR is not initialized by a reset. #### 6.2.13 Branch Flag Register (BRFR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|------|------|------|----|----|---|---| | Bit name: | SVF | PID2 | PID1 | PID0 | _ | | _ | _ | | Initial value: | 0 | * | * | * | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | DVF | _ | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | The branch flag register (BRFR) comprises a set of four 16-bit read-only registers that contain flags indicating whether the address is stored in BRSR and BRDR when a branch is made (branch instruction, repeat, interrupt, etc.), and bit pointers indicating the number of cycles from fetch until execution for the last instruction executed. BRFR has a FIFO (first-in-first-out) queue structure for PC trace use. The queue shifts on each branch. A reset initializes bits SVF and DVF but does not initialize bits PID2-PID0. Bit 15—BRSR Verification Flag (SVF): This flag indicates whether BRSR contains an address and pointer that enable the branch source address to be calculated. SVF is set when a branch destination address instruction is fetched, and reset when BRSR is read. | Bit 15: SVF | Description | |-------------|-----------------------| | 0 | BRSR value is invalid | | 1 | BRSR value is valid | Bits 14 to 12—PID2 to PID0: These bits are pointers that indicate the number of the instruction buffer for the instruction executed immediately before the instruction at which a branch occurred. Bits 14-12: PID2-PID0 Description | 0 | PID indicates instruction buffer number | |---|-------------------------------------------| | 1 | PID+2 indicates instruction buffer number | Bit 7—BRDR Verification Flag (DVF): This flag indicates whether BRDR contains the branch destination address. DVF is set when a branch destination address instruction is fetched, and reset when BRDR is read. | Bit 7: DVF | Description | |------------|-----------------------| | 0 | BRDR value is invalid | | 1 | BRDR value is valid | See the PC Trace section for the method of executing a PC trace using the branch source register (BRSR), branch destination register (BRDR), and branch flag register (BRFR). Bits 11 to 8 and 6 to 0—Reserved. These bits always read 0. The write value should always be 0. # 6.3 Operation #### **6.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 addresses are set in the break address registers (BARA, BARB), the masked addresses are set in the break address mask registers (BAMRA, BAMRB), the break data is set in the break data register (BDRB), and the masked data is set in the break data mask register (BDMRB). The breaking bus conditions are set in the break bus cycle registers (BBRA, BBRB). The three groups of the BBRA and BBRB registers—CPU cycle/DMAC cycle select, instruction fetch/data access select, and read/write select— are each set. No user break interrupt will be generated if even one of these groups is set with 00. The conditions are set in the respective bits of the BRCR register. - When the set conditions are satisfied, the UBC sends a user break interrupt request to the interrupt controller (INTC). When conditions match, the CPU condition match flags (CMFCA, CMFCB) and peripheral condition match flags (CMFPA, CMFPB) for the respective channels are set. - 3. The interrupt controller checks the user break interrupt's priority level. The user break interrupt has priority level 15, so it is accepted only if the interrupt mask level in bits I3–I0 in the status register (SR) is 14 or lower. When the I3–I0 bit level is 15, the user break interrupt cannot be accepted but it is held pending until user break interrupt exception handling can be carried out. Section 5, Interrupt Controller, describes the handling of priority levels in greater detail. - 4. When the priority is found to permit acceptance of the user break interrupt, the CPU starts user break interrupt exception handling. - 5. The appropriate condition match flag (CMFCA, CMFPA, CMFCB, CMFPB) can be used to check if the set conditions match or not. The flags are set by the matching of the conditions, but they are not reset. 0 must first be written to them before they can be used again. If an execution times break is specified for channel B, CMFCB or CMFPB is set when the number of executions matches the execution times setting in BETR. ### **6.3.2** Break on Instruction Fetch Cycle - 1. When CPU/instruction fetch/read/word is set in the break bus cycle registers (BBRA/BBRB), the break condition becomes the CPU's instruction fetch cycle. Whether it breaks before or after the execution of the instruction can then be selected for the appropriate channel with the PCBA/PCBB bit in the break control register (BRCR). - 2. An instruction set for a break before execution breaks when it is confirmed that the instruction has been fetched and will be executed. This means this feature cannot be used on 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 or an instruction following an interrupt-disabled instruction, such as LDC, the interrupt is generated prior to execution of the first instruction at which the interrupt is subsequently then accepted. - 3. When the condition stipulates after execution, the instruction set with the break condition is executed and then the interrupt is generated prior to the execution of the next instruction. As with pre-execution breaks, this cannot be used with overrun fetch instructions. When this kind of break is set for a delayed branch instruction or an interrupt-disabled instruction, such as LDC, the interrupt is generated at the first instruction at which the interrupt is subsequently accepted. - 4. When an instruction fetch cycle is set for channel B, break data register B (BDRB) is ignored. There is thus no need to set break data for an instruction fetch cycle break. - 5. When an instruction fetch cycle is set, set the address for the break as the first address at which that instruction is located. A break will not occur if any other address is set. A break will not occur if the address of the lower word of a 32-bit instruction is set. #### 6.3.3 Break on Data Access Cycle - The memory cycles in which CPU data access breaks occur are: memory cycles from instructions, and stacking and vector reads during exception handling. These breaks cannot be used for vector fetch cycles of external vector interrupts, or for synchronous DRAM access cycles. - 2. The relationship between the data access cycle address and the comparison condition for operand size are shown in table 6.2. This means that when address H'00001003 is set without specifying the size condition, for example, the bus cycle in which the break condition is satisfied is as follows (where other conditions are met): Longword access at address H'00001000 Word access at address H'00001002 Byte access at address H'00001003 Table 6.2 Data Access Cycle Addresses and Operand Size Comparison Conditions | Access Size | Address Compared | |-------------|----------------------------------------------------------------------| | Longword | Break address register bits 31–2 compared with address bus bits 31–2 | | Word | Break address register bits 31–1 compared with address bus bits 31–1 | | Byte | Break address register bits 31–0 compared with address bus bits 31–0 | 3. When the data value is included in the break conditions on channel B: When the data value is included in the break conditions, specify either longword, word, or byte as the operand size in the break bus cycle registers (BBRA, BBRB). When data values are included in break conditions, a break interrupt is generated when the address conditions and data conditions both match. To specify byte data for this case, set the same data in the two bytes at bits 15–8 and bits 7–0 of the break data register B (BDRB) and break data mask register B (BDMRB). When word or byte is set, bits 31–16 of BDRB and BDMRB are ignored. ## 6.3.4 Program Counter (PC) Values Saved - 1. Break on Instruction Fetch (Before Execution): The program counter (PC) value saved to the stack in user break interrupt exception handling is the address that matches the break condition. The user break interrupt is generated before the fetched instruction is executed. If a break condition is set on an instruction that follows an interrupt-disabled instruction, however, the break occurs before execution of the instruction at which the next interrupt is accepted, so the PC value saved is the address of the break. - 2. Break on Instruction Fetch (After Execution): The program counter (PC) value saved to the stack in user break interrupt exception handling is the address executed after the one that matches the break condition. The fetched instruction is executed and the user break interrupt generated before the next instruction is executed. If a break condition is set on an interrupt-disabled instruction, the break occurs before execution of the instruction at which the next interrupt is accepted, so the PC value saved is the address of the break. - 3. Break on Data Access (CPU/DMAC): The program counter (PC) value is the start address of the next instruction after the last instruction executed before the user break exception handling started. When data access (CPU/DMAC) is set as a break condition, the place where the break will occur cannot be specified exactly. The break will occur at an instruction fetched close to where the data access that is to receive the break occurs. #### 6.3.5 X Memory or Y Memory Bus Cycle Breaks Break conditions for X bus cycles or Y bus cycles can be specified only for channel B. When XYE is set to 1 in BBRB, break addresses and break data on the X memory or Y memory bus can be specified. Either the X memory bus or the Y memory bus must be selected by means of the XYS setting in BBRB. It is not possible to include both X memory and Y memory in the break conditions at the same time. The break conditions are applied to X memory bus cycles or Y memory bus cycles by setting CPU bus master, data access cycle, read or write access, and word operand size or no operand size specification in break bus cycle register B (BBRB). When an X memory address is selected as a break condition, specify the X memory address in the upper 16 bits of BARB and BAMRB; when a Y memory address is selected, specify the Y memory address in the lower 16 bits of BARB and BAMRB. X memory data or Y memory data specification for BDRB and BDMRB is carried out in a similar way. #### 6.3.6 Sequential Breaks When the SEQ bit is set to 1 in BRCR, a sequential break occurs when a channel B break condition is satisfied after a channel A break condition has been satisfied. A user break will not be executed if a channel B break condition is satisfied before a channel A break condition, and a sequential break will not be executed if channel A and channel B break conditions occur simultaneously. However, if the bus cycle conditions for channel A are specified as break before instruction execution (PCBA = 0 in BRCR) and instruction fetch cycles (by BBRA), when channel A and channel B bus cycle conditions are satisfied simultanuously, a break is generated and the condition match flag is set to 1 in BRCR. In a sequential break specification, the X bus or Y bus can be selected, and an execution times break condition can also be specified. For example, when an execution times break condition is specified, the break condition is satisfied when the channel B break condition is met when BETR = H'0001 after the channel A break condition is met. Since the BETR value is decremented only by a channel B condition, a user break interrupt is issued after the occurrence of the channel B condition in the last circuit following the occurrence of the channel A condition. #### **6.3.7 PC** Trace - 1. A PC trace is started by setting the PC trace enable bit (PCTE) to 1 in BRCR. When a branch (branch instruction, repeat, interrupt) occurs, an address that enables the branch source address to be calculated and the branch destination address are stored in the branch source register (BRSR) and branch destination register (BRDR). The branch destination instruction fetch address is stored in BRDR, while the last instruction fetch address before the branch is stored in BRSR. The branch flag register (BRFR) holds a pointer that indicates the relationship to the instruction executed immediately before the branch. - 2. The address of the instruction executed immediately before the branch can be calculated from the address stored in BRSR and the pointer stored in BRFR. If the address stored in BRSR is BSA, the pointer stored in BRFR is PID, and the address prior to the branch is IA, then $IA = BSA 2 \times PID$ . With this equation, caution is required in the case where an interrupt (branch) is executed before the branch destination instruction is executed. In the example in figure 6.2, the address of instruction "Exec" executed immediately before the branch is calculated using the equation $IA = BSA - 2 \times PID$ . However, if branch "branch" is the branch instruction which has a delay slot and branch destination is address 4n + 2, branch destination address "Dest" specified by the branch instruction is stored in BRSR as it is. Therefore, the equation $IA = BSA - 2 \times PID$ does not apply in this case, and this PID is invalid. In this case only, BSA is at the 4n + 2 boundary, classified as shown in table 6.3. Figure 6.2 Table 6.3 BSA Value Stored by Exception Processing before Branch instruction | Branch | (Dest) | BSA | Address calculated with BRSR and BRFR | |----------|--------------|--------|---------------------------------------| | Delay | 4n | 4n | Exec = $IA = BSA - 2 \times PID$ | | | 4n + 2 | 4n + 2 | Dest = BSA | | No delay | 4n or 4n + 2 | 4n | Exec = $IA = BSA - 2 \times PID$ | - 3. The location indicated by IA, the address prior to the branch, depends on the type of branch. - a. Branch instruction: Branch instruction address - b. Repeat loop: Second-before-last instruction of the repeat loop c. Interrupt: Instruction executed immediately before the interrupt The start address of the interrupt routine is stored in BRDR. In a repeat loop consisting of no more than three instructions, an instruction fetch cycle is not generated. A PC trace is invalid, since the branch destination address is unknown. 4. BRSR, BRDR, and BRFR have a four-queue structure. When reading addresses stored in a PC trace, reads are performed from the head of the queue. BRFR, BRSR, and BRDR are read in that order. After BRDR is read, the queue shifts by one. BRSR and BRDR should be read by longword access. #### 6.3.8 Example of Use #### Break on a CPU Instruction Fetch Bus Cycle: A. Register settings: BARA = H'00000404, BAMRA = H'00000000, BBRA = H'0054 BARB = H'00008010, BAMRB = H'00000006, BBRB = H'0054 BDRB = H'000000000, BDMRB = H'000000000 BRCR = H'0400 Conditions set (channel A/channel B independent mode): Channel A: Address = H'00000404, address mask H'00000000 Bus cycle = CPU, instruction fetch (after execution), read (operand size not included in conditions) Channel B: Address = H'00008010, address mask H'00000006 Data H'00000000, data mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read (operand size not included in conditions) A user break will occur after the instruction at address H'00000404 is executed, or a user break will be generated before the execution of the instruction at address H'00008010–H'00008016. B. Register settings: BARA = H'00037226, BAMRA = H'00000000, BBRA = H'0056 BARB = H'0003722E, BAMRB = H'00000000, BBRB = H'0056 BDRB = H'000000000, BDMRB = H'000000000 BRCR = H'0010 Conditions set (channel A $\rightarrow$ channel B sequential mode): Channel A: Address = H'00037226, address mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read, word Channel B: Address = H'0003722E, address mask H'00000000 Data H'00000000, data mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read, word The instruction at address H'00037226 will be executed and then a user break interrupt will occur before the instruction at address H'0003722E is executed. ``` C. Register settings: BARA = H'00027128, BAMRA = H'00000000, BBRA = H'005A BARB = H'00031415, BAMRB = H'00000000, BBRB = H'0054 ``` BRCR = H'0000 Conditions set (channel A/channel B independent mode): Channel A: Address = H'00027128, address mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), write, word Channel B: Address = H'00031415, address mask H'00000000 Data H'00000000, data mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read (operand size not included in conditions) A user break interrupt is not generated for channel A since the instruction fetch is not a write cycle. A user break interrupt is not generated for channel B because the instruction fetch is for an odd address. D. Register settings: BARA = H'00037226, BAMRA = H'00000000, BBRA = H'005A BARB = H'0003722E, BAMRB = H'00000000, BBRB = H'0056 BDRB = H'000000000, BDMRB = H'000000000 BRCR = H'0010 Conditions set (channel A $\rightarrow$ channel B sequential mode): Channel A: Address = H'00037226, address mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), write, word Channel B: Address = H'0003722E, address mask H'00000000 Data H'00000000, data mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read, word The break for channel A is a write cycle, so conditions are not satisfied; since the sequence conditions are not met, no user break interrupt occurs. E. Register settings: BARA = H'00000500/BAMRA = H'00000000/BBRA = H'0057 BARB = H'00001000/BAMRB = H'00000000/BBRB = H'0057 BDRB = H'00000000/BDMRB = H'000000000 BRCR = H'0020/BETR = H'0005 Conditions set (channel A/channel B independent mode): Channel A: Address = H'00000500, address mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read, longword Channel B: Address = H'00001000, address mask H'00000000 Data H'00000000, data mask H'00000000 Bus cycle = CPU, instruction fetch (before execution), read, longword Execution times setting break enabled (5 times) The user break interrupt occurs before the instruction execution of the address H'00000500 address in the channel A. In the B channel, the user break address interrupt occurs before the fifth instruction execution after the instruction of the address H'00001000 address was executed 4 times. #### **Break on CPU Data Access Cycle:** ``` A. Register settings: BARA = H'00123456, BAMRA = H'00000000, BBRA = H'0064 BARB = H'000ABCDE, BAMRB = H'000000FF, BBRB = H'006A BDRB = H'0000A512, BDMRB = H'00000000 BRCR = H'0008 ``` Conditions set (channel A/channel B independent mode): Channel A: Address = H'00123456, address mask H'00000000 Bus cycle = CPU, data access, read (operand size not included in conditions) Channel B: Address = H'000ABCDE, address mask H'000000FF Data H'0000A512, data mask H'00000000 Bus cycle = CPU, data access, write, word For channel A, a user break interrupt occurs when it is read as longword at address H'00123454, as word at address H'00123456 or as byte at address H'00123456. For channel B, a user break interrupt occurs when H'A512 is written as word at H'000ABC00–H'000ABCFE. ``` B. Register settings: BARA = H'01000000/BAMRA = H'00000000/BBRA = H'0006 ``` BARB = H'0000F000/BAMRB = H'FFFF0000/BBRB = H'036A BDRB = H'00004567/BDMRB = H'000000000 BRCR = H'0008 Conditions set (channel A/channel B independent mode): Channel A: Address = H'01000000, address mask H'00000000 Bus cycle = CPU, data access, read, word Channel B: Y address = H'0001F000, address mask H'FFFF0000 Data H'00004567, data mask H'000000000 Bus cycle = CPU, data access, write, word For channel A, a user break interrupt occurs in a word read at address H'01000000. For channel B, a user break interrupt occurs when H'4567 is written as a word at address H'0001F000. X/Y memory space addresses differ according to the mode setting. See section 7, Bus State Controller (BSC), for details. ### **Break on DMAC Data Access Cycle:** Register settings: BARA = H'00314156, BAMRA = H'00000000, BBRA = H'0094 BARB = H'00055555, BAMRB = H'00000000, BBRB = H'00A9 BDRB = H'00007878, BDMRB = H'00000F0F BRCR = H'0008 Conditions set (channel A/channel B independent mode): Channel A: Address = H'00314156, address mask H'00000000 Bus cycle = DMA, instruction fetch, read (operand size not included in conditions) Channel B: Address = H'00055555, address mask H'00000000 Data H'00007878, data mask H'00000F0F Bus cycle = DMA, data access, write, byte For channel A, a user break interrupt does not occur, since no instruction fetch occurs in the DMAC cycle. For channel B, a user break interrupt occurs when the DMAC writes H'7\* (where \* means don't care) as byte at H'00055555. #### 6.3.9 Usage Notes - 1. UBC registers can only be read or written to by the CPU. - 2. Note the following regarding sequential break specifications. - a. When set for a sequential break, conditions match when a match of channel B conditions occurs some time after the bus cycle in which a channel A match occurs. This means that the conditions will not be satisfied when set for a bus cycle in which channel A and channel B occur simultaneously. - b. Since the CPU uses a pipeline structure, the order of the instruction fetch cycle and memory cycle is fixed, so sequential conditions will be satisfied when the respective channel conditions are met in the order the bus cycles occur. - c. The following must be noted when the channel A bus cycle conditions are specified as pre-execution break (PCBA = 0 in BRCR) and instruction fetch (by BBRA). When the bus cycle conditions for channel A and channel B match, a break will occur and the BRCR condition match flag will be set to 1. - 3. In change of register settings, the written value usually become valid after three cycles. For on-chip memory, instruction fetches get two instructions simultaneously. If a break condition is set on the fetch of the second of these two instructions but the contents of the UBC registers are changed so as to alter the break condition immediately after the first of the two instructions is fetched, a user break interrupt will still occur before the second instruction. To ensure the timing of the change in the setting, read the register written last as a dummy. The changed settings will be valid thereafter. - 4. When a user break interrupt is generated upon a match of the instruction fetch condition and the conditions match again in the UBC while the exception handling service routine is executing, the break will cause exception handling when the interrupt request mask value is set to 14 or lower. When masking addresses, when setting instruction fetch and after-execution as break conditions, and when executing in steps, the UBC's exception in handling service routine should not cause a match of addresses with the UBC. - 5. When an instruction during repeat execution, including a repeat instruction, is specified as a break condition, the following points must be noted. When an instruction in a repeat loop is specified as a break condition: - a. A break will not occur during execution of a repeat loop consisting of no more than three instructions. - b. When an execution times break is set, an instruction fetch from memory will not be performed during execution of a repeat loop consisting of no more than three instructions. Consequently, the value in the execution times register (BETR) will not be decremented. - 6. Do not execute a branch instruction immediately after reading a PC trace register (BRFR, BRSR, or BRDR). - When an execution times break is set and CPU and DMAC bus cycles are set as break conditions, BETR will only be decremented once if the CPU and DMAC conditions occur simultaneously. # Section 7 Bus State Controller (BSC) #### 7.1 Overview The bus state controller (BSC) manages the address spaces and outputs control signals so that optimum memory accesses can be made in the five spaces. This enables memories like DRAM, and SDRAM, and peripheral chips, to be linked directly. #### 7.1.1 Features The BSC has the following features: - Address space is divided into five spaces - A maximum linear 32 Mbytes for each of the address spaces CS0-CS3 - The type of memory connected can be specified for each space (DRAM, synchronous DRAM, burst ROM, etc.). - Bus width can be selected for each space (8, 16, or 32 bits). - Wait state insertion can be controlled for each space. - Outputs control signals for each space. - Cache - Cache areas and cache-through areas can be selected by access address. - When a cache access misses, 16 bytes are read consecutively in 4-byte units (because of cache fill). In writes, the write-through method/ write back method are selectable. - Cache-through accesses are accessed according to access size. - Refresh - Supports CAS-before-RAS refresh (auto-refresh) and self-refresh. - Refresh interval can be set using the refresh counter and clock selection. - Concentrated refresh are performed by setting the refresh number (1, 2, 4, 6, 8). - Direct interface to DRAM - Multiplexes row/column address output. - Burst transfer during reads, high-speed page mode for consecutive accesses. - Generates a TP cycle to ensure RAS precharge time. - EOD mode. - Direct interface to synchronous DRAM - Multiplexes row/column address output. - Burst read, single write mode or burst read, burst write mode are selectable. - Bank active mode - Refresh counter can be used as an interval timer - Interrupt request generated upon compare match (CMI interrupt request signal). ### 7.1.2 Block Diagram Figure 7.1 shows the BSC block diagram. Figure 7.1 BSC Block Diagram # 7.1.3 Pin Configuration Table 7.1 lists the bus state controller pin configuration. **Table 7.1 Pin Configuration** | Signal | I/O | With Bus<br>Released | Description | |----------------------------|-----|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A24-A0 | I/O | 1 | Address bus. 25 bits are available to specify a total 32 Mbytes of memory space. | | D31-D0 | I/O | Hi-Z | 32-bit data bus. When reading or writing a 16-bit width area, use D15–D0; when reading or writing a 8-bit width area, use D7–D0. With 8-bit accesses that read or write a 32-bit width area, input and output the data via the byte position determined by the lower address bits of the 32-bit bus. | | BS | I/O | I | Indicates start of bus cycle or monitor. With the normal space (device interfaces except for DRAM, synchronous DRAM), signal is asserted for a single clock cycle simultaneous with address output. The start of the bus cycle can be determined by this signal. | | <u>CS0</u> –<br><u>CS4</u> | 0 | Hi-Z | Chip select. When CS3 space is DRAM space, $\overline{\text{CS3}}$ does not assert. | | RD/WR,<br>WE | I/O | I | Read/write signal. Signal that indicates access cycle direction (read/write). Connected to WE pin when DRAM/synchronous DRAM is connected. | | RAS | 0 | Hi-Z | RAS pin for DRAM/synchronous DRAM. | | CAS, OE | 0 | Hi-Z | Open when using DRAM. | | | | | Connected to $\overline{OE}$ pin when using EDO RAM. | | | | | Connected to $\overline{\text{CAS}}$ pin when using synchronous DRAM. | | RD | 0 | Hi-Z | Read pulse signal (read data output enable signal). Normally, connected to the device's $\overline{OE}$ pin; when there is an external data buffer, the read cycle data can only be output when this signal is low. | | WAIT | I | Ignore | Hardware wait input. | | BRLS | I | I | Bus release request input: BRLS. | | BGR | 0 | 0 | Bus grant output: BGR. | **Table 7.1 Pin Configuration (cont)** | Signal | I/O | With Bus<br>Released | Description | |---------------|-----|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | CKE | 0 | 0 | Synchronous DRAM clock enable control. Signal for supporting synchronous DRAM self-refresh. | | ĪVECF | 0 | 0 | Interrupt vector fetch. | | DREQ0 | I | I | DMA request 0. | | DACK0 | 0 | 0 | DMA acknowledge 0. | | DREQ1 | ı | 1 | DMA request 1. | | DACK1 | 0 | 0 | DMA acknowledge 1. | | REFOUT | 0 | 0 | Refresh execution request output in bus-released mode. | | DQMUU,<br>WE3 | 0 | Hi-Z | When synchronous DRAM is used, connected to DQM pin for the most significant byte. For normal space, indicates writing to the most significant byte. | | DQMUL,<br>WE2 | 0 | Hi-Z | When synchronous DRAM is used, connected to DQM pin for the second byte. For normal space, indicates writing to the second byte. | | DQMLU,<br>WE1 | 0 | Hi-Z | When synchronous DRAM is used, connected to DQM pin for the third byte. For normal space, indicates writing to the third byte. | | DQMLL,<br>WE0 | 0 | Hi-Z | When synchronous DRAM is used, connected to DQM pin for the least significant byte. For normal space, indicates writing to the least significant byte. | | CAS3 | 0 | Hi-Z | When DRAM is used, connected to CAS pin for the most significant byte (D31–D24). | | CAS2 | 0 | Hi-Z | When DRAM is used, connected to $\overline{\text{CAS}}$ pin for the second byte (D23–D16). | | CAS1 | 0 | Hi-Z | When DRAM is used, connected to $\overline{CAS}$ pin for the third byte (D15–D8). | | CAS0 | 0 | Hi-Z | When DRAM is used, connected to $\overline{CAS}$ pin for the least significant byte (D7–D0). | Note: Hi-Z: High impedance # 7.1.4 Register Configuration The BSC has seven registers. These registers are used to control wait states, bus width, interfaces with memories like DRAM, synchronous DRAM, and burst ROM, and DRAM and synchronous DRAM refreshing. The register configurations are shown in table 7.2. The size of the registers themselves is 16 bits. If read as 32 bits, the upper 16 bits are 0. In order to prevent writing mistakes, 32-bit writes are accepted only when the value of the upper 16 bits of the write data is H'A55A; no other writes are performed. Initialize the reserved bits. **Initialization Procedure:** Do not access a space other than CS0 until the settings for the interface to memory are completed. **Table 7.2** Register Configuration | Name | Abbr. | R/W | Initial Value | Address*1 | Access Size | |---------------------------------------|-------|-----|---------------|------------|-----------------------| | Bus control register 1 | BCR1 | R/W | H'03F0 | H'FFFFFE0 | 16 <sup>*2</sup> , 32 | | Bus control register 2 | BCR2 | R/W | H'00FC | H'FFFFFE4 | 16 <sup>*2</sup> , 32 | | Bus control register 3 | BCR3 | R/W | H'1F00 | H'FFFFFFC | 16 <sup>*2</sup> , 32 | | Wait control register 1 | WCR1 | R/W | H'AAFF | H'FFFFFE8 | 16 <sup>*2</sup> , 32 | | Wait control register 2 | WCR2 | R/W | H'000A | H'FFFFFC0 | 16 <sup>*2</sup> , 32 | | Wait control register 3 | WCR3 | R/W | H'0000 | H'FFFFFC4 | 16 <sup>*2</sup> , 32 | | Individual memory control register | MCR | R/W | H'0000 | H'FFFFFEC | 16 <sup>*2</sup> , 32 | | Refresh timer control/status register | RTCSR | R/W | H'0000 | H'FFFFFF0 | 16 <sup>*2</sup> , 32 | | Refresh timer counter | RTCNT | R/W | H'0000 | H'FFFFFFF4 | 16 <sup>*2</sup> , 32 | | Refresh time constant register | RTCOR | R/W | H'0000 | H'FFFFFF8 | 16 <sup>*2</sup> , 32 | Notes: 1. This address is for 32-bit accesses; for 16-bit accesses add 2. 2. 16-bit access is for read only. # 7.1.5 Address Map The SH7612 address map, which has a memory space of 320 Mbytes, is divided into five spaces. The types and data width of devices that can be connected are specified for each space. The overall space address map is shown in table 7.3. Since the spaces of the cache area and the cache-through area are the same, the maximum memory space that can be connected is 160 Mbytes. This means that when address H'200000000 is accessed in a program, the data accessed is actually in H'00000000. There are several spaces for cache control. These include the associative purge space for cache purges, address array read/write space for reading and writing addresses (address tags), and data array read/write space for forced reads and writes of data arrays. The SH7612 has 16-kbyte RAM as on-chip memory. The on-chip RAM is divided into an X area and a Y area, which can be accessed in parallel with the DSP instruction. See the Programming Manual for more information. In a reset, the CPU reads the initial values of the program counter (PC) and the stack pointer (SP) from the reset vector area, and set. In a power-on reset, the PC address is H'00000000 and the SP address is H'00000004; in a manual reset, the PC address is H'00000008 and the SP address is H'00000008. Table 7.3 Address Map | Address | Space | Memory | Size | |-----------------------|-------------------------------|-------------------------------------------------|-----------| | H'00000000—H'01FFFFF | CS0 space, cache area | Ordinary space or burst ROM | 32 Mbytes | | H'02000000-H'03FFFFF | CS1 space, cache area | Ordinary space | 32 Mbytes | | H'04000000-H'05FFFFFF | CS2 space, cache area | Ordinary space or synchronous DRAM | 32 Mbytes | | H'06000000-H'07FFFFF | CS3 space, cache area | Ordinary space,<br>synchronous DRAM, or<br>DRAM | 32 Mbytes | | H'08000000-H'09FFFFF | CS4 space, cache area | Ordinary space (I/O device) | 32 Mbytes | | H'0A000000-H'0FFFFFF | Reserved | | | | H'10000000-H'1000DFFF | Reserved | | | | H'1000E000-H'1000FFFF | On-chip X RAM area | | 8 kbytes | | H'10010000-H'1001DFFF | Reserved | | | | H'1001E000-H'1001FFFF | On-chip Y RAM area | | 8 kbytes | | H'10020000-H'1FFFFFF | Reserved | | | | H'20000000-H'21FFFFF | CS0 space, cache-through area | Ordinary space or burst ROM | 32 Mbytes | | H'22000000-H'23FFFFF | CS1 space, cache-through area | Ordinary space | 32 Mbytes | | H'24000000-H'25FFFFF | CS2 space, cache-through area | Ordinary space or synchronous DRAM | 32 Mbytes | | H'26000000-H'27FFFFF | CS3 space, cache-through area | Ordinary space,<br>synchronous DRAM, or<br>DRAM | 32 Mbytes | | H'28000000-H'29FFFFF | CS4 space, cache-through area | Ordinary space (I/O device) | 32 Mbytes | 248 Table 7.3 Address Map (cont) | Address | Space | Memory | Size | |-----------------------|-----------------------------------|--------|------------| | H'2A000000-H'3FFFFFF | Reserved | | | | H'40000000-H'47FFFFF | Associative purge space | | 128 Mbytes | | H'48000000-H'5FFFFFF | Reserved | | | | H'60000000—H'7FFFFFF | Address array, read/write space | | 512 Mbytes | | H'80000000-H'BFFFFFF | Reserved | | | | H'C0000000-H'C0000FFF | Data array, read/write space | | 4 kbytes | | H'C0001000-H'DFFFFFF | Reserved | | | | H'E0000000-H'FFFF7FFF | Reserved | | | | H'FFFF8000-H'FFFFBFFF | For setting synchronous DRAM mode | | 16 kbytes | | H'FFFC000-H'FFFFBFFF | Reserved | | | | H'FFFFC00-H'FFFFFFF | On-chip peripheral modules | | | # 7.2 Description of Registers #### 7.2.1 Bus Control Register 1 (BCR1) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|--------------|--------------|-------|-------|-------| | Bit name: | _ | A4LW1 | A4LW0 | A2EN<br>DIAN | BST<br>ROM | _ | AHLW1 | AHLW0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | R/W: | R | R/W | R/W | R/W | R/W | R | R/W | R/W | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | A1LW1 | A1LW0 | A0LW1 | A0LW0 | A4EN<br>DIAN | DRAM2 | DRAM1 | DRAM0 | | Initial value: | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | R/W: | R/W Initialize ENDIAN, BSTROM, PSHR and DRAM2–DRAM0 bits after a power-on reset and do not write to them thereafter. To change other bits by writing to them, write the same value as they are initialized to. Do not access any space other than CS0 until the register initialization ends. Bit 15—Reserved bits: These bits always read 0, so the write value should always be 0. Bits 14 and 13—Long Wait Specification for CS4 Space (A4LW1, A4LW0): From 3 to 14 wait cycles are inserted in CS4 space accesses when the bits that specify the wait in the wait control register specify long wait (i.e., are set to 11). Bit 12—Endian Specification for CS2 Space (A2ENDIAN): In big-endian format, the MSB of byte data is the lowest byte address and byte data goes in order toward the LSB. For little-endian format, the LSB of byte data is the lowest byte address and byte data goes in order toward the MSB. When this bit is 1, the data is rearranged into little-endian format before transfer when the CS2 space is read or written to. It is used when handling data with little-endian processors or running programs written with little-endian format in mind. | Bit 12: A2ENDIAN | Description | | |------------------|---------------|-----------------| | 0 | Big-endian | (Initial value) | | 1 | Little-endian | | Bit 11—Area 0 Burst ROM Enable (BSTROM) | Bit 11: BSTROM | Description | | |----------------|---------------------------------|-----------------| | 0 | Area 0 is accessed normally | (Initial value) | | 1 | Area 0 is accessed as burst ROM | _ | Bit 10—Reserved: This bit always reads 0. The write value should always be 0. Bits 9 and 8—Long Wait Specification for CS2 and CS3 Space (AHLW1, AHLW0): When the normal space setting is made for CS2 and 3 paces, from 3 to 14 wait cycles are inserted in CS2 and 3 spaces accesses when the bits that specify the respective area waits in the wait control register (W21/W20 or W31/W30) specify long waits (i.e., are set to 11). Bits 7 and 6—Long Wait Specification for CS1 Space(A1LW1, A1LW0): When the normal space setting is made for CS1 space, from 3 to 14 wait cycles are inserted in area 1 accesses when the bits that specify the wait in the wait control register specify long wait (i.e., are set to 11). Bits 5 and 4—Long Wait Specification for CS0 Space (A0LW1, A0LW0): When the normal space setting is made for CS0 space, from 3 to 14 wait cycles are inserted in CS0 space accesses when the bits that specify the wait in the wait control register specify long wait (i.e., are set to 11). Bit 3—Endian Specification for CS4 Space (A4ENDIAN): In big-endian mode, the most significant byte (MSB) is the lowest byte address, and byte data is aligned in order toward the least significant byte (LSB). In little-endian mode, the LSB is the lowest byte address, and byte data is aligned in order toward the MSB. When this bit is set to 1, data in read/write accesses to the CS4 space is rearranged into little endian order before being transferred. This is used for data exchange with a little-endian processor or when executing a program written with awareness of little-endian mode. | Bit 3: A4ENDIAN | Description | | |-----------------|---------------|-----------------| | 0 | Big endian | (Initial value) | | 1 | Little endian | | Bits 2 to 0—Enable for DRAM and Other Memory (DRAM2-DRAM0) | DRAM2 | DRAM1 | DRAM0 | Description | | | | | | | |-------|-------|-------|------------------------------------------------------------------|--|--|--|--|--|--| | 0 | 0 0 | | CS2 and 3 spaces are ordinary spaces (Initial value) | | | | | | | | | | 1 | CS2 space is ordinary space; CS3 space is synchronous DRAM space | | | | | | | | | 1 | 0 | CS2 space is ordinary space; CS3 space is DRAM space | | | | | | | | | | 1 | Reserved (do not set) | | | | | | | | 1 | 0 | 0 | CS2 space is synchronous DRAM space, CS3 space is ordinary space | | | | | | | | | | 1 | CS2 and 3 spaces are synchronous DRAM spaces | | | | | | | | | 1 | 0 | Reserved (do not set) | | | | | | | | | | 1 | Reserved (do not set) | | | | | | | Table 7.4 Wait Values Corresponding to BCR1 and BCR3 Register Settings (All Spaces) | BCR3 | BCR1 | | | | |-------|-------|-------|--------------------|-----------------| | AnLW2 | AnLW1 | AnLW0 | Wait Value | | | 0 | 0 | 0 | 3 cycles inserted | | | | | 1 | 4 cycles inserted | | | | 1 | 0 | 5 cycles inserted | | | | | 1 | 6 cycles inserted | | | 1 | 0 | 0 | 8 cycles inserted | | | | | 1 | 10 cycles inserted | | | | 1 | 0 | 12 cycles inserted | | | | | 1 | 14 cycles inserted | (Initial value) | n: CS space number (0 to 4) AHLW2, AHLW1, and AHLW0 are common to CS2 and 3 spaces. #### 7.2.2 Bus Control Register 2 (BCR2) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|-------|-------|-------|-------|-------|-------| | Bit name: | _ | | | | | | A4SZ1 | A4SZ0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | A3SZ1 | A3SZ0 | A2SZ1 | A2SZ0 | A1SZ1 | A1SZ0 | _ | _ | | Initial value: | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R/W | R/W | R | R | Initialize BCR2 after a power-on reset and do not write to it thereafter. When writing to it, write the same values as those the bits are initialized to. Do not access any space other than CS0 until the register initialization ends. Bus size designation of CS0 space is set by terminal MD4, MD3. For description, refer to "3.3 Bus size of CS0 space". Bits 15 to 10—Reserved: These bits always read 0. The write value should always be 0. Bits 9 and 8—Bus Size Specification for CS4 Space (A4SZ1, A4SZ0) | Bit 8: A4SZ0 | Description | | |--------------|------------------------|-------------------------------------------------------------------| | 0 | Longword (32-bit) size | (Initial value) | | 1 | Byte (8-bit) size | | | 0 | Word (16-bit) size | | | 1 | Longword (32-bit) size | | | | Bit 8: A4SZ0 0 1 0 1 | 0 Longword (32-bit) size 1 Byte (8-bit) size 0 Word (16-bit) size | Bits 7 and 6—Bus Size Specification for CS3 Space (A3SZ1–A3SZ0). Effective only when ordinary space is set. | Bit 7: A3SZ1 | Bit 6: A3SZ0 | Description | | |--------------|--------------|------------------------|-----------------| | 0 | 0 | Reserved (do not set) | _ | | | 1 | Byte (8-bit) size | | | 1 | 0 | Word (16-bit) size | | | | 1 | Longword (32-bit) size | (Initial value) | Bits 5 and 4—Bus Size Specification for CS2 Space (A2SZ1–A2SZ0): Effective only when ordinary space is set. | Bit 5: A2SZ1 | Bit 4: A2SZ0 | Description | | |--------------|--------------|------------------------|-----------------| | 0 | 0 | Reserved (do not set) | | | | 1 | Byte (8-bit) size | | | 1 | 0 | Word (16-bit) size | _ | | | 1 | Longword (32-bit) size | (Initial value) | Bits 3 and 2—Bus Size Specification for CS1 Space (A1SZ1–A1SZ0) | Bit 3: A1SZ1 | Bit 2: A1SZ0 | Description | | |--------------|--------------|------------------------|-----------------| | 0 | 0 | Reserved (do not set) | | | | 1 | Byte (8-bit) size | | | 1 | 0 | Word (16-bit) size | | | | 1 | Longword (32-bit) size | (Initial value) | Bits 1 and 0—Reserved: These bits always read 0. The write value should always be 0. # 7.2.3 Bus Control Register 3 (BCR3) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|----|----|-------|-------|-------|-------| | Bit name: | _ | _ | _ | _ | A4LW2 | AHLW2 | A1LW2 | A0LW2 | | Initial value: | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | DSWW1 | DSWW0 | _ | _ | _ | BASEL | EDO | BWE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R | R | R | R/W | R/W | R/W | Initialize the BASEL, EDO, and BWE bits after a power-on reset and do not write to them thereafter. To change other bits by writing to them, write the same value as they are initialized to. Do not access any space other than CS0 until the register initialization ends. Bits 15 to 12—Reserved bits: These bits always read 0. The write value should always be 0. Bits 11 to 8—Long Wait Specification for CS4~0 Space (AnLW2): When the normal space setting is made for CSn space, from 3 to 14 wait cycles are inserted in area n accesses, according to the combination with the long wait specification bits (AnLW1 and AnLW0) in BCR1, when the bits that specify the wait in the wait control register specify long wait (i.e., are set to 11). For a basic description of long waits, see section 7.2.1, Bus Control Register 1 (BCR1). Bits 7 and 6—DMA Single-Write Wait (DSWW1, DSWW0): These bits determine the number of wait states inserted between DACK assertion and CASn assertion when writing to DRAM or EDO RAM in DMA single address mode. Bit 7: DSWW1 Bit 6: DSWW0 Description | 0 | 0 | 0 waits | (Initial value) | |---|---|-----------------------|-----------------| | | 1 | 1 wait | | | 1 | 0 | 2 waits | | | | 1 | Reserved (do not set) | | Bits 5 and 3—Reserved bits: These bits always read 0. The write value should always be 0. Bit 2—Number of Banks Specification when Using 64M Synchronous DRAM (BASEL) If 64M synchronous DRAM is designated by AMX2-0 of MCR, the bank number can be designated. Bit 2: BASEL Description | 0 | 4 banks | (Initial value) | |---|---------|-----------------| | 1 | 2 banks | | Bit 1—EDO Mode Specification (EDO): Enables EDO mode to be specified when DRAM is specified for CS3 space. | Bit 1: EDO | Description | |------------|-------------| |------------|-------------| | 0 | High-speed page mode | (Initial value) | |---|----------------------|-----------------| | 1 | EDO mode | _ | Bit 0—Synchronous DRAM Burst Write Specification (BWE): Enables burst write mode to be specified when synchronous DRAM is specified for CS2 or CS3 space. | Bit 0: BWE | Description | | |------------|-------------------|-----------------| | 0 | Single write mode | (Initial value) | | 1 | Burst write mode | | ### 7.2.4 Wait Control Register 1 (WCR1) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|------|------|------|------|------|------|------| | Bit name: | IW31 | IW30 | IW21 | IW20 | IW11 | IW10 | IW01 | IW00 | | Initial value: | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | W31 | W30 | W21 | W20 | W11 | W10 | W01 | W00 | | Initial value: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | R/W: | R/W Do not access a space other than CS0 until the settings for register initialization are completed. Bits 15 to 8—Idles between Cycles for CS3 to 0 space (IW31–IW00): These bits specify idle cycles inserted between consecutive accesses to different CS space. Idles are used to prevent data conflict between ROM or the like, which is slow to turn the read buffer off, and fast memories and I/O interfaces. Even when access is to the same CS space, idle cycles must be inserted when a read access is followed immediately by a write access. The idle cycles to be inserted comply with the specification for the previously accessed CS space. | IW31, IW21, IW11, IW01 | IW30, IW20, IW10, IW00 | Description | |------------------------|------------------------|------------------------------------------| | 0 | 0 | No idle cycle | | | 1 | One idle cycle inserted | | 1 | 0 | Two idle cycles inserted (Initial value) | | . <u> </u> | 1 | Four idle cycles inserted | Bits 7 to 0—Wait Control for CS3 to 0 Space (W31–W00): If CSn space is normal space setting, the wait number of CSn space can be set by Wn1, Wn0. | W31, W21, W11, W01 | W30, W20, W10, W00 | Description | |--------------------|-----------------------------------------------------------------------------------------------------|--------------------------------------------| | 0 0 | | No wait external wait input bypass | | | 1 | External wait input enabled with one wait | | 1 | 0 | External wait input enabled with two waits | | | Complies with the long wait spectous control register 1, 3 (BCR1, External wait input is enabled (I | | When CS3 space is DRAM, the number of CAS assert cycles is specified by wait control bits W31 and W30 | Bit 7: W31 | Bit 6: W30 | Description | |------------|------------|-----------------------| | 0 | 0 | 1 cycle | | | 1 | 2 cycles | | 1 | 0 | 3 cycles | | | 1 | Reserved (do not set) | If CAS assert cycle number is two cycles or more setting while the external wait mask bit A3WM of WCR2 is 0, the external wait input becomes enable. When CS2 or 3 space is synchronous DRAM, CAS latency is specified by wait control bits W31 and W30, and W21 and W20, respectively | W31, W21 | W30, W20 | Description | |----------|----------|-------------| | 0 | 0 | 1 cycle | | | 1 | 2 cycles | | 1 | 0 | 3 cycles | | | 1 | 4 cycles | With synchronous DRAM, external wait input is ignored regardless of any setting. ### 7.2.5 Wait Control Register 2 (WCR2) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|----|------|------|------|------|------| | Bit name: | A4WD1 | A4WD0 | _ | A4WM | A3WM | A2WM | A1WM | A0WM | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | | IW41 | IW40 | W41 | W40 | | Initial value: | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | | R/W: | R | R | R | R | R/W | R/W | R/W | R/W | Bits 15 and 14—Number of External Waits Specification for CS4 Space (A4WD1, A4WD0): These bits specify the number of cycles between acceptance of CS4 space external wait negation and $\overline{\text{RD}}$ or $\overline{\text{WEn}}$ negation. | Bit 15: A4WD1 | Bit 14: A4WD0 | Description | | |---------------|---------------|-----------------------|-----------------| | 0 | 0 | 1 cycle | (Initial value) | | | 1 | 2 cycles | | | 1 | 0 | 4 cycles | | | | 1 | Reserved (do not set) | | Bit 13—Reserved bit. This bit always reads 0. The write value should always be 0. Bits 12 to 8—External Wait Mask Specification for CS4 to 0 Space (A4WM–A0WM): These bits enable waits to be masked for CS4 to 0 space. When a value other than 00 is set in the wait control bits for CS4 to 0 space (W41–W00), external wait input can be enabled, but wait input can be masked by setting these bits to 1. With synchronous DRAM, external wait input is ignored regardless of the settings. | A4WM<br>A3WM<br>A2WM<br>A1WM<br>A0WM | W41<br>W31<br>W21<br>W11<br>W01 | W40<br>W30<br>W20<br>W10<br>W00 | External wait input | | |--------------------------------------|---------------------------------|---------------------------------|------------------------------|-----------------| | 0 | 0 | 0 | External wait input bypass | | | | | 1 | External wait input enable | | | | 1 | 0 | EnExternal wait input enable | | | | | 1 | External wait input enable | (Initial value) | | 1 | No effect | No effect | External wait input bypass | | Bits 7 to 4—Reserved bits: These bits always read 0. The write value should always be 0. Bits 3 and 2—Idles between Cycles for CS4 Space (IW41, IW40): These bits specify idle cycles inserted between cycles in CS4 space in the same way as for CS3 to 0 space. | Bit 3: IW41 | Bit 2: IW40 | Description | | |-------------|-------------|---------------------------|-----------------| | 0 | 0 | No idle cycle | | | | 1 | One idle cycle inserted | | | 1 | 0 | Two idle cycles inserted | (Initial value) | | | 1 | Four idle cycles inserted | | Bits 1 and 0—Wait Control for CS4 Space (W41, W40): These bits waits for CS4 space in the same way as for CS3 to 0 space. | Bit 1: W41 | Bit 0: W40 | Description | | | |------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | 0 | External wait input bypass with no wait | | | | | 1 | External wait input enabled with one wait | | | | 1 0 | | External wait input enabled with two waits | | | | | 1 | Complies with the long wait specification of bus control registers 1 and 3 (BCR1, BCR3). External wait input is enabled (Initial value) | | | ### 7.2.6 Wait Control Register 3 (WCR3) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|--------|--------|--------|--------|--------|--------| | Bit name: | _ | | A4SW2 | A4SW1 | A4SW0 | _ | A4HW1 | A4HW0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R/W | R/W | R | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | A3SHW1 | A3SHW0 | A2SHW1 | A2SHW0 | A1SHW1 | A1SHW0 | A0SHW1 | A0SHW0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 and 14—Reserved bits: These bits always read 0. The write value should always be 0. Bits 13 to 11—CS4 Space Address/ $\overline{CS4}$ to $\overline{RD}/\overline{WEn}$ Assert (A4SW2–A4SW0): These bits specify the number of cycles from address/ $\overline{CS4}$ output to $\overline{RD}/\overline{WEn}$ assertion. | Bit 13: A4SW2 | Bit 12: A4SW1 | Bit 11: A4SW0 | Description | | |---------------|---------------|---------------|---------------------------|-----| | 0 | 0 | 0 | 0.5 cycles (Initial value | ue) | | | | 1 | 1.5 cycle | | | | 1 | 0 | 3.5 cycles | | | | | 1 | 5.5 cycles | | | 1 | 0 | 0 | 7.5 cycles | | | | | 1 | Reserved (do not set) | | | | 1 | 0 | Reserved (do not set) | | | | | 1 | Reserved (do not set) | | Bit 10—Reserved bit: This bit always reads 0. The write value should always be 0. Bits 9 and 8—CS4 Space $\overline{RD}/\overline{WEn}$ Negate to Address/ $\overline{CS4}$ Hold (A4HW1, A4HW0): These bits specify the number of cycles from $\overline{RD}/\overline{WEn}$ negation to address/ $\overline{CS4}$ hold. | Bit 9: A4HW1 | Bit 8: A4HW0 | Description | | |--------------|--------------|---------------------------------|-----------------| | 0 | 0 | 0.5 cycles, CS4 hold cycle is 0 | (Initial value) | | | 1 | 1.5 cycles, CS4 hold cycle is 1 | | | 1 | 0 | 3.5 cycles, CS4 hold cycle is 3 | | | | 1 | 5.5 cycles, CS4 hold cycle is 5 | | Bits 7 to 0—CS3 to 0 Space $\overline{CSn}$ Assert Period Extention: These bits specify the number of cycles from address/ $\overline{CSn}$ output to $\overline{RD}/\overline{WEn}$ assertion and from $\overline{RD}/\overline{WEn}$ negation to address/ $\overline{CSn}$ hold for CS3 to 0 space. | A3SHW1<br>A2SHW1<br>A1SHW1<br>A0SHW1 | A3SHW0<br>A2SHW0<br>A1SHW0<br>A0SHW0 | Description | | |--------------------------------------|--------------------------------------|---------------------------------|-----------------| | 0 | 0 | 0.5 cycles, CSn hold cycle is 0 | (Initial value) | | | 1 | 1.5 cycles, CSn hold cycle is 1 | | | 1 | 0 | 2.5 cycles, Csn hold cycle is 2 | | | | 1 | Reserved (do not set) | | ### 7.2.7 Individual Memory Control Register (MCR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|------|-------|-------|-------|-----|------|-------| | Bit name: | TRP0 | RCD0 | TRWL0 | TRAS1 | TRAS0 | BE | RASD | TRWL1 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | AMX2 | SZ | AMX1 | AMX0 | RFSH | RMD | TRP1 | RCD1 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The TRP1 to 0, RCD1 to 0, TRWL1 to 0, TRAS1 to TRAS0, BE, RASD, AMX2 to AMX0 and SZ bits are initialized after a power-on reset. Do not write to them thereafter. When writing to them, write the same values as they are initialized to. Do not access any space other than CS2 and CS3 until the register initialization ends. Bits 1 and 15—RAS Precharge Time (TRP1, TRP0): When DRAM is connected, specifies the minimum number of cycles after $\overline{RAS}$ is negated before the next assert. When synchronous DRAM is connected, specifies the minimum number of cycles after precharge until a bank active command is output. See section 7.5, Synchronous DRAM Interface, for details. | Bit 1: TRP1 | Bit 15: TRP0 | Description | | |-------------|--------------|-------------|-----------------| | 0 | 0 | 1 cycle | (Initial value) | | | 1 | 2 cycles | | | 1 | 0 | 3 cycles | | | | 1 | 4 cycles | | Bits 0 and 14—RAS-CAS Delay (RCD1, RCD0): When DRAM is connected, specifies the number of cycles after $\overline{RAS}$ is asserted before $\overline{CAS}$ is asserted. When pseudo-SRAM is connected, specifies the number of cycles after $\overline{CE}$ is asserted before $\overline{BS}$ is asserted. When synchronous DRAM is connected, specifies the number of cycles after a bank active (ACTV) command is issued until a read or write command (READ, READA, WRIT, WRITA) is issued. | Bit 0: RCD1 | Bit 14: RCD0 | Description | | |-------------|--------------|-----------------------|-----------------| | 0 | 0 | 1 cycle | (Initial value) | | | 1 | 2 cycles | | | 1 | 0 | 3 cycles | | | | 1 | Reserved (do not set) | | Bits 8 and 13—Write-Precharge Delay (TRWL1, TRWL0): When the synchronous DRAM is not in the bank active mode, this bit specifies the number of cycles between the write cycle and the start-up of the auto-precharge. The timing from this point to the point at which the next command can be issued is calculated within the bus state controller. In bank active mode, this bit specifies cycle number up to precharge command issue after the write command (WRIT) is issued. This bit is ignored when memory other than synchronous DRAM is connected. | Bit 8: TRWL1 | Bit 13: TRWL0 | Description | | |--------------|---------------|-----------------------|-----------------| | 0 | 0 | 1 cycle | (Initial value) | | | 1 | 2 cycles | | | 1 | 0 | 3 cycles | | | | 1 | Reserved (do not set) | | Bits 12 and 11—CAS-Before-RAS Refresh RAS Assert Time (TRAS1-TRAS0): These bits specify the RAS assertion width when DRAM is connected. | Bit 12: TRAS1 | Bit 11: TRAS0 | Description | | |---------------|---------------|-------------|-----------------| | 0 | 0 | 2 cycles | (Initial value) | | | 1 | 3 cycles | | | 1 | 0 | 4 cycles | | | | 1 | 5 cycles | | After an auto-refresh command is issued, a bank active command is not issued for TRAS cycles, regardless of the TRP bit setting. For synchronous DRAM, there is no $\overline{RAS}$ assertion period, but there is a limit for the time from the issue of a refresh command until the next access. This value is set to observe this limit. Commands are not issued for TRAS cycles when self-refresh is cleared. | Bit 12: TRAS1 | Bit 11: TRAS0 | Description | | |---------------|---------------|-------------|-----------------| | 0 | 0 | 3 cycles | (Initial value) | | | 1 | 4 cycles | | | 1 | 0 | 6 cycles | | | | 1 | 9 cycles | | Bit 10—Burst Enable (BE) | Bit 10: BE | Description | | | | | |------------|-------------------------------------------------------------------------------------------------------------|-----------------|--|--|--| | 0 | Burst disabled (I | (Initial value) | | | | | 1 | High-speed page mode during DRAM interfacing is enabled. | | | | | | | Burst access conditions are as follows: | | | | | | | <ul> <li>Longword access, cache fill access, or DMAC 16-byte transfer, with 16-bit<br/>bus width</li> </ul> | | | | | | | <ul> <li>Cache fill access or DMAC 16-byte transfer, with 32-bit bus wi</li> </ul> | dth | | | | | | During synchronous DRAM access, burst operation is always ena regardless of this bit. | bled | | | | Bit 9—Bank Active Mode (RASD) | Bit 9: RASD | Description For DRAM, RAS is negated after access ends (normal operation). | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | | | | | | | For synchronous DRAM, a read or write is performed using auto-precharge mode. The next access always starts with a bank active command. | | | | | 1 | For DRAM, after access ends RAS down mode is entered in which RAS is left asserted. When using this mode with an external device connected which performs writes other than to DRAM, see section 7.6.5, Burst Access. | | | | | | For synchronous DRAM, access ends in the bank active state. This is only valid for CS3 space. When CS2 space is synchronous DRAM, the mode is always auto-precharge. | | | | Bits 7, 5, and 4—Address Multiplex (AMX2–AMX0) For DRAM interface | Bit 7: AMX2 | Bit 5: AMX1 | Bit 4: AMX0 | Description | |-------------|-------------|-------------|----------------------------| | 0 | 0 | 0 | 8-bit column address DRAM | | | | 1 | 9-bit column address DRAM | | | 1 | 0 | 10-bit column address DRAM | | | | 1 | 11-bit column address DRAM | | 1 | 0 | 0 | Reserved (do not set) | | | | 1 | Reserved (do not set) | | | 1 | 0 | Reserved (do not set) | | | | 1 | Reserved (do not set) | For synchronous DRAM interface | Bit 7: AMX2 | Bit 5: AMX1 | Bit 4: AMX0 | Description | |-------------|-------------|-------------|------------------------------| | 0 | 0 | 0 | 16-Mbit DRAM (1M × 16 bits) | | | | 1 | 16-Mbit DRAM (2M × 8 bits)* | | | 1 | 0 | 16-Mbit DRAM (4M × 4 bits)* | | | | 1 | 4-Mbit DRAM (256k × 16 bits) | | 1 | 0 | 0 | 64-Mbit DRAM (4M × 16 bits) | | | | 1 | 64-Mbit DRAM (8M × 8 bits)* | | | 1 | 0 | Reserved (do not set) | | | | 1 | 2-Mbit DRAM (128k × 16 bits) | Note: Reserved when SZ bit in MCR is 0 (16-bit bus width), and the value must not be set. Bit 6—Memory Data Size (SZ): For synchronous DRAM and DRAM, the data bus width of BCR2 is ignored in favor of the specification of this bit. | Bit 6: SZ | Description | | | |-----------|-------------------------|-----------------|--| | 0 | Word (16 bits) size | (Initial value) | | | 1 | Longword (32 bits) size | | | Bit 3—Refresh Control (RFSH): This bit determines whether or not the refresh operation of DRAM/synchronous DRAM is performed. This bit is not valid in the slave mode and is always handled as 0. | Bit 3: RFSH | Description | | |-------------|-------------|----------------| | 0 | No refresh | (Initial value | | 1 | Refresh | | Bit 2—Refresh Mode (RMODE): When the RFSH bit is 1, this bit selects normal refresh or self-refresh. When the RFSH bit is 0, do not set this bit to 1. When the RFSH bit is 1, self-refresh mode is entered immediately after the RMD bit is set to 1. When the RFSH bit is 1 and this bit is 0, a CAS-before-RAS refresh or auto-refresh is performed at the interval set in the 8-bit interval timer. When a refresh request occurs during an external area access, the refresh is performed after the access cycle is completed. When set for self-refresh, self-refresh mode is entered immediately unless the SH7612 is in the middle of an synchronous DRAM area access. If it is, self-refresh mode is entered when the access ends. Refresh requests from the interval timer are ignored during self-refresh. | Bit 2: RMODE | Description | | |--------------|----------------|-----------------| | 0 | Normal refresh | (Initial value) | | 1 | Self-refresh | | | | | | # 7.2.8 Refresh Timer Control/Status Register (RTCSR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|------|------|------|------|------|------|------| | Bit name: | | _ | _ | _ | _ | | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | CMF | CMIE | CKS2 | CKS1 | CKS0 | RRC2 | RRC1 | RRC0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 to 8—Reserved: These bits always read 0. The write value should always be 0. Bit 7—Compare Match Flag (CMF): This status flag, which indicates that the values of RTCNT and RTCOR match, is set/cleared under the following conditions: | Bit 7: CMF | Description | |------------|-----------------------------------------------------------------------------------------------| | 0 | RTCNT and RTCOR match Clear condition: After RTCSR is read when CMF is 1, 0 is written in CMF | | 1 | RTCNT and RTCOR do not match Set condition: RTCNT = RTCOR | Bit 6—Compare Match Interrupt Enable (CMIE): Enables or disables an interrupt request caused by the CMF bit of RTSCR when CMF is set to 1. | Bit 6: CMIE | Description | | |-------------|---------------------------------------------|-----------------| | 0 | Interrupt request caused by CMF is disabled | (Initial value) | | 1 | Interrupt request caused by CMF is enabled | | Bits 5 to 3—Clock Select Bits (CKS2–CKS0) | Bit 5: CKS2 | Bit 4: CKS1 | Bit 3: CKS0 | Description | | |-------------|-------------|-------------|----------------------|-----------------| | 0 | 0 | 0 | Count-up disabled | (Initial value) | | | | 1 | Рф/4 | | | | 1 | 0 | Рф/16 | | | | | 1 | Рф/64 | | | 1 | 0 | 0 | P <sub>0</sub> /256 | | | | | 1 | Рф/1024 | | | | 1 | 0 | P <sub>0</sub> /2048 | | | | | 1 | Рф/4096 | | Bits 2 to 0—Refresh Count (RRC2, RRC1, RRC0): These bits specify the number of consecutive refreshes to be performed when the refresh timer counter (RTCNT and refresh time constant register (RTCOR) values match and a refresh request is issued. | Bit 2: RRC2 | Bit 1: RRC1 | Bit 0: RRC0 | Description | | |-------------|-------------|-------------|-----------------------|-----------------| | 0 | 0 | 0 | 1 refresh | (Initial value) | | | | 1 | 2 refreshes | | | | 1 | 0 | 4 refreshes | | | | | 1 | 6 refreshes | | | 1 | 0 | 0 | 8 refreshes | | | | | 1 | Reserved (do not set) | | | | 1 | 0 | Reserved (do not set) | | | | | 1 | Reserved (do not set) | | ### **7.2.9** Refresh Timer Counter (RTCNT) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | _ | _ | _ | | _ | | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The 8-bit counter RTCNT counts up with input clocks. The clock select bit of RTCSR selects an input clock. RTCNT values can always be read/written by the CPU. When RTCNT matches RTCOR, RTCNT is cleared. Returns to 0 after it counts up to 255. Bits 15 to 8—Reserved: These bits always read 0. The write value should always be 0. #### 7.2.10 Refresh Time Constant Register (RTCOR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | _ | _ | _ | _ | _ | _ | - | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W RTCOR is an 8-bit read/write register. The values of RTCOR and RTCNT are constantly compared. When the values correspond, the compare match flag (CMF) in RTCSR is set and RTCNT is cleared to 0. When the refresh bit (RFSH) in the individual memory control register is set to 1, a refresh request occurs. The refresh request is held until refresh operation is performed. If the refresh request is not processed before the next match, the previous request becomes ineffective. When the CMIE bit in RTSCR is set to 1, an interrupt request is sent to the controller by this match signal. The interrupt request is output continuously until the CMF bit in RTSCR is cleared. When the CMF bit clears, it only affects the interrupt; the refresh request is not cleared by this operation. When a refresh is performed and refresh requests are counted using interrupts, a refresh can be set simultaneously with the interval timer interrupt. Bits 15 to 8—Reserved: These bits always read 0. The write value should always be 0. # 7.3 Access Size and Data Alignment # 7.3.1 Connection to Ordinary Devices Byte, word, and longword are supported as access units. Data is aligned based on the data width of the device. Therefore, reading longword data from a byte-width device requires four read operations. The bus state controller automatically converts data alignment and data length between interfaces. An 8-bit, 16-bit, or 32-bit external device data width can be connected by using the mode pins or setting BCR2 for the CS0 space, or by setting BCR2 for the CS1–CS4 spaces. Since the data width of devices connected to the respective spaces is specified statically, however, the data width cannot be changed for each access cycle. Instruction fetches are always performed in 32-bit units. When branching to an odd word boundary (4n + 2 address), instruction fetches are performed in longword units from a 4n address. Figures 7.2 to 7.4 show the relationship between device data widths and access units. | | | 32-bit exte | rnal device ( | ordinary) | | | |--------|-----|-------------|---------------|-----------|----|-------------------------------------| | A24-A0 | D31 | D23 | D15 | D7 | D0 | 32-bit device data input/output pin | | 000000 | 7 | 0 | ' | ' | , | Byte read/write of address 0 | | 000001 | | 7 | 0 | | | Byte read/write of address 1 | | 000002 | | | 7 | 0 | | Byte read/write of address 2 | | 000003 | | | | 7 | 0 | Byte read/write of address 3 | | 000000 | 15 | 8 , 7 | 0 | | | Word read/write of address 0 | | 000002 | | | 15 | 8 , 7 | 0 | Word read/write of address 2 | | 000000 | 31 | 24 23 | 16 , 15 | 8 , 7 | 0 | Longword read/write of address 0 | Figure 7.2 32-Bit External Devices and Their Access Units | A24-A0<br>000000<br>000001<br>000002<br>000003<br>000000<br>000002<br>000000 | D15 7 0 7 0 15 15 31 15 | 7 0<br>7 0<br>0 0<br>16 | Byte read/write of address 0 Byte read/write of address 1 Byte read/write of address 2 Byte read/write of address 3 Word read/write of address 0 Word read/write of address 2 | |------------------------------------------------------------------------------|-------------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 000002 | 15 | 0 | Longword read/write of address 0 | Figure 7.3 16-Bit External Devices and Their Access Units | 000000 | 8-bit device data input/output pin Byte read/write of address 0 Byte read/write of address 1 Byte read/write of address 2 Byte read/write of address 3 Byte read/write of address 3 Word read/write of address 0 Word read/write of address 2 Word read/write of address 0 Solution 10 Word read/write of address 2 Longword read/write of address 0 | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| Figure 7.4 8-Bit External Devices and Their Access Units #### 7.3.2 Connection to Little-Endian Devices The LSI provides a conversion function in CS2, CS4 space for connection to and to maintain program compatibility with devices that use little-endian format (in which the LSB is the 0 position in the byte data lineup). When the endian specification bit of BCR1 is set to 1, CS2, CS4 space is little-endian. The relationship between device data width and access unit for little-endian format is shown in figures 7.5 and 7.6. When sharing memory or the like with a little-endian bus master, the LSI connects D31–D24 to the least significant byte (LSB) of the other bus master and D7–D0 to the most significant byte (MSB), when the bus width is 32 bits. When the width is 16 bits, the LSI connects D15–D8 to the least significant byte of the other bus master and D7–D0 to the most significant byte. When support software like the compiler or linker does not support switching, the instruction code and constants in the program do not become little-endian. For this reason, be careful not to place program code or constants in the CS2, CS4 space. When instructions or data in other CS spaces are used by transferring them to CS2, CS4 space with the LSI, there is no problem because the LSI converts the endian format. Programs that are designed for use with little-endian format assume that the LSB is stored in the lowest address. Even when a program written in a high-level language like C is recompiled as is, it may not execute properly. The sign bit of signed 16-bit data at address 0 is stored at address 1 in little-endian format and at address 0 in big-endian format. It is possible to correctly execute a program written for little-endian format by allocating the program and constants to an area other than CS2, CS4 space and the data area to CS2, CS4 space. | A24-A0 | D31 | D23 | D15 | D7 | D0 | 32-bit device data input/output pin | |--------|-----|--------|--------|---------|----|-------------------------------------| | 000000 | 7 | 0 | ı | ı | 1 | Byte read/write of address 0 | | 000001 | | 7 | 0 | | | Byte read/write of address 1 | | 000002 | | | 7 | 0 | | Byte read/write of address 2 | | 000003 | | | | 7 | 0 | Byte read/write of address 3 | | 000000 | 7 | 0 , 15 | 8 | | | Word read/write of address 0 | | 000002 | | | 7 | 0 , 15 | 8 | Word read/write of address 2 | | 000000 | 7 | 0 , 15 | 8 , 23 | 16 , 31 | 24 | Longword read/write of address 0 | | | | | | | | | Figure 7.5 32-Bit External Devices and Their Access Units | A24-A0<br>000000<br>000001<br>000002<br>000003<br>000000<br>000002 | D15 7 7 7 7 7 | D7 0 7 0 7 0,15 0,15 | 0<br>0<br>8<br>8 | 16-bit device data input/output pin Byte read/write of address 0 Byte read/write of address 1 Byte read/write of address 2 Byte read/write of address 3 Word read/write of address 0 Word read/write of address 2 | |--------------------------------------------------------------------|----------------|-----------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | <u>7</u> | | <del>-</del> | | | 000000<br>000002 | <u>7</u><br>23 | 0 <sub>1</sub> 15<br>16 <sub>1</sub> 31 | 8<br>24 | Longword read/write of address 0 | Figure 7.6 16-Bit External Devices and Their Access Units Figure 7.7 8-Bit External Devices and Their Access Units # 7.4 Accessing Ordinary Space # 7.4.1 Basic Timing A strobe signal is output by ordinary space accesses of CS0–CS4 spaces to provide primarily for SRAM direct connections. Figure 7.8 shows the basic timing of ordinary space accesses. Ordinary accesses without waits end in 2 cycles. The $\overline{BS}$ signal is asserted for 1 cycle to indicate the start of the bus cycle. The $\overline{CSn}$ signal is negated by the fall of clock T2 to ensure the negate period. The negate period is thus half a cycle when accessed at the minimum pitch. The access size is not specified during a read. The correct access start address will be output to the LSB of the address, but since no access size is specified, the read will always be 32 bits for 32-bit devices and 16 bits for 16-bit devices. For writes, only the $\overline{\text{WE}}$ signal of the byte that will be written is asserted. For 32-bit devices, $\overline{\text{WE}3}$ specifies writing to a 4n address and $\overline{\text{WE}0}$ specifies writing to a 2n address and $\overline{\text{WE}0}$ specifies writing to a 2n address and $\overline{\text{WE}0}$ specifies writing to a 2n+1 address. For 8-bit devices, only $\overline{\text{WE}0}$ is used. When data buses are provided with buffers, the $\overline{RD}$ signal must be used for data output in the read direction. When $RD/\overline{WR}$ signals do not perform accesses, the chip stays in read status, so there is a danger of conflicts occurring with output when this is used to control the external data buffer. Figure 7.8 Basic Timing of Ordinary Space Access If the bus state controller accesses with words, long-words for 8 bits bus width, and accesses with long-words for 16 bits bus width, the multiple number of access will be repeated. When the clock ratio is $I\phi: E\phi = 1:2$ or $I\phi: E\phi = 1:4$ , the basic timing shown in fig.7.8 is repeated, but if the clock ratio is $I\phi: E\phi = 1:1$ , as shown in fig.7.9, burst access is performed without $\overline{CSn}$ negation period. Figure 7.9 Figure 7.10 shows an example of a 32-bit data width SRAM connection, figure 7.11 a 16-bit data width SRAM connection, and figure 7.12 an 8-bit data width SRAM connection. Figure 7.10 Example of 32-Bit Data Width SRAM Connection Figure 7.11 Example of 16-Bit Data Width SRAM Connection Figure 7.12 Example of 8-Bit Data Width SRAM Connection #### 7.4.2 Wait State Control The number of wait states inserted into ordinary space access states can be controlled using the WCR, WCR2, BCR1 and BCR3 register settings. When the Wn1 and Wn0 wait specification bits in WCR1, WCR2 for the given CS space are 01 or 10, software waits are inserted according to the wait specification. When Wn1 and Wn0 are 11, wait cycles are inserted according to the long wait specification bit AnLW in BCR1, BCR3. The long wait specification in BCR1, BCR3 can be made independently for CS0, CS1 and CS4 spaces, but the same value must be specified for CS2 and CS3 spaces. All WCR1 specifications are independent. By means of WCR1, WCR2, BCR1, and BCR3, a Tw cycle as long as the number of specified cycles is inserted as a wait cycle at the wait timing for ordinary access space shown in figure 7.12. The names of the control bits that specify Tw for each CS space are shown in table 7.5. Figure 7.13 Wait Timing of Ordinary Space Access (Software Wait Only) | | BCR3 | BCR1 | | WCR1 | | WCR2 | | Tw | |-----|-------|-------|-------|------|-----|------|-----|------| | CS0 | A0LW2 | A0LW1 | A0LW0 | W01 | W00 | _ | _ | 0–14 | | CS1 | A1LW2 | A1LW1 | A2LW0 | W11 | W10 | _ | _ | 0–14 | | CS2 | AHLW2 | AHLW1 | AHLW0 | W21 | W20 | _ | _ | 0–14 | | CS3 | AHLW2 | AHLW1 | AHLW0 | W31 | W30 | _ | _ | 0–14 | | CS4 | A4LW2 | A4LW1 | A4LW0 | _ | _ | W41 | W40 | 0–14 | When a wait is specified by software using WCR1 and WCR2 (Wn1, Wn0), and the external wait mask bit (AnWM) is cleared to 0 in WCR2, the wait input $\overline{WAIT}$ signal from outside is sampled. Figure 7.14 shows $\overline{WAIT}$ signal sampling. A 2-cycle wait is specified as a software wait. The sampling is performed when the Tw state shifts to the T2 state, so there is no effect even when the $\overline{WAIT}$ signal is asserted in the T1 cycle or the first Tw cycle. The $\overline{WAIT}$ signal is sampled at the clock fall. Figure 7.14 Wait State Timing of Ordinary Space Access (Wait States from $\overline{WAIT}$ Signal) For the CS0~CS3 spaces, as shown in fig.7.14, after negation of the external wait signal is accepted, one cycle after negation of the external wait signal is accepted. For the CS4 space, the number of cycles before $\overline{\text{CS}}$ , $\overline{\text{RD}}$ , and $\overline{\text{WEn}}$ are negated after acceptance of external wait negation can be set as 1, 2, or 4 by means of bits A4WD1 and A4WD0 in WCR. Figure 7.15 shows an example. Figure 7.15 Timing of Longword Access in Ordinary Space Using 16-Bit Bus Width (Clock Ratio CKM:CKE = 1:1) Figure 7.16 Wait State Timing of Ordinary Space in CS4 Space #### Idle cycles can be inserted to prevent extension of the $\overline{RD}$ signal or $\overline{WREn}$ signal assertion period beyond the length of the $\overline{CSn}$ signal assertion period by setting control bits in BCR3. This allows for flexible interfacing to external circuitry. The timing is shown in figure 7.17. $T_h$ and $T_f$ cycles are added respectively before and after the ordinary cycle. Only $\overline{CSn}$ is asserted in these cycles; $\overline{RD}$ and $\overline{WREn}$ signals are not. Further, data is extended up to the $T_f$ cycle, which is effective for devices with slower write operations. Figure 7.16 CS Assertion Period Extension Function For the CS0–CS3 spaces, a value from 0 to 2 can be set for $T_h$ and $T_f$ by means of bits AnSHW1 and AnSHW0 in WCR3. For the CS4 space, a value from 0 to 7 can be set for $T_h$ with bits A4SW2–A4SW0 in WCR3, and a value from 0 to 5 can be set for $T_f$ with bits A4HW1 and A4HW0. # 7.5 Synchronous DRAM Interface # 7.5.1 Synchronous DRAM Direct Connection Seven kinds of synchronous DRAM can be connected to the LSI: 2-Mbit ( $128 \times 16$ ), 4-Mbit ( $256k \times 16$ ), 16-Mbit( $1M \times 16$ , $2M \times 8$ , $4M \times 4$ ), and 64-Mbit ( $4M \times 16$ , $8M \times 8$ ). 64-Mbit synchronous DRAMs are internally divided into two or four banks. Other synchronous DRAMs are internally divided into two banks. Since synchronous DRAM can be selected by the $\overline{CS}$ signal, areas CS2 and CS3 can be connected using a common $\overline{RAS}$ or other control signal. When the enable bits for DRAM and other memory (DRAM2–DRAM0) in BCR1 are set to 001, CS2 is ordinary space and CS3 is synchronous DRAM space. When set to 100, CS2 is synchronous DRAM space and CS3 is ordinary space. When set to 101, both CS2 and CS3 are synchronous DRAM spaces. Supported synchronous DRAM operating modes are burst read/single write mode (initial setting) and burst read/burst write mode. The burst length depends on the data bus width, comprising 4 bursts for a 32-bit width, and 8 bursts for a 16-bit width. The data bus width is specified by the SZ bit in MCR. Burst operation is always performed, so the burst enable (BE) bit in MCR is ignored. Switching to burst write mode is performed by means of the BWE bit in BCR3. Control signals for directly connecting synchronous DRAM are the $\overline{RAS}$ , $\overline{CAS}/\overline{OE}$ , $RD/\overline{WR}$ , $\overline{CS2}$ or $\overline{CS3}$ , DQMUU, DQMUL, DQMLU, DQMLL, and CKE signals. Signals other than $\overline{CS2}$ and $\overline{CS3}$ are common to every area, and signals other than CKE are valid and fetched only when $\overline{CS2}$ or $\overline{CS3}$ is true. Therefore, synchronous DRAM of multiple areas can be connected in parallel. CKE is negated (to the low level); only when a self-refresh is performed otherwise it is asserted (to the high level). Commands can be specified for synchronous DRAM using the RAS, CAS/OE, RD/WR, and certain address signals. These commands are NOP, auto-refresh (REF), self-refresh (SELF), all-bank precharge (PALL), specific bank precharge (PRE), row address strobe/bank active (ACTV), read (READ), read with precharge (READA), write (WRIT), write with precharge (WRITA), and mode register write (MRS). Bytes are specified using DQMUU, DQMUL, DQMLU, and DQMLL. The read/write is performed on the byte whose DQM is low. For 32-bit data, DQMUU specifies 4n address access and DQMLL specifies 4n+3 address access. For 16-bit data, only DQMLU and DQMLL are used. Figure 7.17 shows an example in which a 32-bit connection uses a $256k \times 16$ bit synchronous DRAM. Figure 7.18 shows an example with a 16-bit connection. Figure 7.17 Synchronous DRAM 32-bit Device Connection Figure 7.18 Synchronous DRAM 16-bit Device Connection ## 7.5.2 Address Multiplexing Addresses are multiplexed according to the MCR's address multiplex specification bits AMX2–AMX0 and size specification bit SZ so that synchronous DRAMs can be connected directly without an external multiplex circuit. Table 7.6 shows the relationship between the multiplex specification bits and bit output to the address pins. A26 to A16 and A0 always output the original value regardless of multiplexing. When SZ = 0, the data width on the synchronous DRAM side is 16 bits and the LSB of the device's address pins (A0) specifies word address. The A0 pin of the synchronous DRAM is thus connected to the A1 pin of the SH7612, the rest of the connection proceeding in the same order, beginning with the A1 pin to the A2 pin. When SZ = 1, the data width on the synchronous DRAM side is 32 bits and the LSB of the device's address pins (A0) specifies longword address. The A0 pin of the synchronous DRAM is thus connected to the A2 pin of the SH7612, the rest of the connection proceeding in the same order, beginning with the A1 pin to the A3 pin. Table 7.6 SZ and AMX Bits and Address Multiplex Output Setting **External Address Pins** Output SZ AMX2 AMX1 AMX0 Timing A10 A11 A12 A1-A8 **A9** A13 A14 A15 L/H\*1 A21\*2 A14 0 0 0 A1-A8 A11 A15 Column A10 Α9 address A21\*2 A22 A9-A16 A17 A20 Row A18 A19 A23 address L/H<sup>\*1</sup> A22\*2 A14 1 0 0 A1-A8 A10 A11 A15 1 Column Α9 address A22\*2 A23 Row A10-A17 A18 A19 A20 A21 A24 address L/H<sup>\*1</sup> 1 0 1 0 A1-A8 Α9 A10 A11 A23\*2 A14 A15 Column address A22 A23\*2 A24 Row A11-A18 A19 A20 A21 A25 address A19\*2 A12 1 0 1 L/H\*1 1 A1-A8 Α9 A13 A14 Column A15 address A19\*2 A20 Row A9-A16 A17 A21 A22 A23 A18 address A13 A22\*3 A23\*2 1 0 A11 L/H\*1 0 Column A1-A8 Α9 A10 address A22\*3 A23\*2 Row A9-A16 A17 A18 A19 A20 A21 address 1 1 0 1 Column A1-A8 Α9 A10 A11 L/H\*1 A13 A23\*3 A24\*2 address A10-A17 A18 A19 A20 A21 A22 A23\*3 A24\*2 Row address 1 L/H\*1 A18<sup>\*2</sup> A12 1 1 1 Column A1-A8 Α9 A13 A14 A15 address A18\*2 A20 Row A9-A16 A17 A17 A21 A22 A23 address L/H\*1 A20\*2 A13 0 0 0 0 Column A1-A8 A9 A10 A14 A15 address A20\*2 A21 Row A9-A16 A17 A18 A19 A22 A23 address Table 7.6 SZ and AMX Bits and Address Multiplex Output (cont) | Setting | | | | External Address Pins | | | | | | | | | |---------|------|------|------|-----------------------|--------|-------------------|-------------------|-------------------|-----|-------------------|-------|-----| | SZ | AMX2 | AMX1 | AMX0 | Output<br>Timing | A1-A8 | A9 | A10 | A11 | A12 | A13 | A14 | A15 | | 0 | 1 | 0 | 0 | Column<br>address | A1–A8 | A9 | A10 | L/H <sup>*1</sup> | A12 | A21 <sup>*3</sup> | A22*2 | A15 | | | | | | Row<br>address | A9–A16 | A17 | A18 | A19 | A20 | A21*3 | A22*2 | A23 | | 0 | 0 | 1 | 1 | Column<br>address | A1–A8 | L/H <sup>*1</sup> | A18 <sup>*2</sup> | A11 | A12 | A13 | A14 | A15 | | | | | | Row<br>address | A9–A16 | A17 | A18 <sup>*2</sup> | A19 | A20 | A21 | A22 | A23 | | 0 | 1 | 1 | 1 | Column<br>address | A1–A8 | L/H <sup>*1</sup> | A17*2 | A11 | A12 | A13 | A14 | A15 | | | | | | Row<br>address | A9–A16 | A16 | A17 <sup>*2</sup> | A19 | A20 | A21 | A22 | A23 | Notes: AMX2–AMX0 setting 110 is reserved and must not be used. When SZ = 0, AMX2–AMX0 settings 001, 010 and 101 are also reserved and must not be used. - L/H is a bit used to specify commands. It is fixed at L or H according to the access mode. - 2. Bank address specification. - 3. Bank address specification when using four banks. #### 7.5.3 Burst Reads Figure 7.19 shows the timing chart for burst reads. In the following example, 2 synchronous DRAMs of $256k \times 16$ bits are connected, the data width is 32 bits and the burst length is 4. After a Tr cycle that performs ACTV command output, a READA command is called in the Tc cycle and read data is accepted at internal clock falls from Td1 to Td4. Tap is a cycle for waiting for the completion of the auto-precharge based on the READA command within the synchronous DRAM. During this period, no new access commands are issued to the same bank. Accesses of the other bank of the synchronous DRAM by another CS space are possible. Depending on the TRP1, TRP0 specification in MCR, the SH7612 determines the number of Tap cycles and does not issue a command to the same bank during that period. Figure 7.20 shows an example of the basic cycle. Because a slower synchronous DRAM is connected, setting WCRI and MCR bits can extend the cycle. The number of cycles from the ACTV command output cycle Tr to the READA command output cycle Tc can be specified by bits RCD1 and RCD0 in MCR. 00 specifies 1 cycle, 01 specifies 2 cycles, and 10 specifies 3 cycles. For 2 or 3 cycles, a NOP command issue cycle Trw for the synchronous DRAM is inserted between the Tr cycle and the Tc cycle. The number of cycles between the READA command output cycle Tc and the initial read data fetch cycle Td1 can be specified independently for areas CS2 and CS3 between 1 cycle and 4 cycles using the W21/W20 and W31/W30 bits in WCRI. The CAS latency when using bus arbitration in the partial-share master mode can be set differently for CS2 and CS3 spaces. The number of cycles at this time corresponds to the number of CAS latency cycles of the synchronous DRAM. When 2 cycles or more, a NOP command issue cycle Tw is inserted between the Tc cycle and the Td1 cycle. The number of cycles in the precharge completion waiting cycle Tap is specified by bits TRP1 and TRP0 in MCR. When CAS latency is 1, a Tap cycle comprising the number of cycles specified by TRP1 and TRP0 is generated. When the CAS latency is 1, a Tap cycle of 1 or 2 cycles is generated. When the CAS latency is 2 or more, a Tap cycle equal to the TRP specification – 1 is generated. During the Tap cycle, no commands other than NOP are issued to the same bank. Figure 7.19 shows an example of burst read timing when RCD1/RCD0 is 01, W31/W30 is 01, and TRP1/TRP0 is 01. When the data width is 16 bits, 8 burst cycles are required for a 16-byte data transfer. The data fetch cycle goes from Td1 to Td8. Synchronous DRAM CAS latency is up to 3 cycles, but the CAS latency of the bus state controller can be specified up to 4. This is so that circuits containing latches can be installed between synchronous DRAMs and the LSI. Figure 7.19 Basic Burst Read Timing (Auto-Precharge) Figure 7.20 Burst Read Wait Specification Timing (Auto-Precharge) # 7.5.4 Single Reads When a cache area is accessed and there is a cache miss, the cache fill cycle is performed in 16-byte units. This means that all the data read in the burst read is valid. Since the required data when a cache-through area is accessed has a maximum length of 32 bits, however, the remaining 12 bytes are wasted. The same kind of wasted data access is produced when synchronous DRAM is specified as the source in a DMA transfer by the DMAC and the transfer unit is other than 16 bytes. Figure 7.22 shows the timing of a single address read. Because the synchronous DRAM is set to the burst read mode, the read data output continues after the required data is received. To avoid data conflict, an empty read cycle is performed from Td2 to Td4 after the required data is read in Td1 and the device waits for the end of synchronous DRAM operation. When the data width is 16 bits, the number of burst transfers during a read is 8. Data is fetched in cache-through and other DMA read cycles only in the Td1 and Td2 cycles (of the 8 cycles from Td1 to Td8) for longword accesses, and only in the Td1 cycle for word or byte accesses. Empty cycles tend to increase the memory access time, lower the program execution speed, and lower the DMA transfer speed, so it is important to avoid accessing unnecessary cache-through areas and to use data structures that enable 16-byte unit transfers by placing data on 16-byte boundaries when performing DMA transfers that specify synchronous DRAM as the source. Figure 7.21 Single Read Timing (Auto-Precharge) ## 7.5.5 Single Writes Synchronous DRAM writes are executed as single write mode or burst write mode according to the specification by the BWE bit in BCR3. Figure 7.23 shows the basic timing chart for single write accesses. After the ACTV command Tr, a WRITA command is issued in Tc to perform an auto-precharge. In the write cycle, the write data is output simultaneously with the write command. When writing with an auto-precharge, the bank is precharged after the completion of the write command within the synchronous DRAM, so no command can be issued to that bank until the precharge is completed. For that reason, besides a cycle Tap to wait for the precharge during read accesses, the issuing of any new commands to the same bank during this period is delayed by adding a cycle Trw1 to wait until the precharge is started. The number of cycles in the Trw1 cycle can be specified using the TRWL1 and TRWL0 bits in MCR. Figure 7.22 Basic Single Write Mode Timing (Auto-Precharge) #### 7.5.6 Burst Write Mode Burst write mode can be selected by setting the BWE bit to 1 in BCR3. The basic timing chart for burst write access is shown in figure 7.23. This example assumes a 32-bit bus width and a burst length of 4. In the burst write cycle, the WRITA command that performs auto-precharge is issued in Tc1 following the ACTV command Tr cycle. The first 4 bytes of write data are output simultaneously with the WRITA command in Tc1, and the remaining 12 bytes of data are output consecutively in Tc2, Tc3, and Tc4. In a write with auto-precharge, as with a single write, a Trw1 cycle that provides the waiting time until precharge is started is inserted after output of the write data, followed by a Tap cycle for the precharge wait in a write access. The Trw1 and Tap cycles can be set by bits TRWL1 and TRWL0 and bits TRP1 and TRP0, respectively, in MCR. When a single write is performed in burst write mode, since the synchronous DRAM setting is for a burst length of 4, after data is written in Tc1, empty writes are performed in Tc2, Tc3, and Tc4 by driving the DQMxx signal high. These empty cycles increase the memory access time and tend to reduce program execution speed and DMA transfer speed. Therefore, unnecessary cache-through area accesses should be avoided, and copy-back should be selected for the cache setting. Also, in DMA transfer, it is important to use a data structure that allows transfer in 16-bit units. Figure 7.23 Basic Burst Write Mode Timing (Auto-Precharge) #### 7.5.7 Bank Active Function A synchronous DRAM bank function is used to support high-speed accesses of the same row address. When the RASD bit in MCR is set to 1, read/write accesses are performed using commands without auto-precharge (READ, WRIT). In this case, even when the access is completed, no precharge is performed. When accessing the same row address in the same bank, a READ or WRIT command can be called immediately without calling an ACTV command, just like the RAS down mode of the DRAM's high-speed page mode. Synchronous DRAM is divided into two banks, so one row address in each can stay active. When the next access is to a different row address, a PRE command is called first to precharge the bank, and access is performed by an ACTV command and READ or WRIT command, in that order, after the precharge is completed. With successive accesses to different row addresses, the precharge is performed after the access request occurs, so the access time is longer. When writing, performing an auto-precharge means that no command can be called for t<sub>RWL</sub> + t<sub>AP</sub> cycles after a WRITA command is called. When the bank active mode is used, READ or WRIT commands can be issued consecutively if the row address is the same. This shortens the number of cycles by t<sub>RWL</sub> + t<sub>AP</sub> for each write. The number of cycles between the issue of the precharge command and the row address strobe command is determined by the TRP1, TRP0 bit in MCR. Whether execution is faster when the bank active mode is used or when basic access is used is determined by the proportion of accesses to the same row address (P1) and the average number of cycles from the end of one access to the next access $(t_A)$ . When tA is longer than $t_{AP}$ , the delay waiting for the precharge during a read becomes invisible. If $t_A$ is longer than $t_{RWL} + t_{AP}$ , the delay waiting for the precharge also becomes invisible during writes. The difference between the bank active mode and basic access speeds in these cases is the number of cycles between the start of access and the issue of the read/write command: $(t_{RP} + t_{RCD}) \times (1 - P1)$ and $t_{RCD}$ , respectively. The time that a bank can be kept active, $t_{RAS}$ , is limited. When it is not assured that this period will be provided by program execution and that another row address will be accessed without a hit to the cache, the synchronous DRAM must be set to auto-refresh and the refresh cycle must be set to the maximum value $t_{RAS}$ or less. This enables the limit on the maximum active period for each bank to be ensured. When auto-refresh is not being used, some measure must be taken in the program to ensure that the bank does not stay active for longer than the prescribed period. Figure 7.24 shows a burst read cycle that is not an auto-precharge cycle, figure 7.25 shows a burst read cycle to a same row address, figure 7.26 shows a burst read cycle to different row addresses, figure 7.27 shows a write cycle without auto-precharge, figure 7.28 shows a write cycle to a same row address, and figure 7.29 shows a write cycle to different row addresses. In figure 7.25, a cycle that does nothing, Tnop, is inserted before the Tc cycle that issues the READ command. Synchronous DRAMs, however, have a 2 cycle latency during reads for the DQMxx signals that specify bytes. If the Tc cycle is performed immediately without inserting a Tnop cycle, the DQMxx signal for the Td1 cycle data output cannot be specified. This is why the Tnop cycle is inserted. When the CAS latency is 2 or more, the Tnop cycle is not inserted so that timing requirements will be met even when a DQMxx signal is set after the Tc cycle. When the LSI is set to the bank active mode, the access will start with figure 7.24 or figure 7.27 and repeat figure 7.25 or figure 7.28 for as long as the same row address continues to be accessed when only accesses to the respective banks of the CS3 space are considered. Accesses to other CS spaces during this period have no effect. When an access occurs to a different row address while the bank is active, figure 7.26 or figure 7.29 will be substituted for figures 7.25 and 7.28 after this is detected. Both banks will become inactive even in the bank active mode after the refresh cycle ends or after the bus is released by bus arbitration. Figure 7.24 Burst Read Timing (No Precharge) Figure 7.25 Burst Read Timing (Bank Active, Same Row Address) Figure 7.26 Burst Read Timing (Bank Active, Different Row Addresses) Figure 7.27 Single Write Mode Timing (No Precharge) Figure 7.28 Single Write Mode Timing (Bank Active, Same Row Address) Figure 7.29 Single Write Mode Timing (Bank Active, Different Row Addresses) #### 7.5.8 Refreshes The bus state controller is equipped with a function to control refreshes of synchronous DRAM. Auto-refreshes can be performed by setting the MCR's RMD bit to 0 and the RFSH bit to 1. Also, consecutive refreshes can be generated by setting the RC2–RC0 bits in RTCSR. When the synchronous DRAM is not accessed for a long period of time, set the RFSH bit and RMODE bit both to 1 to initiate self-refresh mode, which uses low power consumption to retain data. **Auto-Refresh:** The number of refreshes set in the RRC2–RRC0 bits in RTCSR are performed at the interval determined by the input clock selected by the CKS2–CKS0 bits in RTCSR and the value set in RTCOR. Set the CKS2–CKS0 bits and RTCOR so that the refresh interval specifications of the synchronous DRAM being used are satisfied. First, set RTCOR, RTCNT, and the RMODE and RFSH bits in MCR, then set the CKS2–CKS0 and RRC2–RRC0 bits in RTCSR. When a clock is selected with the CKS2–CKS0 bits, RTCNT starts counting up from the value at that time. The RTCNT value is constantly compared to the RTCOR value, and when the two match a refresh request is made and the number of auto-refreshes set in RC2–RC0 are performed. RTCNT is cleared to 0 at that time and the count up starts again. Figure 7.31 shows the timing for the auto-refresh cycle. First, a PALL command is issued during the Tp cycle to change all the banks from active to precharge states. A number of idle cycles equal to one less than the value set in TRP1 and TRP0 are inserted, and then a REF command is issued in the Trr cycle. After the Trr cycle, no new commands are output for the number of cycles specified in the TRAS bit in MCR. The TRAS bit must be set to satisfy the refresh cycle time specifications (active/active command delay time) of the synchronous DRAM. When the setting value of TRP1 and TRP0 are two or more, an NOP cycle is inserted between the Tp cycle and Trr cycle. During a manual reset, no refresh request is issued, since there is no RTCNT count-up. To perform a refresh properly, make the manual reset period shorter than the refresh cycle interval and set RTCNT to (RTCOR - 1) so that the refresh is performed immediately after the manual reset is cleared. Figure 7.30 Auto-Refresh Timing Self-Refreshes: The self-refresh mode is a type of standby mode that produces refresh timing and refresh addresses within the synchronous DRAM. It is started up by setting the RMODE and RFSH bits to 1. The synchronous DRAM is in self-refresh mode when the CKE signal level is low. During the self-refresh, the synchronous DRAM cannot be accessed. To clear the self-refresh, set the RMODE bit to 0. After self-refresh mode is cleared, issuing of commands is prohibited for the number of cycles specified in the MCR's TRAS bit. Figure 7.31 shows the self-refresh timing. Immediately set the synchronous DRAM so that the auto-refresh is performed in the correct interval. This ensures a correct self-refresh clear and data holding. When self-refresh mode is entered while the synchronous DRAM is set for auto-refresh or when leaving the standby mode with a manual reset or NMI, auto-refresh can be re-started if RFSH is 1 and RMODE is 0 when the self-refresh mode is cleared. When time is required between clearing the self-refresh mode and starting the auto-refresh mode, this time must be reflected in the initial RTCNT setting. When the RTCNT value is set to RTCOR – 1, the refresh can be started immediately. If the standby function of the LSI is used after the self-refresh is set to enter the standby mode, the self-refresh state continues; the self-refresh state will also be maintained after returning from a standby using an NMI. A manual reset cannot be used to exit the self-refresh state either. During a power-on reset, the bus state controller register is initialized, so the self-refresh state is ended. Refresh Requests and Bus Cycle Requests: When a refresh request occurs while a bus cycle is executing, the refresh will not be executed until the bus cycle is completed. When a refresh request occurs while the bus is released using the bus arbitration function, the refresh will not be executed until the bus is recaptured. In the SH7612, the REFOUT pin is provided to send a signal requesting the bus during the wait for refreshing to be executed. REFOUT is asserted until the bus is acquired. If RTCNT and RTCOR match and a new refresh request occurs while waiting for the refresh to execute, the previous refresh request is erased. To make sure the refresh executes properly, be sure that the bus cycle and bus capture do not exceed the refresh interval. If a bus arbitration request occurs during a self-refresh, the bus is not released until the self-refresh is cleared. Figure 7.31 Self-Refresh Timing ## 7.5.9 Power-On Sequence To use synchronous DRAM, the mode for synchronous DRAM must be set after the power is turned on. To properly initialize the synchronous DRAM, the synchronous DRAM mode register must be written to after the registers of the bus state controller have first been set. The synchronous DRAM mode register is set using a combination of the $\overline{CS2}$ or $\overline{CS3}$ , $\overline{RAS}$ , $\overline{CAS}/\overline{OE}$ and $\overline{RD}/\overline{WR}$ signals. They fetch the value of the address signal at that time. If the value to be set is X, the bus state controller operates by writing to address X + H'FFFF8000 from the CPU, which allows the value X to be written to the synchronous DRAM mode register. Data is ignored at this time, but the mode is written using word as the size. Write any data in word size to the following addresses to select the burst read single write supported by the LSI, a CAS latency of 1 to 3, a sequential wrap type, and a burst length of 8 or 4 (depending on whether the width is 16 bits or 32 bits). | 16-bits width | CAS latency 1 | H'FFFF8426 | | |---------------|---------------|------------|--| | | CAS latency 2 | H'FFFF8446 | | | | CAS latency 3 | H'FFFF8466 | | | | | | | | 32-bits width | CAS latency 1 | H'FFFF8848 | | | | CAS latency 2 | H'FFFF8888 | | | | CAS latency 3 | H'FFFF88C8 | | To set burst read, burst write, CAS latency 1 to 3, wrap-type sequential, and burst length 8 or 4 (depending on whether the width is 16 bits or 32 bits), arbitrary data is written to the following addresses, using the load size. | 16-bit width: | CAS latency 1<br>CAS latency 2<br>CAS latency 3 | H'FFFF8026<br>H'FFFF8046<br>H'FFFF8066 | |---------------|-------------------------------------------------|----------------------------------------| | 32-bit width: | CAS latency 1<br>CAS latency 2<br>CAS latency 3 | H'FFFF8048<br>H'FFFF8088<br>H'FFFF80C8 | Figure 7.33 shows the mode register setting timing. By writing to X + H'FFFF800 address, first, all bank precharge command(PALL) is issued, and more, necessary dummy auto-refresh command(REF) for the power on sequence of synchronous DRAM is issued eight times. And lastly, the mode register write command(MRS) is issued. Three idle cycles between all bank precharge command and the first auto-refresh command, eight idle cycles between eighth auto-refresh command and the mode register write are inserted. After ending write for the mode register of the synchronous DRAM, start the normal access after reading the dummy for each bank of the synchronous DRAM.` Synchronous DRAM must assure the idle time of $200\mu S$ after applying power in advance of all bank precharge command. If the pulse width of the reset signal islonger than this idle time, even if the mode register setting is performed immediately, there is no problem, however, if it is short, the cautions are necessary to be paid. Figure 7.32 Synchronous DRAM Mode Write Timing ## 7.6 DRAM Interface #### 7.6.1 DRAM Direct Connection When the DRAM and other memory enable bits (DRAM2–DRAM0) in BCR1 are set to 010, the CS3 space becomes DRAM space, and a DRAM interface function can be used to directly connect the SH7612 to DRAM. The data width of an interface can be 16 or 32 bits (figures 7.33 and 7.34). Two-CAS 16-bit DRAMs can be connected, since $\overline{CAS}$ is used to control byte access. The $\overline{RAS}$ , $\overline{CASHH}$ , $\overline{CASHL}$ , $\overline{CASHL}$ , and $\overline{RD/WR}$ signals are used to connect the DRAM. When the data width is 16 bits, $\overline{CASHH}$ , and $\overline{CASHL}$ are not used. In addition to ordinary read and write access, burst access using high-speed page mode is also supported. Figure 7.33 Example of DRAM Connection (32-Bit Data Width) Figure 7.34 Example of DRAM Connection (16-Bit Data Width) ## 7.6.2 Address Multiplexing When the CS3 space is set to DRAM, addresses are always multiplexed. This allows DRAMs that require multiplexing of row and column addresses to be connected directly to SH7612 microprocessors without additional multiplexing circuits. There are four ways of multiplexing, which can be selected using the MCR's AMX1–AMX0 bits. Table 7.7 illustrates the relationship between the AMX1–AMX0 bits and address multiplexing. Address multiplexing is performed on address output pins A15–A1. The original addresses are output to pins A24–A16. During DRAM accesses, AMX2 is reserved, so set it to 0. Table 7.7 Relationship between AMX1-AMX0 and Address Multiplexing | AMX1 | AMX0 | No. of Column<br>Address Bits | Row<br>Address Output | Column<br>Address Output | |------|------|-------------------------------|-----------------------|--------------------------| | 0 | 0 | 8 bits | A23-A9 | A15–A1 | | | 1 | 9 bits | A24-A10 | A15–A1 | | 1 | 0 | 10 bits | A24-A11 <sup>*1</sup> | A15–A1 | | | 1 | 11 bits | A24-A12 <sup>*2</sup> | A15–A1 | Notes \*1 Address output terminal A15 is high level. <sup>\*2</sup> Address output terminal A15,A14 are high level. # 7.6.3 Basic Timing The basic timing of a DRAM access is 3 cycles. Figure 7.35 shows the basic DRAM access timing. Tp is the precharge cycle, Tr is the RAS assert cycle, Tc1 is the CAS assert cycle, and Tc2 is the read data fetch cycle. When accesses are consecutive, the Tp cycle of the next access overlaps the Tc2 cycle of the previous access, so accesses can be performed in a minimum of 3 cycles each. Figure 7.35 Basic Access Timing #### 7.6.4 Wait State Control When the clock frequency is raised, 1 cycle may not always be sufficient for all states to end, as in basic access. Setting bits in WCR1, WCR2 and MCR enables the state to be lengthened. Figure 7.36 shows an example of lengthening a state using settings. The Tp cycle (which ensures a sufficient RAS precharge time) can be extended to 1 to 4 cycles by insertion of a Tpw cycle by means of the TRP1, TRP2 bit in MCR. The number of cycles between RAS assert and CAS assert can be extended to 1-3 cycles by inserting a Trw cycle by means of the RCD1, RCD0 bit in MCR. "Setting external wait mask bit A32WM of WCR2 to 0". The number of cycles from CAS assert to the end of access can be extended from 1 cycle to 3 cycles by setting the W31/W30 bits in WCRI. "When setting A3WM of WCR2 to 1, the external wait input is ignored regardless of W31, W30 setting of WCR1." When a value other than 00 is set in W31 and W30, the external wait pin WAIT is also sampled, so the number of cycles is further increased. Figure 7.36 shows the timing of wait state control using the WAIT pin. In either case, when consecutive accesses occur, the Tp cycle of one access overlaps the Tc2 cycle of the previous access. In DRAM access, BS is not asserted, and so RAS, CASn, RD, etc., should be used for WAIT pin control. Figure 7.36 Wait State Timing Figure 7.37 External Wait State Timing # 7.6.5 Burst Access In addition to the ordinary mode of DRAM access, in which row addresses are output at every access and data is then accessed, DRAM also has a high-speed page mode for use when continuously accessing the same row that enables fast access of data by changing only the column address after the row address is output. Select ordinary access or high-speed page mode by setting the burst enable bit (BE) in MCR. Figure 7.37 shows the timing of burst operation in high-speed page mode. When performing burst access, cycles can be inserted using the wait state control function. The LSI has an address comparator to detect matches of row addresses in burst mode. When this function is used and the BE bit in MCR is set to 1, setting the MCR's RASD bit (which specifies RAS down mode) to 1 places the LSI in RAS down mode, which leaves the RAS signal asserted. When RAS down mode is used, the refresh cycle must be less than the maximum DRAM RAS assert time $t_{RAS}$ when the refresh cycle is longer than the $t_{RAS}$ maximum. Figure 7.38 Burst Access Timing # **7.6.6 EDO Mode** In addition to the kind of DRAM in which data is output to the data bus only while the CASxx signal is asserted in a data read cycle, there is another kind provided with an EDO mode in which, while both RAS and OE are asserted, once the CASxx signal is asserted data is output to the data bus until CASxx is next asserted, even though CASxx is negated during this time. In the LSI, the EDO mode bit (EDO) in MCR allows selection of ordinary access/high-speed page mode access or ordinary access/burst access using EDO mode. Since $\overline{\text{OE}}$ control is performed in EDO mode DRAM access, the $\overline{CAS}$ and $\overline{OE}$ pins of the LSI must be connected to the $\overline{OE}$ pin of the DRAM. Ordinary access in EDO mode is shown in figure 7.41, and burst access in figure 7.42. In EDO mode, in order to extend the timing for data output to the data bus in a read cycle until the next assertion of $\overline{CASxx}$ , the DRAM access time can be increased by delaying the data latch timing by 1/2 cycle, making it the rise of the CKIO clock. Figure 7.39 Example of EDO DRAM Connection (32-Bit Data Width) Figure 7.40 Example of EDO DRAM Connection (16-Bit Data Width) Figure 7.41 DRAM EDO Mode Ordinary Access Timing Figure 7.42 DRAM EDO Mode Burst Access Timing # 7.6.7 DRAM Single Transfer The LSI allows wait states equivalent to the value set in bits DSWW1 and DSWW0 in BCR3 to be inserted between DACKn assertion and $\overline{CASxx}$ assertion in a write in DMA single address transfer mode. Inserting wait states allows for the data setup time for external device memory. Figure 7.43 shows the write cycle timing in DMA single transfer mode when DSWW1/DSWW0 = 01 and RASD = 1. The DMA single transfer mode read cycle is the same as a CPU or DMA dual transfer mode read cycle. Figure 7.43 DMA Single Transfer Mode Write Cycle Timing (RAS Down Mode, Same Row Address) ### 7.6.8 Refreshing The bus state controller includes a function for controlling DRAM refreshing. Distributed refreshing using a CAS-before-RAS refresh cycle can be performed by clearing the RMODE bit to 0 and setting the RFSH bit to 1 in MCR. Consecutive refreshes can be generated by setting bits RRC2–RRC0 in RTCSR. If DRAM is not accessed for a long period, self-refresh mode, which uses little power consumption for data retention, can be activated by setting both the RMODE and RFSH bits to 1. CAS-Before-RAS Refreshing: Refreshing is performed at intervals determined by the input clock selected by bits CKS2–CKS0 in RTCSR, and the value set in RTCOR. The value of bits CKS2–CKS0 in RTCOR should be set so as to satisfy the specification for the DRAM refresh interval. First make the settings for RTCOR, RTCNT, and the RMODE and RFSH bits in MCR, then make the CKS2–CKS0 and RRC2–RRC0 settings in RTCSR. When the clock is selected by CKS2–CKS0, RTCNT starts counting up from the value at that time. The RTCNT value is constantly compared with the RTCOR value, and when the two values match, a refresh request is generated and the number of CAS-before-RAS refreshes set in bits RRC2–RRC0 are performed. At the same time, RTCNT is cleared to zero and the count-up is restarted. Figure 7.44 shows the CAS-before-RAS refresh cycle timing. The number of RAS assert cycles in the refresh cycle is specified by bits TRAS1 and TRAS0 in MCR. As with ordinary accesses, the specification of the RAS precharge time in the refresh cycle follows the setting of bits TRP1 and TRP0 in MCR. Figure 7.44 DRAM CAS-before-RAS Refresh Cycle Timing **Self-Refreshing:** A self-refresh is started by setting both the RMODE bit and the RFSH bit to 1. During the self-refresh, DRAM cannot be accessed. Self-refreshing is cleared by clearing the RMODE bit to 0. Self-refresh timing is shown in figure 7.45. Settings must be made so that self-refresh clearing and data retention are performed correctly, and CAS-before-RAS refreshing is immediately performed at the correct intervals. When self-refreshing is started from the state in which CAS-before-RAS refreshing is set, or when exiting standby mode by means of a manual reset or NMI, CAS-before-RAS refreshing is restarted if RFSH is set to 1 and RMODE is cleared to 0 when self-refresh mode is cleared. If the transition from clearing of self-refresh mode to the start of CAS-before-RAS 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 SH7612's standby function, and is maintained even after recovery from standby mode by means of NMI input. The self-refresh state is not cleared by a manual reset. In the case of a power-on reset, the bus state controller's registers are initialized, and therefore the self-refresh state is cleared. Figure 7.45 DRAM Self-Refresh Cycle Timing ### 7.6.9 Power-On Sequence When DRAM is used after the power is turned on, there is a requirement for a waiting period during which accesses cannot be performed (100 $\mu s$ or 200 $\mu s$ minimum) followed by at least the prescribed number of dummy CAS-before-RAS refresh cycles (usually 8). The bus state controller (BSC) does not perform any special operations for the power-on reset, so the required power-on sequence must be implemented by the initialization program executed after a power-on reset. # 7.7 Burst ROM Interface Set the BSTROM bit in BCR1 to set the CS0 space for connection to burst ROM. The burst ROM interface is used to permit fast access to ROMs that have the nibble access function. Figure 7.47 shows the timing of nibble accesses to burst ROM. Set for two wait cycles. The access is basically the same as an ordinary access, but when the first cycle ends, only the address is changed. The CS0 signal is not negated, enabling the next access to be conducted without the T1 cycle required for ordinary space access. From the second time on, the T1 cycle is omitted, so access is 1 cycle faster than ordinary accesses. Currently, the nibble access can only be used on 4-address ROM. This function can only be utilized for word or longword reads to 8-bit ROM and longword reads to 16-bit ROM. Mask ROMs have slow access speeds and require 4 instruction fetches for 8-bit widths and 16 accesses for cache fills. Limited support of nibble access was thus added to alleviate this problem. When connecting to an 8-bit width ROM, a maximum of 4 consecutive accesses are performed; when connecting to a 16-bit width ROM, a maximum of 2 consecutive accesses are performed. Figure 7.46 shows the relationship between data width and access size. For cache fills and DMAC 16-byte transfers, longword accesses are repeated 4 times. When one or more wait states are set for a burst ROM access, the $\overline{WAIT}$ pin is sampled. When the burst ROM is set and 0 specified for waits, there are 2 access cycles from the second time on. Figure 7.48 shows the timing. Figure 7.46 Data Width and Burst ROM Access (1 Wait State) Figure 7.47 Burst ROM Nibble Access (2 Wait States) Figure 7.48 Burst ROM Nibble Access (No Wait States) # 7.8 Waits between Access Cycles Because operating frequencies have become high, when a read from a slow device is completed, data buffers may not go off in time to prevent data conflicts with the next access. This lowers device reliability and causes errors. To prevent this, a function has been added to avoid data conflicts that memorizes the space and read/write state of the preceding access and inserts a wait in the access cycle for those cases in which problems are found to occur when the next access starts up. Checks are performed in two cases: if a read cycle is followed immediately by a read access to a different CS space, and if a read access is followed immediately by a write from the LSI. When the LSI is writing continuously, if the format is always to have the direction of the data from the LSI to other memory, there are no particular problems. Neither is there any particular problem if the following read access is to the same CS space, since data is output from the same data buffer. The number of idle cycles to be inserted into the access cycle when reading from another CS space, or performing a write, after a read from the CS3 space, is specified by the IW31 and IW30 bits in WCRI. Likewise, IW21 and IW20 specify the number of idle cycles after CS2 reads, IW11 and IW10 specify the number after CS1 reads, and IW01 and IW00 specify the number after CS0 reads. From 0 to 2 cycles can be specified. When there is already a gap between accesses, the number of empty cycles is subtracted from the number of idle cycles before insertion. When a write cycle is performed immediately after a read access, 1 wait cycle is inserted even when 0 is specified for waits between access cycles. When the LSI shifts to a read cycle immediately after a write, the write data becomes high impedance when the clock rises, but the $\overline{RD}$ signal, which indicates read cycle data output enable, is not asserted until the clock falls. The result is that no waits are inserted into the access cycle. When bus arbitration is being performed, an empty cycle is inserted for arbitration, so no wait is inserted between cycles. Figure 7.50 Waits between Access Cycles # 7.9 Bus Arbitration The LSI has a bus arbitration function that, when a bus release request is received from an external device, releases the bus to that device after the bus cycle being executed is completed. The LSI keeps the bus under normal conditions and permits other devices to use the bus by releasing it when they request its use. In the following explanation, external devices requesting the bus are called slaves. The LSI has two internal bus masters, the CPU and the DMAC. When synchronous DRAM or DRAM is connected and refresh control is performed, the refresh request becomes a third master. In addition to these, there are also bus requests from external devices. The priority for bus requests when they occur simultaneously is, highest to lowest, refresh requests, bus requests from external devices, DMAC and CPU. When the bus is being passed between slave and master, all bus control signals are negated before the bus is released to prevent erroneous operation of the connected devices. Once the bus is received, the bus control signals change from negated to bus driven. The master and slave passing the bus between them drive the same signal values, so output buffer conflict is avoided. A pull-up resistance is required for the bus control signals to prevent malfunction caused by external noise when they are at high impedance. Bus permission is granted at the end of the bus cycle. When the bus is requested, the bus is released immediately if there is no ongoing bus cycle. If there is a current bus cycle, the bus is not released until the bus cycle ends. Even when there does not appear to be an ongoing bus cycle when seen from outside the LSI, it cannot be determined whether or not the bus will be released immediately when a bus control signal such as a $\overline{\text{CSn}}$ signal is seen, since an internal bus cycle, such as inserting a wait between access cycles, may have been started. The bus cannot be released during burst transfers for cache fills or 16-byte DMAC block transfers. Likewise, the bus cannot be released between the read and write cycles of a TAS instruction. Arbitration is also not performed between multiple bus cycles produced by a data width smaller than the access size, such as a longword access to an 8-bit data width memory. Bus arbitration is performed between external vector fetch, PC save, and SR save cycles during interrupt handling, which are all independent accesses. Because the CPU in the LSI is connected to cache memory by a dedicated internal bus, cache memory can be read even when the bus is being used by another bus master on the chip or externally. When writing from the CPU, the LSI cache can be switched between write-through mode and write-back mode; in write-through mode, a write cycle is produced externally, whereas in write-back mode, a write cycle is not produced externally unless there is a replace operation for the relevant address. Since the internal bus that connects the CPU, DMAC, and on-chip peripheral modules can operate in parallel to the external bus, both read and write accesses from the CPU to on-chip peripheral modules and from the DMAC to on-chip peripheral modules are possible even if the external bus is not held. ### 7.9.1 Master Mode SH7612 processors keep the bus unless they receive a bus request. When a bus release request $(\overline{BRLS})$ assertion (low level) is received from an external device, buses are released and a bus grant $(\overline{BGR})$ is asserted (low level) as soon as the bus cycle being executed is completed. When it receives a negated (high level) $\overline{BRLS}$ signal, indicating that the slave has released the bus, it negates the $\overline{BGR}$ (to high level) and begins using the bus. When the bus is released, all output and I/O signals related to the bus interface are changed to high impedance, except for the CKE signal for the synchronous DRAM interface, the $\overline{BGR}$ signal for bus arbitration, and DMA transfer control signals DACK0 and DACK1. When the DRAM has finished precharging, the bus is released. The synchronous DRAM also issues a precharge command to the active bank or banks. After this is completed, the bus is released. The specific bus release sequence is as follows. First, the address bus and data bus become high impedance synchronously with the rise of the clock. Half a cycle later, the bus use enable signal is asserted synchronously with the fall of the clock. Thereafter the bus control signals ( $\overline{BS}$ , $\overline{CSn}$ , $\overline{RAS}$ , $\overline{CAS}$ , $\overline{WEn}$ , $\overline{RD}$ , $\overline{RD}$ , $\overline{WR}$ ) become high impedance with the rise of the clock. These bus control signals are negated at least 1.5 cycles before they become high impedance. Sampling for bus request signals occurs at the clock fall. The sequence when the bus is taken back from the slave is as follows. When the negation of $\overline{BRLS}$ is detected at a clock fall, negation-level driving of the bus control signals starts half a cycle later. The bus use enable signal is then negated at the next clock fall. The address bus and data bus are driven starting at the next clock rise. The bus control signals are asserted and the bus cycle actually starts from the same clock rise at which the address and data signals are driven, at the earliest. Figure 7.50 shows the timing of bus arbitration. To reduce the overhead due to arbitration with a user-designed slave, a number of consecutive bus accesses may be attempted. In this case, to insure dependable refreshing, the design must provide for the slave to release the bus before it has held it for a period exceeding the refresh cycle. The LSI is provided with the REFOUT pin to send a signal requesting the bus while refresh execution is being kept waiting. REFOUT is asserted while refresh execution is being kept waiting until the bus is acquired. When the external slave device receives this signal and releases the bus, the bus is returned to the LSI and refreshing can be executed. Figure 7.50 Bus Arbitration # 7.10 Other Topics #### **7.10.1** Resets The bus state controller is completely initialized only in a power-on reset. All signals are immediately negated, regardless of where in the bus cycle the SH7612 is, and the output buffer is turned off if the bus arbitration mode is slave. Signal negation is simultaneous with turning the output buffer off. All control registers are initialized. In standby mode, sleep mode, and a manual reset, no bus state controller control registers are initialized. When a manual reset is performed, any executing bus cycles are completed, and then the SH7612 waits for an access. When a cache fill or 16-byte DMAC transfer is executing, the CPU or DMAC that is the bus master ends the access in a longword unit, since the access request is canceled by the manual reset. This means that when a manual reset is executed during a cache fill, the cache contents can no longer be guaranteed. During a manual reset, the RTCNT does not count up, so no refresh request is generated, and a refresh cycle is not initiated. To preserve the data of the DRAM and synchronous DRAM, the pulse width of the manual reset must be shorter than the refresh interval. Master mode chips accept arbitration requests even when a manual reset signal is asserted. When a reset is executed only for the chip in master mode while the bus is released, the BGR signal is negated to indicate this. If the BRLS signal is continuously asserted, the bus release state is maintained. ### 7.10.2 Access as Seen from the CPU or DMAC The LSI is internally divided into three buses: cache, internal, and peripheral. The CPU and cache memory are connected to the cache bus, the DMAC and bus state controller are connected to the internal bus, and the low-speed peripherals and mode registers are connected to the peripheral bus. On-chip memory other than cache memory and the user break controller are connected to both the cache bus and the internal bus. The internal bus can be accessed from the cache bus, but not the other way around. The peripheral bus can be accessed from the internal bus, but not the other way around. This results in the following. The DMAC can access on-chip memory other than cache memory, but cannot access cache memory. When the DMAC causes a write to external memory, the external memory contents and the cache contents may be different. When external memory contents are rewritten by a DMA transfer, the cache memory must be purged by software if there is a possibility that the data for that address is present in the cache. When the CPU starts a read access to a cache area, it first takes a cycle to find the cache. If there is data in the cache, it fetches it and completes the access. If there is no data in the cache, a cache data fill is performed via the internal bus, so four consecutive longword reads occur. For misses that occur when byte or word operands are accessed or branches occur to odd word boundaries (4n + 2 addresses), filling is always performed by longword accesses on the chip-external interface. In the cache-through area, the access is to the actual access address. When the access is an instruction fetch, the access size is always longword. For cache-through areas and on-chip peripheral module read cycles, after an extra cycle is added to determine the cycle, the read cycle is started through the internal bus. Read data is sent to the CPU through the cache bus. When word write cycles access the cache area, the cache is searched. When the data of the relevant address is found, it is written here. In write-through mode, the actual write occurs in parallel to this via the internal bus. In write-back mode, since a replace operation occurs for the relevant address, no actual write is performed. When the right to use the internal bus is held, the CPU is notified that the write is completed without waiting for the end of the actual off-chip write. When the right to use the internal bus is not held, as when it is being used by the DMAC or the like, there is a wait until the bus is acquired before the CPU is notified of completion. Accesses to cache-through areas and on-chip peripheral modules work the same as in the cache area, except for the cache search and write. Because the bus state controller has one level of write buffer, the internal bus can be used for another access even when the chip-external bus cycle has not ended. After a write has been performed to low-speed memory off the chip, performing a read or write with an on-chip peripheral module enables an access to the on-chip peripheral module without having to wait for the completion of the write to low-speed memory. During reads, the CPU always has to wait for the end of the operation. To immediately continue processing after checking that the write to the device of actual data has ended, perform a dummy read access to the same address consecutively to check that the write has ended. The bus state controller's write buffer functions in the same way during accesses from the DMAC. A dual-address DMA transfer thus starts in the next read cycle without waiting for the end of the write cycle. When both the source address and destination address of the DMA are external spaces to the chip, however, it must wait until the completion of the previous write cycle before starting the next read cycle. # Section 8 Cache ### 8.1 Introduction The SH7612 incorporates 4 kbytes of 4-way cache memory of mixed instruction/data type. The SH7612 can also be used as 2-kbyte RAM and 2-kbyte cache memory (mixed instruction/data type) by a setting in the cache control register CCR (two-way cache mode). CCR can specify that either instructions or data do not use cache. Both write-through and write-back cache operation methods are supported. Each line of cache memory consists of 16 bytes. Cache memory is always updated in line units. Four 32-bit accesses are required to update a line. Since the number of entries is 64, the six bits (A9 to A4) in each address determine the entry. A four-way set associative configuration is used, so up to four different instructions/data can be stored in the cache even when entry addresses match. To efficiently use four ways having the same entry address, replacement is provided based on a pseudo-LRU (least-recently used) replacement algorithm. The cache configuration is shown in figure 8.1, and addresses in figure 8.2. Figure 8.1 Cache Configuration Figure 8.2 Address # 8.1.2 Register Configuration Table 8.1 shows details of the register used for cache control. **Table 8.1** Register Configuration | Name | Abbrev. | R/W | Initial Value | Address | |------------------------|---------|-----|---------------|------------| | Cache control register | CCR | R/W | H'00 | H'FFFFFE92 | # 8.2 Cache Control Register (CCR) ### 8.2.1 Cache Control Register (CCR) The cache control register (CCR) is used for cache control. CCR must be set and the cache must be initialized before use. CCR is initialized to H'00 by a power-on reset or manual reset. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | W1 | W0 | WB | CP | TW | OD | ID | CE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 7 and 6—Way Specification 1 and 0(W1 to W0): W1 and W0 specify the way when an address array is directly accessed by address specification. | Bit 7: W1 | Bit 6: W0 | Description | | |-----------|-----------|-------------|-----------------| | 0 | 0 | Way 0 | (Initial value) | | | 1 | Way 1 | | | 1 | 0 | Way 2 | | | | 1 | Way 3 | | Bit 5—Write-Back Bit (WB): Specifies the cache operation method when the cache area is accessed. | Bit 5: WB | Description | | |-----------|---------------|-----------------| | 0 | Write-through | (Initial value) | | 1 | Write-back | | Bit 4—Cache Purge (CP): When 1 is written to the CP bit, all cache entries and the valid bits, update bits, and LRU information of all ways are initialized to 0. After initialization is complete, the CP bit reverts to 0. The CP bit always reads 0. | Bit 4: CP | Description | | | | | |-----------|------------------|-----------------|--|--|--| | 0 | Normal operation | (Initial value) | | | | | 1 | Cache purge | | | | | | | | | | | | Note: Always read 0. Bit 3—Two-Way Mode (TW): TW is the two-way mode bit. The cache operates as a four-way set associative cache when TW is 0 and as a two-way set associative cache and 2-kbyte RAM when TW is 1. In the two-way mode, ways 2 and 3 are cache and ways 0 and 1 are RAM. Ways 0 and 1 are read or written by direct access of the data array according to address space specification. | Bit 3: TW | Description | | |-----------|---------------|-----------------| | 0 | Four-way mode | (Initial value) | | 1 | Two-way mode | _ | Bit 2—Data Replacement Disable (OD): OD is the bit for disabling data replacement. When this bit is 1, data fetched from external memory is not written to the cache even if there is a cache miss. Cache data is, however, read or updated during cache hits. OD is valid only when CE is 1. | Bit 2: OD | Description | | |-----------|--------------------------------------------------------------|-----------------| | 0 | Normal operation | (Initial value) | | 1 | Data not replaced even when cache miss occurs in data access | | Bit 1—Instruction Replacement Disable (ID): ID is the bit for disabling instruction replacement. When this bit is 1, an instruction fetched from external memory is not written to the cache even if there is a cache miss. Cache data is, however, read or updated during cache hits. ID is valid only when CE is 1. | Bit 1: ID | Description | | |-----------|----------------------------------------------------------|-----------------| | 0 | Normal operation | (Initial value) | | 1 | Data not replaced even when cache miss occurs in instruc | ction fetch | Bit 0—Cache Enable (CE): CE is the cache enable bit. Cache can be used when CE is set to 1. | Bit 0: CE | Description | | |-----------|----------------|-----------------| | 0 | Cache disabled | (Initial value) | | 1 | Cache enabled | | # 8.3 Address Space and the Cache The address space is divided into six partitions. The cache access operation is specified by addresses. Table 8.2 lists the partitions and their cache operations. For more information on address spaces, see section 7, Bus State Controller. Note that the spaces of the cache area and cache-through area are the same. **Table 8.2** Address Space and Cache Operation | Addresses<br>A31–A29 | Partition | Cache Operation | |----------------------|-------------------------------|-----------------------------------------------------------| | 000 | Cache area | Cache is used when the CE bit in CCR is 1. | | 001 | Cache-through area | Cache is not used. | | 010 | Associative purge area | Cache line of the specified address is purged (disabled). | | 011 | Address array read/write area | Cache address array is accessed directly. | | 110 | Data array read/write area | Cache data array is accessed directly. | | 111 | I/O area | Cache is not used. | # 8.4 Cache Operation #### 8.4.1 Cache Reads This section describes cache operation when the cache is enabled and data is read from the CPU. One of the 64 entries is selected by the entry address part of the address output from the CPU on the cache address bus. The tag addresses of ways 0 through 3 are compared to the tag address parts of the addresses output from the CPU. A match to the tag address of a way is called a cache hit. In proper use, the tag addresses of each way differ from each other, and the tag address of only one way will match. When none of the way tag addresses match, it is called a cache miss. Tag addresses of entries with valid bits of 0 will not match in any case. When a cache hit occurs, data is read from the data array of the way that was matched according to the entry address, the byte address within the line, and the access data size. The data is then sent to the CPU. The address output on the cache address bus is calculated in the CPU's instruction execution phase and the results of the read are written during the CPU's write-back stage. The cache address bus and cache data bus both operate as pipelines in concert with the CPU's pipeline structure. From address comparison to data read requires 1 cycle; since the address and data operate as a pipeline, consecutive reads can be performed at each cycle with no waits (figure 8.3). Figure 8.3 Read Access in Case of a Cache Hit When a cache miss occurs, the way for replacement is determined using the LRU information, and the read address from the CPU is written in the address array for that way. Simultaneously, the valid bit is set to 1. Since the 16 bytes of data for replacing the data array are simultaneously read, the address on the cache address bus is output to the internal address bus and 4 longwords are read consecutively. Access starts with whatever address output to the internal address bus will make the longword that contains the address to be read from the cache come last as the byte address within the line as the order + 4. The read data on the internal data bus is written sequentially to the cache data array. One cycle after the last data is written to the cache data array, it is also output to the cache data bus and the read data is sent to the CPU. The internal address bus and internal data bus also function as pipelines, just like the cache bus (figure 8.4). Figure 8.4 Read Access in Case of a Cache Miss # 8.4.2 Write Access Write-Through Mode: Writing to external memory is performed regardless of whether or not there is a cache hit. The write address output to the cache address bus is used for comparison to the tag address of the cache's address array. If they match, the write data output to the cache data bus in the following cycle is written to the cache data array. If they do not match, nothing is written to the cache data array. The write address is output o the internal address bus 1 cycle later than the cache address bus. The write data is similarly output to the internal data bus 1 cycle later than the cache data bus. The CPU waits until the writes on the internal buses are completed (figure 8.5). Figure 8.5 Write Access (Write-Through) **Write-Back Method:** In the case of a cache hit, the data is written to the data array of the matching way according to the entry address, byte address in the line, and access size, and the update bit of that entry is set to 1. A write is performed only to the data array, not to external memory. A write hit is completed in 2 cycles (figure 8.6). Figure 8.6 Write Access in Case of a Cache Hit (Write-Back) When a cache miss occurs, the way for replacement is determined using the LRU information, and the write address from the CPU is written in the address array for that way. Simultaneously, the valid bit and update bit are set to 1. Since the 16 bytes of data for replacing the data array are simultaneously read when the data on the cache bus is written to the cache, the address on the cache address bus is output to the internal address bus and 4 longwords are read consecutively. Access starts with whatever address output to the internal address bus will make the longword that contains the address to be read from the cache come last as the byte address within the line as the order + 4. The read data on the internal data bus is written sequentially to the cache data array. The internal address bus and internal data bus also function as pipelines, just like the cache bus (figure 8.7). Figure 8.7 Write Access in Case of a Cache Miss (Write-Back Mode) When the update bit of an entry to be replaced in write-back mode is 1, write-back mode to external memory is necessary. To improve performance, the entry to be replaced is first transferred to the write-back buffer, and fetching of the new entry into the cache is given priority over the write-back. When the new entry has been fetched into the cache, the write-back buffer contents are written back to external memory. The cache can be accessed during this write-back. The write-back buffer can hold one cache line (16 bytes) of data and its address. The configuration of the write-back buffer is shown in figure 8.8. Figure 8.8 Write-Back Buffer Configuration ### 8.4.3 Cache-Through Access When reading or writing a cache-through area, the cache is not accessed. Instead, the cache address value is output to the internal address bus. For read operations, the read data output to the internal address bus is fetched and output to the cache data bus, as shown in figure 8.9. The read of the cache-through area is only performed on the address in question. For write operations, the write data on the cache data bus is output to the internal data bus. Writes on the cache through area are compared to the address tag; except for the fact that nothing is written to the data array, the operation is the same as the write shown in figure 8.5. Figure 8.9 Reading Cache-Through Areas ### 8.4.4 The TAS Instruction The TAS instruction reads data from memory, compares it to 0, and reflects the result in the T bit of the status register while setting the most significant bit to 1. It is an instruction for writing to the same address. Accesses to the cache area are handled in the same way as ordinary data accesses. ### 8.4.5 Pseudo-LRU and Cache Replacement When a cache miss occurs during a read, the data of the missed address is read from 1 line (16 bytes) of memory and replaced. This makes it important to decide which of the ways to replace. It is likely that the way least recently used has the highest probability of being the next to be accessed. This algorithm for replacing ways is called the least recently used replacement algorithm, or LRU. The hardware to implement it, however, is complex. For that reason, this cache uses a pseudo-LRU replacement algorithm that keeps track of the order of way access and replaces the oldest way. Six bits of data are used as the LRU information. The bits indicate the access order for 2 ways, as shown in figure 8.10. When the value is 1, access occurred in the direction of the appropriate arrow in the figure. The direction of the arrow can be determined by reading the bit. All the arrows show the oldest access toward that way, which becomes the object of replacement. The access order is recorded in the LRU information bits, so the LRU information is rewritten when a cache hit occurs during a read, when a cache hit occurs during a write, and when replacement occurs after a cache miss. Table 8.3 shows the rewrite values; table 8.4 shows how ways are selected for replacement. After a cache purge by CCR's CP bit, the LRU information is completely zeroized, so the initial order used is way $3 \to \text{way } 2 \to \text{way } 1 \to \text{way } 0$ . Thereafter the way is selected according to the order of access set by the program. Since the replacement will not be correct if the LRU gets an inappropriate value, the address array write function can be used to rewrite. When this is done, be sure not to write a value other than 0 as the LRU information. When CCR's OD bit or ID bit is 1, neither will replace the cache even if a cache miss occurs during data read or instruction fetch. Instead of replacing, the missed address data is read and directly transferred to the CPU. The two-way mode of the cache set by CCR's TW bit can only be implemented by replacing ways 2 and 3. Comparisons of tag addresses of address arrays are carried out on all four ways even in two-way mode, so the valid bit of ways 1 and 0 must be zeroized prior to operation in the two-way mode. Writing for the tag address and valid bit for cache replacement does not wait for the read from memory to be completed. When the memory access is aborted by a reset during replacement or the like, the cache contents and memory contents may be out of sync, so always perform a purge. Figure 8.10 LRU Information and Access Sequence Table 8.3 LRU Information after Update | | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |-------|-------|-------|-------|-------|-------|-------------| | Way 0 | 0 | 0 | 0 | _ | _ | | | Way 1 | 1 | _ | _ | 0 | 0 | <del></del> | | Way 2 | _ | 1 | _ | 1 | _ | 0 | | Way 3 | _ | _ | 1 | _ | 1 | 1 | <sup>—:</sup> Holds the value before update. **Table 8.4** Selection Conditions for Replaced Way | | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | |-------|-------|-------|-------|-------|-------|-------|--| | Way 0 | 1 | 1 | 1 | _ | _ | _ | | | Way 1 | 0 | _ | _ | 1 | 1 | _ | | | Way 2 | _ | 0 | _ | 0 | _ | 1 | | | Way 3 | _ | _ | 0 | _ | 0 | 0 | | <sup>-:</sup> Don't care. # 8.4.6 Cache Initialization Purges of the entire cache area can only be carried out by writing 0 to the CP bit in CCR. Writing to the CP bit initializes the valid bit and update bit of the address array, and all bits of the LRU information, to 0. Cache purges are completed in 1 cycle, but additional time is required for writing to CCR. Always initialize the valid bit, update bit, and LRU before enabling the cache. When the cache is enabled, instruction reads are performed from the cache even during writing to CCR. This means that the prefetched instructions are read from the cache. To do a proper purge, write 0 to CCR's CE bit, then disable the cache and purge. Since CCR's CE bit is cleared to 0 by a power-on reset or manual reset, the cache can be purged immediately by a reset. # 8.4.7 Associative Purges Associative purges invalidate 1 line (16 bytes) corresponding to specific address contents when the contents are in the cache. When the contents of shared addresses are rewritten by one CPU in a multiprocessor configuration, the other CPU cache must be invalidated if it also contains the address. When writing is performed to the address found by adding H'40000000 to the purged address, the valid bit and update bit of the entry storing the address prior to the addition are initialized to 0. 16 bytes are purged in each write, so a purge of 256 bytes of consecutive areas can be accomplished in 16 writes. Access sizes when associative purges are performed should be longword. A purge of 1 line requires 2 cycles. Figure 8.11 Associative Purge Access ### 8.4.8 Data Array Access The cache data array can be read or written directly via the data array read/write area. The access sizes for the data array may be byte, word or longword. Data array accesses are completed in 1 cycle for both reads and writes. Since only the cache bus is used, the operation can proceed in parallel even when another master, such as the DMAC, is using the bus. The data array of way 0 is mapped on H'C00000000 to H'C00003FF, way 1 on H'C0000400 to H'C00007FF, way 2 on H'C0000800 to H'C0000BFF and way 3 on H'C0000C00 to H'C0000FFF. When the two-way mode is being used, the area H'C00000000 to H'C00007FF is accessed as 2 kbytes of on-chip RAM. When the cache is disabled, the area H'C00000000 to H'C0000FFF can be used as 4 kbytes of on-chip RAM. When the contents of the way being used as cache is rewritten using a data array access, the contents of external memory and cache will not match, so this method should be avoided. Figure 8.12 Data Array Access # 8.4.9 Address Array Access The address array of the cache can be accessed so that the contents fetched to the cache can be checked for purposes of program debugging or the like. The address array is mapped on H'60000000 to H'600003FF. Since all of the ways are mapped to the same addresses, ways are selected by rewriting the W1 and W0 bits in CCR. The address array can only be accessed in longwords. When the address array is read, the tag address, LRU information, update bit, and valid bit are output as data. When the address array is written to, the tag address, update bit, and valid bit are written from the cache address bus. This requires that the write address be calculated according to the value to be written, then written. LRU information is written from the cache data bus, but 0 should always be written to prevent malfunctions. Figure 8.13 Address Array Access ## 8.5 Cache Use #### 8.5.1 Initialization Cache memory is not initialized in a reset. Therefore, the cache must be initialized by software before use. Cache initialization clears (to 0) the address array valid bit and all LRU information. The address array write function can be used to initialize each line, but it is simpler to initialize it once by writing 1 to the CP bit in CCR. Figure 8.14 shows how to initialize the cache. ``` W.VOM #H'FE92, R1 MOV.B @R1, R0 AND #H'FE, RO MOV.B #R0, @R1 ; Cache disable #H'10, R0 OR MOV.B R0, @R1 ; Cache purge OR #H'01, R0 MOV.B R0, R1 ; Cache enable ``` Figure 8.14 Cache Initialization # 8.5.2 Purge of Specific Lines Since the SH7612 has no snoop function (for monitoring data rewrites), specific lines of cache must be purged when the contents of cache memory and external memory differ as a result of an operation. For instance, when a DMA transfer is performed to the cache area, cache lines corresponding to the rewritten address area must be purged. All entries of the cache can be purged by setting the CP bit in CCR to 1. However, it is efficient to purge only specific lines if only a limited number of entries are to be purged. An associative purge is used to purge specific lines. Since cache lines are 16 bytes long, purges are performed in a 16-byte units. The four ways are checked simultaneously, and only lines holding data corresponding to specified addresses are purged. When addresses do not match, the data at the specified address is not fetched to the cache, so no purge occurs. ``` ; Purging 32 bytes from address R3 MOV.L #H'40000000, R0 XOR R1, R1 MOV.L R1, @(R0, R3) ADD #16, R3 MOV.L R1, @(R0, R3) ``` Figure 8.15 Purging Specific Addresses When it is troublesome to purge the cache after every DMA transfer, it is recommended that the OD bit in CCR be set to 1 in advance. When the OD bit is 1, the cache operates as cache memory only for instructions. However, when data is already fetched into cache memory, specific lines of cache memory must be purged for DMA transfers. ## 8.5.3 Cache Data Coherency The SH7612's cache memory does not have a snoop function. This means that when data is shared with a bus master other than the CPU, software must be used to ensure the coherency of data. For this purpose, the cache-through area can be used, or a cache purge can be performed with program logic. If the cache-through area is to be used, the data shared by the bus masters is placed in the cache-through area. This makes it easy to maintain data coherency, since access of the cache-through area does not fetch data into the cache. When the shared data is accessed repeatedly and the frequency of data rewrites is low, a lower access speed can adversely affect performance. To purge the cache using program logic, the data updates are detected by the program flow and the cache is then purged. Write-through is specified as the writing method. For example, if the program inputs data from a disk, whenever reading of a unit (such as a sector) is completed, the buffer address used for reading or the entire cache is purged, thereby maintaining coherency. When data is to be handled between two processors, only flags to provide mutual notification of completion of data preparation or completion of a fetch are placed in the cache-through area. The data actually transferred is placed in the cache area and the cache is purged before the first data read to maintain the coherency of the data. When semaphores are used as the means of communication, data coherency can be maintained even when the cache is not purged by utilizing the TAS instruction. The TAS instruction is not read within the cache; the external access is always direct. This means that data can be synchronized with other masters when it is read. When the update unit it is small, specific addresses can be purged, so only the relevant addresses are purged. When the update unit is larger, it is faster to purge the entire cache rather than purging all the addresses in order, and then read in the data previously existing in the cache again from external memory. # 8.5.4 Two-Way Cache Mode The 4-kbyte cache can be used as 2-kbyte RAM and 2-kbyte mixed instruction/data cache memory by setting the TW bit in CCR to 1. Ways 2 and 3 become cache, and ways 0 and 1 become RAM. Initialization is performed by writing 1 to the CP bit in CCR, in the same way as with 4 ways. The valid bit, update bit, and LRU bits are cleared to 0. When the initial values of the LRU information are set to 0, ways 3 and 2 are initially used, in that order. Ways 3 and 2 are subsequently selected for replacement as specified by the LRU information. The conditions for updating the LRU information are the same as for four-way mode, except that the number of ways is two. When designated as 2-kbyte RAM, ways 0 and 1 are accessed by data array access. Figure 8.16 shows the address mapping. Figure 8.16 Address Mapping of 2-kbyte RAM in the Two-Way Mode ## 8.5.5 Usage Notes **Sleep:** When write-back is specified and the sleep state is entered while the cache is in use, the transition must be synchronized with the write-back operation. To do this, execute the SLEEP instruction immediately after accessing external memory space or internal I/O space. **Standby**: Disable the cache before entering the standby mode for power-down operation. After returning from power-down, initialize the cache before use. **Cache Control Register**: Changing the contents of CCR also changes cache operation. The SH7612 makes full use of pipeline operations, so it is difficult to synchronize access. For this reason, change the contents of the cache control register while disabling the cache or after the cache is disabled. After changing the CCR contents, perform a CCR read. # Section 9 Direct Memory Access Controller (DMAC) ## 9.1 Overview The SH7612 includes a two-channel direct memory access controller (DMAC). The DMAC can be used in place of the CPU to perform high-speed data transfers between external devices equipped with DACK (transfer request acknowledge signal), external memories, on-chip memory, memory-mapped external devices, and on-chip peripheral modules (except for the DMAC, BSC, UBC and cache memory). Using the DMAC reduces the burden on the CPU and increases the operating efficiency of the chip as a whole. #### 9.1.1 Features The DMAC has the following features: - Number of channels: 2 - Address space: 4 Gbytes in the architecture - Selectable data transfer unit: Byte, word (2 bytes), longword (4 bytes) or 16-byte unit (16-byte transfers first perform four longword reads and then four longword writes) - Maximum transfer count: 16,777,216 (16M) transfers - With cache hits, CPU instruction processing and DMA operation can proceed in parallel - Single address mode transfers: Either the transfer source or transfer destination (peripheral device) is accessed by a DACK signal (selectable) while the other is accessed by address. One transfer unit of data is transferred in each bus cycle. Devices that can be used in DMA transfer: - External devices with DACK and memory-mapped external devices (including external memories) - Dual address mode transfers: Both the transfer source and transfer destination are accessed by address. One transfer unit of data is transferred in two bus cycles. Device combinations capable of transfer: - Two external memories - External memory and memory-mapped external devices - Two memory-mapped external devices - External memory and on-chip peripheral module (excluding the DMAC, BSC, UBC and cache memory). - Memory-mapped external devices and on-chip peripheral modules (excluding the DMAC, BSC, UBC and cache memory) - Two on-chip peripheral modules (excluding the DMAC, BSC, UBC and cache memory) (access size permitted by a register of the peripheral module that is the transfer source or destination) - On-chip memory and memory-mapped external devices - Two on-chip memory locations - On-chip memory and on-chip peripheral modules (excluding DMAC, BSC, UBC, and cache memory) - On-chip memory and external memory - Transfer requests - External requests (from DREQ pins. DREQ can be detected either by edge or by level, and either active-low or active-high can be selected) - On-chip peripheral module requests (serial communication interface (SCI), serial communication interface with FIFO (SCIF), 16-bit timer pulse unit (TPU), serial I/O) - Auto-request (the transfer request is generated automatically within the DMAC) - Selectable bus modes - Cycle-steal mode - Burst mode - Selectable channel priority levels - Fixed mode - Round-robin mode - An interrupt request can be sent to the CPU when data transfer ends # 9.1.2 Block Diagram Figure 9.1 shows a block diagram of the DMAC. Figure 9.1 DMAC Block Diagram # 9.1.3 Pin Configuration Table 9.1 shows the DMAC pins. **Table 9.1 DMAC Pin Configuration** | Channel | Name | Symbol | I/O | Function | |---------|----------------------------------|--------|-----|---------------------------------------------------------------------------| | 0 | DMA transfer request | DREQ0 | I | DMA transfer request input from external device to channel 0 | | | DMA transfer request acknowledge | DACK0 | 0 | DMA transfer request acknowledge output from channel 0 to external device | | 1 | DMA transfer request | DREQ1 | I | DMA transfer request input from external device to channel 1 | | | DMA transfer request acknowledge | DACK1 | 0 | DMA transfer request acknowledge output from channel 1 to external device | # 9.1.4 Register Configuration Table 9.2 summarizes the DMAC registers. The DMAC has a total of 13 registers. Each channel has six control registers. One control register is shared by both channels. **Table 9.2 DMAC Registers** | Channel | Name | Abbr. | R/W | Initial<br>Value | Address | Access<br>Size*3 | |---------|---------------------------------------------------|---------|---------|------------------|------------|------------------| | 0 | DMA source address register 0 | SAR0 | R/W | Undefined | H'FFFFFF80 | 32 | | | DMA destination address register 0 | DAR0 | R/W | Undefined | H'FFFFFF84 | 32 | | | DMA transfer count register 0 | TCR0 | R/W | Undefined | H'FFFFF88 | 32 | | | DMA channel control register 0 | CHCR0 | R/(W)*1 | H'00000000 | H'FFFFFF8C | 32 | | | Vector number register DMA0 | VCRDMAC | R/(W) | Undefined | H'FFFFFA0 | 32 | | | DMA request/response selection control register 0 | DRCR0 | R/(W) | H'00 | H'FFFFFE71 | 8 <sup>*3</sup> | | 1 | DMA source address register 1 | SAR1 | R/W | Undefined | H'FFFFFF90 | 32 | | | DMA destination address register 1 | DAR1 | R/W | Undefined | H'FFFFFF94 | 32 | | | DMA transfer count register 1 | TCR1 | R/W | Undefined | H'FFFFFF98 | 32 | | | DMA channel control register 1 | CHCR1 | R/(W)*1 | H'00000000 | H'FFFFFF9C | 32 | | | Vector number register DMA1 | VCRDMA1 | R/(W) | Undefined | H'FFFFFA8 | 32 | | | DMA request/response selection control register 1 | DRCR1 | R/(W) | H'00 | H'FFFFFE72 | 8 <sup>*3</sup> | | All | DMA operation register | DMAOR | R/(W)*2 | H'00000000 | H'FFFFFB0 | 32 | Notes: 1.Only 0 can be written to bit 1 of CHCR0 and CHCR1, to clear the flags, after reading 1. <sup>2.</sup> Only 0 can be written to bits 1 and 2 of the DMAOR, to clear the flags, after reading 1. <sup>3.</sup>Access DRCR0 and DRCR1 in byte units. Access all other registers in longword units. # 9.2 Register Descriptions ## 9.2.1 DMA Source Address Registers 0 and 1 (SAR0 and SAR1) DMA source address registers 0 and 1 (SAR0 and SAR1) are 32-bit read/write registers that specify the source address of a DMA transfer. During a DMA transfer, these registers indicate the next source address. (In single-address mode, SAR is ignored in transfers from external devices with DACK to memory-mapped external devices or external memory). In 16-byte unit transfers, always set the value of the source address to a 16-byte boundars (16n address). Operation results cannot be guaranteed if other values are used. Values are retained in a reset, in standby mode, and when the module standby function is used. ## 9.2.2 DMA Destination Address Registers 0 and 1 (DAR0 and DAR1) | Bit: | 31 | 30 | 29 | <br>3 | 2 | 1 | 0 | | |----------------|-----|-----|-----|---------|-----|-----|-----|---| | Bit name: | | | | | | | | ı | | Initial value: | _ | _ | _ | <br>_ | _ | _ | _ | | | R/W: | R/W | R/W | R/W | <br>R/W | R/W | R/W | R/W | | DMA destination address registers 0 and 1 (DAR0 and DAR1) are 32-bit read/write registers that specify the destination address of a DMA transfer. During a DMA transfer, these registers indicate the next destination address. (In single-address mode, DAR is ignored in transfers from memory-mapped external devices or external memory to external devices with DACK). Values are retained in a reset, in standby mode, and when the module standby function is used. # 9.2.3 DMA Transfer Count Registers 0 and 1 (TCR0 and TCR1) | Bit: | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |----------------|-----|-----|-----|----|-----|-----|-----|-----| | Bit name: | | _ | _ | | | | | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 23 | 22 | 21 | | 3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | | Initial value: | _ | _ | _ | | _ | _ | _ | _ | | R/W: | R/W | R/W | R/W | | R/W | R/W | R/W | R/W | DMA transfer count registers 0 and 1 (TCR0 and TCR1) are 32-bit read/write registers that specify the DMA transfer count. The lower 24 of the 32 bits are valid. The value is written as 32 bits, including the upper eight bits. The number of transfers is 1 when the setting is H'00000001, 16,777,215 when the setting is H'00FFFFFF and 16, 777,216 (the maximum) when H'00000000 is set. During a DMA transfer, these registers indicate the remaining transfer count. Set the initial value as the write value in the upper eight bits. These bits always read 0. Values are retained in a reset, in standby mode, and when the module standby function is used. For 16-byte transfers, set the count to 4 times the number of transfers. ## 9.2.4 DMA Channel Control Registers 0 and 1 (CHCR0 and CHCR1) | Bit: | 31 | 30 | 29 | | 19 | 18 | 17 | 16 | |----------------|-----|-----|-----|-----|-----|-----|--------|-----| | Bit name: | _ | _ | _ | | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | R/W: | R | R | R | | R | R | R | R | | | | | | | | | | | | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | Bit name: | DM1 | DM0 | SM1 | SM0 | TS1 | TS0 | AR | AM | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | AL | DS | DL | TB | TA | IE | TE | DE | | 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/(W)* | R/W | Note: Only 0 can be written, to clear the flag. DMA channel control registers 0 and 1 (CHCR0 and CHCR1) are 32-bit read/write registers that control the DMA transfer mode. They also indicate the DMA transfer status. Only the lower 16 of the 32 bits are valid. They are written as 32-bit values, including the upper 16 bits. Write the initial values to the upper 16 bits. These bits always read 0. The registers are initialized to H'00000000 by a reset and in standby mode. Values are retained during a module standby. Bits 15 and 14—Destination Address Mode Bits 1, 0 (DM1, DM0): Select whether the DMA destination address is incremented, decremented or left fixed (in single address mode, DM1 and DM0 are ignored when transfers are made from a memory-mapped external device, on-chip peripheral module, or external memory to an external device with DACK). DM1 and DM0 are initialized to 00 by a reset and in standby mode. Values are retained during a module standby. | Bit 15: DM1 | Bit 14: DM0 | Description | |-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | Fixed destination address (Initial value) | | | 1 | Destination address is incremented (+1 for byte transfer size, +2 for word transfer size, +4 for longword transfer size, +16 for 16-byte transfer size) | | 1 | 0 | Destination address is decremented (–1 for byte transfer size, –2 for word transfer size, –4 for longword transfer size, –16 for 16-byte transfer size) | | | 1 | Reserved (setting prohibited) | Bits 13 and 12—Source Address Mode Bits 1, 0 (SM1, SM0): Select whether the DMA source address is incremented, decremented or left fixed. In single address mode, SM1 and SM0 are ignored when transfers are made from an external device with DACK to a memory-mapped external device, on-chip peripheral module, or external memory. For a 16-byte transfer, the address is incremented by +16 regardless of the SM1 and SM0 values. SM1 and SM0 are initialized to 00 by a reset and in standby mode. Values are retained during a module standby. | Bit 13: SM1 | Bit 12: SM0 | Description | | |-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--| | 0 | 0 | Fixed source address (+16 for 16-byte transfer size)<br>(Initial value) | | | | 1 | Source address is incremented (+1 for byte transfer size, +2 for word transfer size, +4 for longword transfer size, +16 for 16-byte transfer size) | | | 1 | 0 | Source address is decremented (–1 for byte transfer size, –2 for word transfer size, –4 for longword transfer size, +16 for 16-byte transfer size) | | | | 1 | Reserved (setting prohibited) | | Bits 11 and 10—Transfer Size Bits (TS1, TS0): Select the DMA transfer size. When the transfer source or destination is an on-chip peripheral module register for which an access size has been specified, that size must be selected. TS1 and TS0 are initialized to 00 by a reset and in standby mode. Values are retained during a module standby. | Bit 11: TS1 | Bit 10: TS0 | Description | | |-------------|-------------|-------------------------------------|-----------------| | 0 | 0 | Byte unit | (initial value) | | | 1 | Word (2-byte) unit | | | 1 | 0 | Longword (4-byte) unit | | | | 1 | 16-byte unit (4 longword transfers) | | Bit 9—Auto Request Mode Bit (AR): Selects whether auto-request (generated within the DMAC) or module request (an external request or from the on-chip SCI module) is used for the transfer request. The AR bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 9: AR | Description | | |-----------|----------------------------|----------| | 0 | Module request mode value) | (Initial | | 1 | Auto-request mode | | Bit 8—Acknowledge/Transfer Mode Bit (AM): In dual address mode, this bit selects whether the DACK signal is output during the data read cycle or write cycle. In single-address mode, it selects whether to transfer data from memory to device or from device to memory. The AM bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 8: AM | Description | |-----------|-------------------------------------------------------------------------| | 0 | DACK output in read cycle/transfer from memory to device(Initial value) | | 1 | DACK output in write cycle/transfer from device to memory | Bit 7—Acknowledge Level Bit (AL): Selects whether the DACK signal is an active-high signal or an active-low signal. The AL bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 7: AL | Description | | |-----------|-------------------------------------|----------| | 0 | DACK is an active-low signal value) | (Initial | | 1 | DACK is an active-high signal | | Bit 6—DREQ Select Bit (DS): Selects the DREQ input detection method used. The DS bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 6: DS | Description | | |-----------|--------------------------|----------| | 0 | Detected by level value) | (Initial | | 1 | Detected by edge | | Bit 5—DREQ Level Bit (DL): Selects active-high or active-low for the DREQ signal. The DL bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 5: DL | Description | |-----------|-------------------------------------------------------------------------------------------------------------| | 0 | When DS is 0, DREQ is detected by low level; when DS is 1, DREQ is detected by falling edge (Initial value) | | 1 | When DS is 0, DREQ is detected by high level; when DS is 1, DREQ is detected by rising edge | Bit 4—Transfer Bus Mode Bit (TB): Selects the bus mode for DMA transfers. The TB bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 4: TB | Description | | |-----------|-------------------------|----------| | 0 | Cycle-steal mode value) | (Initial | | 1 | Burst mode | | Bit 3—Transfer Address Mode Bit (TA): Selects the DMA transfer address mode. The TA bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 3: TA | Description | | |-----------|--------------------------|----------| | 0 | Dual address mode value) | (Initial | | 1 | Single address mode | | Bit 2—Interrupt Enable Bit (IE): Determines whether or not to request a CPU interrupt at the end of a DMA transfer. When the IE bit is set to 1, an interrupt (DEI) request is setnt to the CPU when the TE bit is set. The IE bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 2: IE | Description | | |-----------|---------------------------|----------| | 0 | Interrupt disabled value) | (Initial | | 1 | Interrupt enabled | | Bit 1—Transfer-End Flag Bit (TE): Indicates that the transfer has ended. When the value in the DMA transfer count register (TCR) becomes 0, the DMA transfer ends normally and the TE bit is set to 1. This flag is not set if the transfer ends because of an NMI interrupt or DMA address error, or because the DME bit of the DMA operation register (DMAOR) or the DE bit was cleared. To clear the TE bit, read 1 from it and then write 0. When the TE bit is set, setting the DE bit to 1 will not enable a transfer. The TE bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 1: TE | Description | | |-----------|-----------------------------------------|----------| | 0 | DMA has not ended or was aborted value) | (Initial | | | Writing 0 after reading 1 in the TE bit | | | 1 | DMA has ended normally (by TCR = 0) | | Bit 0—DMA Enable Bit (DE): Enables or disables DMA transfers. In auto-request mode, the transfer starts when this bit or the DME bit in DMAOR is set to 1. The NMIF and AE bits in DMAOR and the TE bit must be all set to 0. In external request mode or on-chip peripheral module request mode, the transfer begins when the DMA transfer request is received from the relevant device or on-chip peripheral module, provided this bit and the DME bit are set to 1. As with the auto-request mode, the TE bit and the NMIF and AE bits in DMAOR must be all set to 0. The transfer can be stopped by clearing this bit to 0. The DE bit is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 0: DE | Description | | |-----------|------------------------------|----------| | 0 | DMA transfer disabled value) | (Initial | | 1 | DMA transfer enabled | | ## 9.2.5 DMA Vector Number Registers 0 and 1 (VCRDMA0, VCRDMA1) | Bit: | 31 | 30 | 29 | | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | _ | _ | 1 | | _ | 1 | 1 | _ | | Initial value: | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | R/W: | R | R | R | | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | VC7 | VC6 | VC5 | VC4 | VC3 | VC2 | VC1 | VC0 | | Initial value: | _ | _ | _ | _ | _ | _ | _ | | | R/W: | R/W DMA vector number registers 0 and 1 (VCRDMA0, VCRDMA1) are 32-bit read/write registers that set the DMAC transfer-end interrupt vector number. Only the lower eight bits of the 32 are effective. They are written as 32-bit values, including the upper 24 bits. Write the initial values to the upper 24 bits. These bits return 0 if read. Values are retained in a reset, in standby mode, and when the module standby function is used. Bits 31 to 8—Reserved bits: These bits always read 0. The write value should always be 0. Bits 7 to 0—Vector Number Bits 7 to 0 (VC7–VC0): Set the interrupt vector numbers at the end of a DMAC transfer. Interrupt vector numbers of 0–127 can be set. When a transfer-end interrupt occurs, exception handling and interrupt control fetch the vector number and control is transferred to the specified interrupt handling routine. The VC7–VC0 bits retain their values in a reset and in standby mode. As the maximum vector number is 127, 0 must always be written to VC7. ## 9.2.6 DMA Request/Response Selection Control Registers 0 and 1 (DRCR0, DRCR1) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|-----|-----|-----|-----|-----| | Bit name: | _ | _ | _ | RS4 | RS3 | RS2 | RS1 | RS0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R/W | R/W | R/W | R/W | R/W | DMA request/response selection control registers 0 and 1 (DRCR0, DRCR1) are 8-bit read/write registers that set the vector address of the DMAC transfer request source. They are written as 8-bit values. They are initialized to H'00 by a reset, but retain their values in standby mode and a module standby. Bits 7 to 5—Reserved bits: These bits always read 0. The write value should always be 0. Bits 4 to 0—Resource Select Bits 1 and 0 (RS4–RS0): Specify which transfer request to input to the DMAC. Changing the transfer request source must be done when the DMA enable bit (DE) is 0. The RS4–RS0 bits are initialized to 00 by a reset. | Bit 4:<br>RS4 | Bit 3:<br>RS3 | Bit 2:<br>RS2 | Bit 1:<br>RS1 | Bit 0:<br>RS0 | Description | |---------------|---------------|---------------|---------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | 0 | 0 | 0 | 0 | 0 | DREQ (external request) (Initial value) | | | | | | 1 | SCIS RXI (on-chip SCIS receive-data-full interrupt request)* | | | | | 1 | 0 | SCIS TXI (on-chip SCIS transmit-data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | | | 1 | 0 | 0 | Reserved (setting prohibited) | | | | | | 1 | SCIF channel 1 RXI (on-chip FIFO-type SCI channel 1 receive-data-full interrupt request)* | | | | | 1 | 0 | SCIF channel 1 TXI (on-chip FIFO-type SCI channel 1 transmit-data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | 1 0 | | 0 | 0 | 0 | Reserved (setting prohibited) | | 1 | | | 1 | SCIF channel 2 RXI (on-chip FIFO-type SCI channel 2 receive-data-full interrupt request)* | | | | | | 1 | 0 | SCIF channel 2 TXI (on-chip FIFO-type SCI channel 2 transmit-data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | | | 1 | 0 | 0 | TPU TGI0A (on-chip TPU input capture channel 0A interrupt request)* | | | | | | 1 | TPU TGI0B (on-chip TPU input capture channel 0B interrupt request)* | | | | | 1 | 0 | TPU TGI0C (on-chip TPU input capture channel 0C interrupt request)* | | | | | | 1 | TPU TGI0D (on-chip TPU input capture channel 0D interrupt request)* | | Bit 4:<br>RS4 | Bit 3:<br>RS3 | Bit 2:<br>RS2 | Bit 1:<br>RS1 | Bit 0:<br>RS0 | Description | |---------------|---------------|---------------|---------------|---------------|-------------------------------------------------------------------------------------| | 1 | 0 | 0 | 0 | 0 | Reserved (setting prohibited) | | | | | | 1 | SIO channel 0 RXI (on-chip SIO channel 0 receive-data-full interrupt request)* | | | | | 1 | 0 | SIO channel 0 TXI (on-chip SIO channel 0 transmit-data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | | | 1 | 0 | 0 | Reserved (setting prohibited) | | | | | | 1 | SIO channel 1 RXI (on-chip SIO channel 1 receive-data-full interrupt request)* | | | | | 1 | 0 | SIO channel 1 TXI (on-chip SIO channel 1 transmit-<br>data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | | 1 | 0 | 0 | 0 | Reserved (setting prohibited) | | | | | | 1 | SIO channel 2 RXI (on-chip SIO channel 2 receive-data-full interrupt request)* | | | | | 1 | 0 | SIO channel 2 TXI (on-chip SIO channel 2 transmit-<br>data-full interrupt request)* | | | | | | 1 | Reserved (setting prohibited) | | | | 1 | * | * | Reserved (setting prohibited) | Note: \* When a transfer request is generated by an on-chip module, select cycle-steal as the bus mode, dual transfer as the transfer mode, and falling edge detection for the DREQ setting. # 9.2.7 DMA Operation Register (DMAOR) | Bit: | 31 | 30 | 29 | | 11 | 10 | 9 | 8 | |----------------|----|----|----|---|-----|--------|--------|-----| | Bit name: | _ | _ | _ | | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | R/W: | R | R | R | | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | _ | PR | AE | NMIF | DME | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R/W | R/(W)* | R/(W)* | R/W | Note: Only 0 can be written, to clear the flag. The DMA operation register (DMAOR) is a 32-bit read/write register that controls the DMA transfer mode. It also indicates the DMA transfer status. Only the lower four of the 32 bits are valid. DMAOR is written as a 32-bit value, including the upper 28 bits. Write the initial values to the upper 28 bits. These bits always read 0. DMAOR is initialized to H'00000000 by a reset and in standby mode. Values are retained when the module standby function is used. Bits 31 to 4—Reserved bits: These bits always read 0. The write value should always be 0. Bit 3—Priority Mode Bit (PR): Specifies whether a fixed channel priority order or round-robin mode is to be used there are simultaneous transfer requests for multiple channels. It is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 3: PR | Description | | |-----------|------------------------------------------------------------------------------------------------------------|----------| | 0 | Fixed priority (channel 0 > channel 1) value) | (Initial | | 1 | Round-robin (Top priority shifts to bottom after e priority for the first DMA transfer after a reset is 0) | | Bit 2—Address Error Flag Bit (AE): This flag indicates that an address error has occurred in the DMAC. When the AE bit is set to 1, DMA transfer cannot be enabled even if the DE bit in the DMA channel control register (CHCR) is set to 1. To clear the AE bit, read 1 from it and then write 0. Operation is performed up to the DMAC transfer being executed when the address error occurred. AE is initialized to 0 by a reset and in standby mode. It retains its value when the module standby function is used. | Bit 2: AE | Description | | |-----------|--------------------------------------------------------------|----------| | 0 | No DMAC address error value) Read 1 from AE and then write 0 | (Initial | | 1 | | | | 1 | Address error by DMAC | | Bit 1—NMI Flag Bit (NMIF): This flag indicates that an NMI interrupt has occurred. When the NMIF bit is set to 1, DMA transfer cannot be enabled even if the DE bit in the DMA channel control register (CHCR) and the DME bit are set to 1. To clear the NMIF bit, read 1 from it and then write 0. Ends after the DMAC operation executing when the NMI comes in (operation goes to destination). When the NMI interrupt is input while the DMAC is not operating, the NMIF bit is set to 1. The NMIF bit is initialized to 0 by a reset or in the standby mode. Values are held during a module standby. | Bit 1: NMIF | Description | |-------------|----------------------------------------------------------------------| | 0 | No NMIF interrupt (initial value) Read 1 from NMIF and then write 0. | | 1 | NMIF interrupt has occurred | Bit 0—DMA Master Enable Bit (DME): Enables or disables DMA transfers on all channels. A DMA transfer becomes enabled when the DE bit in the CHCR and the DME bit are set to 1. For this to be effective, however, the TE bit in CHCR and the NMIF and AE bits must all be 0. When the DME bit is cleared, all channel DMA transfers are aborted. DME is initialized to 0 by a reset and in standby mode. Its value is retained during a module standby. | Bit 0: DME | Description | | |------------|-----------------------------------------------|----------| | 0 | DMA transfers disabled on all channels value) | (Initial | | 1 | DMA transfers enabled on all channels | _ | # 9.3 Operation When there is a DMA transfer request, the DMAC starts the transfer according to the predetermined channel priority; 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 module request. A transfer can be in either single address mode or dual address mode. The bus mode can be either burst or cycle-steal. #### 9.3.1 DMA Transfer Flow After the DMA source address registers (SAR), DMA destination address registers (DAR), DMA transfer count registers (TCR), DMA channel control registers (CHCR), DMA vector number registers (VCRDMA), DMA request/response selection control registers (DRCR), and DMA operation register (DMAOR) are initialized (initializing sets each register so that ultimately the condition (DE = 1, DME = 1, TE = 0, NMIF = 0, AE = 0) is satisfied), the DMAC transfers data according to the following procedure: - 1. Checks to see if transfer is enabled (DE = 1, DME = 1, TE = 0, NMIF = 0, AE = 0) - 2. When a transfer request comes and transfer is enabled, the DMAC transfers 1 transfer unit of data. (In auto-request mode, the transfer begins automatically when the DE bit and DME bit are set to 1. The TCR value will be decremented by 1.) The actual transfer flows vary depending on the address mode and bus mode. - 3. When the specified number of transfers have been completed (when TCR 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. - 4. When an address error occurs in the DMAC or an NMI interrupt is generated, the transfer is aborted. Transfers are also aborted when the DE bit in CHCR or the DME bit in DMAOR is changed to 0. Figure 9.2 shows a flowchart illustrating this procedure. \* The initial setting sets each register, and lastly, it is set so that (DE = 1, DME = !, TE = 0, NMIF = 0, AE = 0) will be held. Figure 9.2 DMA Transfer Flow ## 9.3.2 DMA Transfer Requests DMA transfer requests are usually generated in either the data transfer source or destination, but they can also be generated by devices that are neither the source nor the destination. Transfers can be requested in three modes: auto-request, external request, and on-chip peripheral module request. The request mode is selected with the AR bit in DMA channel control registers 0 and 1 (CHCR0, CHCR1) and the RS0, RS1, RS2, RS3 and RS4 bits in DMA request/response selection control registers 0 and 1 (DRCR0, DRCR1). Table 9.3 Selecting the DMA Transfer Request Using the AR and RS Bits | CHCR | | | DRCR | | | | | | |------|-----|-----|------|-----|-----|---------------------|-------------------------|--| | AR | RS4 | RS3 | RS2 | RS1 | RS0 | Request Mode | Resource Selection | | | 0 | 0 | 0 | 0 | 0 | 0 | Module request mode | DREQ (external request) | | | | | | | | 1 | _ | SCI RXI | | | | | | | 1 | 0 | _ | SCI TXI | | | | | | 1 | 0 | 1 | _ | SCIF channel 1 RXI | | | | | | | 1 | 0 | _ | SCIF channel 1 TXI | | | | | 1 | 0 | 0 | 1 | _ | SCIF channel 2 RXI | | | | | | | 1 | 0 | _ | SCIF channel 2 TXI | | | | | | 1 | 0 | _ | | TPU TGI0A | | | | | | | | 1 | _ | TPU TGI0B | | | | | | | 1 | 0 | _ | TPU TGI0C | | | | | | | | 1 | _ | TPU TGI0D | | | • | 1 | 0 | 0 | 0 | _ | | SIO channel 0 RXI | | | | | | | 1 | 0 | _ | SIO channel 0 TXI | | | | | | 1 | 0 | 1 | _ | SIO channel 1 RXI | | | | | | | 1 | 0 | _ | SIO channel 1 TXI | | | | | 1 | 0 | 0 | 1 | _ | SIO channel 2 RXI | | | | | | | 1 | 0 | _ | SIO channel 2 TXI | | | 1 | * | * | * | * | * | Auto-request mode | | | **Auto-Request:** 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 CHCR0 and CHCR1 and the DME bit in the DMA operation register (DMAOR) are set to 1, the transfer begins (so long as the TE bits in CHCR0 and CHCR1 and the NMIF and AE bits in DMAOR are all 0). **External Request:** In this mode a transfer is started by a transfer request signal (DREQ) from an external device. Choose one of the modes shown in table 9.4 according to the application system. When DMA transfer is enabled (DE = 1, DME = 1, TE = 0, NMIF = 0, AE = 0), a transfer is performed upon input of a DREQ signal. Table 9.4 Selecting External Request Modes with the TA and AM Bits | С | HCR | Transfer | | | | | |----|-----|------------------------|----------------------------------------|--------------------------------------------------|--------------------------------------------------|--| | TA | AM | Address Mode | Acknowledge Mode | Source | Destination | | | 0 | 0 | Dual address<br>mode | DACK output in read cycle | Any*1 | Any*1 | | | | 1 | Dual address<br>mode | DACK output in write cycle | Any* <sup>1</sup> | Any*1 | | | 1 | 0 | Single address<br>mode | Data transferred from memory to device | External memory or memory-mapped external device | External device with DACK | | | | 1 | Single address<br>mode | Data transferred from device to memory | External device with DACK | External memory or memory-mapped external device | | Notes: 1. External memory, memory-mapped external device, on-chip peripheral module (except DMAC, BSC, UBC, and cache memory) Choose to detect DREQ either by the falling edge or by level using the DS and DL bits in CHCR0 and CHCR1 (DS = 0 is level detection, DS = 1 is edge detection; DL = 0 is active-low, DL = 1 is active-high). The source of the transfer request does not have to be the data transfer source or destination. Table 9.5 Selecting the External Request Signal with the DS and DL Bits | | CHCR | | |----|------|---------------------| | DS | DL | External Request | | 0 | 0 | Level (active-low) | | | 1 | Level (active-high) | | 1 | 0 | Edge (falling) | | | 1 | Edge (rising) | On-Chip Module Request: In this mode, transfers are started by the transfer request signal (interrupt request signal) of an on-chip peripheral module in the SH7612. The transfer request signals are the receive-data-full interrupts (RXI) and transmit-data-empty interrupts (TXI) of the SCI, SCIF, and SIO, and TPU general register signals (table 9.6). If DMA transfer is enabled (DE = 1, DME = 1, TE = 0, NMIF = 0, AE = 0), DMA transfer starts upon the input of a transfer request signal. When RXI (transfer request when the SCI's, SCIF's and SIC's receive data buffer is full) is set as the transfer request, however, the transfer destination must be the receive data register (RDR) of the responded module respectively. Likewise, when TXI (transfer request when the SCI's, SCIF's and SIO's transmit data buffer is empty) is set as the transfer request, the transfer destination must be the respective capable module transmit data register (TDR). The transfer request of TPU is not only restricted. Table 9.6 Selecting On-Chip Peripheral Module Request Mode with the AR and RS Bits | AR | RS4 | RS3 | RS2 | RS1 | RS0 | DMA Transfer<br>Request<br>Source | DMA<br>Transfer<br>Request<br>Signal | Transfer<br>Source | Transfer<br>Destina-<br>tion | Bus<br>Mode | DREQ<br>Setting | |----|-----|-----|-----|-----|-----|-----------------------------------|--------------------------------------|--------------------|------------------------------|-----------------|---------------------| | 0 | 0 | 0 | 0 | 0 | 1 | SCIS receiver | RXI | RDR | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SCIS<br>transmitter | TXI | Any | TDR | Cycle-<br>steal | Edge,<br>active-low | | | | | 1 | 0 | 1 | SCIF channel<br>1 receiver | RXI | SCFRDR1 | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SCIF channel<br>1 transmitter | TXI | Any | SCFTDR1 | Cycle-<br>steal | Edge,<br>active-low | | | | 1 | 0 | 0 | 1 | SCIF channel<br>2 receiver | RXI | SCFRDR2 | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SCIF channel 2 transmitter | TXI | Any | SCFTDR2 | Cycle-<br>steal | Edge,<br>active-low | | | | | 1 | 0 | 0 | TPU channel 0A | TGI0A | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | | TPU channel 0A | TGI0A | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | 1 | TPU channel 0B | TGI0B | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | | TPU channel 0B | TGI0B | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | TPU channel 0C | TGI0C | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | | TPU channel 0C | TGI0C | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | 1 | TPU channel<br>0D | TGI0D | Any | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | | | TPU channel 0D | TGI0D | Any | Any | Cycle-<br>steal | Edge, active-low | Table 9.6 Selecting On-Chip Peripheral Module Request Mode with the AR and RS Bits (cont) | AR | RS4 | RS3 | RS2 | RS1 | RS0 | DMA Transfer<br>Request<br>Source | DMA<br>Transfer<br>Request<br>Signal | Transfer<br>Source | Transfer<br>Destina-<br>tion | Bus<br>Mode | DREQ<br>Setting | |----|-----|-----|-----|-----|-----|-----------------------------------|--------------------------------------|--------------------|------------------------------|-----------------|---------------------| | 0 | 1 | 0 | 0 | 0 | 1 | SIO channel 0 receiver | RXI | SIRDR0 | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SIO channel 0 transmitter | TXI | Any | SITDR0 | Cycle-<br>steal | Edge,<br>active-low | | | | | 1 | 0 | 1 | SIO channel 1 receiver | RXI | SIRDR1 | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SIO channel 1 transmitter | TXI | Any | SITDR1 | Cycle-<br>steal | Edge,<br>active-low | | | | 1 | 0 | 0 | 1 | SIO channel 2 receiver | RXI | SIRDR2 | Any | Cycle-<br>steal | Edge,<br>active-low | | | | | | 1 | 0 | SIO channel 2 transmitter | TXI | Any | SITDR2 | Cycle-<br>steal | Edge,<br>active-low | When outputting transfer requests from the SCI, SCIF, SIO, or TPU, the corresponding interrupt enable bits (TIE, RIE, etc., in SCR) must be set to output the interrupt signals. Note that transfer request signals from on-chip peripheral modules (interrupt request signals) are sent not just to the DMAC but to the CPU as well. When an on-chip peripheral module is specified as the transfer request source, set the priority level values in the interrupt priority level registers (IPRC–IPRE) of the interrupt controller (INTC) at or below the levels set in the I3–I0 bits of the CPU's status register so that the CPU does not accept the interrupt request signal. With the DMA transfer request signals in table 9.6, when DMA transfer is performed a DMA transfer request (interrupt request) from any module will be cleared at the first transfer. ## 9.3.3 Channel Priorities When the DMAC receives simultaneous transfer requests on two channels, it selects a channel according to a predetermined priority order. There are two priority modes, fixed and round-robin. The channel priority is selected by the priority bit, PR, in the DMA operation register (DMAOR). **Fixed Priority Mode:** In this mode, the relative channel priority levels are fixed. When PR is set to 0, the priority, high to low, is channel 0 > channel 1. Figure 9.3 shows an example of a transfer in burst mode. Figure 9.3 Fixed Mode Burst DMA Transfer (Dual Address, Active-Low DREQ Level) In cycle-steal mode, once a channel 0 request is accepted, channel 1 requests are also accepted until the next request is made, which makes more effective use of the bus cycle. When requests come simultaneously for channel 0 and channel 1 when DMA operation is starting, the first is transmitted multiplexed with channel 0 and thereafter channel 1 and channel 0 transfers are performed alternately. Figure 9.4 Fixed Mode Cycle-Steal DMA Transfer (Dual Address, Active-Low DREQ Level) **Round-Robin Mode:** Switches the priority of channel 0 and channel 1, shifting their ability to receive transfer requests. Each time one transfer ends on one channel, the priority shifts to the other channel. The channel on which the transfer just finished is assigned low priority. After reset, channel 0 has higher priority than channel 1. Figure 9.5 shows how the priority changes when channel 0 and channel 1 transfers are requested simultaneously and another channel 0 transfer is requested after the first two transfers end. The DMAC operates as follows: - 1. Transfer requests are generated simultaneously to channels 1 and 0. - 2. Channel 1 has the higher priority, so the channel 1 transfer begins first (channel 0 waits for transfer). - 3. When the channel 1 transfer ends, channel 1 becomes the lower-priority channel. - 4. The channel 0 transfer begins. - 5. When the channel 0 transfer ends, channel 0 becomes the lower-priority channel. - 6. A channel 0 transfer is requested. - 7. The channel 0 transfer begins. - 8. When the channel 0 transfer ends, channel 0 is already the lower-priority channel, so the order remains the same. Figure 9.5 Channel Priority in Round-Robin Mode # 9.3.4 DMA Transfer Types The DMAC supports all the transfers shown in table 9.7. It can operate in single address mode or dual address mode, as defined by how many bus cycles the DMAC takes to access the transfer source and transfer destination. The actual transfer operation timing varies with the DMAC bus mode used: cycle-steal mode or burst mode. **Table 9.7 Supported DMA Transfers** | | Destination | | | | | | | | | |-------------------------------|---------------------------------|--------------------|-----------------------------------------|---------------------------------|-------------------|--|--|--|--| | Source | External<br>Device with<br>DACK | External<br>Memory | Memory-<br>Mapped<br>External<br>Device | On-Chip<br>Peripheral<br>Module | On-Chip<br>Memory | | | | | | External device with DACK | Not available | Single | Single | Not available | Not available | | | | | | External memory | Single | Dual | Dual | Dual | Dual | | | | | | Memory-mapped external device | Single | Dual | Dual | Dual | Dual | | | | | | On-chip peripheral module | Not available | Dual | Dual | Dual* | Dual | | | | | | On-chip memory | Not available | Dual | Dual | Dual | Dual | | | | | Single: Single address mode Dual: Dual address mode Note: Access size enabled by the register of the on-chip peripheral module, which is the source or destination (excludes DMAC, BSC, UBC, and cache memory). #### **Address Modes:** ## Single Address Mode In single address mode, both the transfer source and destination are external; one (selectable) is accessed by a DACK signal while the other is accessed by address. In this mode, the DMAC performs the DMA transfer in one bus cycle by simultaneously outputting a transfer request acknowledge DACK signal to one external device to access it while outputting an address to the other end of the transfer. Figure 9.6 shows an example of a transfer between external memory and external device with DACK. The external device outputs data to the data bus while that data is written in external memory in the same bus cycle. Figure 9.6 Data Flow in Single Address Mode Two types of transfers are possible in single address mode: 1) transfers between external devices with DACK and memory-mapped external devices; and 2) transfers between external devices with DACK and external memory. Transfer requests for both of these must be by means of the external request signal (DREQ). Figure 9.7 shows the DMA transfer timing for single address mode. Figure 9.7 DMA Transfer Timing in Single Address Mode ## • Dual Address Mode In dual address mode, both the transfer source and destination are accessed (selectable) by address. The source and destination can be located externally or internally. The DMAC accesses the source in the read cycle and the destination in the write cycle, so the transfer is performed in two separate bus cycles. The transfer data is temporarily stored in the DMAC. Figure 9.8 shows an example of a transfer between two external memories in which data is read from one memory in the read cycle and written to the other memory in the following write cycle. Figure 9.8 Data Flow in Dual Address Mode In dual address mode transfers, external memory, memory-mapped external devices and onchip peripheral modules can be mixed without restriction. Specifically, this enables transfers between the following: - 1. External memory and external memory transfer. - 2. External memory and memory-mapped external devices. - 3. Memory-mapped external devices and memory-mapped external devices. - 4. External memory and on-chip peripheral modules (excluding the DMAC, BSC, UBC, and cache memory). - 5. Memory-mapped external devices and on-chip peripheral modules (excluding the DMAC, BSC, UBC, and cache memory). - 6. On-chip peripheral modules (excluding the DMAC, BSC, UBC, and cache memory) and on-chip peripheral modules (excluding the DMAC, BSC, UBC, and cache memory).\* - 7. On-chip memory\*2 and on-chip memory transfer. - 8. On-chip memory\* and memory-mapped external devices. - 9. On-chip memory\* and on-chip peripheral modules (excluding the DMAC, BSC, UBC, and cache memory). - 10. On-chip memory\* and external memory. Transfer requests can be auto-request, external requests, or on-chip peripheral module requests. When the transfer source is the SCI, SCIF, or SIO, however, either the transfer source or the transfer destination must be an SCI, SCIF, or SIO register (see table 9.6). Dual address mode outputs DACK in either the read cycle or write cycle. CHCR controls the cycle in which DACK is output. Notes: 1. The access size is that permitted by the register of the on-chip peripheral module that is the transfer source or destination (excluding the DMAC, BSC, UBC, and cache memory). 2. Specify word or byte as the on-chip memory access size. Figure 9.9 shows the DMA transfer timing in dual address mode. Figure 9.9 DMA Transfer Timing in Dual Address Mode (External Memory Space $\rightarrow$ External Memory Space, DACK Output in Read Cycle) **Bus Modes:** There are two bus modes: cycle-steal and burst. Select the mode with the TB bits in CHCR0 and CHCR1. #### • Cycle-Steal Mode In cycle-steal mode, the bus right is given to another bus master after the DMAC transfers one transfer unit (byte, word, longword, or 16 bytes). When another transfer request occurs, the bus right is retrieved from the other bus master and another transfer is performed for one transfer unit. When that transfer ends, the bus right is passed to the other bus master. This is repeated until the transfer end conditions are satisfied. Cycle-steal mode can be used with all categories of transfer destination, transfer source, and transfer request source. The CPU may take the bus twice when an acknowledge signal is output during the write cycle or in single address mode. Figure 9.10 shows an example of DMA transfer timing in cycle-steal mode (dual address mode, DREQ level detection). Figure 9.10 DMA Transfer Timing in Cycle-Steal Mode (Dual Address Mode, DREQ Level Detection) #### Burst Mode In burst mode, once the DMAC gets the bus, the transfer continues until the transfer end condition is satisfied. When external request mode is used with level detection of the DREQ pin, however, negating DREQ will pass the bus to the other bus master after completion of the bus cycle of the DMAC that currently has an acknowledged request, even if the transfer end conditions have not been satisfied. When the transfer request source is an on-chip peripheral module, however, cycle-steal mode is always used. Figure 9.11 shows an example of DMA transfer timing in burst mode (single address mode, DREQ level detection). Figure 9.11 DMA Transfer Timing in Burst Mode (Single Address Mode, DREQ Level Detection) Refreshes cannot be performed during a burst transfer, so ensure that the number of transfers satisfies the refresh request period when a memory requiring refreshing is used. Relationship of Request Modes and Bus Modes by DMA Transfer Category: Table 9.8 shows the relationship between request modes, bus modes, etc., by DMA transfer category. Table 9.8 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<br>(Bytes) | |-----------------|-----------------------------------------------------------------|-------------------|-------------|-----------------------------| | Single | External device with DACK and external memory | External | B/C | 1/2/4/16 | | | External device with DACK and memory-mapped external device | External | B/C | 1/2/4/16 | | Dual | External memory and external memory | All*1 | B/C | 1/2/4/16 | | | External memory and memory-mapped external device | All <sup>*1</sup> | B/C | 1/2/4/16 | | | Memory-mapped external device and memory-mapped external device | All <sup>*1</sup> | B/C | 1/2/4/16 | | | External memory and on-chip peripheral module | All*2 | B/C*3 | 1/2/4/16*4 | | | Memory-mapped external device and on-chip peripheral module | All <sup>*2</sup> | B/C*3 | 1/2/4/16 <sup>*4</sup> | | | On-chip peripheral module and on-chip peripheral module | All* <sup>2</sup> | B/C*3 | 1/2/4/16 <sup>*4</sup> | | | On-chip memory and on-chip memory | Auto | B/C | 1/2 | | | On-chip memory and memory-mapped external device | All <sup>*5</sup> | B/C | 1/2 | | | On-chip memory and on-chip peripheral module | All*2 | B/C*3 | 1/2 | | | On-chip memory and external memory | All*6 | B/C | 1/2 | | | | | | | B: Burst, C: Cycle-steal Notes: 1. External requests and auto-requests are both available. However, the SCI, SCIF and SIO cannot be specified as the transfer request source, except for on-chip peripheral module requests. - External requests, auto-requests and on-chip peripheral module requests are all available. However, the transfer destination or transfer source must be the SCI, SCIF and SIO when the SCI, SCIF and SIO is the transfer request source. - 3. If the transfer request source is the SCI, SIO and TPU, cycle-steal (C) only (DREQ by edge detection, active low). - 4. The access size permitted by the register of the on-chip peripheral module which is the transfer destination or source. - 5. In transfer from on-chip memory to a memory-mapped external device, set DACK for write-time output. - In transfer from a memory-mapped external device to on-chip memory, set DACK for read-time output. - 6. In transfer from on-chip memory to external memory, set DACK for write-time output. In transfer from external memory to on-chip memory, set DACK for read-time output. Bus Mode and Channel Priority: When a given channel (1) is transferring in burst mode and there is a transfer request to a channel (0) with a higher priority, the transfer of the channel with higher priority (0) will begin immediately. When channel 0 is also operating in the burst mode, the channel 1 transfer will continue as soon as the channel 0 transfer has completely finished. When channel 0 is in cycle-steal mode, channel 1 will begin operating again after channel 0 completes the transfer of one transfer unit, but the bus will then switch between the two in the order channel 1, channel 0, channel 1, channel 0. Since channel 1 is in burst mode, it will not give the bus to the CPU. This example is illustrated in Figure 9.12. Figure 9.12 Bus Status when Multiple Channels are Operating (In the case of the priorty channel 0 > channel 1 in the burst mode and channel 0 in the cycle steal mode being set) #### 9.3.5 Number of Bus Cycles The number of states in the bus cycle when the DMAC is the bus master is controlled by the bus control register (BCR1) and wait state control register (WCR) of the bus state controller (BSC) just as it is when the CPU is the bus master. For details, see section 7, Bus State Controller (BSC). #### 9.3.6 DMA Transfer Request Acknowledge Signal Output Timing DMA transfer request acknowledge signal DACKn is output synchronous to the DMAC address output specified by the channel control register AM bit of the address bus. The timing is normally to have the acknowledge signal become valid when the DMA address output begins and become invalid 0.5 cycles before the address output ends. (See figure 9.11.) The output timing of the acknowledge signal varies with the settings of the connected memory space. The output timing of acknowledge signals in the memory spaces is shown in figure 9.13. Figure 9.13 Example of DACK Output Timing ## Acknowledge Signal Output when External Memory Is Set as Ordinary Memory Space Figure 9.14 DACK Output in Ordinary Space Accesses (AM = 0) Figure 9.15 DACK Output in Ordinary Space Accesses (AM = 1) The timing at which the acknowledge signal is output is the same in the DMA read and write cycles specified by the AM bit (figures 9.14 and 9.15). When DMA address output begins, the acknowledge signal becomes valid; 0.5 cycles before address output ends, it becomes invalid. If a wait is inserted in this period and address output is extended, the acknowledge signal is also extended. Figure 9.16 DACK Output in Ordinary Space Accesses (AM = 0, Longword Access to 16-Bit External Device) Figure 9.17 DACK Output in Ordinary Space Accesses (AM = 0, Longword Access to 8-Bit External Device) Figure 9.18 DACK Output in Ordinary Space Accesses (AM = 0, Word Access to 8-Bit External Device) In a longword access of a 16-bit external device (figure 9.16) or an 8-bit external device (figure 9.17), or a word access of an 8-bit external device (figure 9.18), the lower and upper addresses are output 2 and 4 times in each DMAC access in order to align the data. For all of these addresses, the acknowledge signal becomes valid simultaneous with the start of output and becomes invalid 0.5 cycles before the address output ends. When multiple addresses are output in a single access to align data for synchronous DRAM, DRAM, or burst ROM, an acknowledge signal is output to those addresses as well. Acknowledge Signal Output when External Memory is Set as Synchronous DRAM: When the external memory is set at SDRAM, the output timing of DACK becomes valid at the same time when DMA address starts, and it becomes invalid at the same time when the address ends. Figure 9.19 DACK Output in Synchronous DRAM Burst Read (Auto-Precharge, AM = 0) Figure 9.20 DACK Output in Synchronous DRAM Single Read (Auto-Precharge, AM = 0) Figure 9.21 DACK Output in Synchronous DRAM Write (Auto-Precharge, AM = 1) When external memory is set as synchronous DRAM auto-precharge and AM = 0, the acknowledge signal is output across the row address, read command, wait and read address of the DMAC read (figure 9.19). Since the synchronous DRAM read has only burst mode, during a single read an invalid address is output; the acknowledge signal, however, is output on the same timing (figure 9.20). At this time, the acknowledge signal is extended until the write address is output after the invalid read. When AM = 1, the acknowledge signal is output across the row address and column address of the DMAC write (figure 9.21). Figure 9.22 DACK Output in Synchronous DRAM Burst Read (Bank Active, Same Row Address, AM = 0) Figure 9.23 DACK Output in Synchronous DRAM Burst Read (Bank Active, Different Row Address, AM = 0) When external memory is set as bank active synchronous DRAM, during a burst read the acknowledge signal is output across the read command, wait and read address when the row address is the same as the previous address output (figure 9.22). When the row address is different from the previous address, the acknowledge signal is output across the precharge, row address, read command, wait and read address (figure 9.23). Figure 9.24 DACK Output in Synchronous DRAM Single Read (Bank Active, Same Row Address, AM = 0) Figure 9.25 DACK Output in Synchronous DRAM Single Read (Bank Active, Different Row Address, AM = 0) When external memory is set as bank active synchronous DRAM, during a single read the acknowledge signal is output across the read command, wait and read address when the row address is the same as the previous address output (figure 9.24). When the row address is different from the previous address, the acknowledge signal is output across the precharge, row address, read command, wait and read address (figure 9.25). Since the synchronous DRAM read has only burst mode, during a single read an invalid address is output; the acknowledge signal is output on the same timing. At this time, the acknowledge signal is extended until the write address is output after the invalid read. Figure 9.26 DACK Output in Synchronous DRAM Write (Bank Active, Same Row Address, AM = 1) Figure 9.27 DACK Output in Synchronous DRAM Write (Bank Active, Different Row Address, AM = 1) When external memory is set as bank active synchronous DRAM, during a write the acknowledge signal is output across the wait and column address when the row address is the same as the previous address output (figure 9.26). When the row address is different from the previous address, the acknowledge signal is output across the precharge, row address, wait and column address (figure 9.27). #### • SDRAM one-cycle write When a one-cycle write is performed to synchronous DRAM, the DACK signal is synchronized with the rising edge of the clock. A request by the request signal is accepted while the clock is high during DACK output. | Transfer Width | Byte/Word/Longword<br>Transfer | DREQ Detection<br>Method | Level Detection | | |-----------------------|--------------------------------|--------------------------|-----------------|--| | Transfer bus mode | Burst mode | DACK output timing | Write DACK | | | Transfer address mode | Single mode | Bus cycle | Basic bus cycle | | Figure 9.28 SDRAM One-Cycle Write Timing Acknowledge Signal Output when External Memory is Set as DRAM Figure 9.29 DACK Output in Normal DRAM Accesses (AM = 1 or 0) Figure 9.30 DACK Output in DRAM Burst Accesses (Same Row Address, AM = 1 or 0) Figure 9.31 DACK Output in DRAM Burst Accesses (Different Row Address, AM = 1 or 0) When external memory is set as DRAM and a row address is output during a read or write, the acknowledge signal is output across the row address and column address (figures 9.29–9.31). ## Acknowledge Signal Output When External Memory Is Set as Burst ROM Figure 9.32 DACK Output in Nibble Accesses of Burst ROM When external memory is set as burst ROM, the acknowledge signal is output synchronous to the DMAC address (no dual writes allowed) (figure 9.32). #### 9.3.7 DREQ Pin Input Detection Timing In external request mode, DREQ pin signals are usually detected at the falling edge of the clock pulse (CKIO). When a request is detected, a DMAC bus cycle is produced four cycles later at the earliest and a DMA transfer performed. After the request is detected, the timing of the next input detection varies with the bus mode, address mode, method of DREQ input detection, and the memory connected. **DREQ Pin Input Detection Timing In Cycle-Steal Mode:** In cycle-steal mode, once a request is detected from the DREQ pin, request signal detection is not performed until DACK signal output in the next external bus cycle. In cycle-steal mode, request detection is performed from DACK signal output until a request is detected. In the case of a bus mode change or 16-byte transfer, the first DACK signal is the request acceptance start signal. Once a request has been accepted, it cannot be canceled midway. The timing from the detection of a request until the next time requests are detectable is shown below. Cycle-Steal Mode Edge Detection | Transfer Width | Byte/Word/Longword | DREQ Detection<br>Method | Edge Detection | |-----------------------|--------------------|--------------------------|----------------------| | Transfer bus mode | Cycle-steal mode | DACK output timing | Read DACK/write DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.33 DREQ Pin Input Detection Timing in Cycle-Steal Mode with Edge Detection Figure 9.34 When a16-Bit External Device is Connected Figure 9.35 When an 8-Bit External Device is Connected • Cycle-Steal Mode Edge Detection—16-Bit Transfer With 16-byte transfer, the first request signal is the first transfer request, and the second transfer request is accepted when the next request signal is accepted. The third and fourth requests are accepted in the same way. | Transfer Width | 16-Byte Transfer | DREQ Detection Method | Edge Detection | |-----------------------|------------------|-----------------------|-------------------------| | Transfer bus mode | Cycle-steal mode | DACK output timing | Read DACK/write<br>DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.36 DREQ Pin Input Detection Timing in Cycle-Steal Mode with Edge Detection (16-Byte Transfer Setting) Cycle-Steal Mode Level Detection In level detection mode, too, a request cannot be canceled once accepted. | Transfer Width | Byte/Word/Longword | DREQ Detection<br>Method | Level Detection | |-----------------------|--------------------|--------------------------|-------------------------| | Transfer bus mode | Cycle-steal mode | DACK output timing | Read DACK/write<br>DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.37 DREQ Pin Input Detection Timing in Cycle-Steal Mode with Level Detection (Byte/Word/Longword Setting) Figure 9.38 When a 16-Bit External Device is Connected Figure 9.39 When an 8-Bit External Device is Connected • Cycle-Steal Mode Level Detection—16-Byte Transfer With 16-byte transfer, the first request signal is the first transfer request, and the second transfer request is accepted when the next request signal is accepted. The third and fourth requests are accepted in the same way. | Transfer Width | 16-Byte Transfer | DREQ Detection<br>Method | Level Detection | |-----------------------|------------------|--------------------------|----------------------| | Transfer bus mode | Cycle-steal mode | DACK output timing | Read DACK/write DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.40 DREQ Pin Input Detection Timing in Cycle-Steal Mode with Level Detection (16-Byte Transfer Setting) **DREQ Pin Input Detection Timing in Burst Mode:** In burst mode, the request detection timing is different for edge detection and level detection of DREQ input. With edge detection of DREQ input, once a request is detected, DMA transfer continues until the transfer end condition is satisfied, regardless of the state of the DREQ pin. Request detection is not performed during this time. When the transfer start conditions are fulfilled after the end of transfer, request detection is performed again every cycle. With level detection of DREQ input, if a request for the same channel is detected in the following request detection cycle, that channel will continue to operate, but if a request is not input, a bus cycle for another channel or another bus master will be executed. Burst Mode Level Detection—Byte/Word/Longword Size | Transfer Width | Byte/Word/Longword | Method | Level Detection | |-----------------------|--------------------|--------------------|----------------------| | Transfer bus mode | Burst mode | DACK output timing | Read DACK/write DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.41 DREQ Pin Input Detection Timing in Burst Mode with Level Detection (Byte/Word/Longword Setting) With level detection in burst mode, two transfers are performed on the first acceptance of the request signal, and the third transfer request signal is accepted by the first DACK signal. Subsequently, the fifth and sixth transfer requests are accepted in turn. However, if TCR = 1, the operation ends after one transfer on acceptance of the first request. Burst Mode Level Detection—16-Byte Transfer With 16-byte transfer, the first request signal is the first transfer request, and the second transfer request is accepted when the next request signal is accepted. The third and fourth requests are accepted in the same way. | Transfer Width | 16-Byte Transfer | DREQ Detection Method | Level Detection | |-----------------------|------------------|-----------------------|----------------------| | Transfer bus mode | Burst mode | DACK output timing | Read DACK/write DACK | | Transfer address mode | Dual/single mode | Bus cycle | Basic bus cycle | Figure 9.42 DREQ Pin Input Detection Timing in Burst Mode with Level Detection (16-Byte Transfer Setting) #### 9.3.8 DMA Transfer End The DMA transfer ending conditions vary when channels end individually and when both channels end together. **Conditions for Channels Ending Individually:** When either of the following conditions is met, the transfer will end in the relevant channel only: - The DMA transfer count register (TCR) value becomes 0. - The DMA enable bit (DE) of the DMA channel control register (CHCR) is cleared to 0. - The value of the channel's DMA transfer count register (TCR) becomes 0. When the TCR value becomes 0, the DMA transfer for that channel ends and the transfer-end flag bit (TE) is set in CHCR. If the IE (interrupt enable) bit has already been set, a DMAC interrupt (DEI) request is sent to the CPU. Set the transfer number × 4 when transferred in 16 bytes. - The DE bit of the DMA channel control register (CHCR) is cleared to 0. When the DMA enable bit (DE) in CHCR is cleared, DMA transfers in the affected channel are halted. The TE bit is not set when this happens. **Conditions for Both Channels Ending Simultaneously:** Transfers on both channels end when either of the following conditions is met: - The NMIF (NMI flag) bit or AE (address error flag) bit is set to 1 in DMAOR. - The DMA master enable (DME) bit is cleared to 0 in DMAOR. - The NMIF (NMI flag) bit or AE (address error flag) bit is set to 1 in DMAOR. When an NMI interrupt or DMAC address error occurs and the NMIF or AE bit is set to 1 in DMAOR, all channels stop their transfers. The DMA source address register (SAR), designation address register (DAR), and transfer count register (TCR) are all updated by the transfer immediately preceding the halt. When this transfer is the final transfer, TE = 1 and the transfer ends. To resume transfer after NMI interrupt exception handling or address error exception handling, clear the appropriate flag bit. When the DE bit is then set to 1, the transfer on that channel will restart. To avoid this, keep its DE bit at 0. In dual address mode, DMA transfer will be halted after the completion of the following write cycle even when the address error occurs in the initial read cycle. SAR, DAR and TCR are updated by the final transfer. - The DMA master enable (DME) bit in DMAOR is cleared to 0. Clearing the DME bit in DMAOR forcibly aborts the transfers on both channels at the end of the current bus cycle. When the transfer is the final transfer, TE = 1 and the transfer ends. # 9.4 Examples of Use # 9.4.1 DMA Transfer Between On-Chip SCI and External Memory In the following example, data received on the on-chip serial communication interface (SCI) is transferred to external memory using DMAC channel 1. Table 9.9 shows the transfer conditions and register settings. Table 9.9 Register Settings for Transfers between On-Chip SCI and External Memory | Transfer Conditions | Register | Setting | |--------------------------------------------------------------|----------|---------------------| | Transfer source: RDR of on-chip SCI | SAR1 | H'FFFFE05 | | Transfer destination: external memory (word space) | DAR1 | Destination address | | Number of transfers: 64 | TCR1 | H'0040 | | Transfer destination address: incremented | CHCR1 | H'4045 | | Transfer source address: fixed | | | | Bus mode: cycle-steal | | | | Transfer unit: byte | | | | DEI interrupt request generated at end of transfer (DE = 1) | | | | Channel priority: Fixed (0 > 1) (DME = 1) | DMAOR | H'0001 | | Transfer request source (transfer request signal): SCI (RXI) | DRCR1 | H'01 | Note: Check the CPU interrupt level when interrupts are enabled in the SCI. # 9.5 Usage Notes - 1. DMA request/response selection control registers 0 and 1 (DRCR0 and DRCR1) should be accessed in bytes. All other registers should be accessed in longword units. - 2. Before rewriting CHCR0, CHCR1, DRCR0, and DRCR1, first clear the DE bit for the specified channel to 0 or clear the DME bit in DMAOR to 0. - 3. When the DMAC is not operating, the NMIF bit in DMAOR is set even when an NMI interrupt is input. - 4. The DMAC cannot access the cache memory. - 5. Set to standby mode after the DME bit in DMAOR is set to 0. - 6. Do not access the DMAC, BSC, and UBC on-chip peripheral modules. - 7. Do not access the cache (address array, data array, associative purge area). - 8. Note that when level detection of the request signal is used in single address mode, the request signal may be detected before DACK is output. - 9. At the time of the clock ratio 1:1,60MHz operation, do not do the transfer accompanying the dack output against the normal space with 8-bit word, long word accesses and 16-bit long word accesses. # Section 10 Division Unit ## 10.1 Overview The division unit (DIVU) divides 64 bits by 32 bits and 32 bits by 32 bits. The results are expressed as a 32-bit quotient and a 32-bit remainder. When the operation produces an overflow, an interrupt can be generated as specified. #### 10.1.1 Features The division unit has the following features: - Performs signed division of 64 bits by 32 bits and 32 bits by 32 bits - Handles 32-bit quotient, 32-bit remainder - Completes operation execution in 39 cycles - Controls enabling/disabling of overflow interrupts - Even during the division process, instructions not accessing the division unit can be parallelprocessed ## 10.1.2 Block Diagram Figure 10.1 shows a block diagram of the division unit. Figure 10.1 Division Unit Block Diagram ## 10.1.3 Register Configuration Table 10.1 shows the register configuration of the division unit. **Table 10.1 Register Configuration** | Register | Abbr. | R/W | Initial Value | Address | Access Size*1 | |-----------------------------------------|--------|-----|---------------|------------|---------------| | Divisor register | DVSR | R/W | Undefined | H'FFFFFF00 | 32 | | Dividend register L for 32-bit division | DVDNT | R/W | Undefined | H'FFFFFF04 | 32 | | Division control register | DVCR | R/W | H'00000000 | H'FFFFFF08 | 16, 32 | | Vector number setting register DIV | VCRDIV | R/W | Undefined*2 | H'FFFFFF0C | 16, 32 | | Dividend register H | DVDNTH | R/W | Undefined | H'FFFFFF10 | 32 | | Dividend register L | DVDNTL | R/W | Undefined | H'FFFFFF14 | 32 | Notes: 1. Accesses to the division unit are read and written in 32-bit units. DVCR and VCRDIV permit 16 and 32-bit accesses. When registers other than DVCR and VCRDIV are accessed with word accesses, undefined values are read or written. 2. The initial value of VCRDIV is H'0000\*\*\*\* (asterisks represent undefined values). # 10.2 Description of Registers #### 10.2.1 Divisor Register (DVSR) The divisor register (DVSR) is a 32-bit read/write register in which the divisor for the operation is written. It is not initialized by a power-on reset or manual reset, in standby mode, or during module standbys. ## 10.2.2 Dividend Register L for 32-Bit Division (DVDNT) The dividend register L for 32-bit division (DVDNT) is a 32-bit read/write register in which the 32-bit dividend used for 32-bit $\div$ 32-bit division operations is written. When 32-bit $\div$ 32-bit division is run, the value set as the dividend is lost and the quotient written at the end of division. When this register is written to, the same value is written in the DVDNTL register. The MSB written is sign-extended in the DVDNTH register. Writing to this register starts the 32-bit $\div$ 32-bit division operation. It is not initialized by a power-on reset or manual reset, in standby mode, or during module standbys. ## 10.2.3 Division Control Register (DVCR) | Bit: | 31 | 30 | 29 | <br>3 | 2 | 1 | 0 | |----------------|----|----|----|-------|---|-------|-----| | Bit name: | _ | _ | | <br>_ | _ | OVFIE | OVF | | Initial value: | 0 | 0 | 0 | <br>0 | 0 | 0 | 0 | | R/W: | R | R | R | <br>R | R | R/W | R/W | The division control register (DVCR) is a 32-bit read/write register, but is also 16-bit accessible. It controls enabling/disabling of the overflow interrupt. This register is initialized to H'00000000 by a power-on reset or manual reset. It is not initialized in standby mode or during module standbys. Bits 31 to 2—Reserved bits: These bits always read 0. The write value should always be 0. Bit 1— OVF Interrupt Enable (OVFIE): Selects enabling or disabling of the OVF interrupt request (OVFI) upon overflow. Bit 1: OVFIE Description Interrupt request (OVFI) caused by OVF disabled value) Interrupt request (OVFI) caused by OVF enabled Note: Always set the OVFIE bit before starting the operation whenever executing interrupt handling for overflows. Bit 0— Overflow Flag (OVF): Flag indicating an overflow has occurred. | Bit 0: OVF | Description | | |------------|---------------------------------|----------| | 0 | No overflow has occurred value) | (Initial | | 1 | Overflow has occurred | | #### **10.2.4** Vector Number Setting Register DIV (VCRDIV) | Bit: | 31 | 30 | 29 | <br>19 | 18 | 17 | 16 | |----------------|-----|-----|-----|---------|-----|-----|-----| | Bit name: | _ | _ | _ | <br> | _ | _ | _ | | Initial value: | 0 | 0 | 0 | <br>0 | 0 | 0 | 0 | | R/W: | R | R | R | <br>R | R | R | R | | | | | | | | | | | Bit: | 15 | 14 | 13 | <br>3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | Initial value: | _ | _ | _ | <br>_ | _ | _ | _ | | R/W: | R/W | R/W | R/W | <br>R/W | R/W | R/W | R/W | Vector number setting register DIV (VCRDIV) is a 32-bit read/write register, but is also 16-bit accessible. The destination vector number is set in VCRDIV when an interrupt occurs in the division unit due to an overflow or underflow. Values can be set in the 16 bits from bit 15 to bit 0, but only the last 7 bits (bits 6–0) are valid. Always set 0 for the 9 bits from bit 15 to bit 7. VCRDIV is not initialized by a power-on reset or manual reset, in standby mode, or during module standbys. Bits 31 to 7— Reserved bits: These bits always read 0. The write value should always be 0. Bits 6 to 0— Interrupt Vector Number. Sets the interrupt destination vector number. Only the 7 bits 6–0 are valid (as the vector number). ### 10.2.5 Dividend Register H (DVDNTH) Dividend register H (DVDNTH) is a 32-bit read/write register in which the upper 32 bits of the dividend used for 64 bit ÷ 32 bit division operations are written. When a division operation is executed, the value set as the dividend is lost and the remainder written here at the end of the operation. The initial value of DVDNTH is undefined, and its value is also undefined after a power-on reset or manual reset, in standby mode, and during in module standbys. When the DVDNT register is set with a dividend value, the previous DVDNTH value is lost and the MSB of the DVDNT register is extended to all bits in the DVDNTH register. ### 10.2.6 Dividend Register L (DVDNTL) Dividend register L (DVDNTL) is a 32-bit read/write register in which the lower 32 bits of the dividend used for 64-bit $\div$ 32-bit division operations are written. When a value is set in this register, the 64-bit $\div$ 32-bit division operation begins. The value written in the DVDNT register for 32-bit $\div$ 32-bit division is also set in this register. When a 64-bit $\div$ 32-bit division operation is executed, the value set as the dividend is lost and the quotient written here at the end of the operation. The contents of this register are undefined after a power-on reset or manual reset, in standby mode, and during module standbys. ### 10.3 Operation #### **10.3.1 64-Bit** ÷ **32-Bit** Operations 64-bit ÷ 32-bit operations work as follows: - 1. The 32-bit divisor is set in the divisor register (DVSR). - The 64-bit dividend is set in dividend registers H and L (DVDNTH and DVDNTL). First set the value in DVDNTH. When a value is written to DVDNTL, the 64-bit ÷ 32-bit operation begins. - 3. This unit finishes a single operation in 39 cycles (starting from the setting of the value in DVDNTL). When an overflow occurs, however, the operation ends in 6 cycles. See section 10.3.3, Handling of Overflows, for more information. Note that operation is signed. - 4. After the operation, the 32-bit remainder is written to DVDNTH and the 32-bit quotient is written to DVDNTL. #### **10.3.2 32-Bit** ÷ **32-Bit** Operations 32-bit ÷ 32-bit operations work as follows: - 1. The 32-bit divisor is set in the divisor register (DVSR). - 2. The 32-bit dividend is set in dividend register L (DVDNT) for 32-bit division. When a value is written to DVDNT, the 32-bit ÷ 32-bit operation begins. - 3. This unit finishes a single operation in 39 cycles (starting from the setting of the value in DVDNT). When an overflow occurs, however, the operation ends in 6 cycles. See section 10.3.3, Handling of Overflows, for more information. Note that the operation is signed. - 4. After the operation, the 32-bit remainder is written to DVDNTH and the 32-bit quotient is written to DVDNT. #### 10.3.3 Handling of Overflows When the results of operations exceed the ranges expressed as signed 32 bits (when, in division between two negative numbers, the quotient is the maximum value and a remainder (negative number) is generated) or when the divisor is 0, an overflow will result. When an overflow occurs, the OVF bit is set and an overflow interrupt is generated if interrupt generation is enabled (the OVFIE bit in DVCR is 1). The operation will then end with the result after 6 cycles of operation stored in the DVDNTH and DVDNTL registers. If interrupt generation is disabled (the OVFIE bit is 0), the operation will end with the operation result at 6 cycles set in DVDNTH and the maximum value H'7FFFFFFF or minimum value H'80000000 set in DVDNTL. In the SH7612, the maximum value results when a positive quotient overflows; the minimum value results when a negative quotient overflows. The first three cycles of the 6 cycles executed when an overflow occurs are used for flag setting within the division unit and the next three for division. # 10.4 Usage Notes #### 10.4.1 Access All accesses to the division unit except DVCR and VCRDIV must be 32-bit reads or writes. Word accesses to registers other than DVCR and VCRDIV result in reading or writing of undefined values. In the division unit, a read instruction is extended for one cycle immediately after an instruction that writes to a register, even if the register is the same, to ensure that the value written is accurately set in the destination register in the division unit. When a read or write instruction is issued while the division unit is operating, the read or write instruction is continuously extended until the operation ends. This means that instructions that do not access the division unit can be parallel-processed. When an instruction is executed that writes to any register of the division unit immediately following an instruction that writes to the division start-up registers (DVDNTL or DVDNT), the correct value may not be set in the start-up register. Specify an instruction other than one that writes to a division unit register for the instruction immediately following instruction that writes to a start-up register. Because of the above restrictions, efficient processing can be achieved by executing instructions that do not access the division unit for 39 cycles after starting the operation, then issuing a read instruction after the 39th cycle. #### 10.4.2 Overflow Flag When an overflow occurs, the overflow flag (OVF) is set and is not automatically reset. When OVF is set, the operation is not affected. When necessary, clear it before the operation. The states of registers when overflow occurs are shown in table 10.2. **Table 10.2 Overflow Processing** | Register | Overflow Interrupt Enabled | Overflow Interrupt Disabled | | | |----------|------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--|--| | DVSR | Holds the value written | Holds the value written | | | | DVDNT | Holds the results of operations until overflow generation is detected* | The maximum value is set for overflow to the plus side, or the minimum value for overflow to the minus side | | | | DVCR | The OVF bit is set | The OVF bit is set | | | | VCRDIV | Holds the value written | Holds the value written | | | | DVDNTH | Holds the results of operations until overflow generation is detected* | Holds the results of operations until overflow generation is detected * | | | | DVDNTL | Holds the results of operations until overflow generation is detected* | The maximum value is set for overflow to the plus side, or the minimum value for overflow to the minus side | | | Note: In division processing, the intermediate operation result is written for cycles up to detection of overflow generation. # Section 11 16-Bit Free-Running Timer #### 11.1 Overview The LSI has a single-channel, 16-bit free-running timer (FRT) on-chip. The FRT is based on a 16-bit free-running counter (FRC) and can output two types of independent waveforms. The FRT can also measure the width of input pulses and the cycle of external clocks. #### 11.1.1 Features The FRT has the following features: - Allows selection between four types of counter input clocks. Select from external clock or three types of internal clocks (Pφ/8, Pφ/32, and Pφ/128). (External events can be counted.) - Two independent comparators. Two types of waveforms can be output. - Input capture. Select rising edge or falling edge. - Counter clear can be specified. The counter value can be cleared upon compare match A. - Four types of interrupt sources. Two compare matches, one input capture, and one overflow are available as interrupt sources, and interrupts can be requested independently for each. ## 11.1.2 Block Diagram Figure 11.1 shows a block diagram of the FRT. Figure 11.1 FRT Block Diagram # 11.1.3 Pin Configuration Table 11.1 lists FRT I/O pins and their functions. **Table 11.1 Pin Configuration** | Channel | Pin | I/O | Function | | |-----------------------------|------|-----|---------------------------------|--| | Counter clock input pin | FTCI | ı | FRC counter clock input pin | | | Output compare A output pin | FTOA | 0 | Output pin for output compare A | | | Output compare B output pin | FTOB | 0 | Output pin for output compare B | | | Input capture input pin | FTI | I | Input pin for input capture | | # 11.1.4 Register Configuration Table 11.2 shows the FRT register configuration. **Table 11.2 Register Configuration** | Register | Abbreviation | R/W | Initial<br>Value | Address | |--------------------------------------------|--------------|---------|------------------|-------------| | Timer interrupt enable register | TIER | R/W | H'01 | HFFFFFE10 | | Free-running timer control/status register | FTCSR | R/(W)*1 | H'00 | HFFFFFE11 | | Free-running counter H | FRC H | R/W | H'00 | HFFFFFE12 | | Free-running counter L | FRC L | R/W | H'00 | HFFFFFE13 | | Output compare register A H | OCRA H | R/W | H'FF | HFFFFFE14*2 | | Output compare register A L | OCRA L | R/W | H'FF | HFFFFFE15*2 | | Output compare register B H | OCRB H | R/W | H'FF | HFFFFFE14*2 | | Output compare register B L | OCRB L | R/W | H'FF | HFFFFFE15*2 | | Timer control register | TCR | R/W | H'00 | HFFFFFE16 | | Timer output compare control register | TOCR | R/W | H'E0 | HFFFFFE17 | | Input capture register H | FICR H | R | H'00 | HFFFFFE18 | | Input capture register L | FICR L | R | H'00 | HFFFFFE19 | Notes: 1. Bits 7 to 1 are read-only. Only 0 can be written to clear flags. Bit 0 can be read or written. - 2. OCRA and OCRB have the same address. The OCRS bit in TOCR is used to switch between them. - 3. Use byte-size access for all registers. # 11.2 Register Descriptions #### 11.2.1 Free-Running Counter (FRC) FRC is a 16-bit read/write up-counter. It increments upon input of a clock. The input clock can be selected using clock select bits 1 and 0 (CKS1, CKS0) in TCR. FRC can be cleared upon compare match A. When FRC overflows (H'FFFF $\rightarrow$ H'0000), the overflow flag (OVF) in FTCSR is set to 1. FRC can be read or written to by the CPU, but because it is 16 bits long, data transfers involving the CPU are performed via a temporary register (TEMP). See section 11.3, CPU Interface, for more detailed information. FRC is initialized to H'0000 by a reset, in standby mode, and when the module standby function is used. ### 11.2.2 Output Compare Registers A and B (OCRA and OCRB) OCR is composed of two 16-bit read/write registers (OCRA and OCRB). The contents of OCR are always compared to the FRC value. When the two values are the same, the output compare flags in FTCSR (OCFA and OCFB) are set to 1. When the OCR and FRC values are the same (compare match), the output level values set in the output level bits (OLVLA and OLVLB) are output to the output compare pins (FTOA and FTOB). After a reset, FTOA and FTOB output 0 until the first compare match occurs. Because OCR is a 16-bit register, data transfers involving the CPU are performed via a temporary register (TEMP). See section 11.3, CPU Interface, for more detailed information. OCR is initialized to H'FFFF by a reset, in standby mode, and when the module standby function is used. ### 11.2.3 Input Capture Register (FICR) | Bit: | 15 | 14 | 13 | <br>3 | 2 | 1 | 0 | | |----------------|----|----|----|-------|---|---|---|--| | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | <br>0 | 0 | 0 | 0 | | | R/W: | R | R | R | <br>R | R | R | R | | FICR is a 16-bit read-only register. When a rising edge or falling edge of the input capture signal (FTI pin) is detected, the current FRC value is transferred to ICR. At the same time, the input capture flag (ICF) in FTCSR is set to 1. The edge of the input signal can be selected using the input edge select bit (IEDG) in TCR. Because ICR is a 16-bit register, data transfers involving the CPU are performed via a temporary register (TEMP). See Section 11.3, CPU Interface, for more detailed information. To ensure that the input capture operation is reliably performed, set the pulse width of the input capture input signal to six system clocks (CKP) or more. FICR is initialized to H'0000 by a reset, in standby mode, and when the module standby function is used. ### 11.2.4 Timer Interrupt Enable Register (TIER) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|------|---|---|---|-------|-------|------|---|--| | Bit name: | ICIE | _ | _ | _ | OCIAE | OCIBE | OVIE | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | R/W: | R/W | _ | _ | _ | R/W | R/W | R/W | _ | | TIER is an 8-bit read/write register that controls enabling of all interrupt requests. TIER is initialized to H'01 by a reset, in standby mode, and when the module standby function is used. Bit 7—Input Capture Interrupt Enable (ICIE): Selects enabling/disabling of the ICI interrupt request when the input capture flag (ICF) in FTCSR is set to 1. | Bit 7: ICIE | Description | | |-------------|------------------------------------------------|-----------------| | 0 | Interrupt request (ICI) caused by ICF disabled | (Initial value) | | 1 | Interrupt request (ICI) caused by ICF enabled | | Bits 6 to 4—Reserved: These bits always read 0. The write value should always be 0. Bit 3—Output Compare Interrupt A Enable (OCIAE): Selects enabling/disabling of the OCIA interrupt request when the output compare flag A (OCFA) in FTCSR is set to 1. | Bit 3: OCIAE | Description | | |--------------|--------------------------------------------------|-----------------| | 0 | Interrupt request (OCIA) caused by OCFA disabled | (Initial value) | | 1 | Interrupt request (OCIA) caused by OCFA enabled | | Bit 2—Output Compare Interrupt B Enable (OCIBE): Selects enabling/disabling of the OCIB interrupt request when the output compare flag B (OCFB) in FTCSR is set to 1. | Bit 2: OCIBE | Description | | |--------------|--------------------------------------------------|-----------------| | 0 | Interrupt request (OCIB) caused by OCFB disabled | (Initial value) | | 1 | Interrupt request (OCIB) caused by OCFB enabled | _ | Bit 1—Timer Overflow Interrupt Enable (OVIE): Selects enabling/disabling of the OVI interrupt request when the overflow flag (OVF) in FTCSR is set to 1. | Bit 1: OVIE | Description | | |-------------|------------------------------------------------|-----------------| | 0 | Interrupt request (OVI) caused by OVF disabled | (initial value) | | 1 | Interrupt request (OVI) caused by OVF enabled | | Bit 0—Reserved: This bit always reads 1. The write value should always be 1. ### 11.2.5 Free-Running Timer Control/Status Register (FTCSR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|---|---|---|--------|--------|--------|-------| | Bit name: | ICF | _ | _ | _ | OCFA | OCFB | OVF | CCLRA | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/(W)* | _ | _ | _ | R/(W)* | R/(W)* | R/(W)* | R/W | Note: For bits 7, and 3 to 1, only 0 can be written to clear the flags. FTCSR is an 8-bit register that selects counter clearing and controls interrupt request signals. FTCSR is initialized to H'00 by a reset, in standby mode, and when the module standby function is used. See section 11.4, Operation, for the timing. Bit 7—Input Capture Flag (ICF): Status flag that indicates that the FRC value has been sent to FICR by the input capture signal. This flag is cleared by software and set by hardware. It cannot be set by software. | Bit 7: ICF | Description | | |------------|----------------------------------------------------------------------|--------------------------------| | 0 | Clear conditions: When ICF is read while set to 1, and written to it | d then 0 is<br>(Initial value) | | 1 | Set conditions: When the FRC value is sent to FICR be capture signal | by the input | Bits 6 to 4—Reserved: These bits always read 0. The write value should always be 0. Bit 3—Output Compare Flag A (OCFA): Status flag that indicates when the values of the FRC and OCRA match. This flag is cleared by software and set by hardware. It cannot be set by software. | Bit 3: OCFA | Description | | |-------------|---------------------------------------------------------------------|----------------------------------| | 0 | Clear conditions: When OCFA is read while set to 1, a written to it | and then 0 is<br>(Initial value) | | 1 | Set conditions: When the FRC value becomes equal to | o OCRA | Bit 2—Output Compare Flag B (OCFB): Status flag that indicates when the values of FRC and OCRB match. This flag is cleared by software and set by hardware. It cannot be set by software. | Bit 2: OCFB | Description | |-------------|-------------------------------------------------------------------------------------------------| | 0 | Clear conditions: When OCFB is read while set to 1, and then 0 is written to it (Initial value) | | 1 | Set conditions: When the FRC value becomes equal to OCRB | Bit 1—Timer Overflow Flag (OVF): Status flag that indicates when FRC overflows (from H'FFFF to H'0000). This flag is cleared by software and set by hardware. It cannot be set by software. | Bit 1: OVF | Description | | |------------|--------------------------------------------------------------------|---------------------------------| | 0 | Clear conditions: When OVF is read while set to 1, a written to it | nd then 0 is<br>(Initial value) | | 1 | Set conditions: When the FRC value changes from H | l'FFFF to H'0000 | Bit 0—Counter Clear A (CCLRA): Selects whether or not to clear FRC on compare match A (signal indicating match of FRC and OCRA). | Bit 0: CCLRA | Description | | |--------------|--------------------------------|-----------------| | 0 | FRC clear disabled | (Initial value) | | 1 | FRC cleared on compare match A | | ### 11.2.6 Timer Control Register (TCR) TCR is an 8-bit read/write register that selects the input edge for input capture and selects the input clock for FRC. TCR is initialized to H'00 by a reset, in standby mode, and when the module standby function is used. Bit 7—Input Edge Select (IEDG): Selects whether to capture the input capture input (FTI) on the falling edge or rising edge. | Bit 7: IEDG | Description | | |-------------|--------------------------------|-----------------| | 0 | Input captured on falling edge | (Initial value) | | 1 | Input captured on rising edge | | Bits 6 to 2—Reserved: These bits always read 0. The write value should always be 0. Bits 1 and 0—Clock Select (CKS1, CKS0): These bits select whether to use an external clock or one of three internal clocks for input to FRC. The external clock is counted at the rising edge. | Bit 1: CKS1 | Bit 0: CKS0 | Description | | |-------------|-------------|---------------------------------------|-----------------| | 0 | 0 | Internal clock: count at \$\phi/8\$ | (Initial value) | | | 1 | Internal clock: count at \$\psi/32\$ | | | 1 | 0 | Internal clock: count at \$\phi\$/128 | | | | 1 | External clock: count at rising edge | | ### 11.2.7 Timer Output Compare Control Register (TOCR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|------|-----|-----|-------|-------| | Bit name: | _ | _ | _ | OCRS | _ | _ | OLVLA | OLVLB | | Initial value: | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | | | R/W | R/W | R/W | R/W | R/W | TOCR is an 8-bit read/write register that selects the output level for output compare, enables output compare output, and controls switching between access of output compare registers A and B. TOCR is initialized to H'E0 by a reset, in standby mode, and when the module standby function is used. Bits 7 to 5—Reserved: These bits always read 1. The write value should always be 1. Bit 4—Output Compare Register Select (OCRS): OCRA and OCRB share the same address. The OCRS bit controls which register is selected when reading/writing to this address. It does not affect the operation of OCRA and OCRB. | Bit 4: OCRS | Description | | |-------------|------------------------|-----------------| | 0 | OCRA register selected | (Initial value) | | 1 | OCRB register selected | | Bits 3 and 2—Reserved: These bits always read 0. The write value should always be 0. Bit 1—Output Level A (OLVLA): Selects the level output to the output compare A output pin upon compare match A (signal indicating match of FRC and OCRA). | Bit 1: OLVLA | Description | | |--------------|-----------------------------|-----------------| | 0 | 0 output on compare match A | (Initial value) | | 1 | 1 output on compare match A | | Bit 0—Output Level B (OLVLB): Selects the level output to the output compare B output pin upon compare match B (signal indicating match of FRC and OCRB). | Bit 0: OLVLB | Description | | |--------------|-----------------------------|-----------------| | 0 | 0 output on compare match B | (Initial value) | | 1 | 1 output on compare match B | | #### 11.3 CPU Interface FRC, OCRA, OCRB, and FICR are 16-bit registers. The data bus width between the CPU and FRT, however, is only 8 bits. Access of these three types of registers from the CPU therefore needs to be performed via an 8-bit temporary register called TEMP. The following describes how these registers are read from and written to: #### • Writing to 16-bit Registers The upper byte is written, which results in the upper byte of data being stored in TEMP. The lower byte is then written, which results in 16 bits of data being written to the register when combined with the upper byte value in TEMP. ### • Reading from 16-bit Registers The upper byte of data is read, which results in the upper byte value being transferred to the CPU. The lower byte value is transferred to TEMP. The lower byte is then read, which results in the lower byte value in TEMP being sent to the CPU. When registers of these three types are accessed, two byte accesses should always be performed, first to the upper byte, then the lower byte. The same applies to accesses with the on-chip direct memory access controller. If only the upper byte or lower byte is accessed, the data will not be transferred properly. Figure 11.2(a) and 11.2(b) show the flow of data when FRC is accessed. Other registers function in the same way. When reading OCRA and OCRB, however, both upper and lower-byte data is transferred directly to the CPU without passing through TEMP. A sample program is shown next which performs word-unit handling of data read in byte units. Figure 11.2(a) FRC Access Operation (CPU Writes H'AA55 to FRC) Figure 11.2(b) FRC Access Operation (CPU Reads H'AA55 from FRC) ### 11.4 Operation ### 11.4.1 FRC Count Timing The FRC increments on clock input (internal or external). **Internal Clock Operation:** Set the CKS1 and CKS0 bits in TCR to select which of the three internal clocks created by dividing system clock ( $P\phi/8$ , $P\phi/32$ , $P\phi/128$ ) is used. Figure 11.3 shows the timing. **Figure 11.3 Count Timing (Internal Clock Operation)** **External Clock Operation:** Set the CKS1 and CKS0 bits in TCR to select the external clock. External clock pulses are counted on the rising edge. The pulse width of the external clock must be at least 6 system clocks ( $P\phi$ ). A smaller pulse width will result in inaccurate operation. Figures 11.4 shows the timing. Figure 11.4 Count Timing (External Clock Operation) ### 11.4.2 Output Timing for Output Compare When a compare match occurs, the output level set in the OLVL bit in TOCR is output from the output compare output pins (FTOA, FTOB). Figure 11.5 shows the timing for output of output compare A. Figure 11.5 Output Timing for Output Compare A ### 11.4.3 FRC Clear Timing FRC can be cleared on compare match A. Figure 11.6 shows the timing. Figure 11.6 Compare Match A Clear Timing ### 11.4.4 Input Capture Input Timing Either the rising edge or falling edge, can be selected for input capture input using the IEDG bit in TCR. Figure 11.7 shows the timing when the rising edge is selected (IEDG = 1). Figure 11.7 Input Capture Signal Timing (Normal) When the input capture signal is input when FICR is read (upper-byte read), the input capture signal is delayed by one cycle of the clock that drives the timer. Figure 11.8 shows the timing. Figure 11.8 Input Capture Signal Timing (Input Capture Input when FICR is Read) ### 11.4.5 Input Capture Flag (ICF) Setting Timing Input capture input sets the input capture flag (ICF) to 1 and simultaneously transfers the FRC value to FICR. Figure 11.9 shows the timing. Figure 11.9 ICF Setting Timing ### 11.4.6 Output Compare Flag (OCFA, OCFB) Setting Timing The compare match signal output (when OCRA or OCRB matches the FRC value) sets output compare flag OCFA or OCFB to 1. The compare match signal is generated in the last state in which the values matched (at the timing for updating the count value that matched the FRC). After OCRA or OCRB matches the FRC, no compare match signal is generated until the increment lock is generated. Figure 11.10 shows the timing for setting OCFA and OCFB. Figure 11.10 OCF Setting Timing # 11.4.7 Timer Overflow Flag (OVF) Setting Timing FRC overflow (from H'FFFF to H'0000) sets the timer overflow flag (OVF) to 1. Figure 11.11 shows the timing. Figure 11.11 OVF Setting Timing ### 11.5 Interrupt Sources There are four FRT interrupt sources of three types (ICI, OCIA/OCIB, and OVI). Table 11.3 lists the interrupt sources and their priorities after a reset is cleared. The interrupt enable bits in TIER are used to enable or disable the interrupt bits. Each interrupt request is sent to the interrupt controller independently. See section 4, Exception Handling, for more information about priorities and the relationship to interrupts other than those of the FRT. **Table 11.3 FRT Interrupt Sources and Priorities** | Interrupt Source | Description | Priority | |------------------|---------------------------|----------| | ICI | Interrupt by ICF | High | | OCIA, OCIB | Interrupt by OCFA or OCFB | _ | | OVI | Interrupt by OVF | Low | ### 11.6 Example of FRT Use Figure 11.13 shows an example in which pulses with a 50% duty factor and arbitrary phase relationship are output. The procedure is as follows: - 1. Set the CCLRA bit in FTCSR to 1. - 2. The OLVLA and OLVLB bits are inverted by software whenever a compare match occurs. Figure 11.12 Example of Pulse Output # 11.7 Usage Notes Note that the following contention and operations occur when the FRT is operating: ### 1. Contention between FRC Write and Clear When a counter clear signal is generated with the timing shown in figure 11.13 during the write cycle for the lower byte of FRC, writing does not occur to the FRC, and the FRC clear takes priority. Figure 11.13 Contention between FRC Write and Clear ### 2. Contention between FRC Write and Increment When an increment occurs with the timing shown in figure 11.14 during the write cycle for the lower byte of FRC, no increment is performed and the counter write takes priority. Figure 11.14 Contention between FRC Write and Increment #### 3. Contention between OCR Write and Compare Match When a compare match occurs with the timing shown in figure 11.15, during the write cycle for the lower byte of OCRA or OCRB, the OCR write takes priority and the compare match signal is disabled. Figure 11.15 Contention between OCR and Compare Match ### 4. Internal Clock Switching and Counter Operation FRC will sometimes begin incrementing because of the timing of switching between internal clocks. Table 11.4 shows the relationship between internal clock switching timing (CKS1 and CKS0 bit rewrites) and FRC operation. When an internal clock is used, the FRC clock is generated when the falling edge of an internal clock (created by dividing the system clock ( $P\phi$ ) is detected. When a clock is switched to high before the switching and to low after switching, as shown in case 3 in table 11.4, the switchover is considered a falling edge and an FRC clock pulse is generated, causing FRC to increment. FRC may also increment when switching between an internal clock and an external clock. Table 11.4 Internal Clock Switching and FRC Operation Timing of Rewrite of No. CKS1 and CKS0 Bits FRC Operation ### 2 Low-to-high switch Table 11.4 Internal Clock Switching and FRC Operation (cont) Timing of Rewrite of No. CKS1 and CKS0 Bits FRC Operation ### 3 High-to-low switch ### 4 High-to-high switch Note: Because the switchover is considered a falling edge, FRC starts counting up. ### 5. Timer Output (FTOA, FTOB) During a power-on reset, the timer outputs (FTOA, FTOB) will be unreliable until the oscillation stabilizes. The initial value is output after the oscillation settling time has elapsed. # Section 12 Watchdog Timer (WDT) ### 12.1 Overview The LSI has a single-channel watchdog timer (WDT) for monitoring system operations. If a system becomes uncontrolled and the timer counter overflows without being rewritten correctly by the CPU, an overflow signal (WDTOVF) is output externally. The WDT can simultaneously generate an internal reset signal for the entire chip. When this watchdog function is not needed, the WDT can be used as an interval timer. In the interval timer operation, an interval timer interrupt is generated at each counter overflow. The WDT is also used when recovering from standby mode, in modifying a clock frequency, and in clock pause mode. #### 12.1.1 Features - Switchable between watchdog timer mode and interval timer mode. - Outputs WDTOVF in watchdog timer mode. When the counter overflows in watchdog timer mode, overflow signal WDTOVF is output externally. It is possible to select whether to reset the chip internally when this happens. Either the power-on reset or manual reset signal can be selected as the internal reset signal. - Generates interrupts in interval timer mode. When the counter overflows, it generates an interval timer interrupt. - Used for standby mode clearing, clock frequency modification, and clock pause mode. - Works with eight counter clock sources. ### 12.1.2 Block Diagram Figure 12.1 shows a block diagram of the WDT. Figure 12.1 WDT Block Diagram ### 12.1.3 Pin Configuration Table 12.1 shows the pin configuration. **Table 12.1 Pin Configuration** | Name | Abbreviation | I/O | Function | |-------------------------|--------------|-----|------------------------------------------------------| | Watchdog timer overflow | WDTOVF | 0 | Outputs the counter overflow signal in watchdog mode | ### 12.1.4 Register Configuration Table 12.2 summarizes the three WDT registers. They are used to select the clock, switch the WDT mode, and control the reset signal. **Table 12.2 Register Configuration** | | | | | Address | | | |---------------------------------------|--------------|---------|---------------|---------------------|------------|--| | Name | Abbreviation | R/W | Initial Value | Write <sup>*1</sup> | Read*2 | | | Watchdog timer control/status registe | WTCSR<br>r | R/(W)*3 | H'18 | H'FFFFFE80 | H'FFFFFE80 | | | Watchdog timer counter | WTCNT | R/W | H'00 | H'FFFFFE80 | H'FFFFFE81 | | | Reset control/status register | RSTCSR | R/(W)*3 | H'1F | H'FFFFFE82 | H'FFFFFE83 | | Notes: 1. Write by word access. It cannot be written by byte or longword access. - 2. Read by byte access. The correct value cannot be read by word or longword access. - 3. Only 0 can be written in bit 7 to clear the flag. ### 12.2 Register Descriptions ### 12.2.1 Watchdog Timer Counter (WTCNT) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|-----|-----|-----|-----|-----|-----|-----|-----|--| | Bit name: | | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R/W: | R/W | WTCNT is an 8-bit read/write up-counter. WTCNT differs from other registers in that it is more difficult to write. See section 12.2.4, Register Access, for details. When the timer enable bit (TME) in the watchdog timer control/status register (WTCSR) is set to 1, the watchdog timer counter starts counting pulses of an internal clock source selected by clock select bits 2 to 0 (CKS2 to CKS0) in WTCSR. When the value of WTCNT overflows (changes from H'FF to H'00), a watchdog timer overflow signal ( $\overline{\text{WDTOVF}}$ ) or interval timer interrupt (ITI) is generated, depending on the mode selected in the WT/ $\overline{\text{IT}}$ bit in WTCSR. WTCNT is initialized to H'00 by a reset and when the TME bit is cleared to 0. It is not initialized in standby mode, when the clock frequency is changed, or in clock pause mode. ### 12.2.2 Watchdog Timer Control/Status Register (WTCSR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|-------|-----|---|---|------|------|------| | Bit name: | OVF | WT/ĪT | TME | _ | _ | CKS2 | CKS1 | CKS0 | | Initial value: | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | R/W: | R/(W)* | R/W | R/W | _ | _ | R/W | R/W | R/W | The watchdog timer control/status register (WTCSR) is an 8-bit read/write register. WTCSR differs from other registers in being more difficult to write. See section 12.2.4, Register Access, for details. Its functions include selecting the timer mode and clock source. Bits 7 to 5 are initialized to 000 by a reset, in standby mode, when the clock frequency is changed, and in clock pause mode. Bits 2 to 0 are initialized to 000 by a reset, but are not initialized in standby mode, when the clock frequency is changed, or in clock pause mode. Bit 7—Overflow Flag (OVF): Indicates that WTCNT has overflowed from H'FF to H'00. It is not set in watchdog timer mode. | Bit 7: OVF | Description | | |------------|----------------------------------------------------|----------| | 0 | No overflow of WTCNT in interval timer mode value) | (Initial | | | Cleared by reading OVF, then writing 0 in OVF | | | 1 | WTCNT overflow in interval timer mode | _ | Bit 6—Timer Mode Select (WT/IT): Selects whether to use the WDT as a watchdog timer or interval timer. When WTCNT overflows, the WDT either generates an interval timer interrupt (ITI) or generates a WDTOVF signal, depending on the mode selected. | Bit 6: WT/IT | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Interval timer mode: interval timer interrupt (ITI) request to the CPU when WTCNT overflows (Initial value) | | 1 | Watchdog timer mode: WDTOVF signal output externally when WTCNT overflows. Section 12.2.3, Reset Control/Status Register (RSTCSR), describes in detail what happens when WTCNT overflows in watchdog timer mode | Note: See section 12.2.3, Reset Control/Status Register (RSTCSR), describes in detail what happens when WTCNT overflows in watchdog timer mode Bit 5—Timer Enable (TME): Enables or disables the timer. | Bit 5: TME | Description | |------------|--------------------------------------------------------------------------------------------------------------------------| | 0 | Timer disabled: WTCNT is initialized to H'00 and count-up stops (Initial value) | | 1 | Timer enabled: WTCNT starts counting. A $\overline{\text{WDTOVF}}$ signal or interrupt is generated when WTCNT overflows | Bits 4 and 3—Reserved: These bits always read 1. The write value should always be 1. Bits 2 to 0—Clock Select 2 to 0 (CKS2 to CKS0): These bits select one of eight internal clock sources for input to WTCNT. The clock signals are obtained by dividing the frequency of the system clock (φ). #### Description | Bit 2: | CKS2 Bit 1: | CKS1 Bit 0: | CKS0 Clock Source | Overflow Interval* (φ = 60 MHz) | |--------|-------------|-------------|---------------------|---------------------------------| | 0 | 0 | 0 | φ/4 (Initial value) | 17.0 µs | | 0 | 0 | 1 | ф/128 | 544 µs | | 0 | 1 | 0 | φ/256 | 1.1 ms | | 0 | 1 | 1 | φ/512 | 2.2 ms | | 1 | 0 | 0 | ф/1024 | 4.4 ms | | 1 | 0 | 1 | ф/2048 | 8.7 ms | | 1 | 1 | 0 | φ/8192 | 34.8 ms | | 1 | 1 | 1 | ф/16384 | 69.6 ms | Note: The overflow interval listed is a period from when the WTCNT begins counting at H'00 until an overflow occurs. ### 12.2.3 Reset Control/Status Register (RSTCSR) RSTCSR is an eight-bit read/write register that controls output of the reset signal generated by watchdog timer counter (WTCNT) overflow and selects the internal reset signal type. RSTCSR differs from other registers in that it is more difficult to write. See section 12.2.4, Register Access, for details. RSTCR is initialized to H'1F by input of a reset signal from the $\overline{\text{RES}}$ pin, but is not initialized by the internal reset signal generated by overflow of the WDT. It is initialized to H'1F in standby mode and clock pause mode. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----------------|--------|------|------|---|---|---|---|---|---| | Bit name: | WOVF | RSTE | RSTS | | _ | _ | _ | _ | | | Initial value: | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | • | | R/W: | R/(W)* | R/W | R/W | _ | _ | | _ | _ | | Note: Only 0 can be written in bit 7 to clear the flag. Bit 7—Watchdog Timer Overflow Flag (WOVF): Indicates that WTCNT has overflowed (from H'FF to H'00) in watchdog timer mode. It is not set in interval timer mode. | Bit 7: WOVF | Description | | |-------------|-------------------------------------------------|-----------------| | 0 | No WTCNT overflow in watchdog timer mode | (Initial value) | | | Cleared by reading WOVF, then writing 0 in WOVF | | | 1 | Set by WTCNT overflow in watchdog timer mode | | Bit 6—Reset Enable (RSTE): Selects whether to reset the chip internally if WTCNT overflows in watchdog timer mode. | Bit 6: RSTE | Description | | | |-------------|----------------------------------------------------------------|--|--| | 0 | Not reset when WTCNT overflows (Initial value) | | | | | LSI not reset internally, but WTCNT and WTCSR reset within WDT | | | | 1 | Reset when WTCNT overflows | | | Bit 5—Reset Select (RSTS): Selects the type of internal reset generated if WTCNT overflows in watchdog timer mode. | Bit 5: RSTS | Description | | |-------------|----------------|-----------------| | 0 | Power on reset | (Initial value) | | 1 | manual reset | | Bits 4 to 0—Reserved: These bits always read as 1. The write value should always be 1. #### 12.2.4 Notes on Register Access The watchdog timer's WTCNT, WTCSR, and RSTCSR registers differ from other registers in that they are more difficult to write. The procedures for writing and reading these registers are given below. **Writing to WTCNT and WTCSR:** These registers must be written by a word transfer instruction. They cannot be written by byte or longword transfer instructions. WTCNT and WTCSR both have the same write address. The write data must be contained in the lower byte of the written word. The upper byte must be H'5A (for WTCNT) or H'A5 (for WTCSR) (figure 12.2). This transfers the write data from the lower byte to WTCNT or WTCSR. Figure 12.2 Writing to WTCNT and WTCSR Writing to RSTCSR: RSTCSR must be written by a word access to address H'FFFFFE82. It cannot be written by byte or longword transfer instructions. Procedures for writing 0 in WOVF (bit 7) and for writing to RSTE (bit 6) and RSTS (bit 5) are different, as shown in figure 12.3. To write 0 in 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 and RSTS bits are not affected. To write to the RSTE and RSTS bits, the upper byte must be H'5A and the lower byte must be the write data. The values of bits 6 and 5 of the lower byte are transferred to the RSTE and RSTS bits, respectively. The WOVF bit is not affected. Figure 12.3 Writing to RSTCSR **Reading from WTCNT, WTCSR, and RSTCSR:** WTCNT, WTCSR, and RSTCSR are read like other registers. Use byte transfer instructions. The read addresses are H'FFFFE80 for WTCSR, H'FFFFFE81 for WTCNT, and H'FFFFFE83 for RSTCSR. ### 12.3 Operation ### 12.3.1 Operation in Watchdog Timer Mode To use the WDT as a watchdog timer, set the WT/ $\overline{\text{IT}}$ and TME bits in WTCSR to 1. Software must prevent WTCNT overflow by rewriting the WTCNT value (normally by writing H'00) before overflow occurs. Thus, WTCNT will not overflow while the system is operating normally, but if WTCNT fails to be rewritten and overflows occur due to a system crash or the like, a $\overline{\text{WDTOVF}}$ signal is output (figure 12.4). The $\overline{\text{WDTOVF}}$ signal can be used to reset the system. The $\overline{\text{WDTOVF}}$ signal is output for 512 $\varphi$ clock cycles. If the RSTE bit in RSTCSR is set to 1, a signal to reset the chip will be generated internally simultaneously with the $\overline{WDTOVF}$ signal when WTCNT overflows. Either a power-on reset or a manual reset can be selected by the RSTS bit. The internal reset signal is output for 2048 $\phi$ clock cycles. When a watchdog reset is generated simultaneously with input at the $\overline{RES}$ pin, the software distinguishes the $\overline{RES}$ reset from the watchdog reset by checking the WOVF bit in RSTCSR. The $\overline{RES}$ reset takes priority. The WOVF bit is cleared to 0. Figure 12.4 Operation in Watchdog Timer Mode #### 12.3.2 Operation in Interval Timer Mode To use the WDT as an interval timer, clear WT/ $\overline{\text{IT}}$ to 0 and set TME to 1 in WTCSR. An interval timer interrupt (ITI) is generated each time the watchdog timer counter (WTCNT) overflows. This function can be used to generate interval timer interrupts at regular intervals (figure 12.5). Figure 12.5 Operation in Interval Timer Mode #### 12.3.3 Operation when Standby Mode is Cleared The watchdog timer has a special function to clear standby mode with an NMI interrupt. When using standby mode, set the WDT as described below. **Transition to Standby Mode:** The TME bit in WTCSR must be cleared to 0 to stop the watchdog timer counter before it enters standby mode. The chip cannot enter standby mode while the TME bit is set to 1. Set bits CKS2 to CKS0 in WTCSR so that the counter overflow interval is equal to or longer than the oscillation settling time. See section 23, Electrical Characteristics, for the oscillation settling time. Recovery from Standby Mode: When an NMI request signal is received in standby mode the clock oscillator starts running and the watchdog timer starts counting at the rate selected by bits CKS2 to CKS0 before standby mode was entered. When WTCNT overflows (changes from H'FF to H'00) the system clock $(\phi)$ is presumed to be stable and usable; clock signals are supplied to the entire chip and standby mode ends. For details on standby mode, see section 22, Power Down Modes. ### 12.3.4 Timing of Overflow Flag (OVF) Setting In interval timer mode, when WTCNT overflows, the OVF flag in WTCSR is set to 1 and an interval timer interrupt (ITI) is requested (figure 12.6). Figure 12.6 Timing of OVF Setting ### 12.3.5 Timing of Watchdog Timer Overflow Flag (WOVF) Setting When WTCNT overflows the WOVF flag in RSTCSR is set to 1 and a $\overline{\text{WDTOVF}}$ signal is output. When the RSTE bit is set to 1, WTCNT overflow enables an internal reset signal to be generated for the entire chip (figure 12.7). Figure 12.7 Timing of WOVF Setting ### 12.4 Usage Notes ### 12.4.1 Contention between WTCNT Write and Increment If a timer counter clock pulse is generated during the T3 state of a write cycle to WTCNT, the write takes priority and the timer counter is not incremented (figure 12.8). Figure 12.8 Contention between WTCNT Write and Increment ### 12.4.2 Changing CKS2 to CKS0 Bit Values If the values of bits CKS2 to CKS0 are altered while the WDT is running, the count may increment incorrectly. Always stop the watchdog timer (by clearing the TME bit to 0) before changing the values of bits CKS2 to CKS0. ### 12.4.3 Switching between Watchdog Timer and Interval Timer Mode To prevent incorrect operation, always stop the watchdog timer (by clearing the TME bit to 0) before switching between interval timer mode and watchdog timer mode. ### 12.4.4 System Reset with WDTOVF If a $\overline{WDTOVF}$ signal is input to the $\overline{RES}$ pin, the device cannot initialize correctly. Avoid logical input of the $\overline{WDTOVF}$ output signal to the $\overline{RES}$ input pin. To reset the entire system with the $\overline{WDTOVF}$ signal, use the circuit shown in figure 12.9. Figure 12.9 Example of Circuit for System Reset with WDTOVF Signal ### 12.4.5 Internal Reset in Watchdog Timer Mode If the RSTE bit is cleared to 0 in watchdog timer mode, the chip will not reset internally when a WTCNT overflow occurs, but WTCNT and WTCSR in the WDT will reset. # Section 13 Serial Communication Interface #### 13.1 Overview The LSI has a serial communication interface (SCI) that supports both asynchronous and clocked synchronous serial communication. It also has a multiprocessor communication function for serial communication among two or more processors. A smart card interface is supported. This comprises smart card interface serial communication functions conforming to ISO/IEC 7816-3 (Identification Card). For details, see section 14, Smart Card Interface. #### 13.1.1 Features Selection of asynchronous or clock synchronous as the serial communication mode - Asynchronous mode: - Serial data communication is synchronized by the start-stop method in character units. The SCI can communicate with a universal asynchronous receiver/transmitter (UART), an asynchronous communication interface adapter (ACIA), or any other chip that employs standard asynchronous serial communication. It can also communicate with two or more other processors using the multiprocessor communication function. There are twelve selectable serial data communication formats. - Data length: seven or eight bits - Stop bit length: one or two bits - Parity: even, odd, or none - Multiprocessor bit: one or none - Receive error detection: parity, overrun, and framing errors - Clocked synchronous mode: - Serial data communication is synchronized with a clock signal. The SCI can communicate with other chips having a clocked synchronous communication function. There is one serial data communication format. - Data length: eight bits - Receive error detection: overrun errors - Full duplex communication. The transmitting and receiving sections are independent, so the SCI can transmit and receive simultaneously. Both sections use double buffering, so continuous data transfer is possible in both the transmit and receive directions. - Built-in baud rate generator with selectable bit rates - Internal or external transmit/receive clock source. Baud rate generator (internal) or SCK pin (external) • Four types of interrupts. Transmit-data-empty, transmit-end, receive-data-full, and receive-error interrupts are requested independently. The transmit-data-empty and receive-data-full interrupts can start the direct memory access controller (DMAC) to transfer data. ### 13.1.2 Block Diagram Figure 13.1 shows a block diagram of the SCI. Figure 13.1 SCI Block Diagram # 13.1.3 Pin Configuration Table 13.1 summarizes the SCI pins. Table 13.1 SCI Pins | Pin Name | Abbreviation | Input/Output | Function | |-------------------|--------------|--------------|----------------------| | Serial clock pin | SCK | Input/output | Clock input/output | | Receive data pin | RxD | Input | Receive data input | | Transmit data pin | TxD | Output | Transmit data output | # 13.1.4 Register Configuration Table 13.2 summarizes the SCI internal registers. These registers select the communication mode (asynchronous or clock synchronous), specify the data format and bit rate, and control the transmitter and receiver sections. Table 13.2 Registers | Name | Abbreviation | R/W | Initial Value | Address | Access size | |-------------------------|--------------|--------|---------------|------------|-------------| | Serial mode register | SMR | R/W | H'00 | H'FFFFE00 | 8 | | Bit rate register | BRR | R/W | H'FF | H'FFFFFE01 | 8 | | Serial control register | SCR | R/W | H'00 | H'FFFFE02 | 8 | | Transmit data register | TDR | R/W | H'FF | H'FFFFE03 | 8 | | Serial status register | SSR | R/(W)* | H'84 | H'FFFFE04 | 8 | | Receive data register | RDR | R | H'00 | H'FFFFE05 | 8 | Note: Only 0 can be written to clear the flags. # 13.2 Register Descriptions ### 13.2.1 Receive Shift Register (RSR) The receive shift register (RSR) receives serial data. Data input at the RxD pin is loaded into RSR 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 RDR. The CPU cannot read or write to RSR directly. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---|---|---|---|---|---|---|---| | Bit name: | | | | | | | | | | R/W. | | | | | | | | | ### 13.2.2 Receive Data Register (RDR) The receive data register (RDR) stores serial receive data. The SCI completes the reception of one byte of serial data by moving the received data from the receive shift register (RSR) into RDR for storage. RSR is then ready to receive the next data. This double buffering allows the SCI to receive data continuously. The CPU can read but not write to RDR. RDR is initialized to H'00 by a reset and in standby and module standby mode. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|---|---|---| | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | ### 13.2.3 Transmit Shift Register (TSR) The transmit shift register (TSR) transmits serial data. The SCI loads transmit data from the transmit data register (TDR) into TSR, then transmits the data serially from the TxD pin, LSB (bit 0) first. After transmitting one data byte, the SCI automatically loads the next transmit data from TDR into TSR and starts transmitting again. If the TDRE bit in SSR is 1, however, the SCI does not load the TDR contents into TSR. The CPU cannot read or write to TSR directly. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---|---|---|---|---|---|---|---| | Bit name: | | | | | | | | | | R/W. | | | | | | | | | 454 HITACHI # 13.2.4 Transmit Data Register (TDR) The transmit data register (TDR) is an 8-bit register that stores data for serial transmission. When the SCI detects that the transmit shift register (TSR) is empty, it moves transmit data written in TDR into TSR and starts serial transmission. Continuous serial transmission is possible by writing the next transmit data in TDR during serial transmission from TSR. The CPU can always read and write to TDR. TDR is initialized to HFF by a reset and in standby and module standby mode. ### 13.2.5 Serial Mode Register (SMR) The serial mode register (SMR) is an 8-bit register that specifies the SCI serial communication format and selects the clock source for the baud rate generator. The CPU can always read and write to SMR. SMR is initialized to H'00 by a reset and in standby and module standby mode. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|------|-----|------|------| | Bit name: | C/Ā | CHR | PE | O/E | STOP | MP | CKS1 | CKS0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bit 7—Communication Mode $(C/\overline{A})$ : Selects whether the SCI operates in asynchronous or clocked synchronous mode. | Bit 7: C/A | Description | | |------------|--------------------------|----------| | 0 | Asynchronous mode value) | (Initial | | 1 | Clocked synchronous mode | | Bit 6—Character Length (CHR): Selects 7-bit or 8-bit data in asynchronous mode. In clocked synchronous mode, the data length is always eight bits, regardless of the CHR setting. | Bit 6: CHR | Description | | |------------|--------------------------------------------------------------------------------------------|-----------------| | 0 | 8-bit data value) | (Initial | | 1 | 7-bit data. When 7-bit data is selected, the MSB (bit 7) data register is not transmitted. | of the transmit | Bit 5—Parity Enable (PE): 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. | Bit 5: PE | Description | | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| | 0 | Parity bit not added or checked value) | (Initial | | 1 | Parity bit added and checked. When PE is set parity bit is added to transmit data, depending (O/E) setting. Receive data parity is checked a even/odd (O/E) mode setting. | on the parity mode | Bit 4—Parity Mode $(O/\overline{E})$ : Selects even or odd parity when parity bits are added and checked. The $O/\overline{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/\overline{E}$ setting is ignored in clocked synchronous mode, and in asynchronous mode when parity addition and checking is disabled. | Bit 4: O/E | Description | | | | |------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|--| | 0 | Even parity (Initial value) | | | | | | If even parity is selected, the parity bit is added to tromake an even number of 1s in the transmitted characombined. Receive data is checked to see if it has a 1s in the received character and parity bit combined | acter and parity bit<br>in even number of | | | | 1 | Odd parity | | | | | | If odd parity is selected, the parity bit is added to tra<br>an odd number of 1s in the transmitted character an<br>combined. Receive data is checked to see if it has a<br>1s in the received character and parity bit combined | nd parity bit<br>on odd number of | | | Bit 3—Stop Bit Length (STOP): 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. In receiving, only the first stop bit is checked, regardless of the STOP bit setting. Further, the length of stop bit is set at 2-bit, f 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. | Bit 3: STOP | Description | | | | |-------------|----------------------------------------------------------------------------------------|----------------------|--|--| | 0 | One stop bit value) | (Initial | | | | | In transmitting, at the end of each transmitted character is transmitted adding 1-bit. | | | | | 1 | Two stop bits | | | | | | In transmitting, at the end of each transmitted chara adding 2-bit. | acter is transmitted | | | Bit 2—Multiprocessor Mode (MP): Selects multiprocessor format. When multiprocessor format is selected, settings of the parity enable (PE) and parity mode $(O/\overline{E})$ bits are ignored. The MP bit setting is used only in asynchronous mode; it is ignored in clocked synchronous mode. For the multiprocessor communication function, see section 13.3.3, Multiprocessor Communication. | Bit 2: MP | Description | | |-----------|-----------------------------------------|----------| | 0 | Multiprocessor function disabled value) | (Initial | | 1 | Multiprocessor format selected | | Bits 1 and 0—Clock Select 1 and 0 (CKS1 and CKS0): These bits select the internal clock source of the built-in baud rate generator. Four clock sources are available. P $\phi$ , P $\phi$ /4, P $\phi$ /16, and P $\phi$ /64. For further information on the clock source, bit rate register settings, and baud rate, see section 13.2.8, Bit Rate Register (BRR). | Bit 1: CKS1 | Bit 0: CKS0 | Description | | |-------------|-------------|--------------------|----------| | 0 | 0 | Pφ<br>value) | (Initial | | | 1 | Рф/4 | | | 1 | 0 | P <sub>0</sub> /16 | | | | 1 | P <sub>0</sub> /64 | | ### 13.2.6 Serial Control Register (SCR) The serial control register (SCR) operates the SCI transmitter/receiver, selects the serial clock output in asynchronous mode, enables/disables interrupts, and selects the transmit/receive clock source. The CPU can always read and write to SCR. SCR is initialized to H'00 by a reset and in standby and module standby modes. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|------|------|------|------| | Bit name: | TIE | RIE | TE | RE | MPIE | TEIE | CKE1 | CKE0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bit 7—Transmit Interrupt Enable (TIE): Enables or disables the transmit-data-empty interrupt (TXI) requested when the transmit data register empty bit (TDRE) in the serial status register (SSR) is set to 1 due to transfer of serial transmit data from TDR to TSR. | Bit 7: TIE | Description | |------------|-------------------------------------------------------------------------------------------------------------------| | 0 | Transmit-data-empty interrupt request (TXI) is disabled (Initial value) | | | The TXI interrupt request can be cleared to 0 by reading TDRE after it has been set to 1 or by clearing TIE to 0. | | 1 | Transmit-data-empty interrupt request (TXI) is enabled | Bit 6—Receive Interrupt Enable (RIE): Enables or disables the receive-data-full interrupt (RXI) requested when the receive data register full bit (RDRF) in the serial status register (SSR) is set to 1 due to transfer of serial receive data from RSR to RDR. It also enables or disables receive-error interrupt (ERI) requests. | Bit 6: RIE | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receive-data-full interrupt (RXI) and receive-error interrupt (ERI) requests are disabled (Initial value) | | | RXI and ERI interrupt requests can be cleared by reading the RDRF flag or error flag (FER, PER, or ORER) after it has been set to 1, then clearing the flag to 0, or by clearing RIE to 0. | | 1 | Receive-data-full interrupt (RXI) and receive-error interrupt (ERI) requests are enabled | Bit 5—Transmit Enable (TE): Enables or disables the SCI serial transmitter. | Bit 5: TE | Description | | |-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | 0 | Transmitter disabled value) | (Initial | | | The transmit data register empty bit (TDRE) in the (SSR) is locked at 1 | e serial status register | | 1 | Transmitter enabled | | | | Serial transmission starts when the transmit data (TDRE) bit in the serial status register (SSR) is clewriting of transmit data into TDR. Select the transmit before setting TE to 1. | eared to 0 after | Bit 4—Receive Enable (RE): Enables or disables the SCI serial receiver. | Bit 4: RE | Description | | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------| | 0 | Receiver disabled (Invalue) | itial | | | Clearing RE to 0 does not affect the receive flags (RDRF, FEFORER). These flags retain their previous values. | R, PER, | | 1 | Receiver enabled | | | | Serial receive starts when a start bit is detected in asynchronous mode, or synchronous clock input is detected in clocked synchronous. Select the receive format in SMR before setting RE to | nronous | Bit 3—Multiprocessor Interrupt Enable (MPIE): Enables or disables multiprocessor interrupts. The MPIE setting is used only in asynchronous mode, and only if the multiprocessor mode bit (MP) in the serial mode register (SMR) is set to 1 during reception. The MPIE setting is ignored in clocked synchronous mode or when the MP bit is cleared to 0. | Bit 3: MPIE | Description | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Multiprocessor interrupts are disabled (normal receive operation) (Initial value) | | | , | | | MPE is cleared to 0 when MPIE is cleared to 0, or the multiprocessor bit (MPB) is set to 1 in receive data. | | 1 | Multiprocessor interrupts are enabled | | | Receive-data-full interrupt requests (RXI), receive-error interrupt requests (ERI), and setting of the RDRF, FER, and ORER status flags in the serial status register (SSR) are disabled until the multiprocessor bit is set to 1. | | | The SCI does not transfer receive data from RSR to RDR, does not detect receive errors, and does not set the RDRF, FER, and ORER flags in the serial status register (SSR). When it receives data included MPB = 1, MPB is set to 1 in SSR, and the SCI automatically clears MPIE to 0, generates RXI and ERI interrupts (if the TIE and RIE bits in SCR are set to 1), and enables the FER and ORER bits to be set. | Bit 2—Transmit-End Iinterrupt Enable (TEIE): Enables or disables the transmit-end interrupt (TEI) requested if TDR does not contain new transmit data when the MSB is transmitted. | Bit 2: TEIE | Description | | |-------------|------------------------------------------------------------|----------| | 0 | Transmit-end interrupt (TEI) requests are disabled* value) | (Initial | | 1 | Transmit-end interrupt (TEI) requests are enabled* | _ | Note: The TEI request can be cleared by reading the TDRE bit in the serial status register (SSR) after it has been set to 1, then clearing TDRE to 0; by clearing the transmit end (TEND) bit to 0; or by clearing the TEIE bit to 0. Bits 1 and 0—Clock Enable 1 and 0 (CKE1 and CKE0): These bits select the SCI clock source and enable or disable clock output from the SCK pin. Depending on the combination of CKE1 and CKE0, the SCK pin can be used for general-purpose input/output, serial clock output, or serial clock input. The CKE0 setting is valid only in asynchronous mode, and only when the SCI is internally clocked (CKE1 = 0). The CKE0 setting is ignored in clocked synchronous mode, or when an external clock source is selected (CKE1 = 1). Select the SCI operating mode in the serial mode register (SMR) before setting CKE1 and CKE0. For further details on selection of the SCI clock source, see table 13.9 in section 13.3, Operation. HITACHI Bit 1: Bit 0: ## CKE1 CKE0 Description | 0 | 0 | Asynchronous mode | Internal clock, SCK pin used for input pin (input signal is ignored or output pin output level is undefined)*1 | |---|---|--------------------------|----------------------------------------------------------------------------------------------------------------| | | | Clocked synchronous mode | Internal clock, SCK pin used for synchronous clock output*1 | | 0 | 1 | Asynchronous mode | Internal clock, SCK pin used for clock output*2 | | | | Clocked synchronous mode | Internal clock, SCK pin used for synchronous clock output | | 1 | 0 | Asynchronous mode | External clock, SCK pin used for clock input*3 | | | | Clocked synchronous mode | External clock, SCK pin used for synchronous clock input | | 1 | 1 | Asynchronous mode | External clock, SCK pin used for clock input*3 | | | | Clocked synchronous mode | External clock, SCK pin used for synchronous clock input | Notes: 1. Initial value - 2. The output clock frequency is the same as the bit rate. - 3. The input clock frequency is 16 times the bit rate. ### 13.2.7 Serial Status Register (SSR) The serial status register (SSR) is an 8-bit register containing multiprocessor bit values, and status flags that indicate the SCI operating status. The CPU can always read and write to SSR, but cannot write 1 in the status flags (TDRE, RDRF, ORER, PER, and FER). These flags can be cleared to 0 only if they have first been read (after being set to 1). Bits 2 (TEND) and 1 (MPB) are read-only bits that cannot be written. SSR is initialized to H'84 by a reset and in standby and module standby mode. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|--------|------|-----|------| | Bit name: | TDRE | RDRF | ORER | FER | PER | TEND | MPB | MPBT | | Initial value: | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | R/W: | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R | R | R/W | Note: Only 0 can be written to clear the flag. Bit 7—Transmit Data Register Empty (TDRE): Indicates that the SCI has loaded transmit data from TDR into TSR and new serial transmit data can be written in TDR. | Bit 7: TDRE | Description | | | | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 0 | TDR contains valid transmit data | | | | | | | TDRE is cleared to 0 when software reads TDRE after it has been set to 1, then writes 0 in TDRE, or the DMAC writes data in TDR. | | | | | | 1 | TDR does not contain valid transmit data (Initial value) | | | | | | | TDRE is set to 1 when the chip is reset or enters standby mode, the TE bit in the serial control register (SCR) is cleared to 0, or TDR contents are loaded into TSR, so new data can be written in TDR. | | | | | Bit 6—Receive Data Register Full (RDRF): Indicates that RDR contains received data. | Bit 6: RDRF | Description | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 0 | RDR does not contain valid receive data (Initial value) | | | | | | RDRF is cleared to 0 when the chip is reset or enters standby mode, software reads RDRF after it has been set to 1, then writes 0 in RDRF, or the DMAC reads data from RDR. | | | | | 1 | RDR contains valid received data | | | | | | RDRF is set to 1 when serial data is received normally and transferred from RSR to RDR. | | | | Note: RDR and RDRF are not affected by detection of receive errors or by clearing of the RE bit to 0 in the serial control register. They retain their previous contents. If RDRF is still set to 1 when reception of the next data ends, an overrun error (ORER) occurs and the received data is lost. Bit 5—Overrun Error (ORER): Indicates that data reception ended abnormally due to an overrun error. | Bit 5: ORER | Description | | | | | | | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--| | 0 | Receiving is in progress or has ended normally*1 (Initial value) | | | | | | | | | | | ORER is cleared to 0 when the chip is reset or enters standby mode, or software reads ORER after it has been set to 1, then writes 0 in ORER. | | | | | | | | | | 1 | A receive overrun error occurred*2 | | | | | | | | | | | ORER is set to 1 if reception of the next serial data ends when RDRF is set to 1. | | | | | | | | | - Notes: 1. Clearing the RE bit to 0 in the serial control register does not affect the ORER bit, which retains its previous value. - 2. RDR continues to hold the data received before the overrun error, so subsequent receive data is lost. Serial receiving cannot continue while ORER is set to 1. In clocked synchronous mode, serial transmitting is disabled. Bit 4—Framing Error (FER): Indicates that data reception ended abnormally due to a framing error in asynchronous mode. | Bit 4: FER | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receiving is in progress or has ended normally (Initial value) | | | Clearing the RE bit to 0 in the serial control register does not affect the FER bit, which retains its previous value. | | | FER is cleared to 0 when the chip is reset or enters standby mode, or software reads FER after it has been set to 1, then writes 0 in FER. | | 1 | A receive framing error occurred | | | When the stop bit length is two bits, only the first bit is checked. The second stop bit is not checked. When a framing error occurs, the SCI transfers the receive data into RDR but does not set RDRF. Serial receiving cannot continue while FER is set to 1. In clocked synchronous mode, serial transmitting is also disabled. | | | FER is set to 1 if the stop bit at the end of receive data is checked and found to be 0. | Bit 3—Parity Error (PER): Indicates that data reception (with parity) ended abnormally due to a parity error in asynchronous mode. | Bit 3: PER | Description | |------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receiving is in progress or has ended normally (Initial value) | | | Clearing the RE bit to 0 in the serial control register does not affect the PER bit, which retains its previous value. | | | PER is cleared to 0 when the chip is reset or enters standby mode, or software reads PER after it has been set to 1, then writes 0 in PER. | | 1 | A receive parity error occurred | | | When a parity error occurs, the SCI transfers the receive data into RDR but does not RDRF. Serial receiving cannot continue while PER is set to 1. In clocked synchronous mode, serial transmitting is also disabled. | | | PER is set to 1 if the number of 1s in receive data, including the parity bit, does not match the even or odd parity setting of the parity mode bit $(O/\overline{E})$ in the serial mode register (SMR). | Bit 2—Transmit End (TEND): Indicates that when the last bit of a serial character was transmitted, TDR did not contain valid data, so transmission has ended. TEND is a read-only bit and cannot be written. | Bit 2: TEND | Description | | | | | | | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--| | 0 | Transmission is in progress | | | | | | | | | | TEND is cleared to 0 when software reads TDRE after it has been set to 1, then writes 0 in TDRE, or the DMAC writes data in TDR. | | | | | | | | | 1 | End of transmission value) | (Initial | | | | | | | | | TEND is set to 1 when the chip is reset or enters standby to 0 in the serial control register (SCR), or TDRE is 1 wher byte serial character is transmitted. | | | | | | | | Bit 1—Multiprocessor Bit (MPB): Stores the value of the multiprocessor bit in receive data when a multiprocessor format is selected for receiving in asynchronous mode. MPB is a read-only bit and cannot be written. | Bit 1: MPB | Description | | | | | | | | |------------|-------------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--| | 0 | Multiprocessor bit value in receive data is 0 value) | (Initial | | | | | | | | | If RE is cleared to 0 when a multiprocessor format is selected, MPB retains its previous value. | | | | | | | | | 1 | Multiprocessor bit value in receive data is 1 | | | | | | | | Bit 0—Multiprocessor Bit Transfer (MPBT): Stores the value of the multiprocessor bit added to transmit data when a multiprocessor format is selected for transmitting in asynchronous mode. The MPBT setting is ignored in clocked synchronous mode, when a multiprocessor format is not selected, or when the SCI is not transmitting. | Bit 0: MPBT | Description | | |-------------|-------------------------------------------------------|----------| | 0 | Multiprocessor bit value in transmit data is 0 value) | (Initial | | 1 | Multiprocessor bit value in transmit data is 1 | | ### 13.2.8 Bit Rate Register (BRR) The bit rate register (BRR) is an 8-bit register that, together with the baud rate generator clock source selected by the CKS1 and CKS0 bits in the serial mode register (SMR), determines the serial transmit/receive bit rate. The CPU can always read and write to BRR. BRR is initialized to HFF by a reset, by the module standby function, and in standby mode. Table 13.3 shows examples of BRR settings in asynchronous mode; table 13.4 shows examples of BRR settings in clocked synchronous mode. Table 13.3 Bit Rates and BRR Settings in Asynchronous Mode Pφ (MHz) | | | | | | | · + ( | , | ' | | . + ( | | | | | | | | | | | | | | |----------------------|---|-----|--------------|---|-------|--------------|---|------|--------------|-------|-----|--------------|--|--|--|--|--|--|--|--|--|--|--| | | | 2 | | | 2.097 | 152 | | 2.45 | 76 | 3 | | | | | | | | | | | | | | | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | | | | | | | | | | | 110 | 1 | 141 | 0.03 | 1 | 148 | -0.04 | 1 | 174 | -0.26 | 1 | 212 | 0.03 | | | | | | | | | | | | | 150 | 1 | 103 | 0.16 | 1 | 108 | 0.21 | 1 | 127 | 0.00 | 1 | 155 | 0.16 | | | | | | | | | | | | | 300 | 0 | 207 | 0.16 | 0 | 217 | 0.21 | 0 | 255 | 0.00 | 1 | 77 | 0.16 | | | | | | | | | | | | | 600 | 0 | 103 | 0.16 | 0 | 108 | 0.21 | 0 | 127 | 0.00 | 0 | 155 | 0.16 | | | | | | | | | | | | | 1200 | 0 | 51 | 0.16 | 0 | 54 | -0.70 | 0 | 63 | 0.00 | 0 | 77 | 0.16 | | | | | | | | | | | | | 2400 | 0 | 25 | 0.16 | 0 | 26 | 1.14 | 0 | 31 | 0.00 | 0 | 38 | 0.16 | | | | | | | | | | | | | 4800 | 0 | 12 | 0.16 | 0 | 13 | -2.48 | 0 | 15 | 0.00 | 0 | 19 | -2.34 | | | | | | | | | | | | | 9600 | 0 | 6 | -6.99 | 0 | 6 | -2.48 | 0 | 7 | 0.00 | 0 | 9 | -2.34 | | | | | | | | | | | | | 19200 | 0 | 2 | 8.51 | 0 | 2 | 13.78 | 0 | 3 | 0.00 | 0 | 4 | -2.34 | | | | | | | | | | | | | 31250 | 0 | 1 | 0.00 | 0 | 1 | 4.86 | 0 | 1 | 22.88 | 0 | 2 | 0.00 | | | | | | | | | | | | | 38400 | 0 | 1 | -18.62 | 0 | 1 | -14.67 | 0 | 1 | 0.00 | _ | _ | _ | | | | | | | | | | | | Pφ (MHz) | | | 3.68 | 64 | | 4 | | | 4.91 | 52 | 5 | | | | |-------------------|---|------|--------------|---|-----|--------------|---|------|--------------|---|-----|--------------|--| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 2 | 64 | 0.70 | 2 | 70 | 0.03 | 2 | 86 | 0.31 | 2 | 88 | -0.25 | | | 150 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | | | 300 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | | | 600 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | | | 1200 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | | | 2400 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | | | 4800 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | | | 9600 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | | | 19200 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | 0 | 7 | 0.00 | 0 | 7 | 1.73 | | | 31250 | _ | | _ | 0 | 3 | 0.00 | 0 | 4 | -1.70 | 0 | 4 | 0.00 | | | 38400 | 0 | 2 | 0.00 | 0 | 2 | 8.51 | 0 | 3 | 0.00 | 0 | 3 | 1.73 | | | | | | | | | | | | | | | | | Table 13.3 Bit Rates and BRR Settings in Asynchronous Mode (cont) # Pφ (MHz) | | | 6 | | | 6.14 | 14 | | 7.372 | 288 | 8 | | | | |-------------------|---|-----|--------------|---|------|--------------|---|-------|--------------|---|-----|--------------|--| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 2 | 106 | -0.44 | 2 | 108 | 0.08 | 2 | 130 | -0.07 | 2 | 141 | 0.03 | | | 150 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | | | 300 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | | | 600 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | | | 1200 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | | | 2400 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | | | 4800 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | | | 9600 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | | | 19200 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | | | 31250 | 0 | 5 | 0.00 | 0 | 5 | 2.40 | 0 | 6 | 5.33 | 0 | 7 | 0.00 | | | 38400 | 0 | 4 | -2.34 | 0 | 4 | 0.00 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | | # Pφ (MHz) | | 9.8304 | | 04 | | 10 | ) | | 12 | 2 | 12.288 | | | | |-------------------|--------|-----|--------------|---|-----|--------------|---|-----|--------------|--------|-----|--------------|--| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 2 | 174 | -0.26 | 2 | 177 | -0.25 | 2 | 212 | 0.03 | 2 | 217 | 80.0 | | | 150 | 2 | 127 | 0.00 | 2 | 129 | 0.16 | 2 | 155 | 0.16 | 2 | 159 | 0.00 | | | 300 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | | | 600 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | | | 1200 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | | | 2400 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | | | 4800 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | | | 9600 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | | | 19200 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | 0 | 19 | 0.16 | 0 | 19 | 0.00 | | | 31250 | 0 | 9 | -1.70 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 11 | 2.40 | | | 38400 | 0 | 7 | 0.00 | 0 | 7 | 1.73 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | | Table 13.3 Bit Rates and BRR Settings in Asynchronous Mode (cont) Pφ (MHz) | | | 14.7 | 456 | | 16 | 5 | | 19.66 | 808 | 20 | | | | |-------------------|---|------|--------------|---|-----|--------------|---|-------|--------------|----|-----|--------------|--| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 3 | 64 | 0.70 | 3 | 70 | 0.03 | 3 | 86 | 0.31 | 3 | 88 | -0.25 | | | 150 | 2 | 191 | 0.00 | 2 | 207 | 0.16 | 2 | 255 | 0.00 | 3 | 64 | 0.16 | | | 300 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | 2 | 127 | 0.00 | 2 | 129 | 0.16 | | | 600 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | | | 1200 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | | | 2400 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | | | 4800 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | | | 9600 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | | | 19200 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | | | 31250 | 0 | 14 | -1.70 | 0 | 15 | 0.00 | 0 | 19 | -1.70 | 0 | 19 | 0.00 | | | 38400 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | | Pφ (MHz) | | | 24 | | | 24.576 | | | 28. | 7 | 30 | | | | |----------------------|---|-----|--------------|---|--------|--------------|---|-----|--------------|----|-----|--------------|--| | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | | 110 | 3 | 106 | -0.44 | 3 | 108 | 0.08 | 3 | 126 | 0.31 | 3 | 132 | 0.13 | | | 150 | 3 | 77 | 0.16 | 3 | 79 | 0.00 | 3 | 92 | 0.46 | 3 | 97 | -0.35 | | | 300 | 2 | 155 | 0.16 | 2 | 159 | 0.00 | 2 | 186 | -0.08 | 2 | 194 | 0.16 | | | 600 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | 2 | 92 | 0.46 | 2 | 97 | -0.35 | | | 1200 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | 1 | 186 | -0.08 | 1 | 194 | 0.16 | | | 2400 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | 1 | 92 | 0.46 | 1 | 97 | -0.35 | | | 4800 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | 0 | 186 | -0.08 | 0 | 194 | -1.36 | | | 9600 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | 0 | 92 | 0.46 | 0 | 97 | -0.35 | | | 19200 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | 0 | 46 | -0.61 | 0 | 48 | -0.35 | | | 31250 | 0 | 23 | 0.00 | 0 | 24 | -1.70 | 0 | 28 | -1.03 | 0 | 29 | 0.00 | | | 38400 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | 0 | 22 | 1.55 | 0 | 23 | 1.73 | | Table 13.4 Bit Rates and BRR Settings in Clocked Synchronous Mode n 3 2 8 Ν 124 249 | 16 | | | 28.7 | 30 | | | | |----|-----|---|------|----|-----|--|--| | n | N | n | N | n | N | | | | _ | _ | _ | _ | _ | _ | | | | 3 | 249 | _ | _ | _ | _ | | | | 3 | 124 | 3 | 223 | 3 | 233 | | | | 2 | 249 | 3 | 111 | 3 | 116 | | | | 1k | 1 | 249 | 2 | 124 | 2 | 249 | 3 | 111 | 3 | 116 | |------|---|-----|---|-----|---|-----|---|-----|---|-----| | 2.5k | 1 | 99 | 1 | 199 | 2 | 99 | 2 | 178 | 2 | 187 | | 5k | 0 | 199 | 1 | 99 | 1 | 199 | 2 | 89 | 2 | 93 | | 10k | 0 | 99 | 0 | 199 | 1 | 99 | 1 | 178 | 1 | 187 | | 25k | 0 | 39 | 0 | 79 | 0 | 159 | 1 | 71 | 1 | 74 | | 50k | 0 | 19 | 0 | 39 | 0 | 79 | 0 | 143 | 0 | 149 | | 100k | 0 | 9 | 0 | 19 | 0 | 39 | 0 | 71 | 0 | 74 | | 250k | 0 | 3 | 0 | 7 | 0 | 15 | _ | _ | 0 | 29 | | 500k | 0 | 1 | 0 | 3 | 0 | 7 | _ | _ | 0 | 14 | | 1M | 0 | 0* | 0 | 1 | 0 | 3 | _ | _ | _ | _ | | 2M | | | 0 | 0* | 0 | 1 | _ | _ | _ | _ | | | | | | | | | | | | | Pφ (MHz) Note: Settings within an error of 1% or less are recommended. Legeud: Bit Rate (bits/s) 110 250 500 Blank: No setting possible 4 Ν 249 124 n 2 2 —: Setting possible, but error occurs \*: Continuous transmission/reception not possible The BRR setting is calculated as follows: Asynchronous mode: $$N = \frac{P\varphi}{64 \times 2^{2n-1} \times B} \times 10^6 - 1$$ Clocked synchronous mode: $$N = \frac{P\varphi}{8 \times 2^{2n-1} \times B} \times 10^6 - 1$$ B: Bit rate (bit/s) N: BRR setting for baud rate generator (0 = N = 255) Po: Peripheral module clock (MHz) n: Baud rate generator clock source (n = 0, 1, 2, 3) (For the clock sources and values of n, see table 13.5.) Table 13.5 SMR Settings | SMR | Settings | |-----|----------| |-----|----------| | n | Clock Source | CKS1 | CKS0 | |---|--------------|------|------| | 0 | Pφ | 0 | 0 | | 1 | Ρφ/4 | 0 | 1 | | 2 | Pφ/16 | 1 | 0 | | 3 | Pφ/64 | 1 | 1 | The bit rate error for asynchronous mode is given by the following equation: Error (%) = $$\left\{ \frac{P\phi \times 10^6}{(N+1) \times B \times 64 \times 2^{2n-1}} - 1 \right\} \times 100$$ Table 13.6 shows the maximum bit rates in asynchronous mode when the baud rate generator is being used. Tables 13.7 and 13.8 show the maximum rates for external clock input. Table 13.6 Maximum Bit Rates for Various Frequencies with Baud Rate Generator (Asynchronous Mode) | | | | Settings | |----------|---------------------------|---|----------| | Pφ (MHz) | Maximum Bit Rate (bits/s) | n | N | | 2 | 62500 | 0 | 0 | | 2.097152 | 65536 | 0 | 0 | | 2.4576 | 76800 | 0 | 0 | | 3 | 93750 | 0 | 0 | | 3.6864 | 115200 | 0 | 0 | | 4 | 125000 | 0 | 0 | | 4.9152 | 153600 | 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 | 470 HITACHI Table 13.7 Maximum Bit Rates with External Clock Input (Asynchronous Mode) | Pφ (MHz) | External Input Clock (MHz) | Maximum Bit Rate (bits/s) | |----------|----------------------------|---------------------------| | 2 | 0.5000 | 31250 | | 2.097152 | 0.5243 | 32768 | | 2.4576 | 0.6144 | 38400 | | 3 | 0.7500 | 46875 | | 3.6864 | 0.9216 | 57600 | | 4 | 1.0000 | 62500 | | 4.9152 | 1.2288 | 76800 | | 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 | | | | | Table 13.8 Maximum Bit Rates with External Clock Input (Clocked Synchronous Mode) | Pφ (MHz) | External Input Clock (MHz) | Maximum Bit Rate (bits/s) | |----------|----------------------------|---------------------------| | 8 | 1.3333 | 1333333.3 | | 16 | 2.6667 | 2666666.7 | | 24 | 4.0000 | 4000000.0 | | 28.7 | 4.7833 | 4783333.3 | | 30 | 5.0000 | 5000000.0 | | · | | · | # 13.3 Operation #### 13.3.1 Overview For serial communication, the SCI has an asynchronous mode in which characters are synchronized individually, and a clocked synchronous mode in which communication is synchronized with clock pulses. Asynchronous/clocked synchronous mode and the communication format are selected in the serial mode register (SMR), as shown in table 13.9. The SCI clock source is selected by the $C/\overline{A}$ bit in the serial mode register (SMR) and the CKE1 and CKE0 bits in the serial control register (SCR), as shown in table 13.10. ### **Asynchronous Mode:** - Data length is selectable. seven or eight bits. - Parity and multiprocessor bits are selectable, as is the stop bit length (one or two bits). The preceding selections constitute the communication format and character length. - In receiving, it is possible to detect framing errors, parity errors, overrun errors. - An internal or external clock can be selected as the SCI clock source. - When an internal clock is selected, the SCI operates using the built-in baud rate generator, and can output a serial clock signal with a frequency matching the bit rate. - When an external clock is selected, the external clock input must have a frequency 16 times the bit rate. (The built-in baud rate generator is not used.) ### **Clocked Synchronous Mode:** - The communication format has a fixed eight-bit data length. - In receiving, it is possible to detect overrun errors. - An internal or external clock can be selected as the SCI clock source. - When an internal clock is selected, the SCI operates using the built-in baud rate generator, and outputs a synchronous clock signal to external devices. - When an external clock is selected, the SCI operates on the input synchronous clock. The built-in baud rate generator is not used. **Table 13.9 Serial Mode Register Settings and SCI Transfer Formats** **SMR Settings SCI Transfer Format** Bit 7 Bit 6 Bit 2 Bit 5 Bit 3 Data **Multipro-**Stop Bit **Parity** Mode CHR MP PΕ **STOP** Length cessor Bit Bit Length C/A Asynchronous 0 0 0 0 0 8-bit Not set 1 bit Not set 1 2 bits 1 0 Set 1 bit 1 2 bits Not set 1 bit 0 0 7-bit 1 2 bits 1 0 Set 1 bit 1 2 bits Asynchronous 0 0 1 0 8-bit Set Not set 1 bit (multiprocessor format) 1 2 bits 1 0 7-bit 1 bit 1 2 bits Clocked 1 8-bit Not set Not set None synchronous Note: don't care. Table 13.10 SMR and SCR Settings and SCI Clock Source Selection | | SMR | SCR S | Settings | so | SCI Transmit/Receive Clock | | | | | |------------------------|--------------|---------------|---------------|--------------|------------------------------------------------------|--|--|--|--| | Mode | Bit 7<br>C/Ā | Bit 1<br>CKE1 | Bit 0<br>CKE0 | Clock Source | SCK Pin Function | | | | | | Asynchronous | 0 | 0 | 0 | Internal | SCI does not use the SCK pin | | | | | | | | | 1 | | Outputs a clock with frequency matching the bit rate | | | | | | | | 1 | 0 | External | Inputs a clock with frequency 16 times the bit rate | | | | | | | | | 1 | | | | | | | | Clocked<br>Synchronous | 1 | 0 | 0 | Internal | Outputs the synchronous clock | | | | | | | | | 1 | | | | | | | | | | 1 | 0 | External | Inputs the synchronous clock | | | | | | | | | 1 | | | | | | | ### 13.3.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 SCI are independent, so full duplex communication is possible. The transmitter and receiver are both double buffered, so data can be written and read while transmitting and receiving are in progress, enabling continuous transmitting and receiving. Figure 13.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 SCI 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 SCI synchronizes on the falling edge of the start bit. The SCI 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 13.2 Example of Data Format in Asynchronous Communication (8-Bit Data with Parity and Two Stop Bits) **Transmit/Receive Formats.** Table 13.11 shows the 12 communication formats that can be selected in asynchronous mode. The format is selected by settings in the serial mode register (SMR). **Table 13.11 Serial Communication Formats (Asynchronous Mode)** | | SM | R Bits | S | Serial Transmit/Receive Format and Frame Length | | | | | | | | | | | | |-----|----|--------|------|-------------------------------------------------|-----------------------|--|----|-------|------|------|------|------|------|--|--| | CHR | PE | MP | STOP | 1 | 2 3 4 5 6 7 8 9 | | | | | 10 | 11 | 12 | | | | | 0 | 0 | 0 | 0 | START | START 8-bit data | | | | | STOP | | | | | | | 0 | 0 | 0 | 1 | START | START 8-bit data | | | | | | STOP | STOP | | | | | 0 | 1 | 0 | 0 | START 8-bit data | | | | | Р | STOP | | | | | | | 0 | 1 | 0 | 1 | START | START 8-bit data | | | | | Р | STOP | STOP | | | | | 1 | 0 | 0 | 0 | START | START 7-bit data STOP | | | | | | | | | | | | 1 | 0 | 0 | 1 | START | | | 7- | bit d | ata | | | STOP | STOP | | | | 1 | 1 | 0 | 0 | START | | | 7- | bit d | ata | | | Р | STOP | | | | 1 | 1 | 0 | 1 | START | RT 7-bit data P | | | | STOP | STOP | | | | | | | 0 | _ | 1 | 0 | START | RT 8-bit data | | | | MPB | STOP | | | | | | | 0 | _ | 1 | 1 | START | 8-bit data | | | | MPB | STOP | STOP | | | | | | 1 | _ | 1 | 0 | START | 7-bit data MPB | | | | STOP | | | | | | | | 1 | _ | 1 | 1 | START | 7-bit data MPB | | | | STOP | STOP | | | | | | —: Don't care bits. START: Start bit STOP: Stop bit P: Parity bit MPB: Multiprocessor bit **Clock:** An internal clock generated by the built-in baud rate generator or an external clock input from the SCK pin can be selected as the SCI transmit/receive clock. The clock source is selected by the $C/\overline{A}$ bit in the serial mode register (SMR) and bits CKE1 and CKE0 in the serial control register (SCR) (table 13.9). 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 SCI operates on an internal clock, it can output a clock signal at the SCK pin. The frequency of this output clock is equal to the bit rate. The phase is aligned as in figure 13.3 so that the rising edge of the clock occurs at the center of each transmit data bit. Figure 13.3 Output Clock and Serial Data Timing (Asynchronous Mode) ### **Transmitting and Receiving Data** **SCI Initialization (Asynchronous Mode):** Before transmitting or receiving, clear the TE and RE bits to 0 in the serial control register (SCR), then initialize the SCI as follows. When changing the operation mode or communication format, always clear the TE and RE bits to 0 before following the procedure given below. Clearing TE to 0 sets TDRE to 1 and initializes the transmit shift register (TSR). Clearing RE to 0, however, does not initialize the RDRF, PER, FER, and ORER flags and receive data register (RDR), which retain their previous contents. When an external clock is used, the clock should not be stopped during initialization or subsequent operation. SCI operation becomes unreliable if the clock is stopped. Figure 13.4 shows a sample flowchart for initializing the SCI. The procedure for initializing the SCI is as follows: - 1. Select the communication format in the serial mode register (SMR). - 2. Write the value corresponding to the bit rate in the bit rate register (BRR) unless an external clock is used. - 3. Select the clock source in the serial control register (SCR). Leave RIE, TIE, TEIE, MPIE, TE and RE cleared to 0. If clock output is selected in asynchronous mode, clock output starts immediately after the setting is made in SCR. 4. Wait for at least the interval required to transmit or receive one bit, then set TE or RE in the serial control register (SCR) to 1. Also set RIE, TIE, TEIE and MPIE as necessary. Setting TE or RE enables the SCI to use the TxD or RxD pin. The initial states are the mark state when transmitting, and the idle state when receiving (waiting for a start bit). Figure 13.4 Sample Flowchart for SCI Initialization 478 HITACHI **Transmitting Serial Data (Asynchronous Mode):** Figure 13.5 shows a sample flowchart for transmitting serial data. The procedure for transmitting serial data is as follows: - 1. SCI status check and transmit data write: read the serial status register (SSR), check that the TDRE bit is 1, then write transmit data in the transmit data register (TDR) and clear TDRE to 0. - 2. To continue transmitting serial data, read the TDRE bit to check whether it is safe to write (if it reads 1); if so, write data in TDR, then clear TDRE to 0. When the DMAC is started by a transmit-data-empty interrupt request (TXI) in order to write data in TDR, the TDRE bit is checked and cleared automatically. Figure 13.5 Sample Flowchart for Transmitting Serial Data In transmitting serial data, the SCI operates as follows: - 1. The SCI monitors the TDRE bit in SSR. When TDRE is cleared to 0, the SCI recognizes that the transmit data register (TDR) contains new data, and loads this data from TDR into the transmit shift register (TSR). - 2. After loading the data from TDR into TSR, the SCI sets the TDRE bit to 1 and starts transmitting. If the transmit-data-empty interrupt enable bit (TIE) is set to 1 in SCR, the SCI requests a transmit-data-empty interrupt (TXI) at this time. Serial transmit data is transmitted in the following order from the TxD pin: - a. Start bit: one 0-bit is output. - b. Transmit data: seven or eight bits of data are output, LSB first. - c. Parity bit or multiprocessor bit: one parity bit (even or odd parity) or one multiprocessor bit is output. Formats in which neither a parity bit nor a multiprocessor bit is output can also be selected. - d. Stop bit: one or two 1-bits (stop bits) are output. - e. Mark state: output of 1-bits continues until the start bit of the next transmit data. - 3. The SCI checks the TDRE bit when it outputs the stop bit. If TDRE is 0, the SCI loads new data from TDR into TSR, outputs the stop bit, then begins serial transmission of the next frame. If TDRE is 1, the SCI sets the TEND bit to 1 in SSR, outputs the stop bit, then continues output of 1-bits (mark state). If the transmit-end interrupt enable bit (TEIE) in SCR is set to 1, a transmit-end interrupt (TEI) is requested. Figure 13.6 shows an example of SCI transmit operation in asynchronous mode. Figure 13.6 Example of SCI Transmit Operation in Asynchronous Mode (8-Bit Data with Parity and One Stop Bit) **Receiving Serial Data (Asynchronous Mode):** Figure 13.7 shows a sample flowchart for receiving serial data. The procedure for receiving serial data is as follows: - 1. Receive error handling: if a receive error occurs, read the ORER, PER and FER bits of the SSR to identify the error. After executing the necessary error handling, clear ORER, PER and FER all to 0. Receiving cannot resume if ORER, PER or FER remain set to 1. - 2. SCI status check and receive-data read: read the serial status register (SSR), check that RDRF is set to 1, then read receive data from the receive data register (RDR) and clear RDRF to 0. The RXI interrupt can also be used to determine if the RDRF bit has changed from 0 to 1. - 3. To continue receiving serial data: read the RDRF and RDR bits and clear RDRF to 0 before the stop bit of the current frame is received. If the DMAC is started by a receive-data-full interrupt (RXI) to read RDR, the RDRF bit is cleared automatically so this step is unnecessary. Figure 13.7 Sample Flowchart for Receiving Serial Data 482 HITACHI Figure 13.7 Sample Flowchart for Receiving Serial Data (cont) In receiving, the SCI operates as follows: - 1. The SCI monitors the receive data line. When it detects a start bit (0), the SCI synchronizes internally and starts receiving. - 2. Receive data is shifted into RSR in order from LSB to MSB. - 3. The parity bit and stop bit are received. After receiving these bits, the SCI makes the following checks: - a. Parity check: the number of 1s in the receive data must match the even or odd parity setting of the $O/\overline{E}$ bit in SMR. - b. Stop bit check: the stop bit value must be 1. If there are two stop bits, only the first stop bit is checked. - c. Status check: RDRF must be 0 so that receive data can be loaded from RSR into RDR. If these checks all pass, the SCI sets RDRF to 1 and stores the received data in RDR. If one of the checks fails (receive error), the SCI operates as indicated in table 13.11. Note: When a receive error flag is set, further receiving is disabled. In reception, the RDRF bit is not set to 1. Be sure to clear the error flags. 4. After setting RDRF to 1, if the receive-data-full interrupt enable bit (RIE) is set to 1 in SCR, the SCI requests a receive-data-full interrupt (RXI). If one of the error flags (ORER, PER, or FER) is set to 1 and the receive-data-full interrupt enable bit (RIE) in SCR is also set to 1, the SCI requests a receive-error interrupt (ERI). Figure 13.8 shows an example of SCI receive operation in asynchronous mode. Table 13.12 Receive Error Conditions and SCI Operation | Receive Error | Abbreviation | Condition | Data Transfer | | | | |-------------------|--------------|--------------------------------------------------------------------|-------------------------------------------|--|--|--| | Overrun error | ORER | Receiving of next data ends while RDRF is still set to 1 in SSR | Receive data not loaded from RSR into RDR | | | | | Framing error FER | | Stop bit is 0 | Receive data loaded from RSR into RDR | | | | | Parity error | PER | Parity of receive data differs from even/odd parity setting in SMR | Receive data loaded from RSR into RDR | | | | Figure 13.8 Example of SCI Receive Operation (8-Bit Data with Parity and One Stop Bit) ## 13.3.3 Multiprocessor Communication The multiprocessor communication function enables several processors to share a single serial communication line. The processors communicate in asynchronous mode using a format with an additional multiprocessor bit (multiprocessor format). In multiprocessor communication, each receiving processor is addressed by a unique ID. A serial communication cycle consists of an ID-sending cycle that identifies the receiving processor, and a data-sending cycle. The multiprocessor bit distinguishes ID-sending cycles from data-sending cycles. The transmitting processor starts by sending the ID of the receiving processor with which it wants to communicate as data with the multiprocessor bit set to 1. Next, the transmitting processor sends transmit data with the multiprocessor bit cleared to 0. Receiving processors skip incoming data until they receive data with the multiprocessor bit set to 1. When they receive data with the multiprocessor bit set to 1, receiving processors compare the data with their IDs. The receiving processor with a matching ID continues to receive further incoming data. Processors with IDs not matching the received data skip further incoming data until they again receive data with the multiprocessor bit set to 1. Multiple processors can send and receive data in this way. Figure 13.9 shows an example of communication among processors using the multiprocessor format. Figure 13.9 Example of Communication among Processors Using Multiprocessor Format (Sending Data H'AA to Receiving Processor A) **Communication Formats:** Four formats are available. Parity-bit settings are ignored when the multiprocessor format is selected. For details see table 13.8. **Clock:** See the description in the asynchronous mode section. ## **Transmitting and Receiving Data** **Transmitting Multiprocessor Serial Data:** Figure 13.10 shows a sample flowchart for transmitting multiprocessor serial data. The procedure for transmitting multiprocessor serial data is as follows: - 1. SCI status check and transmit data write: read the serial status register (SSR), check that the TDRE bit is 1, then write transmit data in the transmit data register (TDR). Also set the MPBT (multiprocessor bit transfer) bit to 0 or 1 in SSR. Finally, clear TDRE to 0. - 2. To continue transmitting serial data, read the TDRE bit to check whether it is safe to write (if it reads 1); if so, write data in TDR, then clear TDRE to 0. When the DMAC is started by a transmit-data-empty interrupt request (TXI) to write data in TDR, the TDRE bit is checked and cleared automatically. Figure 13.10 Sample Flowchart for Transmitting Multiprocessor Serial Data In transmitting serial data, the SCI operates as follows: - 1. The SCI monitors the TDRE bit in SSR. When TDRE is cleared to 0 the SCI recognizes that the transmit data register (TDR) contains new data, and loads this data from TDR into the transmit shift register (TSR). - 2. After loading the data from TDR into TSR, the SCI sets the TDRE bit to 1 and starts transmitting. If the transmit-data-empty interrupt enable bit (TIE) in SCR is set to 1, the SCI requests a transmit-data-empty interrupt (TXI) at this time. Serial transmit data is transmitted in the following order from the TxD pin: - a. Start bit: one 0 bit is output. - b. Transmit data: seven or eight bits are output, LSB first. - c. Multiprocessor bit: one multiprocessor bit (MPBT value) is output. - d. Stop bit: one or two 1-bits (stop bits) are output. - e. Mark state: output of 1-bits continues until the start bit of the next transmit data. 3. The SCI checks the TDRE bit when it outputs the stop bit. If TDRE is 0, the SCI loads data from TDR into TSR, outputs the stop bit, then begins serial transmission of the next frame. If TDRE is 1, the SCI sets the TEND bit in SSR to 1, outputs the stop bit, then continues output of 1-bits in the mark state. If the transmit-end interrupt enable bit (TEIE) in SCR is set to 1, a transmit-end interrupt (TEI) is requested at this time. Figure 13.11 shows an example of SCI transmit operation using a multiprocessor format. Figure 13.11 Example of SCI Multiprocessor Transmit Operation (8-Bit Data with Multiprocessor Bit and One Stop Bit) **Receiving Multiprocessor Serial Data:** Figure 13.12 shows a sample flowchart for receiving multiprocessor serial data. The procedure for receiving multiprocessor serial data is as follows. - 1. ID receive cycle: set the MPIE bit in the serial control register (SCR) to 1. - 2. SCI status check, ID reception and comparison: read the serial status register (SSR), check that RDRF is set to 1, then read data from the receive data register (RDR) and compare with the processor's own ID. If the ID does not match the receive data, set MPIE to 1 again and clear RDRF to 0. If the ID matches the receive data, clear RDRF to 0. - 3. Receive error handling: if a receive error occurs (figure 13.12 (cont)), read the ORER and FER bits in SSR to identify the error. After executing the necessary error handling, clear both ORER and FER to 0. Receiving cannot resume if ORER or FER remains set to 1. - 4. SCI status check and data receiving: read SSR, check that RDRF is set to 1, then read data from the receive data register (RDR). Figure 13.12 Sample Flowchart for Receiving Multiprocessor Serial Data Figure 13.12 Sample Flowchart for Receiving Multiprocessor Serial Data (cont) Figure 13.13 shows an example of SCI receive operation using a multiprocessor format. Figure 13.13 Example of SCI Receive Operation (Own ID Does Not Match Data, 8-Bit Data with Multiprocessor Bit and One Stop Bit) Figure 13.13 Example of SCI Receive Operation (cont) (Own ID Matches Data, 8-Bit Data with Multiprocessor Bit and One Stop Bit) ## 13.3.4 Clocked Synchronous Operation In clocked synchronous mode, the SCI transmits and receives data in synchronization with clock pulses. This mode is suitable for high-speed serial communication. The SCI transmitter and receiver are independent, so full duplex communication is possible while sharing the same clock. The transmitter and receiver are also double buffered, so continuous transmitting or receiving is possible by reading or writing data while transmitting or receiving is in progress. Figure 13.14 shows the general format in clocked synchronous serial communication. Figure 13.14 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 LSB (first) to MSB (last). After output of the MSB, the communication line remains in the state of the MSB. In clocked synchronous mode, the SCI transmits or receives data by synchronizing with the falling edge of the serial clock. **Communication Format:** The data length is fixed at eight bits. No parity bit or multiprocessor bit can be added. **Clock:** An internal clock generated by the built-in baud rate generator or an external clock input from the SCK pin can be selected as the SCI transmit/receive clock. The clock source is selected by the $C/\overline{A}$ bit in the serial mode register (SMR) and bits CKE1 and CKE0 in the serial control register (SCR). See table 13.9. When the SCI 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 SCI is not transmitting or receiving, the clock signal remains in the high state. In receive-only operations, the SCI performs receive operations with two characters as one unit, and therefore a 16-pulse serial clock is output. To perform receive operations using a one-character unit, an external clock should be selected as the clock source. Figure 13.15 shows an example of SCI transmit operation. In transmitting serial data, the SCI operates as follows. - 1. The SCI monitors the TDRE bit in SSR. When TDRE is cleared to 0 the SCI recognizes that the transmit data register (TDR) contains new data and loads this data from TDR into the transmit shift register (TSR). - 2. After loading the data from TDR into TSR, the SCI sets the TDRE bit to 1 and starts transmitting. If the transmit-data-empty interrupt enable bit (TIE) in SCR is set to 1, the SCI requests a transmit-data-empty interrupt (TXI) at this time. If clock output mode is selected, the SCI outputs eight synchronous clock pulses. If an external clock source is selected, the SCI outputs data in synchronization with the input clock. Data is output from the TxD pin in order from LSB (bit 0) to MSB (bit 7). - 3. The SCI checks the TDRE bit when it outputs the MSB (bit 7). If TDRE is 0, the SCI loads data from TDR into TSR, transmits the MSB, then begins serial transmission of the next frame. If TDRE is 1, the SCI sets the TEND bit in SSR to 1, transmits the MSB (bit 7), then holds the transmit data pin (TxD) in the MSB state. If the transmit-end interrupt enable bit (TEIE) in SCR is set to 1, a transmit-end interrupt (TEI) is requested at this time. - 4. After the end of serial transmission, the SCK pin is held in the high state. #### **Transmitting and Receiving Data** Figure 13.15 Example of SCI Transmit Operation **SCI Initialization (Clocked Synchronous Mode):** Before transmitting or receiving, software must clear the TE and RE bits to 0 in the serial control register (SCR), then initialize the SCI as follows. When changing the mode or communication format, always clear the TE and RE bits to 0 before following the procedure given below. Clearing TE to 0 sets TDRE to 1 and initializes the transmit shift register (TSR). Clearing RE to 0, however, does not initialize the RDRF, PER, FER, and ORER flags and receive data register (RDR), which retain their previous contents. Figure 13.16 shows a sample flowchart for initializing the SCI. The procedure for initializing the SCI is as follows. - 1. Select the communication format in the serial mode register (SMR). - 2. Write the value corresponding to the bit rate in the bit rate register (BRR) unless an external clock is used. - 3. Select the clock source in the serial control register (SCR). Leave RIE, TIE, TEIE, MPIE, TE and RE cleared to 0. - 4. Wait for at least the interval required to transmit or receive one bit, then set TE or RE in the serial control register (SCR) to 1. Also set RIE, TIE, TEIE and MPIE. Figure 13.16 Sample Flowchart for SCI Initialization **Transmitting Serial Data (Clocked Synchronous Mode):** Figure 13.17 shows a sample flowchart for transmitting serial data. The procedure for transmitting serial data is as follows. - 1. SCI status check and transmit data write: read the serial status register (SSR), check that the TDRE bit is 1, then write transmit data in the transmit data register (TDR) and clear TDRE to 0. - 2. To continue transmitting serial data, read the TDRE bit to check whether it is safe to write (if it reads 1); if so, write data in TDR, then clear TDRE to 0. When the DMAC is started by a transmit-data-empty interrupt request (TXI) to write data in TDR, the TDRE bit is checked and cleared automatically. Figure 13.17 Sample Flowchart for Serial Transmitting **Receiving Serial Data (Clocked Synchronous Mode):** Figure 13.18 shows a sample flowchart for receiving serial data. When switching from asynchronous mode to clocked synchronous mode, make sure that ORER, PER, and FER are cleared to 0. If PER or FER is set to 1, the RDRF bit will not be set and both transmitting and receiving will be disabled. Figure 13.19 shows an example of the SCI receive operation. The procedure for receiving serial data is as follows: - 1. Receive error handling: if a receive error occurs, read the ORER bit in SSR to identify the error. After executing the necessary error handling, clear ORER to 0. Transmitting/receiving cannot resume if ORER remains set to 1. - 2. SCI status check and receive data read: read the serial status register (SSR), check that RDRF is set to 1, then read receive data from the receive data register (RDR) and clear RDRF to 0. The RXI interrupt can also be used to determine if the RDRF bit has changed from 0 to 1. - 3. To continue receiving serial data: read RDR, and clear RDRF to 0 before the MSB (bit 7) of the current frame is received. If the DMAC is started by a receive-data-full interrupt (RXI) to read RDR, the RDRF bit is cleared automatically so this step is unnecessary. Figure 13.18 Sample Flowchart for Serial Receiving Figure 13.18 Sample Flowchart for Serial Receiving (cont) Figure 13.19 Example of SCI Receive Operation In receiving, the SCI operates as follows: - 1. The SCI synchronizes with serial clock input or output and initializes internally. - 2. Receive data is shifted into RSR in order from LSB to MSB. After receiving the data, the SCI checks that RDRF is 0 so that receive data can be loaded from RSR into RDR. If this check passes, the SCI sets RDRF to 1 and stores the received data in RDR. If the check does not pass (receive error), the SCI operates as indicated in table 13.8. No further transmit or receive operations are possible in this state. The RDRF bit is not set to 1. Be sure to clear the error flag. - 3. After setting RDRF to 1, if the receive-data-full interrupt enable bit (RIE) is set to 1 in SCR, the SCI requests a receive-data-full interrupt (RXI). If the ORER bit is set to 1 and the receive-data-full interrupt enable bit (RIE) in SCR is also set to 1, the SCI requests a receive-error interrupt (ERI). #### Transmitting and Receiving Serial Data Simultaneously (Clocked Synchronous Mode): Figure 13.20 shows a sample flowchart for transmitting and receiving serial data simultaneously. The procedure for transmitting and receiving serial data simultaneously is as follows: - 1. SCI status check and transmit data write: read the serial status register (SSR), check that the TDRE bit is 1, then write transmit data in the transmit data register (TDR) and clear TDRE to 0. The TXI interrupt can also be used to determine if the TDRE bit has changed from 0 to 1. - 2. Receive error handling: if a receive error occurs, read the ORER bit in SSR to identify the error. After executing the necessary error handling, clear ORER to 0. Transmitting/receiving cannot resume if ORER remains set to 1. - 3. SCI status check and receive data read: read the serial status register (SSR), check that RDRF is set to 1, then read receive data from the receive data register (RDR) and clear RDRF to 0. The RXI interrupt can also be used to determine if the RDRF bit has changed from 0 to 1. - 4. To continue transmitting and receiving serial data: read the RDRF bit and RDR, and clear RDRF to 0 before the MSB (bit 7) of the current frame is received. Also read the TDRE bit to check whether it is safe to write (if it reads 1); if so, write data in TDR, then clear TDRE to 0 before the MSB (bit 7) of the current frame is transmitted. When the DMAC is started by a transmit-data-empty interrupt request (TXI) to write data in TDR, the TDRE bit is checked and cleared automatically. When the DMAC is started by a receive-data-full interrupt (RXI) to read RDR, the RDRF bit is cleared automatically. Figure 13.20 Sample Flowchart for Serial Transmitting ## 13.4 SCI Interrupt Sources and the DMAC The SCI has four interrupt sources in each channel: transmit-end (TEI), receive-error (ERI), receive-data-full (RXI), and transmit-data-empty (TXI). Table 13.13 lists the interrupt sources and indicates their priority. These interrupts can be enabled and disabled by the TIE, RIE, and TEIE bits in the serial control register (SCR). Each interrupt request is sent separately to the interrupt controller. TXI is requested when the TDRE bit in SSR is set to 1. TXI can start the direct memory access controller (DMAC) to transfer data. TDRE is automatically cleared to 0 when the DMAC writes data in the transmit data register (TDR). RXI is requested when the RDRF bit in SSR is set to 1. RXI can start the DMAC to transfer data. RDRF is automatically cleared to 0 when the DMAC reads the receive data register (RDR). ERI is requested when the ORER, PER, or FER bit in SSR is set to 1. ERI cannot start the DMAC. TEI is requested when the TEND bit in SSR is set to 1. TEI cannot start the DMAC. Where the TXI interrupt indicates that transmit data writing is enabled, the TEI interrupt indicates that the transmit operation is complete. **Table 13.13 SCI Interrupt Sources** | Interrupt Source | Description | DMAC Availability | Priority | |------------------|-------------------------------------|-------------------|----------| | ERI | Receive error (ORER, PER, or FER) | No | High | | RXI | Receive data register full (RDRF) | Yes | _ | | TXI | Transmit data register empty (TDRE) | Yes | _ | | TEI | Transmit end (TEND) | No | Low | See section 4, Exception Handling, for information on the priority order and relationship to non-SCI interrupts. ## 13.5 Usage Notes Note the following points when using the SCI. **TDR Write and TDRE Flag:** The TDRE bit in the serial status register (SSR) is a status flag indicating loading of transmit data from TDR into TSR. The SCI sets TDRE to 1 when it transfers data from TDR to TSR. Data can be written to TDR regardless of the TDRE bit status. If new data is written in TDR when TDRE is 0, however, the old data stored in TDR will be lost because the data has not yet been transferred to TSR. Before writing transmit data to TDR, be sure to check that TDRE is set to 1. **Simultaneous Multiple Receive Errors:** Table 13.14 indicates the state of the SSR status flags when multiple receive errors occur simultaneously. When an overrun error occurs, the RSR contents cannot be transferred to RDR, so receive data is lost. Table 13.14 SSR Status Flags and Transfer of Receive Data | | | Receive Data<br>Transfer | | | | |----------------------------------------------|------|--------------------------|---|-----|-----------| | Receive Error Status | RDRF | ORER FER | | PER | RSR → RDR | | Overrun error | 1 | 1 | 0 | 0 | X | | Framing error | 0 | 0 | 1 | 0 | 0 | | Parity error | 0 | 0 | 0 | 1 | 0 | | Overrun error + framing error | 1 | 1 | 1 | 0 | X | | Overrun error + parity error | 1 | 1 | 0 | 1 | Х | | Framing error + parity error | 0 | 0 | 1 | 1 | 0 | | Overrun error + framing error + parity error | 1 | 1 | 1 | 1 | Х | O: Receive data is transferred from RSR to RDR. **Break Detection and Processing:** In the break state, the input from the RxD pin consists of all 0s, so FER is set and the parity error flag (PER) may also be set. In the break state, the SCI receiver continues to operate, so if the FER bit is cleared to 0, it will be set to 1 again. Receive Error Flags and Transmitter Operation (Clocked Synchronous Mode Only): When a receive error flag (ORER, PER, or FER) is set to 1, the SCI will not start transmitting even if TDRE is set to 1. Be sure to clear the receive error flags to 0 before starting to transmit. Note that clearing RE to 0 does not clear the receive error flags. Receive Data Sampling Timing and Receive Margin in Asynchronous Mode: In asynchronous mode, the SCI operates on a base clock of 16 times the bit rate frequency. In receiving, the SCI synchronizes internally with the falling edge of the start bit, which it samples on the base clock. Receive data is latched on the rising edge of the eighth base clock pulse. See figure 13.21. X: Receive data is not transferred from RSR to RDR. Figure 13.21 Receive Data Sampling Timing in Asynchronous Mode The receive margin in asynchronous mode can therefore be expressed as in equation 1. # Equation 1: $$M = \left| \left( 0.5 - \frac{1}{2N} \right) - (L - 0.5) F - \frac{|D - 0.5|}{N} (1 + F) \right| \times 100\%$$ M: Receive margin (%) N: Ratio of clock frequency to bit rate (N = 16) D : Clock duty cycle (D = 0-1.0) L: Frame length (L = 9-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: D = 0.5, 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–30%. #### **Constraints on DMAC Use:** - When using an external clock for the serial clock, update TDR with the direct memory access controller (DMAC), and input the transmit clock after the elapse of at least twenty Pφ cycles. If the transmit clock is input in the first four Pφ clock cycles after TDR is written, an error may occur (figure 13.22). - Before reading the receive data register (RDR) with the DMAC, the relevant SCI receivedata-full interrupt must be selected as an activation source using the resource select (RS) bit in the DMA request/response selection control register (DRCR). Figure 13.22 Example of Clocked Synchronous Transmission with DMAC ## **Cautions for Clocked Synchronous External Clock Mode:** - Set TE = RE = 1 only when external clock SCK is 1. - Do not set TE = RE = 1 until at least four clock cycles after external clock SCK has changed from 0 to 1. - On receiving, RDRF is set to 1 when RE is cleared to 0 after 2.5–3.5 clocks with the rising edge of the SCK input, D7 bit in the RxD. However it cannot be copied to RDR. **Caution for Clocked Synchronous Internal Clock Mode:** When receiving, RDRF is set to 1 when RE is cleared to 0 1.5 clocks after the rising edge of the RxD D7 bit SCK output, but it cannot be copied to RDR. # Section 14 Smart Card Interface #### 14.1 Overview As a serial communication interface(SCI) extension function, an IC card (smart card) interface conforming to ISO/IEC7816-3 (Identification Card) data transmission protocol system T=0; asynchronous duplex character transmission protocol are supported. Register settings are used to switch between the ordinary serial communication interface and the smart card interface. #### 14.1.1 Features The smart card interface has the following features: - Asynchronous mode - Data length: Eight bits - Parity bit generation and check - Receive mode error signal detection (parity error) - Transmit mode error signal detection and automatic re-transmission of data - Supports both direct convention and inverse convention - Bit rate can be selected using on-chip baud rate generator. - Three types of interrupts: Transmit-data-empty, receive-data-full, and communication-error interrupts are requested independently. # 14.1.2 Block Diagram Figure 14.1 shows a block diagram of the smart card interface. Figure 14.1 Smart Card Interface Block Diagram # 14.1.3 Pin Configuration Table 14.1 summarizes the smart card interface pins. Table 14.1 SCI Pins | Pin Name | Abbreviation | Input/Output | Function | |-------------------|--------------|--------------|----------------------| | Serial clock pin | SCK | Output | Clock output | | Receive data pin | RxD | Input | Receive data input | | Transmit data pin | TxD | Output | Transmit data output | # 14.1.4 Register Configuration Table 14.2 summarizes the registers used by the smart card interface. The SMR, BRR, SCR, TDR, and RDR registers are the same as in the ordinary SCI function. They are described in section 13, Serial Communication Interface (SCI). Table 14.2 Registers | Name | Abbreviation | R/W | Initial Value*3 | Address | Access Size | |--------------------------|--------------|---------|-----------------|------------|-------------| | Serial mode register | SMR | R/W | H'00 | H'FFFFE00 | 8 | | Bit rate register | BRR | R/W | H'FF | H'FFFFFE01 | 8 | | Serial control register | SCR | R/W | H'00 | H'FFFFFE02 | 8 | | Transmit data register | TDR | R/W | H'FF | H'FFFFE03 | 8 | | Serial status register | SSR | R/(W)*1 | H'84 | H'FFFFE04 | 8 | | Receive data register | RDR | R | H'00 | H'FFFFE05 | 8 | | Smart card mode register | SCMR | R/W | *2 | H'FFFFE06 | 8 | Notes: 1. Only 0 can be written, to clear the flags. - 2. Bits 0, 2, and 3 are cleared. The value of the other bits is undefined. - 3. Initialized by a power-on or manual reset. # 14.2 Register Descriptions This section describes the registers added for the smart card interface and the bits whose functions are changed. # 14.2.1 Smart Card Mode Register (SCMR) The smart card mode register (SCMR) is an 8-bit read/write register that selects smart card interface functions. SMR bits 0, 2, and 3 are initialized to 0 by a reset and in standby mode. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|------|------|---|------| | Bit name: | _ | _ | _ | _ | SDIR | SINV | _ | SMIF | | Initial value: | | _ | _ | _ | 0 | 0 | _ | 0 | | R/W: | _ | _ | _ | _ | R/W | R/W | _ | R/W | Bits 7 to 4 and 1—Reserved: An undefined value will be returned if these bits are read. Bit 3—Smart Card Data Transfer Direction (SDIR): Selects the serial/parallel conversion format. | Bit 3: SDIR | Description | |-------------|----------------------------------------------------------------------------------------------------| | 0 | Contents of TDR are transferred LSB first, receive data is stored in RDR LSB first (Initial value) | | 1 | Contents of TDR are transferred MSB first, receive data is stored in RDR MSB first | Bit 2—Smart Card Data Inversion (SINV): Specifies whether to invert the logic level of the data. This function is used in combination with bit 3 for transmitting and receiving with an inverse convention card. SINV does not affect the logic level of the parity bit. See section 14.3.4, Register Settings, for information on how parity is set. | Bit 2: SINV | Description | | |-------------|----------------------------------------------------------------------------------------------------|---| | 0 | Contents of TDR are transferred unchanged, receive data is stored in RDF unchanged (Initial value) | ₹ | | 1 | Contents of TDR are inverted before transfer, receive data is inverted before storage in RDR | | Bit 0—Smart Card Interface Mode Select (SMIF): Enables the smart card interface function. | Bit 0: SMIF | Description | | |-------------|-----------------------------------------------|----------| | 0 | Smart card interface function disabled value) | (Initial | | 1 | Smart card interface function enabled | | # 14.2.2 Serial Mode Register (SMR) In the smart card interface mode, the function of SMR bit 7 is changed. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|----------------------|-----|-----|-----|------|-----|------|------| | Bit name: | $GM(C/\overline{A})$ | CHR | PE | O/E | STOP | MP | CKS1 | CKS0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bit 7—GSM Mode (GM): Sets the smart card interface function to GSM mode. With the normal smart card interface, this bit is cleared to 0. Setting this bit to 1 selects GSM mode, an additional mode for controlling the timing for setting the TEND flag that indicates completion of transmission, and the type of clock output used. The details of the additional clock output control mode are specified by the CKE1 and CKE0 bits in the serial control register (SCR). | Bit 7: GM | Description | | | | | | | |-----------|-----------------------------------------------------------------------|--|--|--|--|--|--| | 0 | Normal smart card interface mode operation (Initial value) | | | | | | | | | 1. The TEND flag is set 12.5 etu after the beginning of the start bit | | | | | | | | | 2. Clock output on/off control only | | | | | | | | 1 | GSM mode smart card interface mode operation | | | | | | | | | 1. The TEND flag is set 11.0 etu after the beginning of the start bit | | | | | | | | | 2. Clock output on/off and fixed-high/fixed-low control (set in SCR) | | | | | | | Bits 6 to 0: These bits have the same function as in the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. # 14.2.3 Serial Control Register (SCR) In the smart card interface mode, the function of SCR bits 1 and 0 is changed. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|------|------|------|------| | Bit name: | TIE | RIE | TE | RE | MPIE | TEIE | CKE1 | CKE0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 7 to 2: These bits have the same function as in the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. Bits 1 and 0—Clock Enable 1 and 0 (CKE1, CKE0): These bits specify the function of the SCK pin. In the smart card interface mode, an internal clock is always used as teh clock source. In this mode, it is possible to specify a fixed high level or fixed low level for the clock output, in addition to the usual switching between enabling and disabling of the clock output. | SMR: GM, $C/\overline{A}$ | Bit 1: CKE1 | Bit 0: CKE0 | SCK Pin Function | |---------------------------|-------------|-------------|---------------------------------| | 0 | 0 | 0 | Input pin (input ignored) | | | | 1 | Clock output as SCK output pin | | | 1 | 0 | Invalid setting; do not set | | | | 1 | Invalid setting; do not set | | 1 | 0 | 0 | Fixed low output as output pin | | | | 1 | Clock output as output pin | | | 1 | 0 | Fixed high output as output pin | | | | 1 | Clock output as output pin | ## 14.2.4 Serial Status Register (SSR) In the smart card interface mode, the function of SSR bit 4 is changed. The setting conditions for bit 2, the TEND bit, are also changed. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|---------|--------|------|-----|------| | Bit name: | TDRE | RDRF | ORER | FER/ERS | PER | TEND | MPB | MPBT | | Initial value: | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | R/W: | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R | R | R/W | Note: Only 0 can be written, to clear the flag. Bits 7 to 5: These bits have the same function as in the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. Bit 4—Error Signal Status (ERS): In the smart card interface mode, bit 4 indicates the status of the error signal returned from the receiving side during transmission. The smart card interface cannot detect framing errors. | Bit 4: ERS | Description | | | | | | |---------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | 0 | Receiving ended normally with no error signal (Initial value) | | | | | | | | ERS is cleared to 0 when the chip is reset or enters standby mode, or when software reads ERS after it has been set to 1, then writes 0 in ERS | | | | | | | 1 An error signal indicating a parity error was transmitted from the rece | | | | | | | | | ERS is set to 1 if the error signal sampled is low | | | | | | Note: The ERS flag maintains its status even when the TE bit in SCSCR1 is cleared to 0. Bit 3—Parity Error (PER): This bit has the same function as in the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. Bit 2—Transmit End (TEND): The setting conditions for bit 2, Transmit End (TEND), are shown below. | Bit 2: TEND | Description | | | | | | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | 0 | Transmission is in progress | | | | | | | | | TEND is cleared to 0 when software reads TDRE after it has been set to then writes 0 in TDRE | | | | | | | | 1 | Transmission has ended (Initial value) | | | | | | | | | TEND is set to 1 when: | | | | | | | | | the chip is reset or enters standby mode. | | | | | | | | | <ul> <li>the TE bit in SCR is 0 and the FER/ERS bit is also 0.</li> </ul> | | | | | | | | | • the GM bit in SMR is 0, and TDRE = 1 and FER/ERS = 0 (normal transmission) 2.5 etu after a one-byte serial character is transmitted, or | | | | | | | | | <ul> <li>the GM bit in SMR is 1, and TDRE = 1 and FER/ERS = 0 (normal<br/>transmission) 1.0 etu after a one-byte serial character is transmitted.</li> </ul> | | | | | | | etu: Elementary time unit (time for transfer of 1 bit) The TEND generation timing is shown in figure 14.2. Figure 14.2 TEND Generation Timing Bits 1 and 0: These bits have the same function as in the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. ## 14.3 Operation #### 14.3.1 Overview The smart card interface supports a protocol system T=0: asynchronous duplex character transmission protocol conforming to the ISO/IEC 7816-3 standard. The transmission protocol configuration is shown in figure 14.3. Its primary functions are described below. - 1. Each frame consists of 8 data bits and 1 parity bit. - 2. During transmission, the card leaves a guard time of at least 2 etu (elementary time units: the period for 1 bit to transfer) from the end of the parity bit to the start of the next frame. - 3. During reception, the card outputs an error signal low level for 1 etu after 10.5 etu has elapsed from the start bit if a parity error was detected. - 4. During transmission, it automatically transmits the same data after allowing at least 2 etu from the time the error signal is sampled. - 5. Only start-stop type asynchronous communication functions are supported; no synchronous communication functions are available. Figure 14.3 Transmission Protocol Configuration #### 14.3.2 Pin Connections Figure 14.4 shows the pin connection diagram for the smart card interface. During communication with an IC card, transmission and reception are both carried out over the same data transfer line, so connect the TxD and RxD pins on the chip. Pull up the data transfer line to the power supply $V_{CC}$ side with a resistor. When using the clock generated by the smart card interface on an IC card, input the SCK pin output to the IC card's CLK pin. This connection is not necessary when the internal clock is used on the IC card. Use the chip's port output as the reset signal. Apart from these pins, the power and ground pin connections are usually also required. Note: When the IC card is not connected and both RE and TE are set to 1, closed communication is possible and auto-diagnosis can be performed. Figure 14.4 Pin Connection Diagram for the Smart Card Interface ## 14.3.3 Data Format Figure 14.5 shows the data format for the smart card interface. In this mode, parity is checked every frame while receiving and error signals sent to the transmitting side whenever an error is detected so that data can be re-transmitted. During transmission, error signals are sampled and data re-transmitted whenever an error signal is detected. Figure 14.5 Data Format for Smart Card Interface The operating sequence is: - 1. The data line is high impedance when not in use and is fixed high with a pull-up resistor. - 2. The transmitting side starts one frame of data transmission. The data frame starts with a start bit (Ds, low level). The start bit is followed by eight data bits (D0–D7) and a parity bit (Dp). - 3. On the smart card interface, the data line returns to high impedance after this. The data line is pulled high with a pull-up resistor. - 4. The receiving side checks parity. When the data is received normally with no parity errors, the receiving side then waits to receive the next data. When a parity error occurs, the receiving side outputs an error signal (DE, low level) and requests re-transfer of data. The receiving station returns the signal line to high impedance after outputting the error signal for a specified period. The signal line is pulled high with a pull-up resistor. - 5. The transmitting side transmits the next frame of data unless it receives an error signal. If it does receive an error signal, it returns to step 2 to re-transmit the erroneous data. ## 14.3.4 Register Settings Table 14.3 shows the bit map of the registers that the smart card interface uses. Bits shown as 1 or 0 must be set to the indicated value. The settings for the other bits are described below. Table 14.3 Register Settings for the Smart Card Interface | Register | Address | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |----------|------------|-------|-------|-------|-------------|-------|-------|-------|-------| | SMR | H'FFFFFE80 | GM | 0 | 1 | O/E | 1 | 0 | CKS1 | CKS0 | | BRR | H'FFFFFE82 | BRR7 | BRR6 | BRR5 | BRR4 | BRR3 | BRR2 | BRR1 | BRR0 | | SCR | H'FFFFFE84 | TIE | RIE | TE | RE | 0 | 0 | CKE1 | CKE0 | | TDR | H'FFFFFE86 | TDR7 | TDR6 | TDR5 | TDR4 | TDR3 | TDR2 | TDR1 | TDR0 | | SSR | H'FFFFFE88 | TDRE | RDRF | ORER | FER/<br>ERS | PER | TEND | 0 | 0 | | RDR | H'FFFFFE8A | RDR7 | RDR6 | RDR5 | RDR4 | RDR3 | RDR2 | RDR1 | RDR0 | | SCMR | H'FFFFFE8C | _ | _ | _ | _ | SDIR | SINV | _ | SMIF | Note: Dashes indicate unused bits. - 1. Setting the serial mode register (SCSMR): The GM bit selects the TEND flag setting timing, and, in combination with the CKE1 and CKE0 bits in the serial control register (SCR), the clock output state. Set the O/E bit to 0 when the IC card uses the direct convention or to 1 when it uses the inverse convention. Select the on-chip baud rate generator clock source with the CKS1 and CKS0 bits (see section 14.3.5, Clock). - 2. Setting the bit rate register (BRR): Set the bit rate. See section 14.3.5, Clock, to see how to calculate the set value. - 3. Setting the serial control register (SCR): The TIE, RIE, TE and RE bits function as they do for the ordinary SCI. See section 13, Serial Communication Interface (SCI), for more information. The CKE0 and CKE1 bits select the clock output state. See section 14.3.5, Clock, for more information. - 4. Setting the smart card mode register (SCMR): The SDIR and SINV bits are both set to 0 for IC cards that use the direct convention and both to 1 when the inverse convention is used. The SMIF bit is set to 1 for the smart card interface. Figure 14.6 shows sample waveforms for register settings of the two types of IC cards (direct convention and inverse convention) and their start characters. In the direct convention type, the logical 1 level is state Z, the logical 0 level is state A, and communication is LSB first. The start character data is H'3B. The parity bit is even (from the smart card standards), and thus a 1. In the inverse convention type, the logical 1 level is state A, the logical 0 level is state Z, and communication is MSB first. The start character data is H'3F. The parity bit is even (from the smart card standards), and thus a 0, which corresponds to state Z. Only data bits D7–D0 are inverted by the SINV bit. To invert the parity bit, set the O/E bit in SCSMR to odd parity mode. This applies to both transmission and reception. Figure 14.6 Waveform of Start Character #### 14.3.5 Clock Only the internal clock generated by the on-chip baud rate generator can be used as the communication clock in the smart card interface. The bit rate for the clock is set by the bit rate register (BRR) and the CKS1 and CKS0 bits in the serial mode register (SMR), and is calculated using the equation below. Table 14.5 shows sample bit rates. If clock output is then selected by setting CKE0 to 1, a clock with a frequency 372 times the bit rate is output from the SCK pin. $$B=\frac{P\varphi}{1488\times 2^{2n-1}\times (N+1)}\times 10^6$$ Where: N = Value set in BRR (0 = N = 255) B = Bit rate (bit/s) $P\phi$ = Peripheral module clock (MHz) n = 0-3 (table 14.4) Table 14.4 Relationship of n to CKS1 and CKS0 | n | CKS1 | CKS0 | |---|------|------| | 0 | 0 | 0 | | 1 | 0 | 1 | | 2 | 1 | 0 | | 3 | 1 | 1 | Table 14.5 Examples of Bit Rate B (Bit/s) for BRR Settings (n = 0) ## Pφ (MHz) | N | 7.1424 | 10.00 | 10.7136 | 13.00 | 14.2848 | 16.00 | 18.00 | |---|--------|---------|---------|---------|---------|---------|---------| | 0 | 9600.0 | 13440.9 | 14400.0 | 17473.1 | 19200.0 | 21505.4 | 24193.5 | | 1 | 4800.0 | 6720.4 | 7200.0 | 8736.6 | 9600.0 | 10752.7 | 12096.8 | | 2 | 3200.0 | 4480.3 | 4800.0 | 5824.4 | 6400.0 | 7168.5 | 8064.5 | Note: The bit rate is rounded to two decimal places. Calculate the value to be set in the bit rate register (BRR) from the peripheral module clock and the bit rate. N is an integer in the range 0 = N = 255, specifying a smallish error. $$N = \frac{P\varphi}{1488 \times 2^{2n-1} \times B} \times 10^6 - 1$$ Table 14.6 Examples of BRR Settings for Bit Rate B (Bit/s) (n = 0) Pø (MHz) | | 7 | 7.1424 | | 10.00 | 1 | 0.7136 | | 13.00 | 1 | 4.2848 | | 16.00 | | 18.00 | |--------|---|--------|---|-------|---|--------|---|-------|---|--------|---|-------|---|-------| | Bits/s | N | Error | 9600 | 0 | 0.00 | 1 | 30.00 | 1 | 25.00 | 1 | 8.99 | 1 | 0.00 | 1 | 12.01 | 2 | 15.99 | **Table 14.7** Maximum Bit Rates for Frequencies (Smart Card Interface Mode) | Pφ (MHz) | Maximum Bit Rate (Bit/s) | N | n | |----------|--------------------------|---|---| | 7.1424 | 9600 | 0 | 0 | | 10.00 | 13441 | 0 | 0 | | 10.7136 | 14400 | 0 | 0 | | 13.00 | 17473 | 0 | 0 | | 14.2848 | 19200 | 0 | 0 | | 16.00 | 21505 | 0 | 0 | | 18.00 | 24194 | 0 | 0 | The bit rate error is found as follows: Error(%) = $$(\frac{P\phi}{1488 \times 2^{2n-1} \times B \times (N-1)}) \times 10^6 - 1 \times 100$$ Table 14.8 shows the relationship between transmit/receive clock register set values and output states on the smart card interface. Figure 14.7 shows the difference in clock output according to the setting of the GM bit. Table 14.8 Register Set Values and SCK Pin | | | Regi | ster Value | • | SCK Pin | | | | |-----------------|------|------|------------|------|-------------|---------------------------------|--|--| | Setting | SMIF | GM | CKE1 | CKE0 | Output | State | | | | 1*1 | 1 | 0 | 0 | 0 | Port | Input pin (input ignored) | | | | | 1 | 0 | 0 | 1 | M | SCK (serial clock) output state | | | | 2*2 | 1 | 1 | 0 | 0 | Low output | Low output state | | | | | 1 | 1 | 0 | 1 | M | SCK (serial clock) output state | | | | 3* <sup>2</sup> | 1 | 1 | 1 | 0 | High output | High output state | | | | | 1 | 1 | 1 | 1 | M | SCK (serial clock) output state | | | Notes: 1. The SCK output state changes as soon as the CKE0 bit is modified. The CKE1 bit should be cleared to 0. The clock duty remains constant despite stopping and starting of the clock by modification of the CKE0 bit. Figure 14.7 Difference in Clock Output According to GM Bit Setting #### 14.3.6 Data Transmission and Reception **Initialization:** Initialize the SCI using the following procedure before sending or receiving data. Initialization is also required for switching from transmit mode to receive mode or from receive mode to transmit mode. Figure 14.8 shows a flowchart of the initialization process. - 1. Clear TE and RE in the serial control register (SCR) to 0. - 2. Clear error flags FER/ERS, PER, and ORER to 0 in the serial status register (SSR). - 3. Set the C/A bit, parity bit (O/E bit), and baud rate generator select bits (CKS1 and CKS0 bits) in the serial mode register (SMR). At this time also clear the CHR and MP bits to 0 and set the STOP and PE bits to 1. - 4. Set the SMIF, SDIR, and SINV bits in the smart card mode register (SCMR). When the SMIF bit is set to 1, the TxD and RxD pins both switch from ports to SCI pins and become high impedance. - 5. Set the value corresponding to the bit rate in the bit rate register (BRR). - 6. Set the clock source select bits (CKE1 and CKE0 bits) in the serial control register (SCR). Clear the TIE, RIE, TE, RE, MPIE, and TEIE bits to 0. When the CKE0 bit is set to 1, a clock is output from the SCK pin. - 7. After waiting at least 1 bit, set the TIE, RIE, TE, and RE bits in SCR. Do not set the TE and RE bits simultaneously unless performing auto-diagnosis. Figure 14.8 Initialization Flowchart (Example) **Serial Data Transmission:** The handling procedures in the smart card mode differ from ordinary SCI processing because data is retransmitted when an error signal is sampled during a data transmission. This results in the transmission processing flowchart shown in figure 14.9. - 1. Initialize the smart card interface mode as described in initialization above. - 2. Check that the FER/ERS bit in SSR is cleared to 0. - 3. Repeat steps 2 and 3 until the TEND flag in SSR is set to 1. - 4. Write the transmit data into TDR, clear the TDRE flag to 0 and start transmitting. The TEND flag will be cleared to 0. - 5. To transmit more data, return to step 2. - 6. To end transmission, clear the TE bit to 0. This processing can be interrupted. When the TIE bit is set to 1 and interrupt requests are enabled, a transmit-data-empty interrupt (TXI) will be requested when the TEND flag is set to 1 at the end of the transmission. When the RIE bit is set to 1 and interrupt requests are enabled, a communication error interrupt (ERI) will be requested when the ERS flag is set to 1 when an error occurs in transmission. See Interrupt Operation below for more information. Figure 14.9 Transmission Flowchart **Serial Data Reception:** The handling procedures in the smart card mode are the same as in ordinary SCI processing. The reception processing flowchart is shown in figure 14.10. - 1. Initialize the smart card interface mode as described above in Initialization and in figure 14.5. - 2. Check that the ORER and PER flags in SSR are cleared to 0. If either flag is set, clear both to 0 after performing the appropriate error handling procedures. - 3. Repeat steps 2 and 3 until the RDRF flag is set to 1. - 4. Read the receive data from RDR. - 5. To receive more data, clear the RDRF flag to 0 and return to step 2. - 6. To end reception, clear the RE bit to 0. This processing can be interrupted. When the RIE bit is set to 1 and interrupt requests are enabled, a receive-data-full interrupt (RXI) will be requested when the RDRF flag is set to 1 at the end of the reception. When an error occurs during reception and either the ORER or PER flag is set to 1, a communication error interrupt (ERI) will be requested. See Interrupt Operation below for more information. The received data will be transferred to RDR even when a parity error occurs during reception and PER is set to 1, so this data can still be read. Figure 14.10 Reception Flowchart (Example) **Switching Modes:** When switching from receive mode to transmit mode, check that the receive operation is completed before starting initialization and setting RE to 0 and TE to 1. The RDRF, PER, and ORER flags can be used to check if reception is completed. When switching from transmit mode to receive mode, check that the transmit operation is completed before starting initialization and setting TE to 0 and RE to 1. The TEND flag can be used to check if transmission is completed. **Interrupt Operation:** In the smart card interface mode, there are three types of interrupts: transmit-data-empty (TXI), communication error (ERI) and receive-data-full (RXI). In this mode, the transmit-end interrupt (TEI) cannot be requested. Set the TEND flag in SSR to 1 to request a TXI interrupt. Set the RDRF flag in SSR to 1 to request an RXI interrupt. Set the ORER, PER, or FER/ERS flag in SSR to 1 to request an ERI interrupt (table 14.9). Table 14.9 Smart Card Mode Operating Status and Interrupt Sources | Mode | Status | Flag | Mask Bit | Interrupt Source | |---------------|--------|--------------|----------|------------------| | Transmit mode | Normal | TEND | TIE | TXI | | | Error | FER/ERS | RIE | ERI | | Receive mode | Normal | RDRF | RIE | RXI | | | Error | PER,<br>ORER | RIE | ERI | ## 14.4 Usage Notes When the SCI is used as a smart card interface, be sure that all criteria in sections 14.4.1 and 14.4.2 are applied. #### 14.4.1 Receive Data Timing and Receive Margin in Asynchronous Mode In asynchronous mode, the SCI runs on a basic clock with a frequency of 372 times the transfer rate. During reception, the SCI samples the fall of the start bit using the base clock to achieve internal synchronization. Receive data is latched internally on the rising edge of the 186th basic clock cycle (figure 14.11). Figure 14.11 Receive Data Sampling Timing in Smart Card Mode The receive margin is found from the following equation: For smart card mode: $$M = \left| (0.5 - \frac{1}{2N}) - (L - 0.5)F - \frac{|D - 0.5|}{N} (1 + F) \right| \times 100\%$$ Where: M = Receive margin (%) N = Ratio of bit rate to clock (N = 372) D = Clock duty (D = 0 to 1.0) L = Frame length (L = 10) F = Absolute value of clock frequency deviation Using this equation, the receive margin when F = 0 and D = 0.5 is as follows: $$M = (0.5-1/2\times372)\times100\% = 49.866\%$$ #### 14.4.2 Retransmission (Receive and Transmit Modes) **Retransmission by the SCI in Receive Mode:** Figure 14.12 shows the retransmission operation in the SCI receive mode. - 1. When the received parity bit is checked and an error is found, the PER bit in SSR is automatically set to 1. If the RIE bit in SCR is enabled at this time, an ERI interrupt is requested. Be sure to clear the PER bit in SSR before the next parity bit is sampled. - 2. The RDRF bit in SSR is not set in the frame that caused the error. - 3. When the received parity bit is checked and no error is found, the PER bit in SSR is not set. - 4. When the received parity bit is checked and no error is found, reception is considered to have been completed normally and the RDRF bit in SSR is automatically set to 1. If the RIE bit in SCR is enabled at this time, an RXI interrupt is requested. - 5. When a normal frame is received, the pin maintains a three-state status when it transmits the error signal. Figure 14.12 Retransmission in SCI Receive Mode **Retransmission by the SCI in Transmit Mode:** Figure 14.13 shows the retransmission operation in the SCI transmit mode. - 1. After transmission of one frame is completed, the FER/ERS bit in SSR is set to 1 when a error signal is returned from the receiving side. If the RIE bit in SCR is enabled at this time, an ERI interrupt is requested. Be sure to clear the FER/ERS bit in SSR before the next parity bit is sampled. - 2. The TEND bit in SSR is not set in the frame that received the error signal that indicated the - 3. The FER/ERS bit in SSR is not set when no error signal is returned from the receiving side. - 4. When no error signal is returned from the receiving side, the TEND bit in SSR is set to 1 when the transmission of the frame that includes the retransmission is considered completed. If the TIE bit in SCR is enabled at this time, a TXI interrupt will be requested. Figure 14.13 Retransmission in SCI Transmit Mode # Section 15 Serial Communication Interface with FIFO (SCIF) #### 15.1 Overview The LSI has a two-channel serial communication interface with FIFO (SCIF) that supports asynchronous serial communication. It also has 16-stage FIFO registers for both transfer and receive that enables efficient, high-speed, continuous communication. #### 15.1.1 Features - Asynchronous serial communication: - Serial data communication is performed by the start-stop method in character units. The SCI 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: Seven or eight bits - Stop bit length: One or two bits - Parity: Even, odd, or none - Receive error detection: Parity and framing errors - Break detection: Break is detected when the receive data following the generated framing error is the space 0 level, indicating a framing error. It is also detected by reading the RxD level directly from the port data register (PBDR) when a framing error occurs - Full duplex communication: The transmitting and receiving sections are independent, so the SCI 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. - Built-in 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, break, receive-FIFO-data-full, and receive-error interrupts are requested independently. The direct memory access controller (DMAC) can be activated to execute a data transfer by a transmit-FIFO-data-empty or receive-FIFO-data-full interrupt. - When the SCIF is not in use, it can be stopped by halting the clock supplied to it, saving power. - On-chip modem control functions ( $\overline{RTS}$ and $\overline{CTS}$ ) - The quantity of data in the transmit and receive FIFO registers and the number of errors of the receive data in the receive FIFO register can be ascertained. • A time-out error (DR) can be detected in receiving. ### 15.1.2 Block Diagram Figure 15.1 shows a block diagram of the SCIF. Figure 15.1 SCIF Block Diagram # 15.1.3 Pin Configuration The SCIF has the serial pins summarized in table 15.1. Table 15.1 SCIF Pins | Channel | Pin Name | Abbreviation | I/O | Function | |---------|----------------------|--------------|--------------|----------------------| | 1 | Serial clock pin | SCK1 | Input/output | Clock input/output | | | Receive data pin | RxD1 | Input | Receive data input | | | Transmit data pin | TxD1 | Output | Transmit data output | | | Transmit request pin | RTS | Output | Transmit request | | | Transmit enable pin | CTS | Input | Transmit enable | | 2 | Serial clock pin | SCK2 | Input/output | Clock input/output | | | Receive data pin | RxD2 | Input | Receive data input | | | Transmit data pin | TxD2 | Output | Transmit data output | ## 15.1.4 Register Configuration Table 15.2 summarizes the SCIF internal registers. These registers select the communication mode (asynchronous or synchronous), specify the data format and bit rate, and control the transmitter and receiver sections. Table 15.2 Registers | Channel | Register Name | Abbre-<br>viation | R/W | Initial<br>Value | Address | Access<br>Size | |---------|-------------------------------|-------------------|--------|------------------|------------|----------------| | 1 | Serial mode register 1 | SCSMR1 | R/W | H'00 | H'FFFFFCC0 | 8 bits | | | Bit rate register 1 | SCBRR1 | R/W | H'FF | H'FFFFCC2 | 8 bits | | | Serial control register 1 | SCSCR1 | R/W | H'00 | H'FFFFFCC4 | 8 bits | | | Transmit FIFO data register 1 | SCSFDR1 | W | _ | H'FFFFFCC6 | 8 bits | | | Serial status register 1 | SCSSR1 | R/(W)* | H'0060 | H'FFFFFCC8 | 16 bits | | | Receive FIFO data register 1 | SCFRDR1 | R | Undefined | H'FFFFFCCA | 8 bits | | | FIFO control register 1 | SCFCR1 | R/W | H'00 | H'FFFFFCCC | 8 bits | | | FIFO data count register 1 | SCFDR1 | R | H'0000 | H'FFFFFCCE | 16 bits | | 2 | Serial mode register 2 | SCSMR2 | R/W | H'00 | H'FFFFFCD0 | 8 bits | | | Bit rate register 2 | SCBRR2 | R/W | H'FF | H'FFFFFCD2 | 8 bits | | | Serial control register 2 | SCSCR2 | R/W | H'00 | H'FFFFFCD4 | 8 bits | | | Transmit FIFO data register 2 | SCSFDR2 | W | _ | H'FFFFFCD6 | 8 bits | | | Serial status register 2 | SCSSR2 | R/(W)* | H'0060 | H'FFFFFCD8 | 16 bits | | | Receive FIFO data register 2 | SCFRDR2 | R | Undefined | H'FFFFFCDA | 8 bits | | | FIFO control register 2 | SCFCR2 | R/W | H'00 | H'FFFFFCDC | 8 bits | | | FIFO data count register 2 | SCFDR2 | R | H'0000 | H'FFFFFCDE | 16 bits | Note: Only 0 can be written, to clear the flags. ## 15.2 Register Descriptions #### 15.2.1 Receive Shift Register (SCRSR) The receive shift register (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 SCFRDR, which is a receive FIFO data register. The CPU cannot read or write to SCRSR directly. #### 15.2.2 Receive FIFO Data Register (SCFRDR) The 16-stage receive FIFO data register (SCFRDR) 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. The continuous receive operation is possible until the storage of 16-bit data is ended. CPU can read out from SCFRDR, but cannot write. When reading the data without receive data in FIFO data register, the value becomes undefined. When this data is filled in full with receive data, thereafter, the received serial data are lost. #### 15.2.3 Transmit Shift Register (SCTSR) The transmit shift register (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 SCI automatically loads the next transmit data from SCFTDR into SCTSR and starts transmitting again. The CPU cannot read or write to SCTSR directly. #### 15.2.4 Transmit FIFO Data Register (SCFTDR) The transmit FIFO data register (SCFTDR) is a FIFO register comprising sixteen 8-bit stages that stores data for serial transmission. When the SCIF detects that the transmit shift register (SCTSR) is empty, it moves transmit data written in SCFTDR into SCTSR and starts serial transmission. Continuous serial transmission is performed until the SCFTDR is empty. The CPU can always write to SCFTDR. When SCFTDR is in full with send data(16 bytes), the next data can not be written. In this case, the written data is ignored. #### 15.2.5 Serial Mode Register (SCSMR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|-----|-----|-----|------|---|------|------| | | _ | CHR | PE | O/E | STOP | _ | CKS1 | CKS0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W | R/W | R/W | R/W | R | R/W | R/W | The serial mode register (SCSMR) is an eight-bit register that 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'00 by a reset and in standby and module standby modes. Bit 7—Reserved bit: This bit always reads 0. The write value should always be 0. Bit 6—Character Length (CHR): Selects 7-bit or 8-bit data in asynchronous mode. | Bit 6: CHR | Description | | |------------|---------------------------------------------------------------------------------------------------------|-----------------| | 0 | 8-bit data | (Initial value) | | 1 | 7-bit data. (When seven-bit data is selected, the MSB (bit 7) of FIFO data register is not transmitted) | f the transmit | Bit 5—Parity Enable (PE): Selects whether to add a parity bit to transmit data and to check the parity of receive data. | Bit 5: PE | Description | | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------| | 0 | Parity bit not added and not checked | (Initial value) | | 1 | Parity bit added and checked | | | | When PE is set to 1, an even or odd parity bit is added to transdepending on the parity mode ( $O/\overline{E}$ ) setting. Receive data parity according to the even/odd ( $O/\overline{E}$ ) mode setting | , | Bit 4—Parity Mode $(O/\overline{E})$ : Selects even or odd parity when parity bits are added and checked. The O/E setting is used only when the parity enable bit (PE) is set to 1 to enable parity addition and check. The $O/\overline{E}$ setting is ignored when parity addition and check is disabled. | Bit 4: O/E | Description | | |------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------| | 0 | Even parity (Initia | al value) | | | When sending, the parity bit is transmitted to add so that the total nu 1 becomes even out of combining the parity bit and the send charact receiving, the total of 1 is checked whether it is even number out of c the parity bit and the receive character. | er. In | | 1 | Odd parity | | | | When sending, the parity bit is transmitted to add so that the total nu 1 becomes odd out of combining the parity bit and the send characte receiving, the total of 1 is checked whether it is odd number out of co the parity bit and the receive character. | er. In | Bit 3—Stop Bit Length (STOP): Selects one or two bits as the stop bit length. Selects one or two bits as the stop bit length. In receiving, only the first stop bit is checked regardless of the STOP bit setting. If the length of the stop bit is set at 2 bits, and 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 send character. | Bit 3: STOP | Description | | | |-------------|-----------------------------------------------------------------------------|------------------|--| | 0 | One stop bit | (Initial value) | | | | In transmitting, a single 1-bit is added at the end of each tran character. | smitted | | | 1 | Two stop bits | | | | | In transmitting, two 1-bits is added at the end of each transm | itted character. | | Bit 2—Reserved bit: This bit always reads 0. The write value should always be 0. Bits 1 and 0—Clock Select 1 and 0 (CKS1 and CKS0): These bits select the internal clock source of the built-in baud rate generator. Four clock sources are available: $P\phi$ , $P\phi/4$ , $P\phi/16$ , and $P\phi/64$ . For further information on the clock source, bit rate register settings, and baud rate, see section 15.2.8, Bit Rate Register. | Bit 1: CKS1 | Bit 0: CKS0 | Description | | |-------------|-------------|-------------|-----------------| | 0 | 0 | P | (Initial value) | | | 1 | P | | | 1 | 0 | Pø/16 clock | | | | 1 | Pφ/64 clock | | Note: Po: Peripheral module clock #### 15.2.6 Serial Control Register (SCSCR) The serial control register (SCSCR) operates the SCIF transmitter/receiver, selects the serial clock output in asynchronous mode, 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'00 by a reset and in standby and module standby modes. | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----|-----|-----|-----|-----|-----|------|------| | | TIE | RIE | TE | RE | 0 | 0 | CKE1 | CKE0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bit 7—Transmit Interrupt Enable (TIE): 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 falls to or below the transmit trigger setting, and when the TDFE flag in the serial FIFO status register (SCFSR) is set to 1. | Bit 7: TIE | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Transmit-FIFO-data-empty interrupt request (TXI) is disabled (Initial value) | | | The TXI interrupt request can be cleared by writing a 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 | | 1 | Transmit-FIFO-data-empty interrupt request (TXI) is enabled | Bit 6—Receive Interrupt Enable (RIE): Enables or disables the receive-data-full (RXI) and receive-error (ERI) interrupts requested when serial receive data is transferred from the receive shift register (SCRSR) to the receive FIFO data register (SCFRDR), when the quantity of data in the receive FIFO register reaches or exceeds the receive trigger setting, and when the RDRF flag in SCSSR is set to 1. | Bit 6: RIE | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receive-data-full interrupt (RXI), receive-error interrupt (ERI), and receive break interrupt (BRI) requests are disabled (Initial value) | | | RXI and ERI interrupt requests can be cleared by reading the DR, ER, or RDF flag after it has been set to 1, then clearing the flag to 0, or by clearing RIE to 0. When RDF is set, read 1 from the RDF flag and clear it to 0, after reading the received data from SCFRDR until the quantity of received data is less than the specified receive trigger number | | 1 | Receive-data-full interrupt (RXI) and receive-error interrupt (ERI) requests are enabled | Bit 5—Transmit Enable (TE): Enables or disables the SCI serial transmitter. | Bit 5: TE | Description | | |-----------|-------------------------------------------------------------------------------------------------------------------------------|-----------------| | 0 | Transmitter disabled | (Initial value) | | 1 | Transmitter enabled | | | | Serial transmission starts after writing transmit data into SCFTD transmit format in SCSMR and SCFCR and reset TFRST before 1 | | Bit 4—Receive Enable (RE): Enables or disables the SCI serial receiver. | Bit 4: RE | Description | | |-----------|-----------------------------------------------------------------------------------------------------------------------------|---| | 0 | Receiver disabled (Initial value) | ) | | | Clearing RE to 0 does not affect the receive bits (DR, ER, BRK, FER, PER, and RDF). These bits retain their previous values | | | 1 | Receiver enabled | _ | | | Serial reception starts when a start bit is detected. Select the receive format in SCSMR before setting RE to 1 | | Bits 3 and 2—Reserved bits: These bits always read 0. The write value should always be 0. Bits 1 and 0—Clock Enable 1 and 0 (CKE1 and CKE0): These bits select the SCIF clock source and enable or disable clock output from the SCK pin. Depending on the combination of CKE1 and CKE0, the SCK pin can be used for serial clock output or serial clock input. The CKE0 setting is valid only when the SCIF is operating with the internal clock (CKE1 = 0). The CKE0 setting is ignored when an external clock source is selected (CKE1 = 1). Set CKE1 and CKE0 before selecting the SCIF operating mode in the serial mode register (SCSMR). For further details on selection of the SCIF clock source, see table 15.8 in section 15.3, Operation. | Bit 1:<br>CKE1 | Bit 0:<br>CKE0 | Description | |----------------|----------------|-------------------------------------------------------------------------------------| | 0 | 0 | Internal clock, SCK pin used for input pin (input signal is ignored)(Initial value) | | | 1 | Internal clock, SCK pin used for clock output*1 | | 1 | 0 | External clock, SCK pin used for clock input*2 | | | 1 | External clock, SCK pin used for clock input*2 | Notes: 1. The output clock frequency is 16 times the bit rate. 2. The input clock frequency is 16 times the bit rate. #### 15.2.7 Serial Status Register (SCSSR) The serial status register (SCSSR) is a 16-bit register. The upper 8 bits indicate the number of receive errors in the receive FIFO register data, and the lower 8 bits indicate the SCIF operating status. The CPU can always read and write to SCSSR, but cannot write 1 in 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. SCSSR is initialized to H'0060 by a reset and in standby and module standby modes. | Lower 8 bits: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------|--------|--------|--------|-----|-----|--------|--------| | | ER | TEND | TDFE | BRK | FER | PER | RDF | DR | | Initial value: | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/(W)* | R/(W)* | R/(W)* | R/(W)* | R | R | R/(W)* | R/(W)* | Note: Only 0 can be written, to clear the flag. Bit 7—Receive Error (ER): Indicates that a framing error or parity error has occurred in the received data. \*1 | Bit 7: ER | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receiving is in progress or has ended normally *1 | | | [Clearing condition] | | | ER is cleared to 0 when the chip is reset or enters standby mode, or when 0 is written after 1 is read from ER | | 1 | A framing error or a parity error has occurred | | | [Setting condition] | | | If the last stop bit of 1 data byte receive is 0, refer to note 2, or when the total number of 1s in the receive data and in the parity bit does not match the even/odd parity specification by the $O/\overline{E}$ bit in SCSMR | | Notes: 1. | Clearing the RE bit to 0 in SCSCR does not affect the FR bit, which retains its previous value. Even if a receive error occurs, the receive data is transferred to | Notes: 1. Clearing the RE bit to 0 in SCSCR does not affect the FR 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 SCSSR. 2. In stop bit mode, only the first stop bit is checked, and the second stop bit isnot checked. Bit 6—Transmit End (TEND): Indicates that when the last bit of a serial character was transmitted, the SCFTDR did not contain valid data, so transmission has ended. | Bit 6: TEND | Description | |-------------|-------------------------------------------------------------------------------------------------------------------------------| | 0 | Transmission is in progress | | | [Clearing condition] | | | TEND is cleared to 0 when data is written in SCFTDR | | 1 | End of transmission (Initial value) | | | [Setting condition] | | | 1. When the chip is reset or enters standby mode | | | 2. When the TE bit is cleared to 0 in serial control register (SCSCR). | | | <ol> <li>SCFTDR does not contain transfer data when the last bit of a one-byte serial<br/>character is transmitted</li> </ol> | Bit 5—Transmit FIFO Data Register Empty (TDFE): 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 is equal to or less than the transmission trigger number specified by the TTRG1 and TTRG0 bits in the FIFO control register (SCFCR), and writing of transmit data to SCFTDR is enabled. | Bit 5: TDFE | Description | | | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | This indicates that the transmit data written to SCFTDR are much more thantransmit trigger setting number (Initial value) | | | | | [Clearing condition] | | | | | TDFE is cleared to 0 when data exceeding the specified transmission trigger number is written to SCFTDR, software reads TDFE after it has been set to 1, then writes 0 in TDFE | | | | 1 | The quantity of transmit data in SCFTDR is equal to or less than the specified transmission trigger number | | | | | [Setting condition] | | | | | TDFE is set to 1 by a reset or in standby mode, or when the quantity of transmidata in SCFTDR is equal to or less than the specified transmission trigger number as a result of transmission* | | | Note: Since SCFTDR is a 16-byte FIFO register, the maximum quantity of data which can be written when TDFE is 1 is "16 minus the specified transmission trigger number". If writing of additional data is attempted, the data is ignored. The quantity of data in SCFTDR is indicated by the upper 8 bits of SCFDR. Bit 4—Break Detection (BRK): Indicates that a break has been detected in the receive data. | Bit 4: BRK | Description | | | |------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----------------|--| | 0 | No break is being received | (Initial value) | | | | [Clearing condition] | | | | | BRK is cleared to 0 when the chip is reset or enters standby mode, or software reads BRK after it has been set to 1, then writes 0 in BRK | | | | 1 | The break is received* | | | | | [Setting condition] | | | | | BRK is set to 1 when data associated with a framing error framing error occurs with the next receive data comprising | | | | | | | | Note: When a break is detected, transfer of the received data (H'00) to SCFRDR. When the break ends and the receive signal goes to mark (1), the transfer of the received data resumes. The received data of a frame in which a break is detected is transferred to SCFRDR. After this, however, no received data is transferred until a break ends with the received signal at mark (1), and the next data is received. Bit 3—Framing Error (FER): Indicates a framing error in the data read from the receive FIFO data register (SCFRDR). | Bit 3: FER | Description | |------------|-------------------------------------------------------------------------------------------------------------------------------------| | 0 | No receive framing error occurred in the data read from SCFRDR (Initial value) | | | [Clearing condition] | | | FER is cleared to 0 when the chip is reset or enters standby mode, or when no framing error is present in the data read from SCFRDR | | 1 | A receive framing error occurred in the data read from SCFRDR | | | [Setting condition] | | | FER is set to 1 when a framing error is present in the data read from SCFRDR | Bit 2—Parity Error (PER): Indicates a parity error in the data read from the receive FIFO data register (SCFRDR). | Bit 2: PER | Description | | | |------------|------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | No receive parity error occurred in the data read from SCFRDR (Initial value) | | | | | [Clearing condition] | | | | | PER is cleared to 0 when the chip is reset or enters standby mode, or when no parity error is present in the data read from SCFRDR | | | | 1 | A receive framing error occurred in the data read from SCFRDR | | | | | [Setting condition] | | | | | PER is set to 1 when a parity error is present in the data read from SCFRDR | | | Bit 1—Receive FIFO Data Register Full (RDF): Indicates that received data has been transferred to the receive FIFO data register (SCFRDR), and the quantity of data in SCFRDR reaches or exceeds the receive trigger number set by the RTRG1 and RTRG0 bits in FIFO control register (SCFCR). | Bit 1: RDF | Description | | | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | The quantity of transmit data written to SCFRDR is less than the specified number of receive trigger number (Initial value) | | | | | [Clearing condition] | | | | | RDF is cleared to 0 by a reset or in standby mode, or cleared when SCFRDR is read until the quantity of receive data in SCFRDR is less than the specified receive trigger number, or when 1 is read from RDF, and 0 is then written | | | | 1 | The quantity of receive data in SCFRDR is equal to or greater than the specified receive trigger number | | | | | [Setting condition] | | | | | RDF is set to 1 when a quantity of receive data which is equal to or greater than the specified receive trigger number is stored in SCFRDR* | | | Note: Since SCFRDR is a 16-byte FIFO register, the maximum quantity of data which can be read when RDF is 1 is the specified receive trigger number. If reading is attempted after all data in SCFRDR has been read, the data will be undefined. The quantity of receive data in SCFRDR is indicated by the lower 8 bits of SCFDR. Bit 0—Receive Data Ready (DR): Indicates that the receive FIFO data register (SCFRDR) holds a quantity of data less than the specified receive trigger number, and that the next data has not yet been received after the elapse of 15 etu since the last stop bit. | Bit 0: DR | Description | |-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Receiving is in progress, or no received data remains after reception has ended normally (Initial value) | | | [Clearing condition] | | | DR is cleared to 0 when the chip is reset or enters standby mode, or when software reads DR after it has been set to 1, then writes 0 in DR | | 1 | This indicates that the next receive data have not received | | | [Setting condition] | | | DR is set to 1 when the quantity of receive data in SCFRDR is less than the receive trigger setting, and the next data has not yet been received 15 etu* after the last stop bit | Note: This is equivalent to 1.5 frames with the 8-bit, 1-stop-bit format. (etu: element time at unit) | Upper 8 bits: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------|------|------|------|------|------|------|------| | | PER3 | PER2 | PER1 | PER0 | FER3 | FER2 | FER1 | FER0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | Bits 15 to 12—Number of Parity Errors (PER): Indicates the number of receive data bytes in which a parity error occurred that are stored in the receive FIFO data register (SCFRDR). The value indicated by bits 15 to 12 represents the number of SCFRDR parity errors. Bits 11 to 8—Number of Framing Errors (FER): Indicates the number of receive data bytes in which a framing error occurred that are stored in the receive FIFO data register (SCFRDR). The value indicated by bits 11 to 8 represents the number of SCFRDR framing errors. #### 15.2.8 Bit Rate Register (SCBRR) The bit rate register (SCBRR) is an 8-bit register that, together with the baud rate generator clock source selected by the CKS1 and CKS0 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 reset and in module standby and standby modes. Each channel has independent baud rate generator control, so different values can be set in the two 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$$ B: Bit rate (bit/s) N: SCBRR setting for baud rate generator (0 = N = 255) Po: Supporting modules clock (MHz) n: Baud rate generator clock source (n = 0, 1, 2, 3) (for the clock sources and values of n, see table 15.3.) Table 15.3 SCSMR Settings **SCSMR Settings** | n | Clock Source | CKS1 | CKS0 | |---|--------------|------|------| | 0 | Ρφ | 0 | 0 | | 1 | Ρφ/4 | 0 | 1 | | 2 | Pφ/16 | 1 | 0 | | 3 | Ρφ/64 | 1 | 1 | Note: The the bit rate error is given by the following equation: Error (%) = $$\left\{ \frac{P\phi \times 10^6}{(N+1) \times B \times 64 \times 2^{2n-1}} - 1 \right\} \times 100$$ Table 15.4 lists examples of SCBRR settings. Table 15.4 Bit Rates and SCBRR Settings | Pφ | (MHz) | |----|-------| |----|-------| | | | | | | <i>T</i> \ | , | | | | | |----------|---|-----|-----------|---|------------|-----------|--------|-----|-----------|--| | Bit Rate | | 2 | i | | 2.097 | '152 | 2.4576 | | | | | (bits/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | | 110 | 1 | 141 | 0.03 | 1 | 148 | -0.04 | 1 | 174 | -0.26 | | | 150 | 1 | 103 | 0.16 | 1 | 108 | 0.21 | 1 | 127 | 0.00 | | | 300 | 0 | 207 | 0.16 | 0 | 217 | 0.21 | 0 | 255 | 0.00 | | | 600 | 0 | 103 | 0.16 | 0 | 108 | 0.21 | 0 | 127 | 0.00 | | | 1200 | 0 | 51 | 0.16 | 0 | 54 | -0.70 | 0 | 63 | 0.00 | | | 2400 | 0 | 25 | 0.16 | 0 | 26 | 1.14 | 0 | 31 | 0.00 | | | 4800 | 0 | 12 | 0.16 | 0 | 13 | -2.48 | 0 | 15 | 0.00 | | | 9600 | 0 | 6 | -6.99 | 0 | 6 | -2.48 | 0 | 7 | 0.00 | | | 19200 | 0 | 2 | 8.51 | 0 | 2 | 13.78 | 0 | 3 | 0.00 | | | 31250 | 0 | 1 | 0.00 | 0 | 1 | 4.86 | 0 | 1 | 22.88 | | | 38400 | 0 | 1 | -18.62 | 0 | 0 | -14.67 | 0 | 1 | 0.00 | | | | | | | | | | | | | | # $P\phi$ (MHz) | Bit Rate | 3 | | | | 3.6864 | | | | | |----------|---|-----|-----------|---|--------|-----------|---|-----|-----------| | (bits/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | 110 | 1 | 212 | 0.03 | 2 | 64 | 0.70 | 2 | 70 | 0.03 | | 150 | 1 | 155 | 0.16 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | | 300 | 1 | 77 | 0.16 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | | 600 | 0 | 155 | 0.16 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | | 1200 | 0 | 77 | 0.16 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | | 2400 | 0 | 38 | 0.16 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | | 4800 | 0 | 19 | -2.34 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | | 9600 | 0 | 9 | -2.34 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | | 19200 | 0 | 4 | -2.34 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | | 31250 | 0 | 2 | 0.00 | 0 | 3 | -7.84 | 0 | 3 | 0.00 | | 38400 | _ | | _ | 0 | 2 | 0.00 | 0 | 2 | 8.51 | Table 15.4 Bit Rates and SCBRR Settings (cont) # Pφ (MHz) | Bit Rate | | 4.91 | 52 | | 5 | | | ( | 3 | |----------|---|------|-----------|---|-----|-----------|---|-----|-----------| | (bits/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | 110 | 2 | 86 | 0.31 | 2 | 88 | -0.25 | 2 | 106 | -0.44 | | 150 | 1 | 255 | 0.00 | 2 | 64 | 0.16 | 2 | 77 | 0.16 | | 300 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | 1 | 155 | 0.16 | | 600 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | 1 | 77 | 0.16 | | 1200 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | 0 | 155 | 0.16 | | 2400 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | 0 | 77 | 0.16 | | 4800 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | 0 | 38 | 0.16 | | 9600 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | 0 | 19 | -2.34 | | 19200 | 0 | 7 | 0.00 | 0 | 7 | 1.73 | 0 | 9 | -2.34 | | 31250 | 0 | 4 | -1.70 | 0 | 4 | 0.00 | 0 | 5 | 0.00 | | 38400 | 0 | 3 | 0.00 | 0 | 3 | 1.73 | 0 | 4 | -2.34 | # Pφ (MHz) | | | | | | | • | | | | | |----------|---|-------|-----------|---|------|-----------|---|-----|-----------|--| | Bit Rate | | 6.144 | | | 7.37 | '28 | 8 | | | | | (bits/s) | n | N | Error (%) | n | N | Error (%) | n | N | Error (%) | | | 110 | 2 | 108 | 0.08 | 2 | 130 | -0.07 | 2 | 141 | 0.03 | | | 150 | 2 | 79 | 0.00 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | | | 300 | 1 | 159 | 0.00 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | | | 600 | 1 | 79 | 0.00 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | | | 1200 | 0 | 159 | 0.00 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | | | 2400 | 0 | 79 | 0.00 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | | | 4800 | 0 | 39 | 0.00 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | | | 9600 | 0 | 19 | 0.00 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | | | 19200 | 0 | 9 | 0.00 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | | | 31250 | 0 | 5 | 2.40 | 0 | 6 | 5.33 | 0 | 7 | 0.00 | | | 38400 | 0 | 4 | 0.00 | 0 | 5 | 0.00 | 0 | 6 | -6.99 | | Table 15.4 Bit Rates and SCBRR Settings (cont) Pφ (MHz) | | | 9.830 | 4 | | 10 | | | 12 | | | 12.2 | 88 | |----------------------|---|-------|--------------|---|-----|--------------|---|-----|--------------|---|------|--------------| | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 1 | 174 | -0.26 | 2 | 177 | -0.25 | 1 | 212 | 0.03 | 2 | 217 | 0.08 | | 150 | 1 | 127 | 0.00 | 2 | 129 | 0.16 | 1 | 155 | 0.16 | 2 | 159 | 0.00 | | 300 | 0 | 255 | 0.00 | 2 | 64 | 0.16 | 1 | 77 | 0.16 | 2 | 79 | 0.00 | | 600 | 0 | 127 | 0.00 | 1 | 129 | 0.16 | 0 | 155 | 0.16 | 1 | 159 | 0.00 | | 1200 | 0 | 255 | 0.00 | 1 | 64 | 0.16 | 0 | 77 | 0.16 | 1 | 79 | 0.00 | | 2400 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | 0 | 38 | 0.16 | 0 | 159 | 0.00 | | 4800 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | 0 | 19 | 0.16 | 0 | 79 | 0.00 | | 9600 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | 0 | 9 | 0.16 | 0 | 39 | 0.00 | | 19200 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | 0 | 4 | 0.16 | 0 | 19 | 0.00 | | 31250 | 0 | 9 | -1.70 | 0 | 9 | 0.00 | 0 | 2 | 0.00 | 0 | 11 | 2.40 | | 38400 | 0 | 1 | 0.00 | 0 | 7 | 1.73 | 0 | 9 | -2.34 | 0 | 9 | 0.00 | $P\phi$ (MHz) | | | 14.745 | 56 | | 16 | | | 19.66 | 08 | | 20 | | |----------------------|---|--------|--------------|---|-----|--------------|---|-------|--------------|---|-----|--------------| | Bit Rate<br>(bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 3 | 64 | 0.70 | 3 | 70 | 0.03 | 3 | 86 | 0.31 | 3 | 88 | -0.25 | | 150 | 2 | 191 | 0.00 | 2 | 207 | 0.16 | 2 | 255 | 0.00 | 2 | 64 | 0.16 | | 300 | 2 | 95 | 0.00 | 2 | 103 | 0.16 | 2 | 127 | 0.00 | 2 | 129 | 0.16 | | 600 | 1 | 191 | 0.00 | 1 | 207 | 0.16 | 1 | 255 | 0.00 | 1 | 64 | 0.16 | | 1200 | 1 | 95 | 0.00 | 1 | 103 | 0.16 | 1 | 127 | 0.00 | 1 | 129 | 0.16 | | 2400 | 0 | 191 | 0.00 | 0 | 207 | 0.16 | 0 | 255 | 0.00 | 0 | 64 | 0.16 | | 4800 | 0 | 95 | 0.00 | 0 | 103 | 0.16 | 0 | 127 | 0.00 | 0 | 129 | 0.16 | | 9600 | 0 | 47 | 0.00 | 0 | 51 | 0.16 | 0 | 63 | 0.00 | 0 | 64 | 0.16 | | 19200 | 0 | 23 | 0.00 | 0 | 25 | 0.16 | 0 | 31 | 0.00 | 0 | 32 | -1.36 | | 31250 | 0 | 14 | -1.70 | 0 | 15 | 0.00 | 0 | 19 | -1.70 | 0 | 19 | 0.00 | | 38400 | 0 | 11 | 0.00 | 0 | 12 | 0.16 | 0 | 15 | 0.00 | 0 | 15 | 1.73 | | 115200 | 0 | 3 | 0.00 | 0 | 3 | 8.51 | 0 | 4 | 6.67 | 0 | 4 | 8.51 | | 500000 | 0 | 0 | -7.84 | 0 | 0 | 0.00 | 0 | 0 | 22.9 | 0 | 0 | 25.0 | Table 15.4 Bit Rates and SCBRR Settings (cont) Pφ (MHz) | | | 24 | | | 24.57 | <b>'</b> 6 | | 28.7 | 7 | | 30 | | |-------------------|---|-----|--------------|---|-------|--------------|---|------|--------------|---|-----|--------------| | Bit Rate (bits/s) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | n | N | Error<br>(%) | | 110 | 3 | 106 | -0.44 | 3 | 108 | 0.08 | 3 | 126 | 0.31 | 3 | 132 | 0.13 | | 150 | 3 | 77 | 0.16 | 3 | 79 | 0.00 | 3 | 92 | 0.46 | 3 | 97 | -0.35 | | 300 | 2 | 155 | 0.16 | 2 | 159 | 0.00 | 2 | 186 | -0.08 | 2 | 194 | 0.16 | | 600 | 2 | 77 | 0.16 | 2 | 79 | 0.00 | 2 | 92 | 0.46 | 2 | 97 | -0.35 | | 1200 | 1 | 155 | 0.16 | 1 | 159 | 0.00 | 1 | 186 | -0.08 | 1 | 194 | 0.16 | | 2400 | 1 | 77 | 0.16 | 1 | 79 | 0.00 | 1 | 92 | 0.46 | 1 | 97 | -0.35 | | 4800 | 0 | 155 | 0.16 | 0 | 159 | 0.00 | 0 | 186 | -0.08 | 0 | 194 | -1.36 | | 9600 | 0 | 77 | 0.16 | 0 | 79 | 0.00 | 0 | 92 | 0.46 | 0 | 97 | -0.35 | | 19200 | 0 | 38 | 0.16 | 0 | 39 | 0.00 | 0 | 46 | -0.61 | 0 | 48 | -0.35 | | 31250 | 0 | 23 | 0.00 | 0 | 24 | -1.70 | 0 | 28 | -1.03 | 0 | 29 | 0.00 | | 38400 | 0 | 19 | -2.34 | 0 | 19 | 0.00 | 0 | 22 | 1.55 | 0 | 23 | 1.73 | | 115200 | 0 | 6 | -6.99 | 0 | 6 | -4.76 | 0 | 7 | -2.68 | 0 | 7 | 1.73 | | 500000 | 0 | 1 | -25.0 | 0 | 1 | -23.2 | 0 | 1 | -10.3 | 0 | 1 | -6.25 | Table 15.5 indicates the maximum bit rates in asynchronous mode when the baud rate generator is being used. Table 15.6 list the maximum rates for external clock input. Table 15.5 Maximum Bit Rates for Various Frequencies with Baud Rate Generator (Asynchronous Mode) | | | Sett | ings | |----------|---------------------------|------|------| | Pφ (MHz) | Maximum Bit Rate (bits/s) | n | N | | 2 | 62500 | 0 | 0 | | 2.097152 | 65536 | 0 | 0 | | 2.4576 | 76800 | 0 | 0 | | 3 | 93750 | 0 | 0 | | 3.6864 | 115200 | 0 | 0 | | 4 | 125000 | 0 | 0 | | 4.9152 | 153600 | 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 | Table 15.6 Maximum Bit Rates during External Clock Input (Asynchronous Mode) | $P\phi$ (MHz) | External Input Clock (MHz) | Maximum Bit Rate (bits/s) | |---------------|----------------------------|---------------------------| | 2 | 0.5000 | 31250 | | 2.097152 | 0.5243 | 32768 | | 2.4576 | 0.6144 | 38400 | | 3 | 0.7500 | 46875 | | 3.6864 | 0.9216 | 57600 | | 4 | 1.0000 | 62500 | | 4.9152 | 1.2288 | 76800 | | 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 | | | | | # 15.2.9 FIFO Control Register (SCFCR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-------|-------|-------|-------|-----|-------|-------|------| | | RTRG1 | RTRG0 | TTRG1 | TTRG0 | MCE | TFRST | RFRST | LOOP | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W The FIFO control register (SCFCR) resets the quantity of data in the transmit and receive FIFO registers, sets the trigger data, number and contains the enable bit for loop-back testing. SCFCR can read and be written by the CPU at all times. It is initialized to H'00 by a reset, by the module standby function, and in standby mode. Bits 7 and 6—Receive FIFO Data Trigger (RTRG1, RTRG0): These bits set the quantity of receive data which sets the receive data full (RDF) flag in the serial status register (SCSSR). The RDF flag is set when the quantity of receive data stored in the receive FIFO register (SCFRDR) exceeds the trigger number as shown below. | Bit 7: RTRG1 | Bit 6: RTRG0 | Receive Trigger Number | | |--------------|--------------|------------------------|-----------------| | 0 | 0 | 1 | (Initial value) | | 0 | 1 | 4 | | | 1 | 0 | 8 | | | 1 | 1 | 14 | | Bits 5 and 4—Transmit FIFO Data Trigger (TTRG1, TTRG0): These bits set the quantity of remaining transmit data which sets the transmit FIFO data register empty (TDFE) flag in the serial status register (SCSSR). The TDFE flag when the quantity of transmit data in the transmit FIFO data register (SCFTDR) falls below the trigger number specified by these bits, as shown below. | Bit 5: TTRG1 | Bit 4: TTRG0 | Transmit Trigger Number | | |--------------|--------------|-------------------------|-----------------| | 0 | 0 | 8 (8) | (Initial value) | | 0 | 1 | 4 (12) | | | 1 | 0 | 2 (14) | | | 1 | 1 | 1 (15) | _ | Note: Values in parentheses indicate the number of empty bytes in the SCFTDR register when the TDFE flag is set to 1. Bit 3—Modem Control Enable (MCE): The modem control signal $\overline{\text{CTS}}$ , $\overline{\text{RTS}}$ are accepted and prohibited. | Bit 3: MCE | Description | | |------------|-------------------------|-----------------| | 0 | Modem signals disabled* | (Initial value) | | 1 | Modem signals enabled | _ | Note: $\overline{\text{CTS}}$ is fixed at active-0 regardless of the input value, and $\overline{\text{RTS}}$ is also fixed at 0. Bit 2—Transmit FIFO Data Register Reset (TFRST): Disables the transmit data in the transmit FIFO data register and resets the data to the empty state. | Bit 2: TFRST | Description | | |-----------------|-----------------------------------------|-----------------| | 0 | Reset operation disabled* | (Initial value) | | 1 | Reset operation enabled | | | Note: Resetting | operates in resets and in standby mode. | | Bit 1—Receive FIFO Data Register Reset (RFRST): Disables the receive data in the receive FIFO data register and resets the data to the empty state. | Bit 1: RFRST | Description | | |--------------|---------------------------|-----------------| | 0 | Reset operation disabled* | (Initial value) | | 1 | Reset operation enabled | | Note: Resetting operates in resets and in standby mode. Bit 0—Loop-Back Test (LOOP): Internally connects the transmit output pin (TXD) and receive input pin (RXD) and enables loop-back testing. | Bit 0: LOOP | Description | | |-------------|----------------------------|-----------------| | 0 | Loop-back testing disabled | (Initial value) | | 1 | Loop-back testing enabled | | #### 15.2.10 FIFO Data Count 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 in the upper eight bits, and the quantity of receive data in SCFRDR in the lower eight bits. SCFDR can always be read by the CPU. | Lower 8 Bits: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|----|----|----|----|----| | | _ | _ | _ | R4 | R3 | R2 | R1 | R0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | SCFDR indicates the quantity of receive data stored in SCFRDR. H'00 shows that there are not receive data, and H'10 shows that the receive data are in full condition. | Upper 8 Bits: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|----|----|----|----|----|----|----| | : | _ | _ | _ | T4 | T3 | T2 | T1 | T0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | SCFDR indicates the quantity of non-transmitted data stored in SCFTDR. H'00 indicates that there is no transmit data, and H'10 indicates that full of transmit data is stored in the SCFTDR. #### 15.3 Operation #### 15.3.1 Overview For serial communication, the SCIF uses an asynchronous mode in which characters are synchronized individually. Refer to section 13.3.2 for details of operation in asynchronous mode. The SCIF has a 16-byte FIFO buffer for both transmit and receive operations, reducing CPU overhead and enabling continuous high-speed communication. It also uses $\overline{\text{RTS}}$ and $\overline{\text{CTS}}$ modem control signals. The transmission format is selected in the serial mode register (SCSMR), as shown in table 15.7. The SCIF clock source is selected by the combination of the CKE1 and CKE0 bits in the serial control register (SCSCR), as shown in table 15.8. - Data length is selectable: seven or eight bits. - Parity and multiprocessor bits are selectable, as is the stop bit length (one or two bits). The combination of the preceding selections constitutes the communication format and character length. - In receiving, it is possible to detect framing errors (FER), parity errors (PER), receive FIFO data full, receive data ready, and breaks. - In transmitting, it is possible to detect transmit FIFO data empty. - The number of stored data bytes is displayed 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 built-in baud rate generator, and can output a serial clock signal with a frequency 16 times the bit rate. - When an external clock is selected, the external clock input must have a frequency of 16 times the bit rate. (The built-in baud rate generator is not used.) **Table 15.7 Serial Mode Register Settings and SCIF Communication Formats** | | | S | CSMR Se | SCIF Communication Format | | | |--------------|--------------|-------------|---------------|---------------------------|---------------|-----------------| | Mode | Bit 6<br>CHR | Bit 5<br>PE | Bit 3<br>STOP | Data<br>Length | Parity<br>Bit | Stop Bit Length | | Asynchronous | 0 | 0 | 0 | 8-bit | Not set | 1 bit | | | | | 1 | <del>_</del> | | 2 bits | | | | 1 | 0 | <del>_</del> | Set | 1 bit | | | | | 1 | <del>_</del> | | 2 bits | | | 1 | 0 | 0 | 7-bit | Not set | 1 bit | | | | | 1 | _ | | 2 bits | | | | 1 | 0 | _ | Set | 1 bit | | | | | 1 | _ | | 2 bits | Table 15.8 SCSMR and SCSCR Settings and SCIF Clock Source Selection | | SCSCR | R Settings | SCIF Transmit/Receive Clock | | | | | |--------------|--------------------------|------------|-----------------------------|--------------------------------------------------------|--|--|--| | Mode | Bit 1 Bit 0<br>CKE1 CKE0 | | Clock Source | SCK Pin Function | | | | | Asynchronous | 0 | 0 | Internal | SCIF does not use the SCK pin | | | | | mode | | 1 | | Outputs a clock with a frequency 16 times the bit rate | | | | | | 1 0 External | | External | Inputs a clock with frequency 16 times the | | | | | | | 1 | | bit rate | | | | #### 15.3.2 Serial Operation **Transmit/Receive Formats:** Table 15.9 lists the eight communication formats that can be selected. The format is selected by settings in the serial mode register (SCSMR). **Table 15.9 Serial Communication Formats** | S | CSMF | Bits | ; | Serial Transmit/Receive Format and Frame Length | | | | | | | | | | | |----|------|------|-------|-------------------------------------------------|---|----|--------|-------|----|---|------|------|------|------| | СН | R PE | STOP | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | | 0 | 0 | 0 | START | | | | 8-b | it da | ta | | | STOP | | | | 0 | 0 | 1 | START | | | | 8-b | it da | ta | | | STOP | STOP | | | 0 | 1 | 0 | START | | | | 8-b | it da | ta | | | Р | STOP | | | 0 | 1 | 1 | START | | | | 8-b | it da | ta | | | Р | STOP | STOP | | 1 | 0 | 0 | START | | | 7- | bit da | ata | | | STOP | | | | | 1 | 0 | 1 | START | | | 7- | bit da | ata | | | STOP | STOP | | | | 1 | 1 | 0 | START | | | 7- | bit da | ata | | | Р | STOP | | | | 1 | 1 | 1 | START | | | 7- | bit da | ata | | | Р | STOP | STOP | | Notes: START: Start bit STOP: Stop bit P: Parity bit **Clock:** An internal clock generated by the built-in 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 the bits CKE1 and CKE0 in the serial control register (SCSCR) (table 15.8). 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 at the SCK pin. The frequency of this output clock will be 16 times the bit rate. **Transmitting and Receiving Data (SCIF Initialization):** 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 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 (SCSSR), transmit FIFO data register (SCFTDR), or receive FIFO data register (SCFRDR), which retain their previous contents. Clear TE to 0 after all transmit data are transmitted and the TEND flag in SCSSR is set. The transmitting data enters the high impedance state after clearing to 0 although the bit can be cleared to 0 in transmitting. Set the TFRST bit in SCFCR to 1 and reset SCFTDR before TE bit 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 15.2 shows a sample flowchart for initializing the SCIF. The procedure for initializing the SCIF is shown in the figure. Figure 15.2 Sample SCIF Initialization Flowchart • Serial data transmission Figure 15.3 shows a sample flowchart for serial transmission. Use the following procedure for serial data transmission after enabling the SCIF for transmission. Figure 15.3 Sample Serial Transmission Flowchart In serial transmission, the SCIF operates as described below. - 1. When data is written into the transmit FIFO data register (SCFTDR), SCIF transfers the data from SCFTDR to the transmit shift register(SCTSR) and starts sending. Confirm that the TDFE flag in the serial status register (SCSSR) 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 (SCSCR) 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 0-bit 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. - If there is no transmit data, the TEND flag in SCSSR is set to 1, the stop bit is sent, and then the line goes to the mark state in which 1 is output continuously. Figure 15.4 shows an example of the operation for transmission. Figure 15.4 Example of Transmit Operation (Example with 8-Bit Data, Parity, One Stop Bit) 4. When modem control is enabled, transmission can be stopped and restarted in accordance with the CTS input value. When CTS is 1, if transmission is in progress, the line goes to the mark state after transmission of one frame. When CTS becomes 0, the next send data is output from start bit at the top. Start-up at this time before stop bit. Figure 15.5 shows an example of the operation when modem control is used. Figure 15.5 Example of Operation Using Modem Control (CTS) #### • Serial data reception Figure 15.6 and 15.7 shows a sample flowchart for serial reception. Use the following procedure for serial data reception after enabling the SCIF for reception. Figure 15.6 Sample Serial Reception Flowchart Figure 15.7 Sample Serial Reception Flowchart (cont) In serial reception, the SCIF operates as described below. - 1. The SCIF monitors the transmission line, and if a 0 stop 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. 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: Even if the receive error occurs, the receiving can not be suspended. 4. If the RIE bit in SCSR 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 in SCSR is set to 1 when the ER flag changes to 1, a receive-error interrupt (ERI) request is generated. If the RIE bit in SCSR is set to 1 when the BRK flag changes to 1, a break reception interrupt (BRI) request is generated. Figure 15.8 shows an example of the operation for reception. Figure 15.8 Example of SCIF Receive Operation (Example with 8-Bit Data, Parity, One Stop Bit) 5. When modem control is enabled, the $\overline{RTS}$ signal is output when SCFRDR is empty. When $\overline{RTS}$ is 0, reception is possible. When $\overline{RTS}$ is 1, this indicates that SCFRDR is full and reception is not possible. Figure 15.9 shows an example of the operation when modem control is used. Figure 15.9 Example of Operation Using Modem Control (RTS) # 15.4 SCIF Interrupts The SCIF has four interrupt sources: transmit-FIFO-data-empty (TXI), receive-error (ERI), receive-data-full (RXI), and break (BRI). Table 15.10 shows the interrupt sources and their order of priority. The interrupt sources are enabled or disabled by means of the TIE and RIE bits in SCSCR. A separate interrupt request is sent to the interrupt controller for each of these interrupt sources. When the TDFE flag in the serial status register (SCSSR) is set to 1, a TXI interrupt request is generated. The DMAC can be activated and data transfer performed when this interrupt is generated. The TDFE flag is automatically cleared to 0 when data is written to the transmit data register (SCFTDR) by the DMAC. When the RDF flag in SCSSR is set to 1, an RXI interrupt request is generated. The DMAC can be activated and data transfer performed when the RDF flag in SCSSR is set to 1. The RDF flag is automatically cleared to 0 when data is read from the receive data register (SCFRDR) by the DMAC. When the ER flag in SCSSR is set to 1, an ERI interrupt request is generated. When the BRK flag in SCSSR is set to 1, a BRI interrupt request is generated. The TXI interrupt indicates that transmit data can be written, and the RXI interrupt indicates that there is receive data in SCFRDR. **Table 15.10 SCIF Interrupt Sources** | Interrupt<br>Source | Description | DMAC<br>Activation | Priority on<br>Reset Release | | |---------------------|----------------------------------------------------------------------------------------------|---------------------------|------------------------------|--| | ERI | Interrupt initiated by receive error flag (ER) | Not possible | High | | | RXI | Interrupt initiated by receive FIFO data register further flag (RDF) or data ready flag (DR) | II Possible<br>(RDF only) | <u> </u> | | | BRI | Interrupt initiated by break flag (BRK) | Not possible | _ | | | Txl | Interrupt initiated by transmit FIFO data register empty flag (TDFE) | Possible | _ ↓<br>Low | | See section 4, Exception Handling, for priorities and the relationship with non-SCIF interrupts. ### 15.5 Usage Notes Note the following when using the SCIF. - SCFTDR Writing and the TDFE Flag: The TDFE flag in the serial status register (SCSSR) 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 TTRG1 and TTRG0 in the FIFO control register (SCFCR). After TDFE is set, transmit data up to the number of empty data 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 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). - 2. Relations between Read of SCFRDR and RDF Flag: The RDF flag in the serial status register (SCSSR) 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 RTRG1 and RTRG0 in the FIFO control register (SCFCR). After RDF 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 is equal to or greater than the trigger number, the RDF flag will be set to 1 again if it is cleared to 0. Therefore, clear RDF to 0 after it is read as 1 when all the receive data has been read. - The number of receive data in SCFRDR can be found from the lower 8 bits of the FIFO data count register (SCFDR). - 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, so if the BRK flag is cleared to 0 it will be set to 1 again. - 4. Sending a Break: The input/output condition and level of the TxD pin are determined by the port B data register (PBDR), port B function control register (PBCR), and port B I/O control register (PBIOR). This feature can be used to send a break. To send a break during serial transmission, clear PBDR corresponding to the TxD pin to 0, set PBIOR to 1, set PBCR to the port function, and 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 status, and 0 is output from the TxD pin. - 5. TEND Flag and TE Bit Processing: The TEND flag is set to 1 during transmission of the stop bit of the last data. Consequently, if the TE bit is cleared to 0 immediately after setting of the TEND flag has been confirmed, the stop bit will be in the process of transmission and will not be transmitted normally. Therefore, the TE bit should not be cleared to 0 for at least 0.5 serial clock cycles (or 1.5 cycles if two stop bits are used) after setting of the TEND flag setting is confirmed. - 6. Receive Data Sampling Timing and Receive Margin: 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 15.10. Figure 15.10 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 = \left| \left( 0.5 - \frac{1}{2N} \right) - (L - 0.5) F - \frac{|D - 0.5|}{N} (1 + F) \right| \times 100\% \quad \dots \quad (1)$$ M: Receive margin (%) N: Ratio of clock frequency to bit rate (N = 16) D: Clock duty cycle (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). When D = 0.5 and F = 0: $$M = (0.5 - 1/(2 \times 16)) \times 100\% = 46.875\% \cdot \cdot \cdot \cdot (2)$$ This is a theoretical value. A reasonable margin to allow in system designs is 20% to 30%. # Section 16 IrDA ## 16.1 Overview The LSI has an on-chip Infrared Data Association (IrDA) interface which is based on the IrDA 1.0 system and can perform infrared communication. It can also be used as the SCIF by means of register settings. ### 16.1.1 Features - Based on the IrDA 1.0 system - Asynchronous serial communication - Data length: Eight bits - Stop bit length: One bit - Parity bit: None - Built-in 16-stage FIFO buffers for both transmit and receive - Built-in baud rate generator with selectable bit rates - Guard functions to protect the receiver during transmission - During IrDA unassigned, the clock supply is stopped to reduce the power draw. ## 16.1.2 Block Diagram Figure 16.1 shows a block diagram of the IrDA. Figure 16.1 IrDA Block Diagram ## 16.1.3 Pin Configuration In IrDA, the serial terminal is available as shown in table 16.1. **Table 16.1 IrDA Pin Configuration** | Channel | Pin Name | Abbreviation | I/O | Function | |---------|-------------------|--------------|--------------|----------------------| | 1 | Serial clock pin | SCK1 | Input/output | Clock input/output | | | Receive data pin | RxD1 | Input | Receive data input | | | Transmit data pin | TxD1 | Output | Transmit data output | | 2 | Serial clock pin | SCK2 | Input/output | Clock input/output | | | Receive data pin | RxD2 | Input | Receive data input | | | Transmit data pin | TxD2 | Output | Transmit data output | # 16.1.4 Register Configuration The IrDA has the internal registers shown in table 16.2. By using these registers, the IrDA or SCIF mode can be selected, the data format and bit rate can be specified, and the transmit and receive parts can be controlled. **Table 16.2 Register Configuration** | Channel | Register Name | Abbre-<br>viation | R/W | Initial<br>Value | Address | Access<br>Size | |---------|--------------------------------|-------------------|--------|------------------|------------|----------------| | 1 | Serial mode register 1 | SCSMR1 | R/W | H'00 | H'FFFFCC0 | 8 bits | | | Bit rate register 1 | SCBRR1 | R/W | H'FF | H'FFFFCC2 | 8 bits | | | Serial control register 1 | SCSCR1 | R/W | H'00 | H'FFFFFCC4 | 8 bits | | | Transmit FIFO data register 1 | SCFTDR1 | W | _ | H'FFFFFCC6 | 8 bits | | | Serial status register 1 | SCSSR1 | R/(W)* | H'0060 | H'FFFFFCC8 | 16 bits | | | Receive FIFO data register 1 | SCFRDR1 | R | Undefined | H'FFFFFCCA | 8 bits | | | FIFO control register 1 | SCFCR1 | R/W | H'00 | H'FFFFFCCC | 8 bits | | | FIFO data count set register 1 | SCFDR1 | R | H'0000 | H'FFFFFCCE | 16 bits | | 2 | Serial mode register 2 | SCSMR2 | R/W | H'00 | H'FFFFFCD0 | 8 bits | | | Bit rate register 2 | SCBRR2 | R/W | H'FF | H'FFFFFCD2 | 8 bits | | | Serial control register 2 | SCSCR2 | R/W | H'00 | H'FFFFCD4 | 8 bits | | | Transmit FIFO data register 2 | SCFTDR2 | W | _ | H'FFFFFCD6 | 8 bits | | | Serial status register 2 | SCSSR2 | R/(W)* | H'0060 | H'FFFFFCD8 | 16 bits | | | Receive FIFO data register 2 | SCFRDR2 | R | Undefined | H'FFFFCDA | 8 bits | | | FIFO control register 2 | SCFCR2 | R/W | H'00 | H'FFFFFCDC | 8 bits | | | FIFO data count set register 2 | SCFDR2 | R | H'0000 | H'FFFFFCDE | 16 bits | Note: Only 0 can be written, to clear the flags. # 16.2 Register Description Specifications of the registers in the IrDA are the same as those in the SCIF except for the serial mode register described below. Therefore, refer to section 15, Serial Communication Interface with FIFO, for these registers. ### 16.2.1 Serial Mode Register (SCSMR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-------|------|------|------|------|------|------|------| | | IRMOD | ICK3 | ICK2 | ICK1 | ICK0 | PSEL | CKS1 | CKS0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W SCSMR is an 8-bit register which can select IrDA or SCIF mode, specify the SCIF serial communication format, select the IrDA output pulse width, and select the baud rate generator clock source. This module operates as IrDA by setting the IRMOD bit to 1. At this time, bits 3 to 6 are fixed at 0. This register functions in the same way as the SCSMR register in the SCIF by setting the IRMOD bit to 0; therefore, this module can also operates as the SCIF. SCSMR is initialized to H'00 by a power-on reset, manual reset, stoppage by the module standby function, or standby mode. Bit 7—IrDA Mode (IRMOD): Selects whether this module operates as an IrDA serial communication interface or as an SCIF. | Bit 7: IRMOD | Description | | |--------------|------------------|-----------------| | 0 | Operates as SCIF | (Initial value) | | 1 | Operates as IrDA | _ | Bits 6 to 3—IrDA Clock Select Bits (ICK3-ICK0) Bit 2—Output Pulse Width Select (PSEL) The output pulse width select bit (PSEL) selects an output pulse width of IrDA that is 3/16 of the bit length for 115 kbps or 3/16 of the bit length for the selected baud rate. The IrDA clock select bits should be set properly to fix the output pulse width at 3/16 of the bit length for 115 kbps by setting the PSEL bit to 1. | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Description | |-------|-------|-------|-------|-------|------------------------------------------| | ICK3 | ICK2 | ICK1 | ICK0 | PSEL | | | ICK3 | ICK2 | ICK1 | ICK0 | 1 | Pulse width: 3/16 of 115 kbps bit length | | * | * | * | * | 0 | Pulse width: 3/16 of bit length | \*: Don't care It is necessary to generate a fixed clock pulse, IRCLK, by dividing the P $\phi$ clock by 1/2N+2, with the value of N determined by the setting of ICK3–ICK0. # Example: $P\phi$ clock: 14.7456 MHz IRCLK: 921.6 kHz (fixed) N: Setting of ICK3–ICK0 (0 = N = 15) $$N \ge \frac{P \ \varphi}{2 \times IRCLK} - \ge 7$$ Thus, N is 7. Bits 1 and 0—Clock Select 1 and 0 (CKS1 and CKS0): These bits select the internal baud rate generator clock source. $P\phi$ , $P\phi/4$ , $P\phi/16$ , or $P\phi/64$ can be selected. Refer to section 15.2.8, Bit Rate Register, for the relationship between the clock source, the bit rate register set value, and the baud rate. | Bit 1: CKS1 | Bit 0: CKS0 | Description | | |-------------|-------------|-------------|-----------------| | 0 | 0 | Pφ clock | (Initial value) | | 0 | 1 | Pφ/4 clock | | | 1 | 0 | Pø/16 clock | | | 1 | 1 | Pφ/64 clock | | Note: Pφ: Peripheral module clock ### 16.3 Operation The IrDA module can perform infrared communication conforming to IrDA 1.0 by connecting an infrared transmit/receive unit. The serial communication interface unit includes a 16-stage FIFO buffer in the transmit section and the receive section, enabling CPU overhead to be reduced and continuous high-speed communication to be performed. This module also supports DMAC data transfer. The IrDA module differs from the SCIF described in section 15 in that it does not include modem control signals RTS and CTS. Refer to section 15.3, SCIF Operation, for SCIF mode operation. #### **16.3.1** Overview In IrDA module, the waveform of TxD/Rxd send/receive data is being changed so that IrDA 1.0 infrared rays communication specifications can be satisfied. In IrDA specification, the communication is first executed at rate of 9600bps, and the communication rate is changed. However, in the communication rate in this module, since it can not be changed automatically, if the communication is executed, confirm the communication rate and set the appropriate rate to this module by the software. Note: In IrDA mode, when TE bit of the serial control register (SCSCR) is set (communication permitted) to 1, the receive can not be done. If the receive is performed, clear TE bit of SCSCR to 0. # 16.3.2 Transmission The waveform of the serial output signal (UART frame) from the SCIF is modified and the signal is converted into the IR frame serial output signal by the IrDA module, as shown in figure 16.2. When serial data is 0, a 3/16-bit width pulse of the IR frame is generated and output. When serial data is 1, a pulse is not output. An infrared LED is driven with this signal, demodulated into 3/16 width. ### 16.3.3 Reception The 3/16-bit width pulse of the IR frame that was received is demodulated and converted into a UART frame, as shown in figure 16.2. The demodulation to 0 is executed for the pulse output, and the demodulation to 1 is executed when the pulse output is not available. Figure 16.2 Transmit/Receive Operation # Section 17 Serial I/O (SIO) ### 17.1 Overview The LSI processor provides three channels of simple synchronous serial I/O. This serial I/O functions mainly to interface the processor to the analog front end of a codec or modem. ### 17.1.1 Features The serial I/O has the following features: - Full-duplex operation: Independent receive and transmit registers, independent receive and transmit clocks - Double-buffered receive and transmit ports allow for continuous transmission and reception of data - Interval transfer mode and continuous transfer mode - Memory-mapped receive, transmit, control and status registers: With the exception of SIRSR and SITSR, these registers are all memory-mapped and can be accessed through MOV instructions - Selectable data lengths: 8 or 16 bits - Data transfer notification by polling or interrupt: The receive-data-register-full flag (RDRF) or transmit-data-register-empty flag (TDRE) in the serial status register can be polled to monitor data transfer. The receive-interrupt request flag or transmit-interrupt request flag can be set to request an interrupt on data transfer. - Most significant bit transferred first for data I/O Figure 17.1 shows a block diagram of the serial I/O Figure 17.1 SIO Block Diagram Table 17.1 describes the external pin functions. Because the channels are independent, the channel number is dropped from the name of the signal in subsequent sections. Table 17.1 External Pins for the Serial I/O (SIO) | Channel | Name | Abbr. | I/O | Function | |---------|---------------------------------------|-------|-----|----------------------------------| | 0 | Serial receive data input pin | SRxD0 | I | Serial data input port 0 | | | Serial receive clock input pin | SRCK0 | I | Serial receive clock port 0 | | | Serial receive sync input pin | SRS0 | I | Serial receive sync input port 0 | | | Serial transmit data output pin | STxD0 | 0 | Serial data output port 0 | | | Serial transmit clock input pin | STCK0 | I | Serial transmit clock port 0 | | | Serial transmit sync input/output pin | STS0 | I/O | Serial transmit sync I/O port 0 | | 1 | Serial receive data input pin | SRxD1 | I | Serial data input port 1 | | | Serial receive clock input pin | SRCK1 | I | Serial receive clock port 1 | | | Serial receive sync input pin | SRS1 | | Serial receive sync input port 1 | | | Serial transmit data output pin | STxD1 | 0 | Serial data output port 1 | | | Serial transmit clock input pin | STCK1 | I | Serial transmit clock port 1 | | | Serial transmit sync input/output pin | STS1 | I/O | Serial transmit sync I/O port 1 | | 2 | Serial receive data input pin | SRxD2 | | Serial data input port 2 | | | Serial receive clock input pin | SRCK2 | I | Serial receive clock port 2 | | | Serial receive sync input pin | SRS2 | I | Serial receive sync input port 2 | | | Serial transmit data output pin | STxD2 | 0 | Serial data output port 2 | | | Serial transmit clock input pin | STCK2 | I | Serial transmit clock port 2 | | | Serial transmit sync input/output pin | STS2 | I/O | Serial transmit sync I/O port 2 | Note: All pins are initialized to a high-impedance state on reset. # 17.2 Register Configuration Table 17.2 lists the SIO registers. Because the channels are independent, the channel number is dropped from the name of the signal in subsequent sections. Table 17.2 Registers of the Serial I/O (SIO) | Chan-<br>nel | Register | Abbr. | R/W | Initial<br>Value | Address | Access Size<br>(Bits) | |--------------|---------------------------|--------|-------|------------------|------------|-----------------------| | 0 | Receive shift register 0 | SIRSR0 | _ | _ | _ | _ | | | Receive data register 0 | SIRDR0 | R | H'0000 | H'FFFFC00 | 8, 16, 32 | | | Transmit shift register 0 | SITSR0 | _ | _ | _ | _ | | | Transmit data register 0 | SITDR0 | R/W | H'0000 | H'FFFFC02 | 8, 16, 32 | | | Serial control register 0 | SICTR0 | R/W | H'0000 | H'FFFFC04 | 8, 16, 32 | | | Serial status register 0 | SISTR0 | R/(W) | *H'0002 | H'FFFFFC06 | 8, 16, 32 | | 1 | Receive shift register 1 | SIRSR1 | _ | _ | _ | _ | | | Receive data register 1 | SIRDR1 | R | H'0000 | H'FFFFFC10 | 8, 16, 32 | | | Transmit shift register 1 | SITSR1 | _ | _ | _ | _ | | | Transmit data register 1 | SITDR1 | R/W | H'0000 | H'FFFFFC12 | 8, 16, 32 | | | Serial control register 1 | SICTR1 | R/W | H'0000 | H'FFFFFC14 | 8, 16, 32 | | | Serial status register 1 | SISTR1 | R/(W) | *H'0002 | H'FFFFFC16 | 8, 16, 32 | | 2 | Receive shift register 2 | SIRSR2 | _ | _ | _ | _ | | | Receive data register 2 | SIRDR2 | R | H'0000 | H'FFFFFC20 | 8, 16, 32 | | | Transmit shift register 2 | SITSR2 | _ | _ | _ | _ | | | Transmit data register 2 | SITDR2 | R/W | H'0000 | H'FFFFFC22 | 8, 16, 32 | | | Serial control register 2 | SICTR2 | R/W | H'0000 | H'FFFFFC24 | 8, 16, 32 | | | Serial status register 2 | SISTR2 | R/(W) | *H'0002 | H'FFFFFC26 | 8, 16, 32 | Note: Write only 0 to clear the flag (after reading 1). # 17.2.1 Receive Shift Register (SIRSR) The 16-bit receive shift register (SIRSR) receives serial data. Data is shifted into the SIRSR, starting with the most significant bit, from the SRxD pin synchronous to the falling edge of the serial receive clock (SRCK) signal. The transmit/receive data length select bit (DR) in the corresponding serial control register (SICTR) determines the data length. When the data transfer to the SIRSR is completed, the contents are automatically transferred into the serial receive data register (SIRDR) and the receive-data-register-full flag (RDRF) in the serial status register (SISTR) is set. If the next data word input operation finishes before the RDRF flag is cleared, an overrun error will occur. The receive-overrun-error flag (RERR) in SISTR is set and the overrun-error signal is sent to the interrupt controller (INTC). The data in SIRSR overwrites the data in SIRDR at this time. ### 17.2.2 Receive Data Register (SIRDR) | Bit: | 15 | 14 | 13 | | 3 | 2 | 1 | 0 | | |----------------|----|----|----|---|---|---|---|---|--| | | | | | ] | | | | | | | Initial value: | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | | R/W: | R | R | R | | R | R | R | R | | The 16-bit receive data register (SIRDR) stores serial receive data. As soon as the data is moved from SIRSR to SIRDR, the receive-data-register-full flag (RDRF) in SISTR is set. If the receive-interrupt-enable bit (RIE) in SICTR is set, a receive-data-full interrupt (RDFI) request is also sent to the interrupt controller (INTC) and the direct memory access controller (DMAC). If the flag is cleared, this interrupt request signal is not issued. When SIRDR is read by the DMAC, the RDRF flag is automatically cleared. SIRDR is initialized to H'0000 on reset. ### 17.2.3 Transmit Shift Register (SITSR) The 16-bit transmit shift register (SITSR) transmits serial data. The data is shifted out of this register, starting with the most significant bit, through the STxD pin, synchronous to the rising edge of the STCK serial transmission clock signal. The transmit/receive data length select bit (DL) in SICTR specifies the transfer data length. When the DL bit is set to 0 (data length is 8 bits), the lower-eight bits in SITDR are output. When the serial transmit synchronization signal (STS) becomes high or when the last data transmission finishes with the sync enable (SE) bit in SICTR not having been set, the contents of the transmit data register (SITDR) are transferred into SITSR if the transmit-data-register-empty flag (TDRE) in SISTR is 0, TDRE is set. If the output of the next data begins before the TDRE flag is cleared, an overrun error occurs, setting the transmit overrun error flag (TERR) in SISTR and sending the transmit overrun error interrupt request to the INTC. # 17.2.4 Transmit Data Register (SITDR) The 16-bit transmit data register (SITDR) stores serial transmit data. Data should be written into SITDR when the transmit-data-empty flag (TDRE) is set in SISTR . If TDRE is cleared, new data written into SITDR will overwrite the existing data. When the STS signal becomes high (STS is input from the exterior when TM = 0. When TM = 1, STS is generated within the chip if TDRE is cleared while transmission is not in progress) or output from the transmit shift register (SITSR) ends while the SE bit in SICTR is 0, the data in SITDR automatically shifts into SITSR, and then, if TDRE is 0, it is set. At this time, if the transmit-interrupt-enable flag (TIE) is set, the transmit-data-empty interrupt (TDEI) request is also sent to the INTC and the DMAC. If TIE is cleared, this interrupt request is not issued. When SITDR is written by the DMAC, the TDRE flag is automatically cleared. The TDRE flag can be set only by hardware. SITDR is initialized to H'0000 on reset. ### 17.2.5 Serial Control Registers (SICTR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | _ | _ | | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | TM | SE | DL | TIE | RIE | TE | RE | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R/W The 16-bit serial control register (SICTR) specifies parameters for serial port control. SICTR is initialized to H'0000 on reset. Make TE and RE 0 before modifying bits 4, 5 or 6 (TM, SE, DL). Bits 15 to 7—Reserved: These bits always read 0. The write value should always be 0. 586 Bit 6—Transmit Mode Control (TM): Specifies whether the transmit synchronization signal is input from an external source or generated internally by the LSI. When this flag is cleared, the transmit synchronization signal is input on the STS pin. When set, the transmit synch signal is generated by the LSI and output on the STS pin for an external device. This bit does not affect reception. | Bit 6: TM | Description | |-----------|---------------------------------------------------------------------------------------------------| | 0 | Use an external signal input on the STS pin to indicate the start of transmission (initial value) | | 1 | Use an internal signal output on the STS pin to indicate the start of transmission | Bit 5—Synchronization Signal Enable (SE): Specifies whether a synchronization signal is used for all serial data transfers, or just the first transfer. When this bit is cleared, the synchronization signals (SRS, STS) are necessary only for the first data transfer operation and not needed for subsequent data transfers. When this bit is set to 1, a synchronization signal is required for every data transfer operation. | Bit 5: SE | Description Continuous mode; SRS and STS are used for the first data transfer only (initial value) | | |-----------|-----------------------------------------------------------------------------------------------------|--| | 0 | | | | 1 | Interval mode; SRS and STS are used for all data | | Bit 4—Send/Receive Data Length Select (DL): Specifies the transfer data length of the serial I/O. The initial value of this bit is 0, which means 8-bit data length. If 8-bit data length is specified, the lower eight bits of each I/O register are used. | Bit 4: DL | Description | | |-----------|--------------------------------------------|--| | 0 | 8-bit transfer data length (initial value) | | | 1 | 16-bit transfer data length | | Bit 3—Transmit Interrupt Enable (TIE): Enables transmit-data-empty interrupts. The initial value of this bit is 0. | Bit 3: TIE | Description | | |------------|---------------------------------------------|--| | 0 | Disable transmit interrupts (initial value) | | | 1 | Enable transmit interrupts | | Bit 2—Receive Interrupt Enable (RIE): Enables receive-data-full interrupts. The initial value of this bit is 0. | Bit 2: RIE | Description | | | |------------|--------------------------------------------|--|--| | 0 | Disable receive interrupts (initial value) | | | | 1 | Enable receive interrupts | | | Bit 1—Transmit Enable (TE): Enables data transmission. When this flag is cleared, the STxD, STCK and STS pins go to the high-impedance state. | Bit 1: TE | Description | |-----------|---------------------------------------------------------------------------------------------------------| | 0 | Disable transmission and place the STxD, STCK, and STS pins in the high-impedance state (initial value) | | 1 | Enable transmission | Bit 0—Receive Enable (RE): Enables data reception. When this flag is cleared, the SRxD, SRCK, and SRS pins go to the high impedance state. | Bit 0: RE | Description | |-----------|------------------------------------------------------------------------------------------------------| | 0 | Disable reception and place the SRxD, SRCK, and SRS pins in the high-impedance state (initial value) | | 1 | Enable reception | ### 17.2.6 Serial Status Register (SISTR) Note: Only a 0 write is possible to clear the flag. The 16-bit serial status register indicates the status of the serial I/O. SISTR is initialized to H'0002 on reset. Bits 15 to 4—Reserved. These bits always read 0. The write value should always be 0. Bit 3—Transmit Overrun Error (TERR): This flag indicates that a transmit overrun has occurred. | Bit 3: TERR Description | | |-------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | 0 | Transmission is in progress or has ended normally | | | TERR is cleared to 0 (initial value) when: | | | <ul> <li>Software reads TERR after it has been set to 1, then writes 0 in TERR</li> <li>The processor is in reset mode</li> </ul> | | 1 | A transmit overrun error has occurred TERR is set 1 to when data transmission starts while TDRE is 1 | Bit 2—Receive Overrun Error (RERR): This flag indicates that a receive overrun has occurred. | Bit 2: RERR | Description | | |--------------------------------------------------|-----------------------------------------------------------------------------------------------|--| | 0 Reception is in progress or has ended normally | | | | | RERR is cleared to 0 (initial value) when: | | | | <ul> <li>Software reads RERR after it has been set to 1, then writes 0 in<br/>RERR</li> </ul> | | | | The processor is in reset mode | | | 1 | A receive overrun error has occurred | | | | RERR is set to 1 when data reception ends while RDRE is 1 | | Bit 1—Transmit Data Register Empty (TDRE): This flag indicates that the SITDR register is empty, so new data can be entered. | Bit 1: TDRE | Description | | |-------------|-----------------------------------------------------------------------------------------------|--| | 0 | SITDR contains valid transmit data | | | | TDRE is cleared to 0 when: | | | | <ul> <li>Software reads TDRE after it has been set to 1, then writes 0 in<br/>TDRE</li> </ul> | | | | The DMAC writes data to SITDR | | | 1 | SITDR does not contain valid transmit data | | | | TDRE is set to 1 (initial value) when: | | | | <ul> <li>Data is transferred from SITDR to SITSR</li> </ul> | | | | <ul> <li>The TE bit in the serial control register (SICTR) is cleared to 0</li> </ul> | | | | The processor is in reset mode | | Bit 0—Receive Data Register Full (RDRF): This flag indicates that receive data is waiting in SIRDR. | Bit 0: RDRF | Description | | | |-------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | SIRDR does not contain valid receive data | | | | | RDRF is cleared to 0 (initial value) when: | | | | | The DMAC reads data from SIRDR | | | | | <ul> <li>Software reads RDRF after it has been set to 1, then writes 0 in<br/>RDRF. (When the TE bit is 0, TDRE cannot be cleared.)</li> </ul> | | | | | • The RE bit in the serial control register (SICTR) is cleared to 0 | | | | | The processor is in reset mode | | | | 1 | SIRDR contains valid receive data | | | | | RDRF is set to 1 when serial data is received normally and transferred from SIRSR to SIRDR | | | # 17.3 Operation ## 17.3.1 Input Figure 17.2 shows the interval transfer mode (the SE in the SICTR is 1). Figure 17.3 shows the continuous transfer mode (the SE in the SICTR is 0). Figure 17.2 Receive: Interval Transfer Mode Figure 17.3 Receive: Continuous Transfer Mode # 17.3.2 Output Figure 17.4 shows the interval transfer mode (the SE in the SICTR is 1) when TM in the SICTR is 0. Figure 17.5 shows the continuous transfer mode (the SE in the SICTR is 0) when TM in the SICTR is 0. Figure 17.6 shows the interval transfer mode (the SE in the SICTR is 1) when TM in the SICTR is 1. Figure 17.7 shows the continuous transfer mode (the SE in the SICTR is 0) when TM in the SICTR is 1. Figure 17.4 Transmit: Interval Transfer Mode with TM = 0 Figure 17.5 Transmit: Continuous Transfer Mode with TM = 0 Figure 17.6 Transmit: Interval Transfer Mode with TM = 1 Figure 17.7 Transmit: Continuous Transfer Mode with TM = 1 # 17.4 SIO Interrupt Sources and the DMAC The SIO has four interrupt sources for each channel: receive-overrun error (RERI), transmit-overrun error (TERI), receive-data-full (RDFI), and transmit-data-empty (TDEI). Table 17.3 lists the interrupt sources and indicates their priority. The RDFI and TDEI interrupts are enabled by the RIE and TIE bits in SICTR, respectively. The RERI and TERI interrupt requests cannot be disabled. An RDFI interrupt is requested when the RDRF bit in SISTR is set to 1. An RDFI can initiate a direct memory access controller (DMAC) transfer to read SIRDR data. RDRF is automatically cleared to 0 when the DMAC reads the data in SIRDR. A TDEI interrupt is requested when the TDRE bit in SISTR is set to 1. A TDEI can initiate a DMAC transfer to load new data into SITDR. TDRE is automatically cleared to 0 when the DMAC writes the data into SITDR. DMAC performs handling for TDEI interrupt request and RDFI interrupt request, and if the handling is not performed in the interrupt controller, do not make the interrupt controller operate lowering the interrupt priority from SIO. An RERI interrupt is requested when the RERR bit in SISTR is set to 1. A TERI interrupt is requested when the TERR bit in SISTR is set to 1. In the interrupt priority of the channel, as shown in "Chapter 5 Interrupt Controller (INTC)", this is set by the IRPE register.. **Table 17.3 SIO Interrupt Sources** | Interrupt<br>Source | Description | DMAC<br>Activation | Priority | |---------------------|-------------------------------|--------------------|----------| | RERI | Receive overrun error (RERR) | No | High | | TERI | Transmit overrun error (RDRF) | No | _ | | RDFI | Receive data full (RDRF) | Yes | _ | | TDEI | Transmit data empty (TDRE) | Yes | Low | # Section 18 16-Bit Timer Pulse Unit (TPU) #### 18.1 Overview The SH7612 has an on-chip 16-bit timer pulse unit (TPU) that comprises three 16-bit timer channels. #### 18.1.1 Features - Maximum 8-pulse input/output - A total of 8 timer general registers (TGRs) are provided (four for channel 0 and two each for channels 1, and 2), each of which can be set independently as an output compare/input capture register TGRC and TGRD for channel 0 can also be used as buffer registers - Selection of 7 or 8 counter input clocks for each channel - The following operations can be set for each channel: - Waveform output at compare match: Selection of 0, 1, or toggle output - Input capture function: Selection of rising edge, falling edge, or both edge detection - Counter clear operation: Counter clearing possible by compare match or input capture - Synchronous operation: Multiple timer counters (TCNT) can be written to simultaneously Simultaneous clearing by compare match and input capture possible Register simultaneous input/output possible by counter synchronous operation - PWM mode: Any PWM output duty can be set Maximum of 7-phase PWM output possible by combination with synchronous operation - Buffer operation settable for channel 0 - Input capture register double-buffering possible - Automatic rewriting of output compare register possible - Phase counting mode settable independently for each of channels 1, and 2 - Two-phase encoder pulse up/down-count possible - Fast access via internal 16-bit bus - Fast access is possible via a 16-bit bus interface - 13 interrupt sources - For channel 0 four compare match/input capture dual-function interrupts and one overflow interrupt can be requested independently - For channels 1, and 2, two compare match/input capture dual-function interrupts, one overflow interrupt, and one underflow interrupt can be requested independently - Automatic transfer of register data - Block transfer, 1-word data transfer, and 1-byte data transfer possible by data transfer controller (DTC) activation 598 HITACHI Table 18.1 lists the functions of the TPU. **Table 18.1 TPU Functions** | Item | | Channel 0 | Channel 1 | Channel 2 | | | |---------------------------|---------------|--------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------|--|--| | Count cloo | ck | Pφ/1<br>Pφ/4<br>Pφ/16<br>Pφ/64<br>TCLKA<br>TCLKB<br>TCLKC<br>TCLKD | Pø/1<br>Pø/4<br>Pø/16<br>Pø/64<br>Pø/256<br>TCLKA<br>TCLKB | Pø/1<br>Pø/4<br>Pø/16<br>Pø/64<br>Pø/1024<br>TCLKA<br>TCLKB<br>TCLKC | | | | General re | egisters | TGR0A<br>TGR0B | TGR1A<br>TGR1B | TGR2A<br>TGR2B | | | | General re<br>buffer regi | | TGR0C<br>TGR0D | _ | _ | | | | I/O pins | | TIOCA0 TIOCA1 TIOCB0 TIOCB1 TIOCC0 TIOCD0 | | TIOCA2<br>TIOCB2 | | | | Counter cl | lear | TGR compare match or input capture | TGR compare match or input capture | TGR compare match or input capture | | | | Compare match output | 0 output | 0 | 0 | 0 | | | | | 1 output | 0 | 0 | 0 | | | | | Toggle output | 0 | 0 | 0 | | | | Input capture function | | 0 | 0 | 0 | | | | Synchronous operation | | 0 | 0 | 0 | | | | PWM mod | de | 0 | 0 | 0 | | | | Phase cou | unting | _ | 0 | 0 | | | | Buffer ope | eration | 0 | _ | _ | | | | Lagand | | | | _ | | | Legend O : Possible — : Not possible **Table 18.1 TPU Functions (cont)** | Item | Channel 0 | Channel 1 | Channel 2 | | | |-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | DMAC activation | TGR compare match or input capture | TGR compare match or input capture | TGR compare match or input capture | | | | Interrupt sources | <ul> <li>S sources</li> <li>Compare match or input capture 0A</li> <li>Compare match or input capture 0B</li> <li>Compare match or input capture 0C</li> <li>Compare match or input capture 0D</li> <li>Overflow</li> </ul> | <ul> <li>4 sources</li> <li>Compare match or input capture 1A</li> <li>Compare match or input capture 1B</li> <li>Overflow</li> <li>Underflow</li> </ul> | <ul> <li>4 sources</li> <li>Compare match or input capture 2A</li> <li>Compare match or input capture 2B</li> <li>Overflow</li> <li>Underflow</li> </ul> | | | # 18.1.2 Block Diagram Figure 18.1 shows a block diagram of the TPU. Figure 18.1 Block Diagram of TPU # 18.1.3 Pin Configuration Table 18.2 shows the pin configuration of the TPU. Table 18.2 TPU Pins | Channel | Name | Symbol | I/O | Function | |---------|---------------------------------------|--------|-------|--------------------------------------------------------------------------| | All | Clock input A | TCLKA | Input | External clock A input pin (Channel 1 phase counting mode A phase input) | | | Clock input B | TCLKB | Input | External clock B input pin (Channel 1 phase counting mode B phase input) | | | Clock input C | TCLKC | Input | External clock C input pin (Channel 2 phase counting mode A phase input) | | | Clock input D | TCLKD | Input | External clock D input pin (Channel 2 phase counting mode B phase input) | | 0 | Input capture/output compare match A0 | TIOCA0 | I/O | TGR0A input capture input/output compare output/PWM output pin | | | Input capture/output compare match B0 | TIOCB0 | I/O | TGR0B input capture input/output compare output/PWM output pin | | | Input capture/output compare match C0 | TIOCC0 | I/O | TGR0C input capture input/output compare output/PWM output pin | | | Input capture/output compare match D0 | TIOCD0 | I/O | TGR0D input capture input/output compare output/PWM output pin | | 1 | Input capture/output compare match A1 | TIOCA1 | I/O | TGR1A input capture input/output compare output/PWM output pin | | | Input capture/output compare match B1 | TIOCB1 | I/O | TGR1B input capture input/output compare output/PWM output pin | | 2 | Input capture/output compare match A2 | TIOCA2 | I/O | TGR2A input capture input/output compare output/PWM output pin | | | Input capture/output compare match B2 | TIOCB2 | I/O | TGR2B input capture input/output compare output/PWM output pin | 602 HITACHI # 18.1.4 Register Configuration Table 18.3 summarizes the 16-bit timer pulse unit (TPU). **Table 18.3 Register Configuration** | Channel | Name | Abbreviation | R/W | Initial Value | Address | |---------|-----------------------------------|--------------|--------|---------------|------------| | 0 | Timer control register 0 | TCR0 | R/W | H'00 | H'FFFFFC50 | | | Timer mode register 0 | TMDR0 | R/W | H'C0 | H'FFFFFC51 | | | Timer I/O control register 0H | TIOR0H | R/W | H'00 | H'FFFFC52 | | | Timer I/O control register 0L | TIOR0L | R/W | H'00 | H'FFFFFC53 | | | Timer interrupt enable register 0 | TIER0 | R/W | H'40 | H'FFFFFC54 | | | Timer status register 0 | TSR0 | R/(W)* | H'C0 | H'FFFFFC55 | | | Timer counter 0 | TCNT0 | R/W | H'0000 | H'FFFFFC56 | | | Timer general register 0A | TGR0A | R/W | H'FFFF | H'FFFFC58 | | | Timer general register 0B | TGR0B | R/W | H'FFFF | H'FFFFFC5A | | | Timer general register 0C | TGR0C | R/W | H'FFFF | H'FFFFC5C | | | Timer general register 0D | TGR0D | R/W | H'FFFF | H'FFFFC5E | | 1 | Timer control register 1 | TCR1 | R/W | H'00 | H'FFFFFC60 | | | Timer mode register 1 | TMDR1 | R/W | H'C0 | H'FFFFFC61 | | | Timer I/O control register 1 | TIOR1 | R/W | H'00 | H'FFFFC62 | | | Timer interrupt enable register 1 | TIER1 | R/W | H'40 | H'FFFFFC64 | | | Timer status register 1 | TSR1 | R/(W)* | H'C0 | H'FFFFFC65 | | | Timer counter 1 | TCNT1 | R/W | H'0000 | H'FFFFFC66 | | | Timer general register 1A | TGR1A | R/W | H'FFFF | H'FFFFC68 | | | Timer general register 1B | TGR1B | R/W | H'FFFF | H'FFFFFC6A | | 2 | Timer control register 2 | TCR2 | R/W | H'00 | H'FFFFFC70 | | | Timer mode register 2 | TMDR2 | R/W | H'C0 | H'FFFFFC71 | | | Timer I/O control register 2 | TIOR2 | R/W | H'00 | H'FFFFFC72 | | | Timer interrupt enable register 2 | TIER2 | R/W | H'40 | H'FFFFFC74 | | | Timer status register 2 | TSR2 | R/(W)* | H'C0 | H'FFFFFC75 | | | Timer counter 2 | TCNT2 | R/W | H'0000 | H'FFFFFC76 | | | Timer general register 2A | TGR2A | R/W | H'FFFF | H'FFFFFC78 | | | Timer general register 2B | TGR2B | R/W | H'FFFF | H'FFFFFC7A | Table 18.2 TPU Registers (cont) | Channel | Name | Abbreviation | R/W | Initial Value | Address*1 | |---------|------------------------|--------------|-----|---------------|------------| | All | Timer start register | TSTR | R/W | H'00 | H'FFFFFC40 | | | Timer synchro register | TSYR | R/W | H'00 | H'FFFFFC41 | Note: Only 0 can be written to clear flags. # **18.2** Register Descriptions # **18.2.1** Timer Control Register (TCR) Channel 0: TCR0 Channel 1: TCR1 Channel 2: TCR2 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|-------|-------|-------|-------|-------|-------|-------| | | _ | CCLR1 | CCLR0 | CKEG1 | CKEG0 | TPSC2 | TPSC1 | TPSC0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | R/W The TCR registers are 8-bit registers that control the TCNT channels. The TPU has three TCR registers, one for each of channels 0 to 2. The TCR registers are initialized to H'00 by a reset. TCNT operation should be stopped when making TCR settings. 604 HITACHI Bits 7, 6, 5—Counter Clear 2, 1, and 0 (CCLR2, CCLR1, CCLR0): These bits select the TCNT counter clearing source. | Channel | Bit 7:<br>CCLR2 | Bit 6:<br>CCLR1 | Bit 5:<br>CCLR0 | Description | | |---------|---------------------|-------------------|-----------------|---------------------------------------------------------------------------------------------------------|--------------| | 0 | 0 | 0 | 0 | TCNT clearing disabled (In | itial value) | | | | | 1 | TCNT cleared by TGRA compare mate capture | ch/input | | | | 1 | 0 | TCNT cleared by TGRB compare mate capture | ch/input | | | | | 1 | TCNT cleared by counter clearing for a channel performing synchronous clearing/synchronous operation *1 | another | | | 1 | 0 | 0 | TCNT clearing disabled | | | | | | 1 | TCNT cleared by TGRC compare mate capture *2 | ch/input | | | | 1 | 0 | TCNT cleared by TGRD compare mate capture *2 | ch/input | | | | | 1 | TCNT cleared by counter clearing for a channel performing synchronous clearing/synchronous operation *1 | another | | Channel | Bit 7:<br>Reserved* | Bit 6:<br>3 CCLR1 | Bit 5:<br>CCLR0 | Description | | | 1, 2 | 0 | 0 | 0 | TCNT clearing disabled (In | itial value) | | | | | 1 | TCNT cleared by TGRA compare mate capture | ch/input | | | | 1 | 0 | TCNT cleared by TGRB compare mate capture | ch/input | | | | | 1 | TCNT cleared by counter clearing for a channel performing synchronous clear synchronous operation *1 | | Notes: 1. Synchronous operation setting is performed by setting the SYNC bit in TSYR to 1. - 2. When TGRC or TGRD is used as a buffer register, TCNT is not cleared because the buffer register setting has priority, and compare match/input capture does not occur. - 3. Bit 7 is reserved in channels 1 and 2. It is always read as 0 and cannot be modified. Bits 4 and 3—Clock Edge 1 and 0 (CKEG1, CKEG0): These bits select the input clock edge. When a both-edges count is selected, a clock divided by two from the input clock can be selected. (e.g. $P\phi/4$ both edges = $P\phi/2$ rising edge). If phase counting mode is used on channels 1, and 2, this setting is ignored and the phase counting mode setting has priority. | Bit 4: CKEG1 | Bit 3: CKEG0 | Description | | |--------------|--------------|-----------------------|-----------------| | 0 | 0 | Count at rising edge | (Initial value) | | | 1 | Count at falling edge | | | 1 | _ | Count at both edges | | Note: Internal clock edge selection is valid when the input clock is $P\phi/4$ or slower. If $P\phi/1$ is selected for the input clock, this setting is ignored and a rising-edge count is selected. Bits 2, 1, and 0—Time Prescaler 2, 1, and 0 (TPSC2 to TPSC0): These bits select the TCNT counter clock. The clock source can be selected independently for each channel. Table 18.4 shows the clock sources that can be set for each channel. Table 18.4 TPU Clock Sources | | | | Inte | rnal Clo | ck | | Extern | al Clock | | | |---------|------|------|-------|----------|--------|---------|--------|----------|-------|-------| | Channel | Pφ/1 | P¢/4 | Pø/16 | P¢/64 | Pφ/256 | Pφ/1024 | TCLKA | TCLKB | TCLKC | TCLKD | | 0 | 0 | 0 | 0 | 0 | | | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 0 | 0 | | 0 | 0 | | _ | | 2 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | 0 | | Legend: O: Setting Blank: No setting | Bit 2:<br>TPSC2 | Bit 1:<br>TPSC1 | Bit 0:<br>TPSC0 | Description | |-----------------|-----------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | 0 | Internal clock: counts on Po/1 (Initial value) | | | | 1 | Internal clock: counts on P | | | 1 | 0 | Internal clock: counts on P | | | | 1 | Internal clock: counts on P∳/64 | | 1 | 0 | 0 | External clock: counts on TCLKA pin input | | | | 1 | External clock: counts on TCLKB pin input | | | 1 | 0 | External clock: counts on TCLKC pin input | | | | 1 | External clock: counts on TCLKD pin input | | | | TPSC2 TPSC1 0 0 1 | TPSC2 TPSC1 TPSC0 0 0 0 1 0 1 1 0 1 | | Channel | Bit 2:<br>TPSC2 | Bit 1:<br>TPSC1 | Bit 0:<br>TPSC0 | Description | |---------|-----------------|-----------------|-----------------|----------------------------------------------| | 1 | 0 | 0 | 0 | Internal clock: counts on P (Initial value) | | | | | 1 | Internal clock: counts on P | | | | 1 | 0 | Internal clock: counts on Po/16 | | | | | 1 | Internal clock: counts on Po/64 | | | 1 | 0 | 0 | External clock: counts on TCLKA pin input | | | | | 1 | External clock: counts on TCLKB pin input | | | | 1 | 0 | Internal clock: counts on Po/256 | | | | | 1 | Setting prohibited | Note: This setting is ignored when channel 1 is in phase counting mode. | Channel | Bit 2:<br>TPSC2 | Bit 1:<br>TPSC1 | Bit 0:<br>TPSC0 | Description | |---------|-----------------|-----------------|-----------------|------------------------------------------------| | 2 | 0 | 0 | 0 | Internal clock: counts on Pφ/1 (Initial value) | | | | | 1 | Internal clock: counts on P | | | | 1 | 0 | Internal clock: counts on Po/16 | | | | | 1 | Internal clock: counts on Po/64 | | | 1 | 0 | 0 | External clock: counts on TCLKA pin input | | | | | 1 | External clock: counts on TCLKB pin input | | | | 1 | 0 | External clock: counts on TCLKC pin input | | | | | 1 | Internal clock: counts on Po/1024 | Note: This setting is ignored when channel 2 is in phase counting mode. # 18.2.2 Timer Mode Register (TMDR) # Channel 0: TMDR0 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|-----|-----|-----|-----|-----|-----| | | _ | _ | BFB | BFA | MD3 | MD2 | MD1 | MD0 | | Initial value: | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | R/W | R/W | R/W | R/W | R/W | R/W | Channel 1: TMDR1 Channel 2: TMDR2 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|-----|-----|-----|-----| | | _ | _ | _ | _ | MD3 | MD2 | MD1 | MD0 | | Initial value: | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | _ | _ | R/W | R/W | R/W | R/W | The TMDR registers are 8-bit readable/writable registers that are used to set the operating mode for each channel. The TPU has three TMDR registers, one for each channel. The TMDR registers are initialized to H'C0 by a reset. TCNT operation should be stopped when making TMDR settings. Bits 7 and 6—Reserved: Read-only bits, always read as 1. Bit 5—Buffer Operation B (BFB): Specifies whether TGRB is to operate in the normal way, or TGRB and TGRD are to be used together for buffer operation. When TGRD is used as a buffer register, TGRD input capture/output compare is not generated. In channels 1 and 2, which have no TGRD, bit 5 is reserved. It is always read as 0 and cannot be modified. | Bit 5: BFB | Description | | |------------|--------------------------------------------------|-----------------| | 0 | TGRB operates normally | (Initial value) | | 1 | TGRB and TGRD used together for buffer operation | _ | Bit 4—Buffer Operation A (BFA): Specifies whether TGRA is to operate in the normal way, or TGRA and TGRC are to be used together for buffer operation. When TGRC is used as a buffer register, TGRC input capture/output compare is not generated. In channels 1, and 2, which have no TGRC, bit 4 is reserved. It is always read as 0 and cannot be modified. Bit 4: BFA Description 0 TGRA operates normally (Initial value) 1 TGRA and TGRC used together for buffer operation Bits 3 to 0—Modes 3 to 0 (MD3 to MD0): These bits are used to set the timer operating mode. | Bit 3:<br>MD3* <sup>1</sup> | Bit 2:<br>MD2* <sup>2</sup> | Bit 1:<br>MD1 | Bit 0:<br>MD0 | Description | | |-----------------------------|-----------------------------|---------------|---------------|-----------------------|-----------------| | 0 | 0 | 0 | 0 | Normal operation | (Initial value) | | | | | 1 | Reserved | | | | | 1 | 0 | PWM mode 1 | | | | | | 1 | PWM mode 2 | | | | 1 | 0 | 0 | Phase counting mode 1 | | | | | | 1 | Phase counting mode 2 | | | | | 1 | 0 | Phase counting mode 3 | | | | | | 1 | Phase counting mode 4 | | | 1 | * | * | * | <del>-</del> | | \*: Don't care Notes: 1. MD3 is a reserved bit. In a write, it should always be written with 0. Phase counting mode cannot be set for channel 0. In this case, 0 should always be written to MD2. # 18.2.3 Timer I/O Control Register (TIOR) Channel 0: TIOR0H Channel 1: TIOR1 Channel 2: TIOR2 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------|------|------|------|------|------|------| | | IOB3 | IOB2 | IOB1 | IOB0 | IOA3 | IOA2 | IOA1 | IOA0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W #### **Channel 0: TIOR0L** | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|------|------|------|------|------|------|------| | | IOD3 | IOD2 | IOD1 | IOD0 | IOC3 | IOC2 | IOC1 | IOC0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Note: When TGRC or TGRD is designated for buffer operation, this setting is invalid and the register operates as a buffer register. The TIOR registers are 8-bit registers that control the TGR registers. The TPU has four TIOR registers, two for channel 0 and one each for channels 1, and 2. The TIOR registers are initialized to H'00 by a reset. Take note that TIOR is subject to affect by setting TMDR. The initial output designated by TIOR becomes valid under the condition that the counter stopped(cleared CST bit of TSTR to 0). And also, in the case of PWM mode 2, the output is designated at the time of clearing the counter to 0. Bits 7 to 4— I/O Control B3 to B0 (IOB3 to IOB0) I/O Control D3 to D0 (IOD3 to IOD0): Bits IOB3 to IOB0 specify the function of TGRB. Bits IOD3 to IOD0 specify the function of TGRD. #### TIOR0H Bit 7: Bit 6: Bit 5: Bit 4: Channel IOB3 IOB2 IOB1 IOB0 Description | Channel | IOD3 | IUDZ | IODI | IODU | Description | on | | |---------|------|------|------|------|-------------------------------------------|------------------------------------------|--------------------------------| | 0 | 0 | 0 | 0 | 0 | TGR0B is<br>output<br>compare<br>register | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | <del>_</del> | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | _ | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | <del>_</del> | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | 0 | 0 | 0 | TGR0B is input capture register | Capture input<br>source is<br>TIOCB0 pin | Input capture at rising edge | | | | | | 1 | _ | | Input capture at falling edge | | | | | 1 | * | _ | | Input capture at both edges | | | | 1 | * | * | _ | Setting prohibited | | | | | | | | | | | <sup>\*:</sup> Don't care # TIOR0L Bit 7: Bit 6: Bit 5: Bit 4: Channel IOD3 IOD2 IOD1 IOD0 Description | 1 0 1 output 1 0 1 output 1 0 0 1 0 output disabled Initial output is 1 output 0 output 1 0 1 output 1 0 output Toggle match | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------| | Output 1 0 1 Toggle match 1 0 0 Output disabled Initial output is 1 Output output 1 0 Output disabled Initial output is 1 Output output 1 0 Output disabled Initial output is 1 Output Toggle match 1 0 0 OTGROD is Capture input input source is capture TIOCD0 pin | (Initial value) | | Toggle match 1 0 0 1 Output disabled Initial output is 1 0 output output 1 0 1 Toggle match 1 1 Output disabled Initial output is 1 0 output output 1 0 Toggle match 1 0 Toggle match 1 0 Toggle match 1 0 Toggle match 1 O TOGOD is Capture input input source is capture TIOCD0 pin | t at compare match | | Toutput disabled 1 | t at compare match | | 1 0 0 1 TGR0D is Capture input source is capture TIOCD0 pin | output at compare | | output 1 0 1 Toutput Toggle match 1 0 0 TGR0D is Capture input Input calinput source is capture TIOCD0 pin | | | Toggle match 1 0 0 0 TGR0D is Capture input Input cainput source is capture TIOCD0 pin | t at compare match | | match 1 0 0 0 TGR0D is Capture input Input ca input source is capture TIOCD0 pin | t at compare match | | input source is capture TIOCD0 pin | output at compare | | | pture at rising edge | | 1 Input ca | pture at falling edge | | 1 * Input ca | pture at both edges | | 1 * * Seetting prohibited | + D 1 | <sup>\*:</sup> Don't care TIOR1 Bit 7: Bit 6: Bit 5: Bit 4: | Channel | IOB3 | IOB2 | IOB1 | IOB0 | Description | on | | |---------|------|------|------|------|-------------------------------------------|------------------------------------------|--------------------------------| | 1 | 0 | 0 | 0 | 0 | TGR1B is<br>output<br>compare<br>register | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | 0 | 0 | 0 | TGR1B is input capture register | Capture input<br>source is<br>TIOCB1 pin | Input capture at rising edge | | | | | | 1 | | | Input capture at falling edge | | | | | 1 | * | _ | | Input capture at both edges | | | | 1 | * | * | | Setting prohibited | | <sup>\*:</sup> Don't care # TIOR2 Bit 7: Bit 6: Bit 5: Bit 4: | Channel | IOB3 | IOB2 | IOB1 | IOB0 | Description | on | | |---------|------|------|------|------|-------------------------------------------|------------------------------------------|--------------------------------| | 2 | 0 | 0 | 0 | 0 | TGR2B is<br>output<br>compare<br>register | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | <del>_</del> | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | <del>_</del> | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | * | 0 | 0 | TGR2B is input capture register | Capture input<br>source is<br>TIOCB2 pin | Input capture at rising edge | | | | | | 1 | <del>_</del> | | Input capture at falling edge | | | | | 1 | * | <del>_</del> | | Input capture at both edges | <sup>\*:</sup> Don't care Bits 3 to 0— I/O Control A3 to A0 (IOA3 to IOA0) I/O Control C3 to C0 (IOC3 to IOC0): IOA3 to IOA0 specify the function of TGRA. IOC3 to IOC0 specify the function of TGRC. #### TIOR0H Bit 3: Bit 2: Bit 1: Bit 0: Channel IOA3 IOA2 IOA1 IOA0 Description | Chamilei | IOAS | IUAZ | IOAI | IOAU | Description | JII | | |----------|------|------|------|------|----------------------------------|------------------------------------------|--------------------------------| | 0 | 0 | 0 | 0 | 0 | TGR0A is output compare register | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | <del>_</del> | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | 0 | 0 | 0 | TGR0A is input capture register | Capture input<br>source is<br>TIOCA0 pin | Input capture at rising edge | | | | | | 1 | | | Input capture at falling edge | | | | | 1 | * | _ | | Input capture at both edges | | | | 1 | * | * | _ | Setting prohibited | I | | | | | | | | | | <sup>\*:</sup> Don't care # TIOR0L Bit 3: Bit 2: Bit 1: Bit 0: Channel IOC3 IOC2 IOC1 IOC0 Description | Chamilei | 1003 | 1002 | 1001 | 1000 | Description | 711 | | |----------|------|------|------|------|---------------------------------------------|------------------------------------------|--------------------------------| | 0 | 0 | 0 | 0 | 0 | TGR0C is<br>output<br>compare<br>register*1 | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | _ | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | 0 | 0 | 0 | TGR0C is input capture register*1 | Capture input<br>source is<br>TIOCC0 pin | Input capture at rising edge | | | | | | 1 | _ | | Input capture at falling edge | | | | | 1 | * | _ | | Input capture at both edges | | | | 1 | * | * | _ | Setting prohibited | | \*: Don't care Note: \*1. When the BFA bit in TMDR0 is set to 1 and TGR0C is used as a buffer register, this setting is invalid and input capture/output compare is not generated. TIOR1 Bit 3: Bit 2: Bit 1: Bit 0: Channel IOA3 IOA2 IOA1 IOA0 Description | Channel | IOA3 | IOA2 | IOA1 | IOA0 | Description | | | | |---------|------|------|------|------|-------------------------------------------|------------------------------------------|--------------------------------|--| | 1 | 0 | 0 | 0 | 0 | TGR1A is<br>output<br>compare<br>register | Output disabled | (Initial value) | | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | | 1 | _ | | Toggle output at compare match | | | | | 1 | 0 | 0 | _ | Output disabled | | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | 0 | TGR1A is input capture register | Capture input<br>source is<br>TIOCA1 pin | Input capture at rising edge | | | | | | | 1 | _ | | Input capture at falling edge | | | | | | 1 | * | _ | | Input capture at both edges | | | | | 1 | * | * | <u> </u> | Setting prohibited | 1 | | <sup>\*:</sup> Don't care TIOR2 Bit 3: Bit 2: Bit 1: Bit 0: | Channel | IOA3 | IOA2 | IOA1 | IOA0 | Description | |---------|------|------|------|------|-------------| | | | | | | | | • • • • • • • • • • • • • • • • • • • • | | | . • | | | • • • | | |-----------------------------------------|---|---|-----|---|-------------------------------------------|------------------------------------------|--------------------------------| | 2 | 0 | 0 | 0 | 0 | TGR2A is<br>output<br>compare<br>register | Output disabled | (Initial value) | | | | | | 1 | _ | Initial output is 0 output | 0 output at compare match | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | | 1 | 0 | 0 | _ | Output disabled | | | | | | | 1 | _ | Initial output is 1 output | 0 output at compare match | | | | | 1 | 0 | _ | | 1 output at compare match | | | | | | 1 | _ | | Toggle output at compare match | | | 1 | * | 0 | 0 | TGR2A is input capture register | Capture input<br>source is<br>TIOCA2 pin | Input capture at rising edge | | | | | | 1 | _ | | Input capture at falling edge | | | | | 1 | * | _ | | Input capture at both edges | <sup>\*:</sup> Don't care # 18.2.4 Timer Interrupt Enable Register (TIER) # Channel 0: TIER0 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|-------|-------|-------|-------|-------| | | _ | _ | _ | TCIEV | TGIED | TGIEC | TGIEB | TGIEA | | Initial value: | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | _ | R/W | R/W | R/W | R/W | R/W | 618 HITACHI # Channel 1: TIER1 Channel 2: TIER2 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|-------|-------|---|---|-------|-------| | | _ | _ | TCIEU | TCIEV | _ | _ | TGIEB | TGIEA | | Initial value: | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | R/W | R/W | _ | _ | R/W | R/W | The TIER registers are 8-bit registers that control enabling or disabling of interrupt requests for each channel. The TPU has three TIER registers, one for each channel. The TIER registers are initialized to H'40 by a reset. Bit 7—Reserved: This bit always reads 0. The write value should always be 0. Bit 6—Reserved: Read-only bit, always read as 1. Bit 5—Underflow Interrupt Enable (TCIEU): Enables or disables interrupt requests (TCIU) by the TCFU flag when the TCFU flag in TSR is set to 1 in channels 1 and 2. In channel 0 bit 5 is reserved. It is always read as 0 and cannot be modified. | Bit 5: TCIEU | Description | | |--------------|--------------------------------------------|-----------------| | 0 | Interrupt requests (TCIU) by TCFU disabled | (Initial value) | | 1 | Interrupt requests (TCIU) by TCFU enabled | | Bit 4—Overflow Interrupt Enable (TCIEV): Enables or disables interrupt requests (TCIV) by the TCFV flag when the TCFV flag in TSR is set to 1. | Bit 4: TCIEV | Description | | |--------------|--------------------------------------------|-----------------| | 0 | Interrupt requests (TCIV) by TCFV disabled | (Initial value) | | 1 | Interrupt requests (TCIV) by TCFV enabled | | Bit 3—TGR Interrupt Enable D (TGIED): Enables or disables interrupt requests (TGID) by the TGFD bit when the TGFD bit in TSR is set to 1 in channel 0. In channels 1, and 2, bit 3 is reserved. It is always read as 0 and cannot be modified. | Bit 3: TGIED | Description | | |--------------|------------------------------------------------|-----------------| | 0 | Interrupt requests (TGID) by TGFD bit disabled | (Initial value) | | 1 | Interrupt requests (TGID) by TGFD bit enabled | | Bit 2—TGR Interrupt Enable C (TGIEC): Enables or disables interrupt requests (TGIC) by the TGFC bit when the TGFC bit in TSR is set to 1 in channel 0. In channels 1, and 2, bit 2 is reserved. It is always read as 0 and cannot be modified. | Bit 2: TGIEC | Description | | |--------------|------------------------------------------------|-----------------| | 0 | Interrupt requests (TGIC) by TGFC bit disabled | (Initial value) | | 1 | Interrupt requests (TGIC) by TGFC bit enabled | | Bit 1—TGR Interrupt Enable B (TGIEB): Enables or disables interrupt requests (TGIB) by the TGFB bit when the TGFB bit in TSR is set to 1. | Bit 1: TGIEB | Description | | |--------------|------------------------------------------------|-----------------| | 0 | Interrupt requests (TGIB) by TGFB bit disabled | (Initial value) | | 1 | Interrupt requests (TGIB) by TGFB bit enabled | | Bit 0—TGR Interrupt Enable A (TGIEA): Enables or disables interrupt requests (TGIA) by the TGFA bit when the TGFA bit in TSR is set to 1. | Bit 0: TGIEA | Description | | |--------------|------------------------------------------------|-----------------| | 0 | Interrupt requests (TGIA) by TGFA bit disabled | (Initial value) | | 1 | Interrupt requests (TGIA) by TGFA bit enabled | | # 18.2.5 Timer Status Register (TSR) # Channel 0: TSR0 Note: \* Can only be written with 0 for flag clearing. Channel 1: TSR1 Channel 2: TSR2 | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|------|---|--------|--------|---|---|--------|--------| | | TCFD | _ | TCFU | TCFV | _ | _ | TGFB | TGFA | | Initial value: | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | _ | R/(W)* | R/(W)* | _ | _ | R/(W)* | R/(W)* | Note: \* Can only be written with 0 for flag clearing. The TSR registers are 8-bit registers that indicate the status of each channel. The TPU has three TSR registers, one for each channel. The TSR registers are initialized to H'C0 by a reset. Bit 7—Count Direction Flag (TCFD): Status flag that shows the direction in which TCNT counts in channels 1, and 2. In channel 0 bit 7 is reserved. It is always read as 1 and cannot be modified. | Bit 7: TCFD | Description | | |-------------|------------------|-----------------| | 0 | TCNT counts down | | | 1 | TCNT counts up | (Initial value) | Bit 6—Reserved: Read-only bit, always read as 1 and cannot be modified. Bit 5—Underflow Flag (TCFU): Status flag that indicates that TCNT underflow has occurred when channels 1 and 2 are set to phase counting mode. In channel 0 bit 5 is reserved. It is always read as 0 and cannot be modified. | Bit 5: TCFU | Description | | |-------------|-------------------------------------------------------------------------------|-----------------| | 0 | [Clearing condition] When 0 is written to TCFU after reading TCFU = 1 | (Initial value) | | 1 | [Setting condition] When the TCNT value underflows (changes from H'0000 to H' | FFFF) | Bit 4—Overflow Flag (TCFV): Status flag that indicates that TCNT overflow has occurred. | Bit 4: TCFV | Description | | |-------------|----------------------------------------------------------|-----------------| | 0 | [Clearing condition] | (Initial value) | | | When 0 is written to TCFV after reading TCFV = 1 | | | 1 | [Setting condition] | | | | When the TCNT value overflows (changes from H'FFFF to H' | 0000) | Bit 3—Input Capture/Output Compare Flag D (TGFD): Status flag that indicates the occurrence of TGRD input capture or compare match in channel 0. In channels 1, and 2, bit 3 is reserved. It is always read as 0 and cannot be modified. | Bit 3: TGFD | Description | | |-------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------| | 0 | [Clearing conditions] | (Initial value) | | | <ul> <li>When DMAC is activated by TGID interrupt while DMAC's<br/>TGIOD</li> </ul> | DRCR setting is | | | <ul> <li>When 0 is written to TGFD after reading TGFD = 1</li> </ul> | | | 1 | [Setting conditions] | | | | <ul> <li>When TCNT = TGRD while TGRD is functioning as output<br/>register</li> </ul> | t compare | | | <ul> <li>When TCNT value is transferred to TGRD by input capture<br/>TGRD is functioning as input capture register</li> </ul> | e signal while | Bit 2—Input Capture/Output Compare Flag C (TGFC): Status flag that indicates the occurrence of TGRC input capture or compare match in channel 0. In channels 1, and 2, bit 2 is reserved. It is always read as 0 and cannot be modified. | Bit 2: TGFC | Description | | |-------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------| | 0 | [Clearing conditions] (Initial va | alue) | | | <ul> <li>When DMAC is activated by TGIC interrupt while DMAC's DRCR settlement</li> <li>TGIOC</li> </ul> | ing is | | | <ul> <li>When 0 is written to TGFC after reading TGFC = 1</li> </ul> | | | 1 | [Setting conditions] | | | | <ul> <li>When TCNT = TGRC while TGRC is functioning as output compare<br/>register</li> </ul> | | | | <ul> <li>When TCNT value is transferred to TGRC by input capture signal while<br/>TGRC is functioning as input capture register</li> </ul> | le | Bit 1—Input Capture/Output Compare Flag B (TGFB): Status flag that indicates the occurrence of TGRB input capture or compare match. | Bit 1: TGFB | Description | | |-------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------| | 0 | [Clearing conditions] (Initial v | alue) | | | <ul> <li>When DMAC is activated by TGIB interrupt while DMAC's DRCR se<br/>TGI0B</li> </ul> | etting is | | | <ul> <li>When 0 is written to TGFB after reading TGFB = 1</li> </ul> | | | 1 | [Setting conditions] | | | | <ul> <li>When TCNT = TGRB while TGRB is functioning as output compare<br/>register</li> </ul> | | | | <ul> <li>When TCNT value is transferred to TGRB by input capture signal w<br/>TGRB is functioning as input capture register</li> </ul> | hile | Bit 0—Input Capture/Output Compare Flag A (TGFA): Status flag that indicates the occurrence of TGRA input capture or compare match. | Bit 0: TGFA | Description | | | | | | |-------------|---------------------------------------------------------------------------------------------------------------------------|-----------------|--|--|--|--| | 0 | [Clearing conditions] | (Initial value) | | | | | | | <ul> <li>When DMAC is activated by TGIA interrupt while DMAC's DRCR setting is<br/>TGI0A</li> </ul> | | | | | | | | <ul> <li>When 0 is written to TGFA after reading TGFA = 1</li> </ul> | | | | | | | 1 | [Setting conditions] | | | | | | | | <ul> <li>When TCNT = TGRA while TGRA is functioning as output<br/>register</li> </ul> | ut compare | | | | | | | <ul> <li>When TCNT value is transferred to TGRA by input capture TGRA is functioning as input capture register</li> </ul> | re signal while | | | | | # 18.2.6 Timer Counter (TCNT) Channel 0: TCNT0 (up-counter) Channel 1: TCNT1 (up/down-counter\*) Channel 2: TCNT2 (up/down-counter\*) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|-----|-----|-----|-----| | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | | | | | | | | | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Note: These counters can be used as up/down-counters only in phase counting mode. In other cases they function as up-counters. The TCNT registers are 16-bit counters. The TPU has three TCNT counters, one for each channel. The TCNT counters are initialized to H'0000 by a reset. The TCNT counters cannot be accessed in 8-bit units; they must always be accessed as a 16-bit unit. #### **18.2.7** Timer General Register (TGR) The TGR registers are 16-bit registers with a dual function as output compare and input capture registers. The TPU has 8 TGR registers, four for channel 0 and two each for channels 1, and 2. TGRC and TGRD for channel 0 can also be designated for operation as buffer registers\*. The TGR registers are initialized to H'FFFF by a reset. The TGR registers cannot be accessed in 8-bit units; they must always be accessed as a 16-bit unit. Note: \* TGR buffer register combinations are TGRA-TGRC and TGRB-TGRD. #### 18.2.8 Timer Start Register (TSTR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|------|------|------| | Bit name: | | _ | _ | _ | _ | CST2 | CST1 | CST0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | _ | _ | | R/W | R/W | R/W | TSTR is an 8-bit readable/writable register that selects operation/stoppage for channels 0 to 2. TSTR is initialized to H'00 by a reset. TCNT counter operation should be stopped when setting the operating mode in TMDR or the TCNT count clock in TCR. Bits 7 to 3—Reserved: Should always be written with 0. Bits 2 to 0—Counter Start 2 to 0 (CST2 to CST0): These bits select operation or stoppage for TCNT. | Bit n: CSTn | Description | | |-------------|----------------------------------|-----------------| | 0 | TCNTn count operation is stopped | (Initial value) | | 1 | TCNTn performs count operation | | | - | | n = 2 to 0 | Note: If 0 is written to the CST bit during operation with the TIOC pin designated for output, the counter stops but the TIOC pin output compare output level is retained. If TIOR is written to when the CST bit is cleared to 0, the pin output level will be changed to the set initial output value. # 18.2.9 Timer Synchro Register (TSYR) | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|-------|-------|-------| | Bit name: | | _ | _ | _ | _ | SYNC2 | SYNC1 | SYNC0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | _ | _ | _ | _ | _ | R/W | R/W | R/W | TSYR is an 8-bit readable/writable register that selects independent operation or synchronous operation for the channel 0 to 2 TCNT counters. A channel performs synchronous operation when the corresponding bit in TSYR is set to 1. TSYR is initialized to H'00 by a reset. Bits 7 to 3—Reserved: Should always be written with 0. Bits 2 to 0—Timer Synchro 2 to 0 (SYNC2 to SYNC0): These bits select whether operation is independent of or synchronized with other channels. When synchronous operation is selected, synchronous presetting of multiple channels\*<sup>1</sup>, and synchronous clearing through counter clearing on another channel\*<sup>2</sup> are possible. | Bit n: SYNCn | Description | | |--------------|------------------------------------------------------------------------------|-------------------------------| | 0 | TCNTn operates independently (TCNT presetting/clearing is ur other channels) | related to<br>(Initial value) | | 1 | TCNTn performs synchronous operation | | | | TCNT synchronous presetting/synchronous clearing is possible | ) | | | | - 04-0 | Notes: \*1. To set synchronous operation, the SYNC bits for at least two channels must be set to 1. <sup>\*2.</sup> To set synchronous clearing, in addition to the SYNC bit , the TCNT clearing source must also be set by means of bits CCLR2 to CCLR0 in TCR. #### 18.3 Interface to Bus Master #### **18.3.1 16-Bit Registers** TCNT and TGR are 16-bit registers. As the data bus to the bus master is 16 bits wide, these registers can be read and written to in 16-bit units. These registers cannot be read or written to in 8-bit units; 16-bit access must always be used. An example of 16-bit register access operation is shown in figure 18.2. Figure 18.2 Example of 16-Bit Register Access Operation [Bus Master ↔ TCNT (16 Bits)] # 18.3.2 8-Bit Registers Registers other than TCNT and TGR are 8-bit. As the data bus to the CPU is 16 bits wide, these registers can be read and written to in 16-bit units. They can also be read and written to in 8-bit units. 628 HITACHI Examples of 8-bit register access operation are shown in figures 18.3, 18.4, and 18.5. Figure 18.3 Example of 8-Bit Register Access Operation [Bus Master ↔ TCR (Upper 8 Bits)] Figure 18.4 Example of 8-Bit Register Access Operation [Bus Master $\leftrightarrow$ TMDR (Lower 8 Bits)] Figure 18.5 Example of 8-Bit Register Access Operation [Bus Master ↔ TCR and TMDR (16 Bits)] # 18.4 Operation #### 18.4.1 Overview Operation in each mode is outlined below. **Normal Operation:** Each channel has a TCNT and TGR register. TCNT performs up-counting, and is also capable of free-running operation, synchronous counting, and external event counting. Each TGR can be used as an input capture register or output compare register. **Synchronous Operation:** When synchronous operation is designated for a channel, TCNT for that channel performs synchronous presetting. That is, when TCNT for a channel designated for synchronous operation is rewritten, the TCNT counters for the other channels are also rewritten at the same time. Synchronous clearing of the TCNT counters is also possible by setting the timer synchronization bits in TSYR for channels designated for synchronous operation. #### **Buffer Operation** - When TGR is an output compare register When a compare match occurs, the value in the buffer register for the relevant channel is transferred to TGR. - When TGR is an input capture register When input capture occurs, the value in TCNT is transfer to TGR and the value previously held in TGR is transferred to the buffer register. **PWM Mode:** In this mode, a PWM waveform is output. The output level can be set by means of TIOR. A PWM waveform with a duty of between 0% and 100% can be output, according to the setting of each TGR register. **Phase Counting Mode:** In this mode, TCNT is incremented or decremented by detecting the phases of two clocks input from the external clock input pins in channels 1, and 2. When phase counting mode is set, the corresponding TCLK pin functions as the clock pin, and TCNT performs up- or down-counting. This can be used for two-phase encoder pulse input. #### 18.4.2 Basic Functions **Counter Operation:** When one of bits CST0 to CST2 is set to 1 in TSTR, the TCNT counter for the corresponding channel starts counting. TCNT can operate as a free-running counter, periodic counter, and so on. Example of count operation setting procedure Figure 18.6 shows an example of the count operation setting procedure. Figure 18.6 Example of Counter Operation Setting Procedure Free-running count operation and periodic count operation Immediately after a reset, the TPU's TCNT counters are all designated as free-running counters. When the relevant bit in TSTR is set to 1 the corresponding TCNT counter starts up-count operation as a free-running counter. When TCNT overflows (from H'FFFF to H'0000), the TCFV bit in TSR is set to 1. If the value of the corresponding TCIEV bit in TIER is 1 at this point, the TPU requests an interrupt. After overflow, TCNT starts counting up again from H'0000. Figure 18.7 illustrates free-running counter operation. Figure 18.7 Free-Running Counter Operation When compare match is selected as the TCNT clearing source, the TCNT counter for the relevant channel performs periodic count operation. The TGR register for setting the period is designated as an output compare register, and counter clearing by compare match is selected by means of bits CCLR2 to CCLR0 in TCR. After the settings have been made, TCNT starts up-count operation as periodic counter when the corresponding bit in TSTR is set to 1. When the count value matches the value in TGR, the TGF bit in TSR is set to 1 and TCNT is cleared to H'0000. If the value of the corresponding TGIE bit in TIER is 1 at this point, the TPU requests an interrupt. After a compare match, TCNT starts counting up again from H'0000. Figure 18.8 illustrates periodic counter operation. Figure 18.8 Periodic Counter Operation **Waveform Output by Compare Match:** The TPU can perform 0, 1, or toggle output from the corresponding output pin using compare match. • Example of setting procedure for waveform output by compare match Figure 18.9 shows an example of the setting procedure for waveform output by compare match Figure 18.9 Example of Setting Procedure for Waveform Output by Compare Match Examples of waveform output operation Figure 18.10 shows an example of 0 output/1 output. In this example TCNT has been designated as a free-running counter, and settings have been made so that 1 is output by compare match A, and 0 is output by compare match B. When the set level and the pin level coincide, the pin level does not change. Figure 18.10 Example of 0 Output/1 Output Operation Figure 18.11 shows an example of toggle output. In this example TCNT has been designated as a periodic counter (with counter clearing performed by compare match B), and settings have been made so that output is toggled by both compare match A and compare match B. Figure 18.11 Example of Toggle Output Operation **Input Capture Function:** The TCNT value can be transferred to TGR on detection of the TIOC pin input edge. Rising edge, falling edge, or both edges can be selected as the detected edge. • Example of input capture operation setting procedure Figure 18.12 shows an example of the input capture operation setting procedure. Figure 18.12 Example of Input Capture Operation Setting Procedure • Example of input capture operation Figure 18.13 shows an example of input capture operation. In this example both rising and falling edges have been selected as the TIOCA pin input capture input edge, falling edge has been selected as the TIOCB pin input capture input edge, and counter clearing by TGRB input capture has been designated for TCNT. Figure 18.13 Example of Input Capture Operation #### 18.4.3 Synchronous Operation In synchronous operation, the values in a number of TCNT counters can be rewritten simultaneously (synchronous presetting). Also, a number of TCNT counters can be cleared simultaneously by making the appropriate setting in TCR (synchronous clearing). Synchronous operation enables TGR to be incremented with respect to a single time base. Channels 0 to 2 can all be designated for synchronous operation. **Example of Synchronous Operation Setting Procedure:** Figure 18.14 shows an example of the synchronous operation setting procedure. Figure 18.14 Example of Synchronous Operation Setting Procedure **Example of Synchronous Operation:** Figure 18.15 shows an example of synchronous operation. In this example, synchronous operation and PWM mode 1 have been designated for channels 0 to 2, TGR0B compare match has been set as the channel 0 counter clearing source, and synchronous clearing has been set for the channel 1 and 2 counter clearing source. Three-phase PWM waveforms are output from pins TIOC0A, TIOC1A, and TIOC2A. At this time, synchronous presetting, and synchronous clearing by TGR0B compare match, is performed for channel 0 to 2 TCNT counters, and the data set in TGR0B is used as the PWM cycle. For details of PWM modes, see section 18.4.5, PWM Modes. Figure 18.15 Example of Synchronous Operation ### 18.4.4 Buffer Operation Buffer operation, provided for channel 0 enables TGRC and TGRD to be used as buffer registers. Buffer operation differs depending on whether TGR has been designated as an input capture register or as a compare match register. Table 18.5 shows the register combinations used in buffer operation. **Table 18.5 Register Combinations in Buffer Operation** | Channel | Timer General Register | Buffer Register | |---------|------------------------|-----------------| | 0 | TGR0A | TGR0C | | | TGR0B | TGR0D | • When TGR is an output compare register When a compare match occurs, the value in the buffer register for the corresponding channel is transferred to the timer general register. This operation is illustrated in figure 18.16. Figure 18.16 Compare Match Buffer Operation • When TGR is an input capture register When input capture occurs, the value in TCNT is transferred to TGR and the value previously held in the timer general register is transferred to the buffer register. This operation is illustrated in figure 18.17. Figure 18.17 Input Capture Buffer Operation **Example of Buffer Operation Setting Procedure:** Figure 18.18 shows an example of the buffer operation setting procedure. Figure 18.18 Example of Buffer Operation Setting Procedure #### **Examples of Buffer Operation** • When TGR is an output compare register Figure 18.19 shows an operation example in which PWM mode 1 has been designated for channel 0, and buffer operation has been designated for TGRA and TGRC. The settings used in this example are TCNT clearing by compare match B, 1 output at compare match A, and 0 output at compare match B. As buffer operation has been set, when compare match A occurs the output changes and the value in buffer register TGRC is simultaneously transferred to timer general register TGRA. This operation is repeated each time compare match A occurs. For details of PWM modes, see section 18.4.5, PWM Modes. Figure 18.19 Example of Buffer Operation (1) • When TGR is an input capture register Figure 18.20 shows an operation example in which TGRA has been designated as an input capture register, and buffer operation has been designated for TGRA and TGRC. Counter clearing by TGRA input capture has been set for TCNT, and both rising and falling edges have been selected as the TIOCA pin input capture input edge. As buffer operation has been set, when the TCNT value is stored in TGRA upon occurrence of input capture A, the value previously stored in TGRA is simultaneously transferred to TGRC. Figure 18.20 Example of Buffer Operation (2) ### **18.4.5 PWM Modes** In PWM mode, PWM waveforms are output from the output pins. 0, 1, or toggle output can be selected as the output level in response to compare match of each TGR. Designating TGR compare match as the counter clearing source enables the period to be set in that register. All channels can be designated for PWM mode independently. Synchronous operation is also possible. There are two PWM modes, as described below. #### • PWM mode 1 The PWM output is generated from TIOCA, TIOCC terminals using TGRA and TGRB, TGRC and TGRD with pair. The output which designated with IOA3-IOA0, IOC3-IOC0 bits of TIOR by compare match A,C from TIOCA, TIOCC terminals and the output which designated with IOB3-IOB0, IOD3-IOD0 bits of TIOR by compare match B, D are executed. The initial output value becomes the set value at TGRA, TGRC. If the setting value of TGR using with pare is same, even though the compare match occurs, the output value does not change. In PWM mode 1, the maximum 4th phase PWM output is possible. #### • PWM mode 2 The PWM output is generated using 1 piece in the cycle register of TGR and usingother TGR in the duty register. The designated output in TIOR is executed by the compare match. And also, the initial value set by TIOR is output in each terminal output value with clear of the counter by the compare match of the synchronous register. If the setting value of the cycle register and the duty register is same, even though the compare match occurs, the output value does not change. In PWM mode 2, the maximum 7th phase PWM output is possible by using synchronousoperation in common. The correspondence between PWM output pins and registers is shown in table 18.6. Table 18.6 PWM Output Registers and Output Pins | | | Output Pins | | | |---------|-----------|-------------|------------|--| | Channel | Registers | PWM Mode 1 | PWM Mode 2 | | | 0 | TGR0A | TIOCA0 | TIOCA0 | | | | TGR0B | | TIOCB0 | | | | TGR0C | TIOCC0 | TIOCC0 | | | | TGR0D | | TIOCD0 | | | 1 | TGR1A | TIOCA1 | TIOCA1 | | | | TGR1B | | TIOCB1 | | | 2 | TGR2A | TIOCA2 | TIOCA2 | | | | TGR2B | | TIOCB2 | | Note: In PWM mode 2, PWM output is not possible for the TGR register in which the period is set. **Example of PWM Mode Setting Procedure:** Figure 18.21 shows an example of the PWM mode setting procedure. Figure 18.21 Example of PWM Mode Setting Procedure **Examples of PWM Mode Operation:** Figure 18.22 shows an example of PWM mode 1 operation. In this example, TGRA compare match is set as the TCNT clearing source, 0 is set for the TGRA initial output value and output value, and 1 output is set as the TGRB output value. In this case, the value set in TGRA is used as the period, and the values set in TGRB registers as the duty. Figure 18.22 Example of PWM Mode Operation (1) Figure 18.23 shows an example of PWM mode 2 operation. In this example, synchronous operation is designated for channels 0 and 1, TGR1B compare match is set as the TCNT clearing source, and 0 is set for the initial output value and 1 for the output value of the other TGR registers, to output a 5-phase PWM waveform. In this case, the value set in TGR1B is used as the cycle, and the values set in the other TGRs as the duty. Figure 18.23 Example of PWM Mode Operation (2) Figure 18.24 shows examples of PWM waveform output with 0% duty and 100% duty in PWM mode. Figure 18.24 Example of PWM Mode Operation (3) ### 18.4.6 Phase Counting Mode In phase counting mode, the phase difference between two external clock inputs is detected and TCNT is incremented/decremented accordingly. This mode can be set for channels 1, and 2. When phase counting mode is set, an external clock is selected as the counter input clock and TCNT operates as an up/down-counter regardless of the setting of bits TPSC2 to TPSC0 and bits CKEG1 and CKEG0 in TCR. However, the functions of bits CCLR1 and CCLR0 in TCR, and of TIOR, TIER, and TGR are valid, and input capture/compare match and interrupt functions can be used. When overflow occurs while TCNT is counting up, the TCFV flag in TSR is set; when underflow occurs while TCNT is counting down, the TCFU flag is set. The TCFD bit in TSR is the count direction flag. Reading the TCFD flag provides an indication of whether TCNT is counting up or down. Table 18.7 shows the correspondence between external clock pins and channels. **Table 18.7 Phase Counting Mode Clock Input Pins** | | External Clock Pins | | | |----------------------------------------------|---------------------|---------|---| | Channels | A-Phase | B-Phase | _ | | When channel 1 is set to phase counting mode | TCLKA | TCLKB | _ | | When channel 2 is set to phase counting mode | TCLKC | TCLKD | _ | **Example of Phase Counting Mode Setting Procedure:** Figure 18.25 shows an example of the phase counting mode setting procedure. Figure 18.25 Example of Phase Counting Mode Setting Procedure **Examples of Phase Counting Mode Operation:** In phase counting mode, TCNT counts up or down according to the phase difference between two external clocks. There are four modes, according to the count conditions. ## • Phase counting mode 1 Figure 18.26 shows an example of phase counting mode 1 operation, and table 18.8 summarizes the TCNT up/down-count conditions. Figure 18.26 Example of Phase Counting Mode 1 Operation Table 18.8 Up/Down-Count Conditions in Phase Counting Mode 1 | TCLKA (Channel 1) TCLKC (Channel 2) | TCLKB (Channel 1) TCLKD (Channel 2) | Operation | |-------------------------------------|-------------------------------------|------------| | High level | | Up-count | | Low level | 7_ | | | <u></u> | Low level | | | 7_ | High level | | | High level | 7_ | Down-count | | Low level | | | | | High level | | | 7_ | Low level | | ## Legend ## • Phase counting mode 2 Figure 18.27 shows an example of phase counting mode 2 operation, and table 18.9 summarizes the TCNT up/down-count conditions. Figure 18.27 Example of Phase Counting Mode 2 Operation Table 18.9 Up/Down-Count Conditions in Phase Counting Mode 2 | TCLKA (Channel 1) TCLKC (Channel 2) | TCLKB (Channel 1) TCLKD (Channel 2) | Operation | |-------------------------------------|-------------------------------------|------------| | High level | | Don't care | | Low level | Ŧ_ | Don't care | | <u></u> | Low level | Don't care | | 7_ | High level | Up-count | | High level | Ŧ. | Don't care | | Low level | <u></u> | Don't care | | | High level | Don't care | | 7_ | Low level | Down-count | ## Legend \_ ∃ : Rising edge¬ ∃ : Falling edge ## • Phase counting mode 3 Figure 18.28 shows an example of phase counting mode 3 operation, and table 18.10 summarizes the TCNT up/down-count conditions. Figure 18.28 Example of Phase Counting Mode 3 Operation Table 18.10 Up/Down-Count Conditions in Phase Counting Mode 3 | TCLKA (Channel 1) TCLKC (Channel 2) | TCLKB (Channel 1) TCLKD (Channel 2) | Operation | |-------------------------------------|-------------------------------------|------------| | High level | | Don't care | | Low level | 7_ | Don't care | | | Low level | Don't care | | 7_ | High level | Up-count | | High level | Ŧ_ | Down-count | | Low level | | Don't care | | <u>_</u> | High level | Don't care | | Z | Low level | Don't care | ## Legend \_ : Rising edge¬ : Falling edge ## • Phase counting mode 4 Figure 18.29 shows an example of phase counting mode 4 operation, and table 18.11 summarizes the TCNT up/down-count conditions. Figure 18.29 Example of Phase Counting Mode 4 Operation Table 18.11 Up/Down-Count Conditions in Phase Counting Mode 4 | TCLKA (Channel 1) TCLKC (Channel 2) | TCLKB (Channel 1) TCLKD (Channel 2) | Operation | |-------------------------------------|-------------------------------------|------------| | High level | | Up-count | | Low level | 7_ | | | <u></u> | Low level | Don't care | | 7_ | High level | | | High level | 7_ | Down-count | | Low level | | | | <u></u> | High level | Don't care | | 7_ | Low level | | Legend # 18.5 Interrupts # 18.5.1 Interrupt Sources and Priorities There are three kinds of TPU interrupt source: TGR input capture/compare match, TCNT overflow, and TCNT underflow. Each interrupt source has its own status flag and enable/disabled bit, allowing generation of interrupt request signals to be enabled or disabled individually. When an interrupt request is generated, the corresponding status flag in TSR is set to 1. If the corresponding enable/disable bit in TIER is set to 1 at this time, an interrupt is requested. The interrupt request is cleared by clearing the status flag to 0. Relative channel priorities can be changed by the interrupt controller, but the priority order within a channel is fixed. For details, see section 5, Interrupt Controller (INTC). Table 18.12 lists the TPU interrupt sources. **Table 18.12 TPU Interrupts** | Channel | Interrupt<br>Source | Description | DTC<br>Activation | Priority | |---------|---------------------|-----------------------------------|-------------------|----------| | 0 | TGI0A | TGR0A input capture/compare match | Possible | High | | | TGI0B | TGR0B input capture/compare match | Possible | | | | TGI0C | TGR0C input capture/compare match | Possible | _ | | | TGI0D | TGR0D input capture/compare match | Possible | _ | | | TCI0V | TCNT0 input capture/compare match | Not possible | _ | | 1 | TGI1A | TGR1A input capture/compare match | Not possible | _ | | | TGI1B | TGR1B input capture/compare match | Not possible | _ | | | TCI1V | TCNT1 overflow | Not possible | _ | | | TCI1U | TCNT1 underflow | Not possible | _ | | 2 | TGI2A | TGR2A input capture/compare match | Not possible | _ | | | TGI2B | TGR2B input capture/compare match | Not possible | _ | | | TCI2V | TCNT2 overflow | Not possible | _ + | | | TCI2U | TCNT2 underflow | Not possible | Low | Note: This table shows the initial state immediately after a reset. The relative channel priorities can be changed by the interrupt controller. **Input Capture/Compare Match Interrupt:** An interrupt is requested if the TGIE bit in TIER is set to 1 when the TGF flag in TSR is set to 1 by the occurrence of a TGR input capture/compare match on a particular channel. The interrupt request is cleared by clearing the TGF flag to 0. The TPU has 8 input capture/compare match interrupts, four for channel 0, and two each for channels 1, and 2. **Overflow Interrupt:** An interrupt is requested if the TCIEV bit in TIER is set to 1 when the TCFV flag in TSR is set to 1 by the occurrence of TCNT overflow on a particular channel. The interrupt request is cleared by clearing the TCFV flag to 0. The TPU has three overflow interrupts, one for each channel. **Underflow Interrupt:** An interrupt is requested if the TCIEU bit in TIER is set to 1 when the TCFU flag in TSR is set to 1 by the occurrence of TCNT underflow on channel. The interrupt request is cleared by clearing the TCFU flag to 0. The TPU has two underflow interrupts, one each for channels 1, and 2. #### 18.5.2 DMAC Activation **DMAC Activation:** The DTC can be activated by the TGR input capture/compare match interrupt for a channel. For details, see section 9, Data Transfer Controller (DMAC). A total of four TPU input capture/compare match interrupts can be used as DMAC activation sources for channel 0. # **18.6** Operation Timing ### 18.6.1 Input/Output Timing **TCNT Count Timing:** Figure 18.30 shows TCNT count timing in internal clock operation, and figure 18.31 shows TCNT count timing in external clock operation. Figure 18.30 Count Timing in Internal Clock Operation Figure 18.31 Count Timing in External Clock Operation **Output Compare Output Timing:** A compare match signal is generated in the final state in which TCNT and TGR match (the point at which the count value matched by TCNT is updated). When a compare match signal is generated, the output value set in TIOR is output at the output compare output pin (TIOC pin). After a match between TCNT and TGR, the compare match signal is not generated until the TCNT input clock is generated. Figure 18.32 shows output compare output timing. Figure 18.32 Output Compare Output Timing **Input Capture Signal Timing:** Figure 18.33 shows input capture signal timing. Figure 18.33 Input Capture Input Signal Timing **Timing for Counter Clearing by Compare Match/Input Capture:** Figure 18.34 shows the timing when counter clearing by compare match occurrence is specified, and figure 18.35 shows the timing when counter clearing by input capture occurrence is specified. Figure 18.34 Counter Clear Timing (Compare Match) Figure 18.35 Counter Clear Timing (Input Capture) **Buffer Operation Timing:** Figures 18.36 and 18.37 show the timing in buffer operation. Figure 18.36 Buffer Operation Timing (Compare Match) Figure 18.37 Buffer Operation Timing (Input Capture) # 18.6.2 Interrupt Signal Timing **TGF Flag Setting Timing in Case of Compare Match:** Figure 18.38 shows the timing for setting of the TGF flag in TSR by compare match occurrence, and TGI interrupt request signal timing. Figure 18.38 TGI Interrupt Timing (Compare Match) **TGF Flag Setting Timing in Case of Input Capture:** Figure 18.39 shows the timing for setting of the TGF flag in TSR by input capture occurrence, and TGI interrupt request signal timing. Figure 18.39 TGI Interrupt Timing (Input Capture) **TCFV Flag/TCFU Flag Setting Timing:** Figure 18.40 shows the timing for setting of the TCFV flag in TSR by overflow occurrence, and TCIV interrupt request signal timing. Figure 18.41 shows the timing for setting of the TCFU flag in TSR by underflow occurrence, and TCIU interrupt request signal timing. Figure 18.40 TCIV Interrupt Setting Timing Figure 18.41 TCIU Interrupt Setting Timing **Status Flag Clearing Timing:** After a status flag is read as 1 by the CPU, it is cleared by writing 0 to it. When the DMAC is activated, the flag is cleared automatically. Figure 18.42 shows the timing for status flag clearing by the CPU, and figure 18.43 shows the timing for status flag clearing by the DTC. Figure 18.42 Timing for Status Flag Clearing by CPU Figure 18.43 Timing for Status Flag Clearing by DMAC Activation ## 18.7 Usage Notes Note that the kinds of operation and contention described below occur during TPU operation. **Input Clock Restrictions:** The input clock pulse width must be at least 1.5 states in the case of single-edge detection, and at least 2.5 states in the case of both-edge detection. The TPU will not operate properly with a narrower pulse width. In phase counting mode, the phase difference and overlap between the two input clocks must be at least 1.5 states, and the pulse width must be at least 2.5 states. Figure 18.44 shows the input clock conditions in phase counting mode. Figure 18.44 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode **Caution on Period Setting:** When counter clearing by compare match is set, TCNT is cleared in the final state in which it matches the TGR value (the point at which the count value matched by TCNT is updated). Consequently, the actual counter frequency is given by the following formula: $$f = \frac{P\phi}{(N+1)}$$ Where f: Counter frequency Pφ : Peripheral module clock N: TGR set value **Contention between TCNT Write and Clear Operations:** If the counter clear signal is generated in the T2 state of a TCNT write cycle, TCNT clearing takes precedence and the TCNT write is not performed. Figure 18.45 shows the timing in this case. Figure 18.45 Contention between TCNT Write and Clear Operations **Contention between TCNT Write and Increment Operations:** If incrementing occurs in the T2 state of a TCNT write cycle, the TCNT write takes precedence and TCNT is not incremented. Figure 18.46 shows the timing in this case. Figure 18.46 Contention between TCNT Write and Increment Operations **Contention between TGR Write and Compare Match:** If a compare match occurs in the T2 state of a TGR write cycle, the TGR write takes precedence and the compare match signal is inhibited. A compare match does not occur even if the same value as before is written. Figure 18.47 Contention between TGR Write and Compare Match Contention between Buffer Register Write and Compare Match: If a compare match occurs in the T2 state of a TGR write cycle, the data transferred to TGR by the buffer operation will be the data prior to the write. Figure 18.48 shows the timing in this case. Figure 18.48 Contention between Buffer Register Write and Compare Match **Contention between TGR Read and Input Capture:** If the input capture signal is generated in the T1 state of a TGR read cycle, the data that is read will be the data before input capture transfer. Figure 18.49 shows the timing in this case. Figure 18.49 Contention between TGR Read and Input Capture **Contention between TGR Write and Input Capture:** If the input capture signal is generated in the T2 state of a TGR write cycle, the input capture operation takes precedence and the write to TGR is not performed. Figure 18.50 shows the timing in this case. Figure 18.50 Contention between TGR Write and Input Capture **Contention between Buffer Register Write and Input Capture:** If the input capture signal is generated in the T2 state of a buffer write cycle, the buffer operation takes precedence and the write to the buffer register is not performed. Figure 18.51 shows the timing in this case. Figure 18.51 Contention between Buffer Register Write and Input Capture Contention between Overflow/Underflow and Counter Clearing: If overflow/underflow and counter clearing occur simultaneously, the TCFV/TCFU flag in TSR is not set and TCNT clearing takes precedence. Figure 18.52 shows the operation timing when a TGR compare match is specified as the clearing source, and H'FFFF is set in TGR. Figure 18.52 Contention between Overflow and Counter Clearing **Contention between TCNT Write and Overflow/Underflow:** If there is an up-count or downcount in the T2 state of a TCNT write cycle, and overflow/underflow occurs, the TCNT write takes precedence and the TCFV/TCFU flag in TSR is not set. Figure 18.53 shows the operation timing in the case of contention between a TCNT write and overflow. Figure 18.53 Contention between TCNT Write and Overflow **Multiplexing of I/O Pins:** In the SH7612 Series, the TCLKA input pin is multiplexed with the TIOCC0 I/O pin, the TCLKB input pin with the TIOCD0 I/O pin, the TCLKC input pin with the TIOCB1 I/O pin, and the TCLKD input pin with the TIOCB2 I/O pin. When an external clock is input, compare match output should not be performed from a multiplexed pin. **Interrupt when the module is stopped:** When the module is stopped under the request of interrupt, the clear of CPU interrupt factor and DMAC starting factor can not be performed. Set the module stop mode after setting the interrupt disable in advance. # Section 19 Hitachi User Debug Interface (H-UDI) ### 19.1 Overview The Hitachi user debug interface (H-UDI) provides data transfer and interrupt request functions. The H-UDI performs serial transfers under external signal control. ### 19.1.1 Features The H-UDI implements the following features of the IEEE 1149.1 specification: - Five test signals (TCK, TDI, TDO, TMS, and $\overline{TRST}$ ) - TAP controller - Instruction register - Data register - · Bypass register The H-UDI has two instructions: - BYPASS mode: test mode conforming to IEEE 1149.1 - H-UDI interrupt: sends H-UDI interrupt requests to the INTC This LSI does not support any test modes other than the BYPASS mode. ## 19.1.2 H-UDI Block Diagram Figure 19.1 H-UDI Block Diagram ## 19.1.3 Pin Configuration Table 19.1 shows the H-UDI pin configuration. **Table 19.1 Pin Configuration** | Name | Abbr. | I/O | Function | |------------------|-------|-----|-------------------------------| | Test clock | TCK | I | Test clock input | | Test mode select | TMS | 1 | Test mode select input signal | | Test data input | TDI | 1 | Serial data input | | Test data output | TDO | 0 | Serial data output | | Test reset | TRST | I | Test reset input signal | ## 19.1.4 Register Configuration Table 19.2 summarizes the registers of the H-UDI. **Table 19.2 Register Configuration** | Register | Abbreviation | R/W*1 | Initial<br>Value <sup>*2</sup> | Address | Access<br>Size (Bits) | |----------------------|--------------|-------|--------------------------------|------------|-----------------------| | Instruction register | SDIR | R | H'F000 | H'FFFFCE0 | 8/16/32 | | Status register | SDSR | R/W | H'0101 | H'FFFFCE2 | 8/16/32 | | Data register H | SDDRH | R/W | Undefined | H'FFFFCE4 | 8/16/32 | | Data register L | SDDRL | R/W | Undefined | H'FFFFFCE6 | 8/16/32 | | Bypass register | SDBPR | _ | _ | _ | _ | Notes: 1. Indicates whether read/write from the CPU is possible. 2. Initial value upon $\overline{\text{TRST}}$ signal input. Not initialized in reset (power-on reset/manual reset) or standby mode. Instructions and data can be input by serial transfer to the instruction register (SDIR) and data register (SDDR) via the test data input (TDI) pin. Test data from SDIR, the status register (SDSR) and SDDR can be output from the chip via the test data output (TDO) pin. The bypass register (SDBPR) is a one-bit register to which TDI and TDO are connected during bypass mode. All registers except SDBPR can be accessed by the CPU. Table 19.3 summarizes the types of serial transfers possible for each H-UDI register. Table 19.3 Serial Transfer Characteristics of H-UDI Registers | Register | Serial Input | Serial Output | |----------|--------------|---------------| | SDIR | Yes | Yes | | SDSR | No | Yes | | SDDRH | Yes | Yes | | SDDRL | Yes | Yes | | SDBPR | Yes | Yes | ## 19.2 External Signals ### 19.2.1 Test Clock (TCK) The test clock pin (TCK) supplies an independent clock to the H-UDI. The input clock to TCK is supplied to the H-UDI as is, so input a clock waveform with an approximately 50% duty ratio. (See Section 23, Electrical Characteristics for details.) When nothing is input, TCK is held at 1 by internal pull-up. ### 19.2.2 Test Mode Select (TMS) The test mode select pin (TMS) is sampled on the rise of TCK. TMS controls the internal state of the TAP controller. When nothing is input, TMS is held at 1 by internal pull-up. ### 19.2.3 Test Data Input (TDI) The test data input pin (TDI) performs serial input of instructions and data to the H-UDI registers. It is sampled on the rise of TCK. When nothing is input, TDI is held at 1 by internal pull-up. ### 19.2.4 Test Data Output (TDO) The test data output pin (TDO) performs serial output of instructions and data from the H-UDI registers. Transfers are synchronous with TCK. When not being driven, TDO is in a Hi-Z state. ### 19.2.5 Test Reset $(\overline{TRST})$ The test reset pin (TRST) is a signal that initializes the H-UDI asynchronously. When nothing is input, TRST is held at 1 by internal pull-up. ## 19.3 Registers ### 19.3.1 Instruction Register (SDIR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-----|-----|-----|-----|----|----|---|---| | Bit name: | TS3 | TS2 | TS1 | TS0 | _ | _ | _ | _ | | Initial value: | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | | _ | | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | The instruction register (SDIR) is a 16-bit register that can be read from and written to by the CPU. H-UDI instructions also can be loaded into the SDIR by serial input from TDI. H-UDI interrupts can be set by writes from the CPU, but it cannot request interrupts. Interrupt requests are possible only upon serial input. This can be either a write by the CPU in BYPASS mode or a serial input. The SDIR is initialized by the $\overline{TRST}$ signal, but is not initialized in reset or standby mode. Instructions transferred to SDIR must be four bits wide. If an instruction more than four bits wide is input, only the last four bits of serial data are stored in SDIR. Bits 15 to 12—Test Set (TS3–TS0): The H-UDI issues instructions according to the test bit settings. **Table 19.4 Instruction Configuration** | Bit 15: TS2 | Bit 14: TS1 | Bit 13: TS0 | Bit 13: TS0 | Instruction | |-------------|-------------|-------------|-------------|-----------------------------| | 0 | 0 | 0 | 0 | Reserved | | 0 | 0 | 0 | 1 | Reserved | | 0 | 0 | 1 | 0 | Reserved | | 0 | 0 | 1 | 1 | Reserved | | 0 | 1 | 0 | 0 | Reserved | | 0 | 1 | 0 | 1 | Reserved | | 0 | 1 | 1 | 0 | Reserved | | 0 | 1 | 1 | 1 | Reserved | | 1 | 0 | 0 | 0 | Reserved | | 1 | 0 | 0 | 1 | Reserved | | 1 | 0 | 1 | 0 | H-UDI interrupt | | 1 | 0 | 1 | 1 | Reserved | | 1 | 1 | 0 | 0 | Reserved | | 1 | 1 | 0 | 1 | Reserved | | 1 | 1 | 1 | 0 | Reserved | | 1 | 1 | 1 | 1 | Bypass mode (initial value) | | | | | | | Bits 11 to 0—Reserved: Always read as 0. The write value should always be 0. ## 19.3.2 Status Register (SDSR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|----|----|----|----|----|----|---|-------| | Bit name: | _ | _ | _ | _ | _ | _ | _ | _ | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R | R | R | R | R | R | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | _ | _ | _ | _ | _ | _ | _ | SDTRF | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | R/W: | R | R | R | R | R | R | R | R/W | The status register (SDSR) is a 16-bit register that can be read from and written to by the CPU. SDSR can be output from TDO, but serial data cannot be written to SDSR via TDI. The SDTRF bit is output by a one-bit shift. On a two-bit shift, the SDTRF bit is output first, followed by a reserved bit. The SDSR is initialized by $\overline{TRST}$ signal input, but cannot be initialized in reset or standby mode. Bits 15–1—Reserved: Bits 15 to 9, 7 to 1, always read as 0. The write value should always be 0. When bit-8 reads, 1 is always read. The write value should be always 1. Bit 0—Serial Data Transfer Control Flag (SDTRF): Indicates whether the H-UDI registers are accessible by the CPU. The SDTRF bit is reset by the $\overline{TRST}$ signal, but is not initialized in reset or standby mode. | Bit 0: SDTRF | Description | |--------------|----------------------------------------------------------------------| | 0 | End of serial transfer to SDDR H-UDI registers are accessible by CPU | | 1 | During serial transfer into SDDR (initial value) | Note: When SDTRF = 1, accesses of H-UDI registers are made to wait until SDTRF = 0. ### 19.3.3 Data Register (SDDR) The data register (SDDR) consists of data register H (SDDRH) and data register L (SDDRL), each of which has the following form: SDDRH and SDDRL are 16-bit read/write registers that can be read from and written to by the CPU. SDDR is connected to TDO and TDI for transfer of serial data to and from external devices. 32-bit data is input or output during serial data transfer. If data wider than 32 bits is input, only the final 32 bits are stored in the SDDR. Serial data is input from the MSB of SDDR (bit 15 of the SDDRH), and is output from the LSB (bit 0 of the SDDRL). This register is not initialized by the TRST signal, or when in reset or standby mode. ## 19.3.4 Bypass Register (SDBPR) The bypass register is a one-bit shift register. When in bypass mode, TDI and TDO are connected to the SDBPR, and the LSI is bypassed during board testing. SDBPR cannot be read from or written to by the CPU. ## 19.4 Operation ### 19.4.1 H-UDI Interrupt An interrupt occurs when the H-UDI interrupt instruction is sent to the SDIR via the TDI. Data transfer can be controlled by the H-UDI interrupt service routine. Transfers can be performed via the SDDR. Control of data I/O between the exterior and the H-UDI is performed externally by checking the SDTRF bit of the SDSR. The H-UDI interrupt and serial transfer procedure is: - 1. The instruction is loaded into SDIR by serial transfer, and an H-UDI interrupt request is generated. - 2. After the H-UDI interrupt request has been issued, the external controller monitors the SDTRF bit of SDSR. When the controller detects that SDTRF = 1 has been output from TDO, it transfers serial data to SDDR. - 3. After serial transfer to the SDDR ends, the SDTRF bit is cleared to 0, and the H-UDI registers become accessible by the CPU. After the end of H-UDI register access, setting the SDTRF bit of SDSR to 1 enables SDDR serial transfers. - 4. By always monitoring the SDTRF bit of the SDSR externally, serial data transfers between the exterior and the H-UDI become possible. Figures 19.2, 19.3, and 19.4 are timing diagrams for transfer of data between an external controller and the H-UDI. Figure 19.2 Data I/O Timing (1) Figure 19.3 Data I/O Timing (2) Figure 19.4 Data I/O Timing (3) ## 19.4.2 Bypass Mode IEEE 1149.1-compliant bypass mode is available to bypass the SH-DSP chip during boundary-scan testing. Bypass mode is entered by transferring b'111 to SDIR. In bypass mode, TDI and TDO are connected to SDBPR. ## 19.4.3 Resetting the H-UDI The H-UDI can be reset in two ways: - Hold the $\overline{TRST}$ signal at 0. - When $\overline{TRST} = 1$ , input five or more TCK clocks while TMS = 1. ### 19.5 Precautions - When starting the H-UDI, be sure to always set the TRST signal to 0 and hold it low for several TCK clocks. - Registers are not initialized in standby mode. Setting TRST to 0 while in standby mode sets bypass mode. - TCK frequency must be lower than Pφ frequency. See Section 23, Electrical Characteristics for details. - Data I/O during serial transfer proceeds from the LSB. Figure 19.5 shows the serial data I/O. - Be sure to do a TRST reset if the H-UDI serial transfer sequence is disrupted, then, regardless of the transfer operation, re-do the transfer. - The TDO output timing starts at TCK startup. - When Shift-IR is in effect, the final 2 bits of output data from TDO (the IR status word) are not always 01. - If debug is performed, use H-UDI. For this reason, do not use 5 pieces terminal of H-UDI related as a E10 emulator(general purpose I/O) port. Figure 19.5 Serial Data I/O # Section 20 Pin Function Controller ## 20.1 Overview The pin function controller (PFC) consists of registers for selecting multiplex pin functions and their input/output direction. The pin function and input/output direction can be selected for individual pins regardless of the operating mode of the SH7612. Table 20.1 shows the SH7612's multiplex pins. Table 20.1 SH7612 Multiplex Pins | | Function 1 | | F | Function 2 | | | Function 3 | | | |------|----------------|-----|-------------------|----------------|-----|-------------------|----------------|-----|-------------------| | Port | Signal<br>Name | I/O | Related<br>Module | Signal<br>Name | I/O | Related<br>Module | Signal<br>Name | I/O | Related<br>Module | | Α | TCK | I | (H-UDI) | PA13 | I/O | (Port) | _ | _ | | | Α | TMS | I | (H-UDI) | PA12 | I/O | (Port) | _ | _ | | | Α | TDI | I | (H-UDI) | PA11 | I/O | (Port) | _ | _ | | | Α | TDO | 0 | (H-UDI) | PA10 | I/O | (Port) | _ | _ | _ | | Α | PA9 | I/O | (Port) | STS2 | I/O | (SIO2) | _ | _ | _ | | Α | PA8 | I/O | (Port) | STXD2 | 0 | (SIO2) | _ | _ | _ | | Α | WDTOVF | 0 | (WDT) | PA7 | I/O | (Port) | _ | _ | _ | | Α | FTCI | I | (FRT) | PA6 | I/O | (Port) | _ | _ | _ | | Α | FTI | I | (FRT) | PA5 | I/O | (Port) | <b>—</b> | _ | _ | | Α | FTOA | 0 | (FRT) | PA4 | I/O | (Port) | _ | _ | _ | | Α | FTOB | 0 | (FRT) | СКРО | 0 | (Port) | _ | _ | _ | | Α | SCK | I/O | (SCI)*1 | PA2 | I/O | (Port) | _ | _ | _ | | Α | RXD | I | (SCI) | PA1 | I/O | (Port) | _ | _ | _ | | Α | TXD | 0 | (SCI) | PA0 | I/O | (Port) | _ | _ | _ | | В | PB15 | I/O | (Port) | SRCK0 | I | (SIO) | SCK2 | I/O | (SCIF) | | В | PB14 | I/O | (Port) | SRS0 | I | (SIO) | RXD2 | I | (SCIF) | | В | PB13 | I/O | (Port) | SRXD0 | l | (SIO) | TXD2 | 0 | (SCIF) | | В | PB12 | I/O | (Port) | STCK0 | I | (SIO) | SCK1 | I/O | (SCIF) | | В | PB11 | I/O | (Port) | STS0 | I/O | (SIO) | RXD1 | I | (SCIF) | | В | PB10 | I/O | (Port) | STXD0 | 0 | (SIO) | TXD1 | 0 | (SCIF) | Table 20.1 SH7612 Multiplex Pins | | Function 1 | | F | Function 2 | | | Function 3 | | | |------|----------------|-----|-------------------|----------------|-----|-------------------|----------------|-----|-------------------| | Port | Signal<br>Name | 1/0 | Related<br>Module | Signal<br>Name | 1/0 | Related<br>Module | Signal<br>Name | I/O | Related<br>Module | | В | PB9 | I/O | (Port) | SRCK1 | I | (SIO) | RTSN | 0 | (SCIF) | | В | PB8 | I/O | (Port) | SRS1 | I | (SIO) | CTSN | I | (SCIF) | | В | PB7 | I/O | (Port) | SRXD1 | I | (SIO) | TIOCA2 | I/O | (TPU) | | В | PB6 | I/O | (Port) | STCK1 | I | (SIO) | TIOCB2 | I/O | (TPU) | | В | PB5 | I/O | (Port) | STS1 | I/O | (SIO) | TIOCA1 | I/O | (TPU) | | В | PB4 | I/O | (Port) | STXD1 | 0 | (SIO) | TIOCB1 | I/O | (TPU) | | В | PB3 | I/O | (Port) | SRCK2 | I | (SIO) | TIOCA0 | I/O | (TPU) | | В | PB2 | I/O | (Port) | SRS2 | I | (SIO) | TIOCB0 | I/O | (TPU) | | В | PB1 | I/O | (Port) | SRXD2 | I | (SIO) | TIOCC0 | I/O | (TPU) | | В | PB0 | I/O | (Port) | STCK2 | I | (SIO) | TIOCD0 | I/O | (TPU) | Notes: In the initial state, function 1 is selected. ## 20.2 Register Configuration PFC registers are listed in table 20.2. Table 20.2 PFC Registers | Name | Abbreviation | R/W | Initial Value | Address | Access Size | |---------------------------|--------------|-----|---------------|------------|-------------| | Port A control register | PACR | R/W | H'0000 | H'FFFFFC80 | 8, 16 | | Port A I/O register | PAIOR | R/W | H'0000 | H'FFFFFC82 | 8, 16 | | Port B control register | PBCR | R/W | H'0000 | H'FFFFFC88 | 8, 16 | | Port B I/O register | PBIOR | R/W | H'0000 | H'FFFFFC8A | 8, 16 | | Port B control register 2 | PBCR2 | R/W | H'0000 | H'FFFFFC8E | 8, 16 | <sup>\*1.</sup> The initial state is input. ## **20.3** Description of Registers ### 20.3.1 Port A Control Register (PACR) The port A control register (PACR) is a 16-bit read/write register that selects the functions of the 14 multiplex pins in port A. PACR is initialized to H'0000 by a power-on reset. It is not initialized by a manual reset or in standby mode or sleep mode. Bits 15 and 14—Reserved. These bits always read 0. The write value should always be 0. Bit 13—PA13 Mode Bit (PA13MD): Selects the function of pin TCK/PA13. | Bit 13: PA13MD | Description | | |----------------|-----------------------------|-----------------| | 0 | H-UDI clock input (TCK) | (Initial value) | | 1 | General input/output (PA13) | _ | Bit 12—PA12 Mode Bit (PA12MD): Selects the function of pin TMS/PA12. | Bit 12: PA12MD | Description | | |----------------|-------------------------------|-----------------| | 0 | H-UDI mode signal input (TMS) | (Initial value) | | 1 | General input/output (PA12) | | Bit 11—PA11 Mode Bit (PA11MD): Selects the function of pin TDI/PA11. ## Bit 11: PA11MD Description | 0 | H-UDI data input (TDI) | (Initial value) | |---|-----------------------------|-----------------| | 1 | General input/output (PA11) | | Bit 10—PA10 Mode Bit (PA10MD): Selects the function of pin TDO/PA10. | Bit 10: PA10MD | Description | | |----------------|-----------------------------|-----------------| | 0 | H-UDI data output (TDO) | (Initial value) | | 1 | General input/output (PA10) | | Bit 9—PA9 Mode Bit (PA9MD): Selects the function of pin PA9/STS2. | Bit 9: PA9MD | Description | | |--------------|------------------------------------------------|-----------------| | 0 | General input/output (PA9) | (Initial value) | | 1 | SIO2 transmit start signal input/output (STS2) | | Bit 8—PA8 Mode Bit (PA8MD): Selects the function of pin PA8/STXD2. | Bit 8: PA8MD | Description | | |--------------|-----------------------------------|-----------------| | 0 | General input/output (PA8) | (Initial value) | | 1 | SIO2 transmit data output (STXD2) | | Bit 7—PA7 Mode Bit (PA7MD): Selects the function of pin WDTOVF/PA7. | Bit 7: PA7MD | Description | | |--------------|-------------------------------------|-----------------| | 0 | WDT overflow signal output (WDTOVF) | (Initial value) | | 1 | General input/output (PA7) | _ | Bit 6—PA6 Mode Bit (PA6MD): Selects the function of pin FTCI/PA6. | Bit 6: PA6MD | Description | | |--------------|----------------------------|-----------------| | 0 | FRT clock input (FTCI) | (Initial value) | | 1 | General input/output (PA6) | _ | Bit 5—PA5 Mode Bit (PA5MD): Selects the function of pin FTI/PA5. | Bit 5: PA5MD | Description | | |--------------|-------------------------------|-----------------| | 0 | FRT input capture input (FTI) | (Initial value) | | 1 | General input/output (PA5) | | Bit 4—PA4 Mode Bit (PA4MD): Selects the function of pin FTO4/PA4. | Bit 4: PA4MD | Description | | |--------------|----------------------------------|-----------------| | 0 | FRT output compare output (FTOA) | (Initial value) | | 1 | General input/output (PA4) | | Bit 3—PA3 Mode Bit (PA3MD): Selects the function of pin FTOB/CKPO. | Bit 3: PA3MD | Description | | |--------------|---------------------------------------|-----------------| | 0 | FRT output compare output (FTOB) | (Initial value) | | 1 | Peripheral module clock output (CKPO) | | Bit 2—PA2 Mode Bit (PA2MD): Selects the function of pin SCK/PA2. | Bit 2: PA2MD | Description | | |--------------|-----------------------------------------------|-----------------| | 0 | SCI transmit/receive clock input/output (SCK) | (Initial value) | | 1 | General input/output (PA2) | | Bit 1—PA1 Mode Bit (PA1MD): Selects the function of pin RXD/PA1. | Bit 1: PA1MD | Description | | |--------------|------------------------------|-----------------| | 0 | SCI receive data input (RXD) | (Initial value) | | 1 | General input/output (PA1) | | Bit 0—PA0 Mode Bit (PA0MD): Selects the function of pin TXD/PA0. | Bit 0: PA0MD | Description | | |--------------|--------------------------------|-----------------| | 0 | SCI transmit data output (TXD) | (Initial value) | | 1 | General input/output (PA0) | | ### 20.3.2 Port A I/O Register (PAIOR) The port A I/O register (PAIOR) is a 16-bit read/write register that selects the input/output direction of the 14 multiplex pins in port A. Bits PA13IOR to PA4IOR and PA2IOR to PA0IOR correspond to individual pins in port A. PAIOR is enabled when port A pins function as general input pins (PA13 to PA4 and PA2 to PA0), and disabled otherwise. When port A pins function as PA13 to PA0, a pin becomes an output when the corresponding bit in PAIOR is set to 1, and an input when the bit is cleared to 0. PAIOR is initialized to H'0000 by a power-on reset. It is not initialized by a manual reset or in standby mode or sleep mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|--------|--------|---------|---------|---------|---------|--------|--------| | | _ | _ | PA13IOR | PA12IOR | PA11IOR | PA10IOR | PA9IOR | PA8IOR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PA7IOR | PA6IOR | PA5IOR | PA4IOR | _ | PA2IOR | PA1IOR | PA0IOR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R/W | R/W | R/W | ### 20.3.3 Port B Control Registers (PBCR, PBCR2) The port B control registers (PBCR and PBCR2) are 16-bit read/write registers that select the functions of the 16 multiplex pins in port B. PBCR selects the functions of the pins for the upper 8 bits in port B, and PBCR2 selects the functions of the pins for the lower 8 bits in port B. PBCR and PBCR2 are initialized to H'0000 by a power-on reset. They are not initialized by a manual reset or in standby mode or sleep mode. Port B Control Register (PBCR) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------| | Bit name: | PB15<br>MD1 | PB15<br>MD0 | PB14<br>MD1 | PB14<br>MD0 | PB13<br>MD1 | PB13<br>MD0 | PB12<br>MD1 | PB12<br>MD0 | | | IVIDI | WIDO | IVIDI | WIDO | IVIDI | WIDO | IVID I | IVIDO | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Bit name: | PB11 | PB11 | PB10 | PB10 | PB9 | PB9 | PB8 | PB8 | | | MD1 | MD0 | MD1 | MD0 | MD1 | MD0 | MD1 | MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Bits 15 and 14—PB15 Mode Bits 1 and 0 (PB15MD1, PB15MD0): These bits select the function of pin PB15/SRCK0/SCK2. | Bit 15: PB15MD1 | Bit 14: PB15MD0 | Description | |-----------------|-----------------|--------------------------------------------------| | 0 | 0 | General input/output (PB15) (Initial value) | | | 1 | Reserved | | 1 | 0 | SIO0 receive clock input (SRCK0) | | | 1 | SCIF2 transmit/receive clock input/output (SCK2) | Bits 13 and 12—PB14 Mode Bits 1 and 0 (PB14MD1, PB14MD0): These bits select the function of pin PB14/SRS0/RXD2. | Bit 13: PB14MD1 | Bit 12: PB14MD0 | Description | | |-----------------|-----------------|----------------------------------------|-----------------| | 0 | 0 | General input/output (PB14) | (Initial value) | | | 1 | Reserved | | | 1 | 0 | SIO0 receive start signal input (SRS0) | | | | 1 | SCIF2 receive data input (RXD2) | | | | | | | Bits 11 and 10—PB13 Mode Bits 1 and 0 (PB13MD1, PB13MD0): These bits select the function of pin PB13/SRXD0/TXD2. | Bit 11: PB13MD1 | Bit 10: PB13MD0 | Description | | |-----------------|-----------------|-----------------------------------|-----------------| | 0 | 0 | General input/output (PB13) | (Initial value) | | | 1 | Reserved | | | 1 | 0 | SIO0 receive data input (SRXD0) | | | | 1 | SCIF2 transmit data output (TXD2) | | Bits 9 and 8—PB12 Mode Bits 1 and 0 (PB12MD1, PB12MD0): These bits select the function of pin PB12/STCK0/SCK1. | Bit 9: PB12MD1 | Bit 8: PB12MD0 | Description | |----------------|----------------|--------------------------------------------------| | 0 | 0 | General input/output (PB12) (Initial value) | | | 1 | Reserved | | 1 | 0 | SIO0 transmit clock input (STCK0) | | | 1 | SCIF1 transmit/receive clock input/output (SCK1) | Bits 7 and 6—PB11 Mode Bits 1 and 0 (PB11MD1, PB11MD0): These bits select the function of pin PB11/STS0/RXD1. | Bit 7: PB11MD1 | Bit 6: PB11MD0 | Description | | |----------------|----------------|---------------------------------------|-----------------| | 0 | 0 | General input/output (PB11) | (Initial value) | | | 1 | Reserved | | | 1 | 0 | SIO0 transmit start signal input/outp | ut (STS0) | | | 1 | SCIF1 receive data input (RXD1) | | Bits 5 and 4—PB10 Mode Bits 1 and 0 (PB10MD1, PB10MD0): These bits select the function of pin PB10/STXD0/TXD1. | Bit 5: PB10MD1 | Bit 4: PB10MD0 | Description | | |----------------|----------------|-----------------------------------|-----------------| | 0 | 0 | General input/output (PB10) | (Initial value) | | | 1 | Reserved | | | 1 | 0 | SIO0 transmit data output (STXD0) | | | | 1 | SCIF1 transmit data output (TXD1) | | Bits 3 and 2—PB9 Mode Bits 1 and 0 (PB9MD1, PB9MD0): These bits select the function of pin PB9/SRCK1/RTSN. | Bit 3: PB9MD1 | Bit 2: PB9MD0 | Description | | | |---------------|---------------|---------------------------------------------|--|--| | 0 | 0 | General input/output (PB9) (Initial value) | | | | | 1 | Reserved | | | | 1 | 0 | SIO1 receive clock input (SRCK1) | | | | | 1 | SCIF1 transmit request signal output (RTSN) | | | Bits 1 and 0—PB8 Mode Bits 1 and 0 (PB8MD1, PB8MD0): These bits select the function of pin PB8/SRS1/CTSN. | Bit 1: PB8MD1 | Bit 0: PB8MD0 | Description | |---------------|---------------|--------------------------------------------| | 0 | 0 | General input/output (PB8) (Initial value) | | | 1 | Reserved | | 1 | 0 | SIO1 receive start signal input (SRS1) | | | 1 | SCIF1 transmit clear signal input (CTSN) | ## Port B Control Register 2 (PBCR2) | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|------------|------------|------------|------------|------------|------------|------------|------------| | | PB7<br>MD1 | PB7<br>MD0 | PB6<br>MD1 | PB6<br>MD0 | PB5<br>MD1 | PB5<br>MD0 | PB4<br>MD1 | PB4<br>MD0 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 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 | | R/W: | R/W Bits 15 and 14—PB7 Mode Bits 1 and 0 (PB7MD1, PB7MD0): These bits select the function of pin PB7/SRXD1/TIOCA2. | Bit 15: PB7MD1 | Bit 14: PB7MD0 | Description | | | |----------------|----------------|-----------------------------------------------|-----------------|--| | 0 | 0 | General input/output (PB7) | (Initial value) | | | | 1 | Reserved | | | | 1 | 0 | SIO1 receive data input (SRXD1) | | | | | 1 | TPU input capture input/output compa (TIOCA2) | are output | | Bits 13 and 12—PB6 Mode Bits 1 and 0 (PB6MD1, PB6MD0): These bits select the function of pin PB6/STCK1/TIOCB2. | Bit 13: PB6MD1 | Bit 12: PB6MD0 | Description | | | |----------------|----------------|----------------------------------------------|-----------------|--| | 0 | 0 | General input/output (PB6) | (Initial value) | | | | 1 | Reserved | | | | 1 | 0 | SIO1 transmit clock input (STCK1) | | | | | 1 | TPU input capture input/output comp (TIOCB2) | are output | | Bits 11 and 10—PB5 Mode Bits 1 and 0 (PB5MD1, PB5MD0): These bits select the function of pin PB5/STS1/TIOCA1. | Bit 11: PB5MD1 | Bit 10: PB5MD0 | Description | | | |----------------|----------------|-----------------------------------------------|-----------------|--| | 0 | 0 | General input/output (PB5) | (Initial value) | | | | 1 | Reserved | | | | 1 | 0 | SIO1 transmit start signal input/output (STS1 | | | | | 1 | TPU input capture input/output comp (TIOCA1) | are output | | Bits 9 and 8—PB4 Mode Bits 1 and 0 (PB4MD1, PB4MD0): These bits select the function of pin PB4/STXD1/TIOCB1. | Bit 9: PB4MD1 | Bit 8: PB4MD0 | Description | |---------------|---------------|--------------------------------------------------------| | 0 | 0 | General input/output (PB4) (Initial value) | | | 1 | Reserved | | 1 | 0 | SIO1 transmit data output (STXD1) | | | 1 | TPU input capture input/output compare output (TIOCB1) | Bits 7 and 6—PB3 Mode Bits 1 and 0 (PB3MD1, PB3MD0): These bits select the function of pin PB3/SRCK2/TIOCA0. | Bit 7: PB3MD1 | Bit 6: PB3MD0 | Description | | | |---------------|---------------|--------------------------------------------------------|-----|--| | 0 | 0 | General input/output (PB3) (Initial value | ue) | | | | 1 | Reserved | | | | 1 | 0 | SIO2 receive clock input (SRCK2) | | | | | 1 | TPU input capture input/output compare output (TIOCA0) | | | Bits 5 and 4—PB2 Mode Bits 1 and 0 (PB2MD1, PB2MD0): These bits select the function of pin PB2/SRS2/TIOCB0. | Bit 5: PB2MD1 | Bit 4: PB2MD0 | Description | |---------------|---------------|--------------------------------------------------------| | 0 | 0 | General input/output (PB2) (Initial value) | | | 1 | Reserved | | 1 | 0 | SIO2 receive start signal input (SRS2) | | | 1 | TPU input capture input/output compare output (TIOCB0) | Bits 3 and 2—PB1 Mode Bits 1 and 0 (PB1MD1, PB1MD0): These bits select the function of pin PB1/SRXD2/TIOCC0. | Bit 3: PB1MD1 | Bit 2: PB1MD0 | Description | | |---------------|---------------|--------------------------------------------------------|-----| | 0 | 0 | General input/output (PB1) (Initial value | ue) | | | 1 | Reserved | | | 1 | 0 | SIO2 receive data input (SRXD2) | | | | 1 | TPU input capture input/output compare output (TIOCC0) | | Bits 1 and 0—PB0 Mode Bits 1 and 0 (PB0MD1, PB0MD0): These bits select the function of pin PB0/STCK2/TIOCD0. | Bit 1: PB0MD1 | Bit 0: PB0MD0 | Description | | |---------------|---------------|----------------------------------------------------|------------| | 0 | 0 | General input/output (PB0) (Init | ial value) | | | 1 | Reserved | | | 1 | 0 | SIO2 transmit clock input (STCK2) | | | | 1 | TPU input capture input/output compare ou (TIOCD0) | tput | ### 20.3.4 Port B I/O Register (PBIOR) The port B I/O register (PBIOR) is a 16-bit read/write register that selects the input/output direction of the 16 multiplex pins in port B. Bits PB15IOR to PB0IOR correspond to individual pins in port B. PBIOR is enabled when port B pins function as general input pins (PB15 to PB0), and disabled otherwise. When port B pins function as PB15 to PB0, a pin becomes an output when the corresponding bit in PBIOR is set to 1, and an input when the bit is cleared to 0. PBIOR is initialized to H'0000 by a power-on reset. It is not initialized by a manual reset or in standby mode or sleep mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------------|-------------|-------------|-------------|-------------|-------------|------------|------------| | | PB15<br>IOR | PB14<br>IOR | PB13<br>IOR | PB12<br>IOR | PB11<br>IOR | PB10<br>IOR | PB9<br>IOR | PB8<br>IOR | | | 1011 | 1011 | 1011 | 1011 | 1011 | 1011 | 1011 | 1011 | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PB7 | PB6 | PB5 | PB4 | PB3 | PB2 | PB1 | PB0 | | | IOR | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W ## Section 21 I/O Ports ### 21.1 Overview The LSI has two ports: A and B. Port A is a 14-bit I/O port, and port B is a 16-bit I/O port. All the port pins are multiplexed as general input/output pins and special function pins. The functions of the multiplex pins are selected by means of the pin function controller (PFC). Ports A and B are each provided with a data register for storing the pin data. ### 21.2 Port A Port A is an input/output port with the 14 pins shown in figure 21.1. Of the 14 pins, the FTOB pin has no port data register bit, and is multiplexed as an internal clock pin. Figure 21.1 Port A ### 21.2.1 Register Configuration The port A register is shown in table 21.1. **Table 21.1 Register Configuration** | Register | Abbreviation | R/W | Initial Value | Address | Access Size | |----------------------|--------------|-----|---------------|------------|-------------| | Port A data register | PADR | R/W | H'0000 | H'FFFFFC84 | 8, 16 | ### 21.2.2 Port A Data Register (PADR) The port A data register (PADR) is a 16-bit read/write register that stores port A data. Bits 15, 14, and 3 are reserved: they always read 0, and the write value should always be 0. Bits PA13DR to PA0DR correspond to pins PA13 to PA0. When a pin functions as a general output, if a value is written to PADR, that value is output directly from the pin, and if PADR is read, the register value is returned directly regardless of the pin state. When a pin functions as a general input, if PADR is read the pin state, not the register value, is returned directly. If a value is written to PADR, although that value is written into PADR it does not affect the pin state. Table 21.3 summarizes port A data register read/write operations. PADR is initialized to H'0000 by a power-on reset. It is not initialized by a manual reset or in standby mode or sleep mode. | Bit: | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |----------------|-------|-------|--------|--------|--------|--------|-------|-------| | | _ | _ | PA13DR | PA12DR | PA11DR | PA10DR | PA9DR | PA8DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PA7DR | PA6DR | PA5DR | PA4DR | _ | PA2DR | PA1DR | PA0DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | R/W | R/W | R/W | R | R/W | R/W | R/W | Table 21.2 Port A Data Register (PADR) Read/Write Operations | PAIOR | Pin Function | Read | Write | |-------|---------------------------|------------|---------------------------------------------------------| | 0 | General input | Pin state | Value is written to PADR, but does not affect pin state | | | Other than general input | Pin state | Value is written to PADR, but does not affect pin state | | 1 | General output | PADR value | Write value is output from pin | | | Other than general output | PADR value | Value is written to PADR, but does not affect pin state | ### 21.3 Port B Port B is an input/output port with the 16 pins shown in figure 21.2. Figure 21.2 Port B ### 21.3.1 Register Configuration The port B register is shown in table 21.3. **Table 21.3 Register Configuration** | Name | Abbreviation | R/W | Initial Value | Address | Access Size | |----------------------|--------------|-----|---------------|------------|-------------| | Port B data register | PBDR | R/W | H'0000 | H'FFFFFC8C | 8, 16 | ### 21.3.2 Port B Data Register (PBDR) The port B data register (PBDR) is a 16-bit read/write register that stores port B data. Bits PB15DR to PB0DR correspond to pins PB15 to PB0. When a pin functions as a general output, if a value is written to PBDR, that value is output directly from the pin, and if PBDR is read, the register value is returned directly regardless of the pin state. When a pin functions as a general input, if PBDR is read the pin state, not the register value, is returned directly. If a value is written to PBDR, although that value is written into PBDR it does not affect the pin state. Table 21.4 summarizes port B data register read/write operations. PBDR is initialized to H'0000 by a power-on reset. It is not initialized by a manual reset or in standby mode or sleep mode. | Bit: | Bit: 15 14 | | 13 12 | | 11 | 10 | 9 | 8 | |----------------|------------|--------|--------|--------|--------|--------|-------|-------| | | PB15DR | PB14DR | PB13DR | PB12DR | PB11DR | PB10DR | PB9DR | PB8DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W | | | | | | | | | | | Bit: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | PB7DR | PB6DR | PB5DR | PB4DR | PB3DR | PB2DR | PB1DR | PB0DR | | Initial value: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R/W: | R/W Table 21.4 Port B Data Register (PBDR) Read/Write Operations | PAIOR | Pin Function | Read | Write | | |-------|---------------------------|------------|---------------------------------------------------------|--| | 0 | General input | Pin state | Value is written to PBDR, but does not affect pin state | | | | Other than general input | Pin state | Value is written to PBDR, but does not affect pin state | | | 1 | General output | PBDR value | Write value is output from pin | | | | Other than general output | PBDR value | Value is written to PBDR, but does not affect pin state | | ## Section 22 Power-Down Modes ### 22.1 Overview The SH7612 has a module standby function (which reduces power consumption by selectively halting operation of unnecessary modules among the on-chip peripheral modules and the DSP unit), a sleep mode (which halts CPU functions), and a standby mode (which halts all functions). ### 22.1.1 Power-Down Modes The following modes and function are provided as power-down modes: - 1. Sleep mode - 2. Standby mode - Module standby function (UBC, DMAC, DSP, DIVU, FRT, SCIF1/2, TPU, SIO0–2, SCI) Table 22.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 22.1 Power-Down Modes** | | | State | | | | | | | | |-------------------------------|------------------------------------------------------------------------------|-------|---------------|---------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----------------------------------------|--| | Mode | Transition<br>Condition | | CPU,<br>Cache | DSP | BSC | UBC, DMAC,<br>DIVU, FRT,<br>SCIF1-2,<br>TPU, SIO2-0,<br>SCI | Pins | Canceling<br>Procedure | | | Sleep<br>mode | SLEEP<br>instruction<br>executed<br>with SBY<br>bit set to 0 | Run | Halt | Halt | Run | Run | Run | Interrupt DMA address error | | | | in<br>SBYCR1 | | | | | | | 3. Power-on reset | | | | | | | | | | | 4. Manual reset | | | Standby<br>mode | SLEEP<br>instruction<br>executed<br>with SBY<br>bit set to 1<br>in<br>SBYCR1 | Halt | Halt | Halt | Stop and<br>retention<br>of<br>register's<br>value | UBC: Stop | Held or high impedance | 1. NMI interrupt | | | | | | | | | | | 2. Power-on reset | | | | | | | | | value<br>Other than<br>UBC: Stop | | 3. Manual reset | | | Module<br>standby<br>function | MSTP bit<br>for<br>relevant<br>module is<br>set to 1 | Run | Run | When MSTP is 1, the clock supply is halted. | Run | When MSTP<br>bit is 1, the<br>supply of<br>the clock to<br>the relevant<br>module is<br>halted. | FRT, SCI,<br>and<br>SCIF1, 2<br>pins are<br>initialized,<br>and others<br>operate. | 1. Clear<br>MSTP bit<br>to 0 | | | | | | | | | | | 2. Power-on reset | | | | | | | | | | | 3. Manual reset | | ## 22.1.2 Register Table 22.2 shows the register configuration. **Table 22.2 Register Configuration** | Name | Abbreviation | R/W | Initial Value | Address | Access Size | |----------------------------|--------------|-----|---------------|------------|-------------| | Standby control register 1 | SBYCR1 | R/W | H'00 | H'FFFFFE91 | 8 | | Standby control register 2 | SBYCR2 | R/W | H'00 | H'FFFFFE93 | 8 | ## 22.2 Register Description #### 22.2.1 Standby Control Register 1 (SBYCR1) Standby control register 1 (SBYCR1) is an 8-bit read/write register that sets the power-down mode. SBYCR is initialized to H'00 by a reset. Bit 7—Standby (SBY): Specifies transition to standby mode. To enter the standby mode, halt the WDT (set the TME bit in WTCSR to 0) and set the SBY bit. | Bit 7: SBY | Description | | |------------|--------------------------------------------------------------------|----------| | 0 | Executing a SLEEP instruction puts the chip into sleep mode value) | (Initial | | 1 | Executing a SLEEP instruction puts the chip into standby mode | | Bit 6—Port High Impedance (HIZ): Selects whether output pins are set to high impedance or retain the output state in standby mode. When HIZ = 0 (initial state), the specified pin retains its output state. When HIZ = 1, the pin goes to the high-impedance state. See Appendix A.1, Pin States during Resets, Power-Down States and Bus Release State, for which pins are controlled. | Bit 6: HIZ | Description | | |------------|--------------------------------------------|----------| | 0 | Pin state retained in standby mode value) | (Initial | | 1 | Pin goes to high impedance in standby mode | | Bit 5—Module Stop 5 (MSTP5): Specifies halting the clock supply to the user break controller (UBC). When the MSTP5 bit is set to 1, the supply of the clock to the UBC is halted. When the clock halts, the UBC registers retain their pre-halt state. Do not set this bit while the UBC is running. | Bit 5: MSTP5 | Description | | |--------------|----------------------------|----------| | 0 | UBC running value) | (Initial | | 1 | Clock supply to UBC halted | | Bit 4—Module Stop 4 (MSTP4): Specifies halting the clock supply to the DMAC. When MSTP4 bit is set to 1, the supply of the clock to the DMAC is halted. When the clock halts, the DMAC retains its pre-halt state. When MSTP4 is cleared to 0 and the DMAC begins running again, its starts operating from its pre-halt state. Set this bit while the DMAC is halted; this bit cannot be set while the DMAC is operating (transferring data). | Bit 4: MSTP4 | Description | | |--------------|-----------------------------|----------| | 0 | DMAC running value) | (Initial | | 1 | Clock supply to DMAC halted | | Bit 3—Module Stop 3 (MSTP3): Specifies halting the clock supply to the DSP unit. When the MSTP3 bit is set to 1, the supply of the clock to the DSP unit is halted. When the clock halts, the operation result prior to the halt is retained. This bit should be set when the DSP unit is halted. | Bit 3: MSTP3 | Description | | |--------------|----------------------------|----------| | 0 | DSP running value) | (Initial | | 1 | Clock supply to DSP halted | | Bit 2—Module Stop 2 (MSTP2): Specifies halting the clock supply to the division unit (DIVU). When the MSTP2 bit is set to 1, the supply of the clock to DIVU is halted. When the clock halts, the DIVU registers retain their pre-halt state. This bit should be set when the DIVU is halted. | Bit 2: MSTP2 | Description | | |--------------|-----------------------------|----------| | 0 | DIVU running value) | (Initial | | 1 | Clock supply to DIVU halted | | Bit 1—Module Stop 1 (MSTP1): Specifies halting the clock supply to the 16-bit free-running timer (FRT). When the MSTP1 bit is set to 1, the supply of the clock to the FRT is halted. When the clock halts, all FRT registers are initialized except the FRT interrupt vector register in INTC, which holds its previous value. When MSTP1 is cleared to 0 and the FRT begins running again, its starts operating from its initial state. #### Bit 1: MSTP1 Description | 0 | FRT running value) | (Initial | |---|----------------------------|----------| | 1 | Clock supply to FRT halted | | Bit 0—Module Stop 0 (MSTP0): Specifies halting the clock supply to the serial communication interface (SCI). When the MSTP0 bit is set to 1, the supply of the clock to the SCI is halted. When the clock halts, all SCI registers are initialized except the SCI interrupt vector register in INTC, which holds its previous value. When MSTP0 is cleared to 0 and the SCI begins running again, its starts operating from its initial state. Bit 0: MSTP0 Description | 0 | SCI running value) | (Initial | |---|----------------------------|----------| | 1 | Clock supply to SCI halted | | #### 22.2.2 Standby Control Register 2 (SBYCR2) Standby control register 2 (SBYCR2) is an 8-bit read/write register that sets the power-down mode state. SBYCR2 is initialized to H'00 by a reset. Bits 7 and 6—Reserved: These bits always read 0. The write value should always be 0. Bit 5—Module Stop 11 (MSTP11): Specifies halting the clock supply to the 16-bit timer pulse unit (TPU). When the MSTP11 bit is set to 1, the supply of the clock to the TPU is halted. When the clock halts, the TPU registers are initialized, but the TPU interrupt vector register in the INTC retains its pre-halt value. Therefore, when MSTP11 is cleared to 0 and the TPU begins running again, it starts operating from its initial state. #### Bit 5: MSTP11 Description | 0 | TPU running value) | (Initial | |---|----------------------------|----------| | 1 | Clock supply to TPU halted | | Bit 4—Module Stop 10 (MSTP10): Specifies halting the clock supply to SIO channel 2. When the MSTP10 bit is set to 1, the supply of the clock to SIO channel 2 is halted. When the clock halts, SIO channel 2 retains its pre-halt state, and the SIO channel 2 interrupt vector register in the INTC retains its pre-halt value. Therefore, when MSTP10 is cleared to 0 and the clock supply to SIO channel 2 is restarted, operation starts again. #### Bit 4: MSTP10 Description | 0 | SIO channel 2 running value) | (Initial | |---|--------------------------------------|----------| | 1 | Clock supply to SIO channel 2 halted | | Bit 3—Module Stop 9 (MSTP9): Specifies halting the clock supply to SIO channel 1. When the MSTP9 bit is set to 1, the supply of the clock to SIO channel 1 is halted. When the clock halts, SIO channel 1 retains its pre-halt state, and the SIO channel 1 interrupt vector register in the INTC retains its pre-halt value.. Therefore, when MSTP9 is cleared to 0 and the clock supply to SIO channel 1 is restarted, operation starts again. #### Bit 3: MSTP9 Description | 0 | SIO channel 1 running value) | (Initial | |---|--------------------------------------|----------| | 1 | Clock supply to SIO channel 1 halted | | Bit 2—Module Stop 8 (MSTP8): Specifies halting the clock supply to SIO channel 0. When the MSTP8 bit is set to 1, the supply of the clock to SIO channel 0 is halted. When the clock halts, SIO channel 0 retains its pre-halt state, and the SIO channel 0 interrupt vector register in the INTC retains its pre-halt value. Therefore, when MSTP8 is cleared to 0 and the clock supply to SIO channel 0 is restarted, operation starts again. #### Bit 2: MSTP8 Description | 0 | SIO channel 0 running value) | (Initial | |---|--------------------------------------|----------| | 1 | Clock supply to SIO channel 0 halted | | Bit 1—Module Stop 7 (MSTP7): Specifies halting the clock supply to SCIF2. When the MSTP7 bit is set to 1, the supply of the clock to SCIF2 is halted. When the clock halts, the SCIF2 registers are initialized, but the SCIF2 interrupt vector register in the INTC retains its pre-halt value. Therefore, when MSTP7 is cleared to 0 and SCIF2 begins running again, it starts operating from its initial state. #### Bit 1: MSTP7 Description | 0 | SCIF2 running value) | (Initial | |---|------------------------------|----------| | 1 | Clock supply to SCIF2 halted | | Bit 0—Module Stop 6 (MSTP6): Specifies halting the clock supply to SCIF1. When the MSTP6 bit is set to 1, the supply of the clock to SCIF1 is halted. When the clock halts, the SCIF1 registers are initialized, but the SCIF1 interrupt vector register in the INTC retains its pre-halt value. Therefore, when MSTP6 is cleared to 0 and SCIF1 begins running again, it starts operating from its initial state. #### Bit 0: MSTP6 Description | 0 | SCIF1 running value) | (Initial | |---|------------------------------|----------| | 1 | Clock supply to SCIF1 halted | | ## 22.3 Sleep Mode ## 22.3.1 Transition to Sleep Mode Executing the SLEEP instruction when the SBY bit in SBYCR 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 peripheral modules continue to run in sleep mode. #### 22.3.2 Canceling Sleep Mode Sleep mode is canceled by an interrupt, DMA address error, power-on reset, or manual reset. Cancellation by an Interrupt: When an interrupt occurs, sleep mode is canceled and interrupt exception handling is executed. Sleep mode is not canceled if the interrupt cannot be accepted because its priority level is equal to or less than the mask level set in the CPU's status register (SR) or if an interrupt by an on-chip peripheral module is disabled at the peripheral module. **Cancellation by a DMA Address Error:** If a DMA address error occurs, sleep mode is canceled and DMA address error exception handling is executed. Cancellation by a Power-On Reset: A power-on reset cancels sleep mode. Cancellation by a Manual Reset: A manual reset cancels sleep mode. # 22.4 Standby Mode #### 22.4.1 Transition to Standby Mode To enter standby mode, set the SBY bit to 1 in SBYCR1, then execute the SLEEP instruction. The chip switches from the program execution state to standby mode. The NMI interrupt cannot be accepted when the SLEEP instruction is executed, or for the following five cycles. In standby mode, power consumption is greatly reduced by halting not only the CPU, but the clock and on-chip peripheral modules as well. CPU register contents are held, and some on-chip peripheral modules are initialized. Table 22.3 Register States in Standby Mode | Module | Registers Initialized | Registers that Retain<br>Data | Registers with<br>Undefined Contents | |----------------------------------------------------------|-----------------------------------------------------------------------------------------|--------------------------------------------------------------------------|--------------------------------------| | Interrupt controller (INTC) | _ | All registers | _ | | User break controller (UBC) | _ | All registers | _ | | Bus state controller (BSC) | _ | All registers | _ | | Direct Memory<br>Access Controller<br>(DMAC) | DMA channel control register 0 DMA channel control | All registers except DMA channel control register 0, DMA channel control | _ | | | register 1 DMA operation register | register 1, and DMA operation register | | | Division Unit(DIVU) | | _ | All registers | | Watchdog timer (WDT) | Bits 7 to 5 of the timer<br>control/status register<br>Reset control/status<br>register | Bits 2 to 0 of the timer<br>control/status register<br>Timer counter | _ | | 16-bit free-running timer (FRT) | All registers | _ | _ | | Serial communication interface (SCI) | All registers | _ | _ | | Serial communication<br>interface with FIFO<br>(SCIF1–2) | All registers | _ | _ | | Serial I/O (SIO0-2) | _ | All registers | _ | | Hitachi user debug interface (H-UDI) | _ | All registers | _ | | 16-bit timer pulse unit (TPU) | _ | All registers | _ | | Pin function controller (PFC) | _ | All registers | _ | | Others | _ | Standby control register 1, 2 | _ | | | | Frequency modification register | | #### 22.4.2 Canceling Standby Mode Standby mode is canceled by an NMI interrupt, a power-on reset, or a manual reset. **Cancellation by an NMI Interrupt:** When a rising edge or falling edge is detected in the NMI signal, after the elapse of the time set in the WDT timer control/status register, clocks are supplied to the entire chip, standby mode is canceled, and NMI exception handling begins. Cancellation by a Power-On Reset: A power-on reset cancels standby mode. Cancellation by a Manual Reset: A manual reset cancels standby mode. #### 22.4.3 Standby Mode Cancellation by NMI Interrupt The following example describes moving to the standby mode upon the fall of the NMI signal and clearing the standby when the NMI signal rises. Figure 22.1 shows the timing. When the NMI pin level changes from high to low after the NMI edge select bit (NMIE) of the interrupt control register (ICR) has been set to 0 (detect falling edge), an NMI interrupt is accepted. When the NMIE bit is set to 1 (detect rising edge) by the NMI exception service routine, the standby bit (SBY) of the standby control register 1 (SBYCR1) is set to 1 and a SLEEP instruction is executed, the standby mode is entered. The standby mode is cleared the next time the NMI pin level changes from low level to high level. Figure 22.1 Standby Mode Cancellation by NMI Interrupt #### 22.4.4 Clock Pause Function If the clock is input from the CKIO terminal, the frequency of the clock can be changed, and the clock itself can be stopped. This LSI has $\overline{\text{CKPREQ}}/\text{CKM}$ terminals for this reason. However, during operation of the watchdog timer (WDT)(when Timer control of WDT /Timer enable bit(TME) of status register(WTCSR) are 1),the clock pose can not be accepted. And also, if the clock pose request function is used, input the request signal after setting standby bit(SBY) of standby control register 1(SBYCR1) to 1without fail. The clock pose function can be used as follows: - 1. Set TME bit of WTCSR in WDT to 0, and set SBY bit of SBYCR1 to 1. - 2. Low level is applied to CKPREQ/CKM terminals - When LSI internal part transits to standby condition, low level from CKPACK terminal is output. - 4. After confirming that the CKPACK terminal became low level, perform stop of the clock or change of frequency. - 5. In order to deselect the clock pose condition( standby status), apply high level power to CKPREQ/CKM terminals. (In LSI internal part, standby status is deselected by detecting rising edge of CKPREQ/CKM terminals.) - 6. When the PLL circuit 1 is operating, WDT starts count-up in LSI internal part. If the PLL circuit 1 is in the stopped condition, WDT does not start. - 7. As the internal clock is stable, $\overline{\text{CKPACK}}$ terminal changes high level, and take a notice to the outside that LSI became enable condition. Furthermore, standby status by the clock pose, each built-in peripheral module condition and terminal conditions become the same condition as normal standby mode. Timing chart of the clock pose function in the operating condition of PLL circuit 1 is shown in fig.22.2. Figure 22.2 Clock Pause Function Timing Chart (When PLL circuit 1 operated) Timing chart of the clock pose function in the stopped condition of PLL circuit 1 is shown in fig.22.3 Fig.22.3 Timing Chart of Clock Pose Function (When PLL circuit 1 stopped) As with normal standby condition, the clock pose condition can be also reset by NMI input. However, reset the clock pose request within 4 cycles of CKIO clock after NMI input. Timing chart of the clock pose condition reset by NMI input(when fall edge detected) is shown in fig.22.4. Fig.22.4 Timing Chart of Clock Pose Function (reset by NMI input) #### 22.4.5 Notes on Standby Mode - When the SH7612 enters standby mode during use of the cache, disable the cache before making the mode transition. Initialize the cache beforehand when the cache is used after returning to standby mode. The contents of the on-chip RAM are not retained in standby mode when cache is used as on-chip RAM. - 2. If an on-chip peripheral register is written in the 10 clock cycles before the SH7612 transits to standby mode, read the register before executing the SLEEP instruction. - 3. When using clock mode 0, 1, or 2, the CKIO pin is the clock output pin. Note the following when standby mode is used in these clock modes. When standby mode is canceled by NMI, an unstable clock is output from the CKIO pin during the oscillation settling time after NMI input. This also applies to clock output in the case of cancellation by a power-on reset or manual reset. Power-on reset and manual reset input should be continued for a period at least equal to for the oscillation settling time. ## 22.5 Module Standby Function #### 22.5.1 Transition to Module Standby Function By setting one of bits MSTP11—MSTP0 to 1 in standby control register 1 or 2, the supply of the clock to the corresponding on-chip peripheral module can be halted. This function can be used to reduce the power consumption. Do not perform read/write operations for a module in module standby mode. With the module standby function, the external pins of the DMAC and SIO0–SIO2 on-chip peripheral modules retain their states prior to halting, as do DMAC, DSP, DIVU, and SIO0–SIO2 registers. The external pins of the FRT, SCF1/SCF2, TPU, and SCI are reset and all their registers are initialized. Do not switch an on-chip peripheral module to the module standby state while it is running. Also, interrupts from a module placed in the module stop state should be disabled. #### 22.5.2 Clearing the Module Standby Function Clear the module standby function by clearing the MSTP11–MSTP0 bits, or by a power-on reset or manual reset. # Section 23 Electrical Characteristics # 23.1 Absolute Maximum Ratings Table 23.1 shows the absolute maximum ratings. **Table 23.1 Absolute Maximum Ratings** | Item | Symbol | Rating | Unit | |-----------------------|-----------------|-------------------------------|------| | Power supply voltage | V <sub>CC</sub> | -0.3 to +4.3 | V | | Input voltage | Vin | -0.3 to V <sub>CC</sub> + 0.3 | V | | Operating temperature | Topr | -20 to +75 | °C | | Storage temperature | Tstg | -55 to +125 | °C | Caution: Operating this LSI in excess of the absolute maximum rating may result in permanent damage. # 23.2 DC Characteristics Tables 23.2 and 23.3 show DC characteristics. Table 23.2 DC Characteristics (Conditions: $V_{CC}$ = 3.0 to 3.6 V, Ta = -20 to +75° C) | Item | | Symbol | Min | Тур | Max | Unit | <b>Test Conditions</b> | |---------------------------------|----------------------------------|------------------|-----------------------|-----|-----------------------|------|--------------------------------------| | Input<br>high-level<br>voltage | RES, TRST,<br>NMI, MD5-MD0 | VIH | V <sub>CC</sub> ×0.9 | _ | V <sub>CC</sub> + 0.3 | V | During standby | | | | | $V_{CC} \times 0.9$ | _ | V <sub>CC</sub> + 0.3 | V | Normal operation | | | EXTAL, CKIO | _ | $V_{CC} \times 0.9$ | _ | V <sub>CC</sub> + 0.3 | V | | | | Other input pins | _ | $V_{CC} \times 0.7$ | _ | V <sub>CC</sub> + 0.3 | V | | | Input<br>low- level<br>voltage | RES, TRST,<br>NMI, MD5–MD0 | VIL | -0.3 | _ | V <sub>CC</sub> ×0.1 | V | During standby | | | | | -0.3 | _ | V <sub>CC</sub> ×0.1 | V | Normal operation | | | Other input pins | _ | -0.3 | _ | V <sub>CC</sub> ×0.1 | V | | | Input leak current | All input pins | lin | _ | _ | 1.0 | μΑ | $Vin = 0.5 \text{ to } V_{CC} - 0.5$ | | 3-state<br>leak<br>current | Input output,<br>output all pins | I <sub>STi</sub> | _ | _ | 1.0 | μΑ | Vin = 0.5 to V <sub>CC</sub> – 0.5 V | | Output<br>high-level<br>voltage | All output pins | VOH | V <sub>CC</sub> – 0.5 | _ | _ | V | Ι <sub>ΟΗ</sub> = –200 μΑ | | | | | V <sub>CC</sub> – 1.0 | _ | _ | V | $I_{OH} = -1 \text{ mA}$ | | Output low level voltage | All output pins | V <sub>OL</sub> | _ | _ | 0.4 | V | I <sub>OL</sub> = 1.6 mA | | Input<br>capaci-<br>tance | CAP1, CAP2 | Cin | _ | _ | 20 | pF | Vin = 0 V<br>f = 1 MHz | | | Other all input pins | | _ | _ | 15 | pF | Ta = 25°C | Table 23.2 DC Characteristics (Conditions: $V_{CC} = 3.0$ to 3.6 V, Ta = -20 to $+75^{\circ}$ C) (cont) | Item | | Symbol | Min | Тур | Max | Unit | Test Conditions | |----------|-----------|-----------------|-----|-----|-------|------|----------------------| | Current | Normal | I <sub>CC</sub> | _ | _ | T.B.D | mA | _ | | consump- | operation | | _ | _ | T.B.D | mΑ | | | tion | | _ | _ | _ | T.B.D | mΑ | | | | Sleep | | _ | _ | T.B.D | mΑ | | | | | | _ | _ | T.B.D | mΑ | | | | | _ | _ | _ | T.B.D | mΑ | | | | Standby | | _ | 5 | 20 | μΑ | Ta <sup>2</sup> 50°C | | | | | _ | _ | 300 | μΑ | 50°C < Ta | Notes: 1. When no PLL is used, do not leave the $PLLV_{CC}$ and $PLLV_{SS}$ pins open. Connect $PLLV_{CC}$ to $V_{CC}$ and $PLLV_{SS}$ to $V_{SS}$ . Table 23.3 Permitted Output Current Values (Conditions: $V_{CC}$ = 3.0 - 3.6 V , Ta = -20 to +75°C) | Item | Symbol | Min | Тур | Max | Unit | |-------------------------------------------------|----------------------|-----|-----|-----|------| | Output low-level permissible current (per pin) | I <sub>OL</sub> | _ | _ | 2.0 | mA | | Output low-level permissible current (total) | _ I <sub>OL</sub> | _ | _ | 80 | mA | | Output high-level permissible current (per pin) | -I <sub>OH</sub> | _ | _ | 2.0 | mA | | Output high-level permissible current (total) | _(-I <sub>OH</sub> ) | _ | _ | 25 | mA | Note: To ensure the chip reliability, do not exceed the output current values given in table 16.3. <sup>2.</sup> Current consumption values shown are the values at which all output pins are under conditions of $V_{IH}$ min = $V_{CC}$ – 0.5 V, $V_{IL}$ max = 0.5 V, without loading. ## 23.3 AC Characteristics The LSI input is the clock synchronous input in principle. Unless otherwise stated, be sure to observe the setup hold time of each input signal. Table 23.4 Maximum Operating Frequency (Conditions: $V_{CC}$ = 3.0 to 3.6 V, Ta = -20 to +75°C) | Item | | Symbol | Min | Тур | Max | Unit | |---------------------|-----------------------------------------|--------|-----|-----|-----|------| | Operating frequency | CPU, DSP | f | 1 | _ | 60 | MHz | | | External bus | f | 1 | _ | 30 | MHz | | | (When SDRAM is unassigned) | | | | | | | | External bus<br>(When SDRAM is<br>used) | f | 1 | _ | 60 | MHz | | | Peripheral modules | f | 1 | _ | 30 | MHz | # 23.3.1 Bus Timing Table 23.4 Bus Timing With PLL On [Mode 0, 4] $(Conditions:\ V_{CC}=3.0\ to\ 3.6\ V,\ Ta=-20\ to\ +75^{\circ}C)$ | Item | Symbol | Min | Max | Unit | Figures | |------------------------------------------|-------------------|--------------|---------------|------|---------| | Address delay time | t <sub>AD</sub> | _ | 10 | ns | | | BS delay time | t <sub>BSD</sub> | _ | 15 | ns | | | CS delay time 1 | t <sub>CSD1</sub> | _ | 10 | ns | | | CS delay time 2 | t <sub>CSD2</sub> | _ | 1/2 tcyc + 10 | ns | _ | | Read/write delay time | t <sub>RWD</sub> | _ | 12 | ns | _ | | Read strobe delay time 1 | t <sub>RSD1</sub> | _ | 1/2 tcyc + 10 | ns | | | Read data setup time 1 | t <sub>RDS1</sub> | 1/2 tcyc + 8 | _ | ns | _ | | Read data setup time 3 (SDRAM) | t <sub>RDS3</sub> | 1/2 tcyc + 8 | _ | ns | | | Read data hold time 2 | t <sub>RDH2</sub> | 3 | _ | ns | | | Read data hold time 4 (SDRAM) | t <sub>RDH4</sub> | 0 | _ | ns | | | Read data hold time 5 (DRAM) | t <sub>RDH5</sub> | 0 | _ | ns | | | Read data hold time 6 (EDO) | t <sub>RDH6</sub> | 3 | _ | ns | | | Read data hold time 7 (interrupt vector) | t <sub>RDH7</sub> | 0 | _ | ns | | | Write enable delay time 1 | t <sub>WED1</sub> | _ | 1/2 tcyc + 10 | ns | | | Write data delay time | t <sub>WDD</sub> | _ | 15 | ns | | | Write data hold time 1 | t <sub>WDH1</sub> | 0 | _ | ns | | | Data buffer on time | t <sub>DON</sub> | _ | 15 | ns | | | Data buffer off time | t <sub>DOF</sub> | _ | 15 | ns | | Table 23.5 Bus Timing With PLL On [Mode 0, 4] (cont) $(Conditions: V_{CC} = 3.0 \ to \ 3.6 \ V, Ta = -20 \ to \ +75^{\circ}C)$ | Item | Symbol | Min | Max | Unit | Figures | |--------------------------|--------------------|----------------|---------------|------|---------| | DACK delay time 1 | t <sub>DACD1</sub> | _ | 10 | ns | | | DACK delay time 2 | t <sub>DACD2</sub> | _ | 1/2 tcyc + 10 | ns | | | WAIT setup time | t <sub>WTS</sub> | 1/2 tcyc + 10 | _ | ns | | | WAIT hold time | t <sub>WTH</sub> | -1/2 tcyc + 5 | _ | ns | | | RAS delay time 1 (SDRAM) | t <sub>RASD1</sub> | _ | 8 | ns | | | RAS delay time 2 (DRAM) | t <sub>RASD2</sub> | _ | 1/2 tcyc + 8 | ns | | | RAS delay time 3 (EDO) | t <sub>RASD3</sub> | _ | 8 | ns | | | CAS delay time 1 (SDRAM) | t <sub>CASD1</sub> | _ | 8 | ns | | | CAS delay time 2 (DRAM) | t <sub>CASD2</sub> | _ | 1/2 tcyc + 8 | ns | | | DQM delay time | t <sub>DQMD</sub> | _ | 15 | ns | | | CKE delay time | t <sub>CKED</sub> | _ | 20 | ns | | | OE delay time 1 | t <sub>OED1</sub> | _ | 1/2 tcyc + 8 | ns | | | OE delay time 2 | t <sub>OED2</sub> | _ | 8 | ns | | | IVECF delay time | t <sub>IVD</sub> | _ | 15 | ns | | Figure 23.1 Basic Read Cycle (No Waits, PLL On) Figure 23.2 Basic Write Cycle (No Waits, PLL On) Figure 23.3 Basic Bus Cycle (1 Wait Cycle) Figure 23.4 Basic Bus Cycle (External Wait Input) Figure 23.5 SDRAM Read Bus Cycle (RCD = 1 Cycle, CAS Latency = 1 Cycle, Bursts = 4, PLL On) Figure 23.6 SDRAM Single Read Bus Cycle (RCD = 1 Cycle, CAS Latency = 1 Cycle, Bursts = 4, PLL On) Figure 23.7 SDRAM Read Bus Cycle (RCD = 2 Cycles, CAS Latency = 2 Cycles, Bursts = 4) Figure 23.8 SDRAM Read Bus Cycle (Bank Active, Same Row Access, CAS Latency = 1 Cycle) Figure 23.9 SDRAM Read Bus Cycle (Bank Active, Same Row Access, CAS Latency = 2 Cycles) Figure 23.10 SDRAM Read Bus Cycle (Bank Active, Different Row Access, TRP = 1 Cycle, RCD = 1 Cycle, CAS Latency = 1 Cycle) Figure 23.11 SDRAM Read Bus Cycle (Bank Active, Different Row Access, TRP = 2 Cycles, RCD = 1 Cycle, CAS Latency = 1 Cycle) Figure 23.12 SDRAM Write Bus Cycle (RASD = 0, RCD = 1 Cycle, TRWL = 1 Cycle, PLL On) Figure 23.13 SDRAM Write Bus Cycle (RASD = 0, RCD = 2 Cycles, TRWL = 2 Cycles) Figure 23.14 SDRAM Write Bus Cycle (Bank Active, Same Row Access) Figure 23.15 SDRAM Consecutive Write Cycles (Bank Active, Same Row Access) Figure 23.16 SDRAM Write Bus Cycle (Bank Active, Different Row Access, TRP = 1 Cycle, RCD = 1 Cycle) Figure 23.17 SDRAM Write Bus Cycle (Bank Active, Different Row Access, TRP = 2 Cycles, RCD = 2 Cycles) Figure 23.18 SDRAM Mode Register Write Cycle (TRP = 1 Cycle) Figure 23.19 SDRAM Mode Register Write Cycle (TRP = 2 Cycles) Figure 23.20 SDRAM Auto-Refresh Cycle (TRAS = 4 Cycles) Figure 23.21 Synchronous DRAM Auto-Refresh Cycle (Shown From Precharge Cycle, TRP = 1 Cycle, TRAS = 4 Cycles) Figure 23.22 Synchronous DRAM Self-Refresh Cycle (TRAS = 3) Figure 23.23 DRAM Read Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.24 DRAM Write Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.25 DRAM Bus Cycle (TRP = 2 Cycles, RCD = 2 Cycles, 1 Wait) Figure 23.26 DRAM Bus Cycle (TRP = 1 Cycle, RCD = 1 Cycle, External Wait Input) Figure 23.27 DRAM Burst Read Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.28 DRAM Burst Write Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.29 EDO Read Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.30 EDO Write Cycle (TRP = 1 Cycle, RCD = 1 Cycle, No Waits, PLL On) Figure 23.31 DRAM CAS-Before-RAS Refresh Cycle (TRP = 1 Cycle, TRAS = 2 Cycles, PLL On) Figure 23.32 Burst ROM Read Cycle (PLL On, 1 Wait) Figure 23.34 Interrupt Vector Fetch Cycle (PLL On, No Waits, I\u03c4 : E\u03c4 = 1:1) Figure 23.35 Interrupt Vector Fetch Cycle (1 External Wait Cycle) ## Appendix A Pin States ## A.1 Pin States in Reset, Power-Down State, and Bus-Released State Pin State | Power-On Pin Name Power-On Reset Released R | Bus-<br>Released | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------| | Pin Type Pin Name Reset Acquired Released Mode Mode Mode | State IO*1 I*1 O*1 I | | EXTAL I*1 | *1<br> O*1<br> | | XTAL O*1 | O*1 | | CKPREQ/CKM I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I <td>ı</td> | ı | | CKPACK H | | | MDTOVF/PA7 H H/IO H/IO O/K*3 O/IO BGR H O O H O BRLS Z I I Z I MD4-MD0 I I I I I I I Interrupt NMI I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I <td>Н</td> | Н | | WDTOVF/PA7 H | | | BGR H O O H O BRLS Z I I Z I MD4-MD0 I I I I I I Interrupt NMI I I I I I I I | I | | BRLS Z I I Z I MD4-MD0 I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I | O/IO | | MD4-MD0 I I I I I I Interrupt NMI I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I I | 0 | | Interrupt NMI I I I I I | I | | | I | | | I | | | I | | IVECF H H H H*3 H | Н | | Address bus A24–A0 O O Z Z O | Z | | Data bus D31–D0 Z IO Z Z Z | Z | | Bus control $\overline{\text{CS4}} - \overline{\text{CS0}}$ H O Z H H | Z | | BS H O Z H H | Z | | RD/WR H O Z H H | Z | | RAS H O Z H H | Z | | CAS/OE H O Z H H | Z | | DQMUU/WE3 H O Z H H | Z | | DQMUL/WE2 H O Z H H | Z | | DQMLU/WE1 H O Z H H | Z | | DQMLL/WEO H O Z H H | Z | | CAS3-CAS0 H O Z H H | Z | | RD H O Z H H | Z | | CKE H O H O O | | | WAIT Z I Z Z I | Н | | REFOUT L L L*3 L | H<br>Ignored | | | | Pin State | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------|-----------------|-----------------|---------------------------------------------------|---------------|-------------------|--| | | | | Manual Reset | | Power-Down State | | Bus- | | | Pin Type | Pin Name | Power-On<br>Reset | Bus<br>Acquired | Bus<br>Released | Standby<br>Mode | Sleep<br>Mode | Released<br>State | | | Direct memory access controller (DMAC) | DACK1-<br>DACK0 | Н | Н | Н | K*3 | 0 | 0 | | | • | DREQ1-<br>DREQ0 | Z | Z | Z | Z | 1 | I | | | 16-bit free-running timer (FRT) | FTCI/PA6 | Z | Z/IO | Z/IO | K*3 | I/IO | I/IO | | | | FTCI/PA5 | Z | Z/IO | Z/IO | K*3 | I/IO | I/IO | | | | FTOA/PA4 | L | L/IO | L/IO | K*3 | O/IO | O/IO | | | | FTOB/CKPO | L | L/IO | L/IO | K*3 | O/IO | O/IO | | | Serial communication interface(SCI) | SCK/PA2 | Z | Z/IO | Z/IO | K* <sup>3</sup> | IO/IO | IO/IO | | | | RxD/PA1 | Z | Z/IO | Z/IO | K*3 | I/IO | I/IO | | | | TxD/PA0 | Z | Z/IO | Z/IO | K*3 | I/IO | I/IO | | | Serial I/O (SIO)/ serial communication interface (SCI)/ Serial communication nterface with FIFO (SCIF)/ 16-bit timer pulse unit (TPU) | PB15/SRCK0/<br>SCK2 | Z | IO/Z/Z | IO/Z/Z | K* <sup>3</sup> /K* <sup>3</sup> /K* <sup>3</sup> | IO/I/IO | IO/I/IO | | | | PB14/SRS0/<br>RxD2 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/I | IO/I/I | | | | PB13/SRXD0/<br>TxD2 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/O | IO/I/O | | | | PB12/STCK0/<br>SCK1 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/IO | IO/I/IO | | | | PB11/STS0/<br>RxD1 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/IO/I | IO/IO/I | | | | PB10/STXD0/<br>TxD1 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | 10/0/0 | IO/O/O | | | | PB9/SRCK1/<br>RTS | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/O | IO/I/O | | | | PB8/SRS1/<br>CTS | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/I | IO/I/I | | | | PB7/SRXD1/<br>TIOCA2 | Z | IO/Z/Z | IO/Z/Z | K* <sup>3</sup> /K* <sup>3</sup> /K* <sup>3</sup> | IO/I/IO | IO/I/IO | | | | PB6/STCK1/<br>TIOCB2/<br>TCLKD | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/IO | IO/I/IO | | | | PB5/STS1/<br>TIOCA1 | Z | IO/Z/Z | IO/Z/Z | K* <sup>3</sup> /K* <sup>3</sup> /K* <sup>3</sup> | IO/IO/IO | IO/IO/IO | | | | PB4/STXD1/<br>TIOCB1/<br>TCLKC | Z | IO/Z/Z | IO/Z/Z | K* <sup>3</sup> /K* <sup>3</sup> /K* <sup>3</sup> | IO/O/IO | IO/O/IO | | ## Pin State **Power-Down State** Sleep Standby Bus- Released **Manual Reset** Bus | Pin Type | Pin Name | Reset | Acquired | Released | Mode | Mode | State | |----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-------|----------|----------|---------------------------------------------------|---------|---------| | Serial I/O (SIO)/<br>serial communication<br>interface (SCI)/<br>serial communication<br>interface with FIFO (SCIF)/<br>16-bit timer pulse unit<br>(TPU) | PB3/SRCK2/<br>TIOCA0 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/IO | IO/I/IO | | | PB2/SRS2/<br>TIOCB0 | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/IO | IO/I/IO | | | PB1/SRXD2/<br>TIOCC0/<br>TCLKA | Z | IO/Z/Z | IO/Z/Z | K* <sup>3</sup> /K* <sup>3</sup> /K* <sup>3</sup> | IO/I/IO | IO/I/IO | | | PB0/STCK2/<br>TIOCD0/<br>TCLKB | Z | IO/Z/Z | IO/Z/Z | K*3/K*3/K*3 | IO/I/IO | IO/I/IO | | | PA9/STS2 | Z | IO/Z | IO/Z | K*3/K*3 | IO/IO | IO/IO | | | PA8/STXD2 | Z | IO/Z | IO/Z | K*3/K*3 | IO/O | IO/O | | Hitachi user debug interface<br>(Hitachi-UDI) | TRST | I | I | I | I | I | I | | | TCK/PA13 | I | I/IO | I/IO | I/K*3 | I/IO | I/IO | | | TMS/PA12 | 1 | I/IO | I/IO | I/K*3 | I/IO | I/IO | | | TDI/PA11 | 1 | I/IO | I/IO | I/K*3 | I/IO | I/IO | | | TDO/PA10 | 0 | O/IO | O/IO | O/K*3 | O/IO | O/IO | Power-On Bus I: Input O: Output H: High-level output L: Low-level output Z: High-impedance state K: Input pins are in the high-impedance state; output pins maintain their previous state. Notes: In sleep mode, if the DMAC is operating the address/data bus and bus control signals vary according to the operation of the DMAC. (The same applies when refreshing is performed.) - 1. Depends on the clock mode (MD2-MD0 setting). - 2. Low-level output in clock pause standby mode. - 3. When the high-impedance bit (HIZ) is set to 1 in the standby control register (SBYCR), output pins go to the high-impedance state. ## Appendix B Package Dimensions Figure B.1 shows the SH7612 package dimensions (FP-176). Figure B.1 Package Dimensions (FP-176)