# PRELIMINARY M30240 ## M30240 Group Specification | Description | 1-3 | |--------------------------------------------------|-------| | Features | | | Applications | | | Pin Configuration | | | Block Diagram | | | Performance outline | | | Pin Description | | | Overview | | | Operation of Functional Blocks | | | Central Processing Unit (CPU) | 1-11 | | Processor Mode | | | Memory | | | SFR MAP | | | Reset | 1-22 | | Software Reset | | | Clock-Generating Circuit | 1-23 | | Clock Control | | | Stop Mode | | | Wait Mode | | | Status Transition Of the Internal Clock $\Phi$ . | | | Power Control | | | Protection | | | Interrupts | 1-29 | | NMI Interrupt | | | Key-Input Interrupt | | | Address Match Interrupt | | | Watchdog Timer | 1-39 | | Frequency Synthesizer Circuit | | | Universal Serial Bus | 1-44 | | DMAC | 1-63 | | Timers | 1-68 | | Timer A | 1-69 | | Timer B | 1-80 | | UART0 through UART2 | 1-83 | | A-D Converter | | | CRC Calculation Circuit | 1-116 | | Programmable I/O Ports | | | Usage | 1-124 | | Usage Precautions | 1-124 | | Specifications | 1-128 | | Electrical | | | Timing | | | Timing Diagrams- Peripheral/interrupt | 1-133 | | Applications | | | Frequency Synthesizer Interface | | | and DC-DC Converter | 1-134 | | Attach/Detach Function | | | Low Pass Filter Network | | | USB Transceiver | | | Programming Notes | 1-141 | | | | **Features** ## 1.0 Description The M30240 group is a 16-bit microcomputer based on the M16C family core technology. They are single-chip USB peripheral microcontrollers based on the Universal Serial Bus (USB) Version 1.1 specification. They are packaged in an 80-pin, molded plastic QFP. These single-chip microcontrollers operate using sophisticated instructions featuring a high level of instruction efficiency, making them capable of executing instructions at high speed. They also feature a built-in multiplier and DMAC, making them ideal for controlling office communications, industrial equipment, and other high-speed processing applications. #### 1.1 Features | • CPU | , , | |------------------------------------------------------------------|-----------------------------------------------------------------------------| | Number of instructions Shortest instruction execution time. | | | Shortest instruction execution time | | | USB Features: | FIFO Sizes (endpoints 0-4):32,128, 32, 32 | | | Conforms to USB V1.1 Specification | | USB Transceiver | . Conforms to USB V1.1 Specification-Internal Vref | | Frequency Synthesizer | | | Memory capacity (mask device): | | | Memory capacity (OTP device): | . PROM (128K) / RAM (5K) | | Supply Voltage | . 4.1 to 5.25V f(XIN)=12MHz) | | Interrupts | . 21 internal and 4 external interrupt sources, | | | 4 software interrupt sources; 7 levels (including key input interrupt X 16) | | Multifunction timer | . 5 X 16-bit, w/integrated 20mA (peak) PWM outputs | | General purpose timer | . 3 X 16-bit, internal interrupt only | | • UART | · | | | Configurable for synchronous or asynchronous mode | | • DMAC | | | A-D Converter | . 10 bits X 8 channels | | CRC calculation circuit | . 1 circuit (industry standard polynomial) | | Watchdog timer | . 1 line (15 bit) | | Programmable I/O | | | High current and LED Drivers | - | | - | . 1 built-in circuit including feedback resistor | | Package: | . 80P6N (0.8 mm pitch) | | | | ## 1.2 Applications USB peripherals, such as telephones, audio systems, scanners, and digital cameras. Pin Configuration ## 1.3 Pin Configuration Figure 1.1 shows the pin configuration (top view). Figure 1.1: Pin Configuration (top view) **Block Diagram** ## 1.4 Block Diagram Figure 1.2 is a block diagram of the M30240 group. Figure 1.2: Block diagram of M30240 group Performance outline ## 1.5 Performance outline Table 1.1 is a performance outline of the M30240 group. #### **Table 1.1:** Performance outline of M30240 group | Item | | Performance | | | |------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Number of basic instructions | | 91 instructions | | | | Shortest instruction execu | ution time | 83ns (f(XIN) =12MHz) | | | | Manager | ROM | (0. 5: 0. 501) | | | | Memory capacity | RAM | (See Figure 3: ROM capacity field) | | | | I/O port | P0 to P3, P6,P7, P8 (except P85), P10 | 8 bits x 7, 7 bits x 1 | | | | Input port | P85 | 1 bit x 1 | | | | Multifunction Timer | TA0, TA1, TA2, TA3, TA4 | 16 bits x 5 | | | | General purpose Timer | TB0, TB1, TB2 | 16 bits x 3 | | | | Serial I/O | UART0, UART1, UART2 | (UART or clock synchronous) x 3 | | | | A-D converter | | 10 bits x 8 channels | | | | DMAC | | 2 channels (trigger:18 sources) | | | | CRC calculation circuit | | CRC-CCITT | | | | Watchdog timer | | 15 bits x 1 (with prescaler) | | | | Interrupt | | 21 internal and 4 external sources, 4 software sources, 7 levels | | | | Clock-generating circuit | | Built-in clock generation circuit (built-in feedback resistor, and external ceramic or quartz oscillator) | | | | Supply voltage (typical) | | 4.1 to 5.25V, (f(XIN)=12MHz, without software wait) | | | | Power consumption (typic | al) | 250 mwatt, Vcc=5.0V, 12MHz | | | | | I/O withstand voltage | 5V | | | | I/O characteristics | Average output current | 5 mA available on ports P0, P1, P3,P6, P7 <sub>1</sub> , P7 <sub>3</sub> , P7 <sub>5</sub> , P7 <sub>7</sub> , P8 <sub>1</sub> ~P8 <sub>4</sub> , P8 <sub>6</sub> , P8 <sub>7</sub> , P10 10 mA available on ports P2, P7 <sub>0</sub> , P7 <sub>2</sub> , P7 <sub>4</sub> , P7 <sub>6</sub> , P8 <sub>0</sub> | | | | Operating temperature | | 0 to 70°C | | | | Device configuration | | CMOS high performance silicon gate | | | | Package | | 80-pin plastic molded QFP | | | #### Performance outline Mitsubishi plans to release the following products in the M30240 group: - (1) Support for mask ROM version and one-time PROM version - (2) ROM capacity - (3) Package - 80P6N: Plastic molded QFP (mask ROM version and one-time PROM version) Figure 1.3 shows the type number, memory size and package for the M30240 group. Figure 1.3: Type number, memory size, and package Table 1.2 shows the Package Number, type, ROM and RAM Capacity for M30240 Group. **Table 1.2:** M30240 Group | Туре | ROM Capacity | RAM Capacity | Package Type | Remarks | |------------|--------------|--------------|--------------|-----------------------| | M30240M5 | 40K bytes | 3K bytes | 80P6N | Mask ROM Version | | M30240M6 | 48K bytes | 3K bytes | 80P6N | Mask ROM Version | | M30240ECFP | 128K bytes | 5K bytes | 80P6N | One-time PROM version | Pin Description ## 1.6 Pin Description #### **Table 1.3: Figure Pin Description** | Pin# | Name | I/O | Description | |-------|--------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | P8 <sub>7</sub> | I/O | CMOS I/O port. This pin also functions as an external trigger for A-D conversion. | | 2 | P8 <sub>6</sub> | I/O | CMOS I/O port. This pin also functions as the start of frame (SOF) pulse for the USB module. | | 3 | P8 <sub>5</sub> /(NMI) | I | CMOS input port. This pin also functions as a non-maskable external interrupt. | | 4,5 | P8 <sub>4</sub> ~ P8 <sub>3</sub> | I/O | CMOS I/O port. These pins also functions as external interrupt 1 and are used to enable the stealth detach function for the USB transceiver. | | 6 | EXTCAP | _ | An external capacitor (Ext. Cap) pin. When the USB transceiver voltage converter is used, a 2.2 $\mu$ F and a 0.1 $\mu$ F capacitor should connect between this pin and V <sub>ss</sub> to ensure proper operation of the USB line driver. This option is enabled by setting bit 4 of the USB control register (000C <sub>16</sub> ) to a "1". | | 7 | BYTE | I | Connect this pin to Vss | | 8 | CNV <sub>ss</sub> | I | Connect this pin to Vss | | 9 | USB D+ | I/O | USB D+ voltage line interface, a series resistor of 33 $\Omega$ is connected to this pin. | | 10 | USB D- | I/O | USB D- voltage line interface, a series resistor of 33 $\Omega$ is connected to this pin. | | 11 | RESET | ı | A "L" on this input resets the microcomputer. | | 12 | Xout | 0 | See Xin | | 13 | V <sub>ss</sub> | ı | Ground: V <sub>ss</sub> = 0V | | 14 | Xin | I | Input and output signals to and from the internal clock generation circuit. Connect a ceramic resonator or quartz crystal between Xin and Xout pins to set the oscillation frequency. If an external clock is used, connect the clock source to the Xin pin and leave the Xout pin open. | | 15 | V <sub>cc</sub> | ı | Power: V <sub>cc</sub> = 4.1~ 5.25V | | 16 | P8 <sub>2</sub> | I/O | CMOS I/O port. This pin also functions as external interrupt 0. | | 17-18 | P8 <sub>1</sub> ~ P8 <sub>0</sub> | I/O | CMOS I/O port. Pins in this port also function as TimerA4 input and output as selected by software. | | 19-22 | P7 <sub>7</sub> ~ P7 <sub>4</sub> | I/O | CMOS I/O port. Pins in this port also function as timer pins. P7 <sub>7</sub> and P7 <sub>6</sub> can function as TimerA3 input and output as selected by software. P7 <sub>5</sub> and P7 <sub>4</sub> can function as TimerA2 input and output as selected by software. | | 23-26 | P7 <sub>3</sub> ~ P7 <sub>0</sub> | I/O | CMOS I/O port. Pins in this port also function as UART2 CTS, RTS, CLK, RXD, and TXD as selected by software. P7 <sub>3</sub> and P7 <sub>2</sub> can function as TimerA1 input and output as selected by software. P7 <sub>1</sub> and P7 <sub>0</sub> can function as TimerA0 input and output as selected by software. | | 27-30 | P6 <sub>7</sub> ~ P6 <sub>4</sub> | I/O | CMOS I/O port. Pins in this port also function as UART1 CTS, RTS, CLK, Serial Clock, RXD, and TXD as selected by software. TXD(OE~) and RTS(SUSPEND) in addition to D+ and D- can be used to run the device in USB bypass mode. | | 31-34 | P6 <sub>3</sub> ~ P6 <sub>0</sub> | I/O | CMOS I/O port. Pins in this port also function as UART0 CTS, RTS, CLK, RXD, and TXD as selected by software. | | 35-42 | P3 <sub>7</sub> ~ P3 <sub>0</sub> | I/O | CMOS I/O port. | | 43-50 | P2 <sub>7</sub> /LED7<br>~ P2 <sub>0</sub> /LED0 | I/O | CMOS I/O port. These pins are capable of driving up to 20mA (peak) for LEDs. | Pin Description #### **Figure Pin Description Table 1.3:** | Pin# | Name | I/O | Description | |-------|--------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------| | 51 | V <sub>cc</sub> | I | Power: V <sub>cc</sub> = 4.1~ 5.25V | | 52 | P1 <sub>7</sub> /KI <sub>15</sub> | I/O | CMOS I/O port. This port can also function as the key-on wakeup interrupt KI15. | | 53 | V <sub>ss</sub> | I | Ground: V <sub>ss</sub> = 0V | | 54-60 | P1 <sub>6</sub> /KI <sub>14</sub><br>~ P1 <sub>0</sub> /KI <sub>8</sub> | I/O | CMOS I/O port. This port can also function as the key-on wakeup interrupts ( $\overline{\text{KI8}}$ ~ $\overline{\text{KI14}}$ ). | | 61-68 | P0 <sub>7</sub> / <del>K</del> I <sub>7</sub><br>~ P0 <sub>0</sub> / <del>K</del> I <sub>0</sub> | I/O | CMOS I/O port. This port can also function as the key-on wakeup interrupts ( $\overline{\text{KI0}}$ ~ $\overline{\text{KI7}}$ ). | | 69-76 | P10 <sub>7</sub> ~ P10 <sub>0</sub> | I/O | CMOS I/O port. These pins also function as Analog inputs 7-0 for A-D conversion | | 77 | AV <sub>ss</sub> | I | This pin is a power supply input for the AD converter. (Connect to Vss) | | 78 | LPF | 0 | Loop filter for the frequency synthesizer. | | 79 | V <sub>REF</sub> | I | This pin is the reference voltage input for the A-D converter. | | 80 | AV <sub>cc</sub> | I | This pin is a power supply input for the AD converter. (Connect to Vcc) | Overview #### 1.7 Overview The M30240 group is a single chip PC peripheral microcontroller based on the Universal Serial Bus (USB) Version 1.1 specification. This device provides interface between a USB-equipped host computer and PC peripherals such as telephones, audio systems, and digital cameras. The M30240 block diagram is shown in Figure 1.4. The USB function control unit of the M30240 group can support all four data transfer types listed in the USB specification: Isochronous, Interrupt, Bulk, and Control. Each transfer type is used for controlling a different set of PC peripherals. <u>Isochronous transfers</u> provide guaranteed bus access, a constant data rate, and error tolerance for devices such as computer-telephone integration (CTI) and audio systems. <u>Interrupt transfers</u> are designed to support human input devices (HID) that communicate small amounts of data infrequently. <u>Bulk transfers</u> are necessary for devices such as digital cameras and scanners that communicate large amounts of data to the PC as bus bandwidth becomes free. Finally, <u>control transfers</u> are supported and are useful for bursty, host-initiated type communication where bus management is the primary concern. Figure 1.4: M30240 block diagram Central Processing Unit (CPU) ## 2.0 Operation of Functional Blocks The M30240 group accommodates certain units in a single chip. These units include ROM and RAM to store instructions and data, and the central processing unit (CPU) to execute arithmetic/logic operations. Also included are peripheral units such as USB, timers, serial I/O, DMAC, CRC calculation circuit, A-D converter, and I/O ports. The following explains each unit. ## 2.1 Central Processing Unit (CPU) The CPU has a total of 13 registers shown in Figure 1.5. Seven of these registers (R0, R1, R2, R3, A0, A1, and FB) come in two sets; therefore, these have two register banks. Figure 1.5: Central processing unit register #### 2.1.1 Data registers (R0, R0H, R0L, R1, R1H, R1L, R2, and R3) Data registers (R0, R1, R2, and R3) are configured with 16 bits, and are used primarily for transfer and arithmetic/logic operations. Central Processing Unit (CPU) Registers R0 and R1 each can be used as separate 8-bit data registers, high-order bits as (R0H/R1H), and low-order bits as (R0L/R1L). In some instructions, registers R2 and R0, as well as R3 and R1, can be used as 32-bit data registers (R2R0/R3R1). #### 2.1.2 Address registers (A0 and A1) Address registers (A0 and A1) are configured with 16 bits, and have functions equivalent to those of data registers. These registers can also be used for address register indirect addressing and address register relative addressing. In some instructions, registers A1 and A0 can be combined for use as a 32-bit address register (A1A0). #### 2.1.3 Frame base register (FB) Frame base register (FB) is configured with 16 bits, and is used for FB relative addressing. #### 2.1.4 Program counter (PC) Program counter (PC) is configured with 20 bits, indicating the address of an instruction to be executed. #### 2.1.5 Interrupt table register (INTB) Interrupt table register (INTB) is configured with 20 bits, indicating the start address of an interrupt vector table. INTB can be used as separate registers of four high-order bits and 16 low-order bits. #### 2.1.6 Stack pointer (USP/ISP) Stack pointer comes in two types: user stack pointer (USP) and interrupt stack pointer (ISP), each configured with 16 bits. Your desired type of stack pointer (USP or ISP) can be selected by a stack pointer select flag (U flag). This flag is located at the position of bit 7 in the flag register (FLG). #### 2.1.7 Static base register (SB) Static base register (SB) is configured with 16 bits, and is used for SB relative addressing. #### 2.1.8 Flag register (FLG) Flag register (FLG) is configured with 11 bits, each bit is used as a flag. Figure 1.6 shows the flag register (FLG). The following explains the function of each flag: #### 2.1.8.1 Bit 0: Carry flag (C flag) This flag retains a carry, borrow, or shift-out bit that has occurred in the arithmetic/logic unit. #### 2.1.8.2 Bit 1: Debug flag (D flag) This flag enables a single-step interrupt. When this flag is "1", a single-step interrupt is generated after instruction execution. This flag is cleared to "0" when the interrupt is acknowledged. #### 2.1.8.3 Bit 2: Zero flag (Z flag) This flag is set to "1" when an arithmetic operation resulted in 0; otherwise, cleared to "0". #### 2.1.8.4 Bit 3: Sign flag (S flag) This flag is set to "1" when an arithmetic operation resulted in a negative value; otherwise, cleared to "0". #### 2.1.8.5 Bit 4: Register bank select flag (B flag) This flag chooses a register bank. Register bank 0 is selected when this flag is "0"; register bank 1 is selected when this flag is "1". #### 2.1.8.6 Bit 5: Overflow flag (O flag) This flag is set to "1" when an arithmetic operation resulted in overflow; otherwise, cleared to "0". Central Processing Unit (CPU) #### 2.1.8.7 Bit 6: Interrupt enable flag (I flag) This flag enables a maskable interrupt. An interrupt is disabled when this flag is "0", and is enabled when this flag is "1". This flag is cleared to "0" when the interrupt is acknowledged. #### 2.1.8.8 Bit 7: Stack pointer select flag (U flag) Interrupt stack pointer (ISP) is selected when this flag is "0"; user stack pointer (USP) is selected when this flag is "1". This flag is cleared to "0" when a hardware interrupt is acknowledged or an INT instruction of software interrupts 0 to 31 is executed. #### 2.1.8.9 Bits 8 to 11: Reserved area #### 2.1.8.10 Bits 12 to 14: Processor interrupt priority level (IPL) Processor interrupt priority level (IPL) is configured with three bits, for specification of up to eight processor interrupt priority levels from level 0 to level 7. If a requested interrupt has priority greater than the processor interrupt priority level (IPL), the interrupt is enabled. #### 2.1.8.11 Bit 15: Reserved area The C, Z, S, and O flags are changed when instructions are executed. See the M16C software manual for details. Figure 1.6: Flag register (FLG) **Processor Mode** #### 2.2 Processor Mode Figure 1.7 shows the processor mode registers 0 and 1. Figure 1.7: Processor mode registers 0 and 1 Memory SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER / Figure 1.8: Memory Map Figure 1.8 is a memory map of the M30240 group. The address space extends the 1M bytes from address $00000_{16}$ to FFFFF<sub>16</sub>. Addresses above $yyyyy_{16}$ are ROM. For example, in the M30240ECFP, there is 128K bytes of internal ROM from $E0000_{16}$ to FFFFF<sub>16</sub>. The special page vector table is mapped from FFE00<sub>16</sub> to FFFDB<sub>16</sub>. If the starting addresses of subroutines or the destination addresses of jumps are stored here, subroutine call instructions and jump instructions can be used as two-byte instructions, reducing the number of program steps. The vector table for fixed interrupts such as the reset and $\overline{\text{NMI}}$ are mapped from FFFDC<sub>16</sub> to FFFFF<sub>16</sub>. The starting addresses of the interrupt routines are stored here. The address of the vector table for software interrupts can be set as desired using the internal register (INTB). See Section 2.12 on interrupts for further details. Addresses below $xxxxx_{16}$ are RAM. For example, in M30240ECFP, 5K bytes of internal RAM are mapped to the space from $00400_{16}$ to $017FF_{16}$ . In addition to storing data, the RAM also stores the stack used when calling subroutines and when interrupts are generated. The SFR area is mapped to $00000_{16}$ to $003FF_{16}$ . This area accommodates control registers for peripheral devices such as I/O ports, A-D converter, serial I/O, and timers. Section 2.4 describes the SFR area for peripheral unit control registers. Any part of the SFR area that is unoccupied is reserved and cannot be used for other purposes. ## 2.4 SFR MAP The table below shows the peripheral control registers, their addresses, names, acronyms, and values after reset. | D000136 D000136 Processor mode register 0 | Address | Register name | Acronym | Value after reset | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----------------------------------------|-----------|-------------------| | DOD DODD DODD DODD DODD DODD DOD DODD DO | | | ] | | | Processor mode register 0 | 0001 <sub>16</sub> | | 7 | | | Dools Processor mode register 0 | | | | | | Dools Processor mode register 1 | | | | | | System clock control register 0 CM0 System clock control register 1 CM1 2016 | | | 4 | | | System clock control register 1 | | | - | | | Address match interrupt enable register | | | - | | | Address match interrupt enable register Protect USBC | | System clock control register 1 | - CIVIT | 2016 | | Double D | | Address match interrupt enable register | AIFR | [0]0 | | USB | | | - | | | 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 000012 0 | | | 1 | | | Watchdog timer start register | 000C <sub>16</sub> | USB control register | USBC | 0016 | | Machdog timer control register WDC | | | | | | Oct | | | - | | | Ool 1 | | Watchdog timer control register | WDC | | | 001216 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 001516 0 | | Address match interrupt register 0 | DMADO | | | O01316 | | Address match interrupt register o | RIVIADO | | | Oct 1 | | | 1 | 0 0 0 0 0 | | Address match interrupt register 1 | | | 1 | 0016 | | 001016 6 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 | | Address match interrupt register 1 | RMAD1 | | | 001816 0010116 0010116 0010116 0010116 0010116 0010116 0010116 0010116 0010116 0010116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 0020116 00201 | 0016 <sub>16</sub> | | | | | 001916 001A16 001B16 001D16 001D16 001D16 001D16 001D16 001D16 001D16 001D16 001D16 002016 002016 002316 002316 002416 002516 002516 002416 002816 002916 002816 002916 002D16 002D16 002D16 002D16 002D16 002D16 002D16 002D16 003D16 003D16 003S16 0 | 0017 <sub>16</sub> | | | | | O01A16 O01B16 O01C16 O01C16 O01C16 O01D16 O01C16 O01C16 O01C16 O01C16 O01C16 O02C16 O | | | | | | Ool | | | 4 | | | O101c16 | | | 4 | | | Old | | | - | | | Reserved USBAD | | | 1 | | | USB attach / detach register | | Reserved | | | | DMA0 source pointer SAR0 DMA0 source pointer SAR0 DMA0 source pointer SAR0 DMA0 source pointer DAR0 DMA0 destination pointer DAR0 DMA0 destination pointer DAR0 DMA0 transfer counter TCR0 DMA0 transfer counter DMA1 transfer counter DMA1 transfer counter DMA1 transfer counter DAR1 DMA1 transfer counter | | USB attach / detach register | LISBAD | 00.5 | | DMA0 source pointer SAR0 | | | JOODAD | 3316 | | 0022 <sub>16</sub> 0023 <sub>16</sub> 0025 <sub>16</sub> 0025 <sub>16</sub> 0026 <sub>16</sub> 0027 <sub>16</sub> 0028 <sub>16</sub> 0029 <sub>16</sub> 0020 0030 <sub>16</sub> 0031 <sub>16</sub> 0033 | | DMA0 source pointer | CARO | | | 002316<br>002416<br>002516<br>002016<br>002016<br>0020216<br>0020216<br>0020216<br>0020216<br>0020216<br>0020216<br>0020216<br>0020216<br>0020216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216<br>0030216 | | DIMAO Source pointer | SARU | | | 0024 <sub>16</sub> 0025 <sub>16</sub> DMA0 destination pointer DAR0 0027 <sub>16</sub> 0027 <sub>16</sub> DMA0 transfer counter TCR0 0028 <sub>16</sub> 0029 <sub>16</sub> DMA0 control register DM0CON 002D <sub>16</sub> DMA0 control register DM0CON 002E <sub>16</sub> 002E <sub>16</sub> DMA1 source pointer SAR1 0030 <sub>16</sub> 0030 <sub>16</sub> DMA1 source pointer DAR1 0038 <sub>16</sub> 0035 <sub>16</sub> DMA1 destination pointer DAR1 0038 <sub>16</sub> 0037 <sub>16</sub> DMA1 transfer counter TCR1 0038 <sub>16</sub> 0038 <sub>16</sub> DMA1 control register DM1CON 0030 <sub>16</sub> 003C <sub>16</sub> DMA1 control register DM1CON | | | 1 | | | 0025 <sub>16</sub> DMA0 destination pointer DAR0 0026 <sub>16</sub> 0027 <sub>16</sub> DMA0 transfer counter TCR0 0028 <sub>16</sub> DMA0 transfer counter TCR0 0020 <sub>16</sub> DMA0 control register DMOCON 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | | | | 0027 <sub>16</sub> 0028 <sub>16</sub> 0029 <sub>16</sub> 0020 0030 | | DMA0 destination pointer | DAR0 | | | 002816<br>002916<br>002B16<br>002C16<br>002D16<br>002F16<br>003016<br>00316<br>00316<br>003416<br>003616<br>003716<br>003716<br>003716<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>003816<br>00 | | | | | | 0029 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0030 <sub>16</sub> 0030 <sub>16</sub> 0031 | | | | | | 0029 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0020 <sub>16</sub> 0030 <sub>16</sub> 0030 <sub>16</sub> 0031 <sub>16</sub> 0034 <sub>16</sub> 0034 <sub>16</sub> 0036 <sub>16</sub> 0037 <sub>16</sub> 0036 <sub>16</sub> 0037 <sub>16</sub> 0038 | | DMA0 transfer counter | TCR0 | | | 002B <sub>16</sub> DMA0 control register DM0CON 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | - | - | | | 002C <sub>16</sub> DMA0 control register DMOCON 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | - | | | 002D <sub>16</sub> 002F <sub>16</sub> 003O | | DMA0 control register | DMOCON | | | 002E <sub>16</sub> 002F <sub>16</sub> 0030 <sub>16</sub> 0031 <sub>16</sub> 0032 <sub>16</sub> 0033 <sub>16</sub> 0034 <sub>16</sub> 0035 <sub>16</sub> 0036 <sub>16</sub> 0037 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003C <sub>16</sub> 003D <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> | | 2 to control regional | 5,0,000,0 | | | 002F <sub>16</sub> 0030 <sub>16</sub> 0031 <sub>16</sub> 0032 <sub>16</sub> 0033 <sub>16</sub> 0034 <sub>16</sub> 0035 <sub>16</sub> 0037 <sub>16</sub> 0037 <sub>16</sub> 0038 003B <sub>16</sub> 003B <sub>16</sub> 003C <sub>16</sub> 003D <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> 003B <sub>16</sub> | | | 1 | | | 0031 <sub>16</sub> 0032 <sub>16</sub> 0033 <sub>16</sub> 0034 <sub>16</sub> 0035 <sub>16</sub> 0MA1 destination pointer 0035 <sub>16</sub> 0MA1 destination pointer 0037 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0038 <sub>16</sub> 0030 | 002F <sub>16</sub> | | | | | 0032 <sub>16</sub> 0033 <sub>16</sub> 0034 <sub>16</sub> 0035 <sub>16</sub> 0036 <sub>16</sub> 0037 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0038 <sub>16</sub> 0030 | | | | | | 0033 <sub>16</sub> 0034 <sub>16</sub> 0035 <sub>16</sub> 0036 <sub>16</sub> 0037 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0038 <sub>16</sub> 0030 | | DMA1 source pointer | SAR1 | | | 0034 <sub>16</sub> 0035 <sub>16</sub> 0037 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0038 <sub>16</sub> 0030 | | | 1 | | | 0035 <sub>16</sub> 0036 <sub>16</sub> 0038 003 | | | - | | | 0036 <sub>16</sub> 0037 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0030 | | DMA1 destination pointer | DAR1 | | | 0037 <sub>16</sub> 0038 <sub>16</sub> 0039 <sub>16</sub> 0030 | | Divir (1 destination pointer | DAIL | | | 0038 <sub>16</sub> 0039 <sub>16</sub> DMA1 transfer counter TCR1 003A <sub>16</sub> 003B <sub>16</sub> DMA1 control register DM1CON 0 0 0 0 0 0 0 0 0 0 0 0 0 003D <sub>16</sub> 003E <sub>16</sub> 003E <sub>16</sub> 003E <sub>16</sub> | 003716 | | 1 | | | 0039 <sub>16</sub> 003R <sub>16</sub> 003B <sub>16</sub> 003C <sub>16</sub> 003D <sub>16</sub> 003E <sub>16</sub> 003E <sub>16</sub> | 003816 | DMAA transfer county | TODA | | | 003A <sub>16</sub> 003B <sub>16</sub> 003C <sub>16</sub> 003D <sub>16</sub> 003E <sub>16</sub> 003E <sub>16</sub> | | DIMA I transfer counter | TCRT | | | 003C <sub>16</sub> DMA1 control register DM1CON 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 003A <sub>16</sub> | | | | | 003D <sub>16</sub><br>003E <sub>16</sub> | | | 1 | | | 003E <sub>16</sub> | | DMA1 control register | DM1CON | 0 0 0 0 7 0 0 | | 003F <sub>16</sub> | | | - | | | 000116 | 003E16 | | - | | | | 003F16 | | J | | | Address | Register name | Acronym | Value after reset | | |------------------------------------------|-------------------------------------------------------------------------------------|----------------|-------------------|-----------| | 0040 <sub>16</sub> | | | | П | | 0041 <sub>16</sub> | | | | | | 0042 <sub>16</sub> | | _ | | | | 0043 <sub>16</sub> | O and a distance of a deal as sister | OLIODIO. | | 4 | | 0044 <sub>16</sub><br>0045 <sub>16</sub> | Suspend interrupt control register | SUSPIC | ? 0 0 0 | $\dashv$ | | 0046 <sub>16</sub> | Resume interrupt control register | RSMIC | ?000 | $\dashv$ | | 0047 <sub>16</sub> | USB SOF interrupt control register | SOFIC | 007000 | $\exists$ | | 004816 | , , | | | П | | 004916 | | | | | | $004A_{16}$ | Bus collision detection interrupt control register | BCNIC | ? 0 0 0 | | | 004B <sub>16</sub> | DMA0 interrupt control register | DM0IC | ? 0 0 0 | | | 004C <sub>16</sub> | | DM1IC | ? 0 0 0 | $\dashv$ | | 004D <sub>16</sub> | Key input interrupt control register | KUPIC | ? 0 0 0 | - | | 004E <sub>16</sub><br>004F <sub>16</sub> | A-D conversion interrupt control register UART2 transmit interrupt control register | ADIC<br>S2TIC | ? 0 0 0 | $\dashv$ | | 005016 | UART2 receive interrupt control register | S2RIC | ? 0 0 0 | $\dashv$ | | 0051 <sub>16</sub> | UART0 transmit interrupt control register | SOTIC | ? 0 0 0 | $\neg$ | | 005216 | | SORIC | ? 0 0 0 | $\exists$ | | 0053 <sub>16</sub> | UART1 transmit interrupt control register | S1TIC | ? 0 0 0 | | | | UART1 receive interrupt control register | S1RIC | ? 0 0 0 | | | 0055 <sub>16</sub> | TIMER A0 interrupt control register | TA0IC | ? 0 0 0 | | | 0056 <sub>16</sub> | TIMER A1 interrupt control register | TA1IC | ? 0 0 0 | | | 0057 <sub>16</sub> | TIMER A2 interrupt control register | TA2IC | ? 0 0 0 | $\dashv$ | | 0058 <sub>16</sub> | TIMER A3 interrupt control register TIMER A4 interrupt control register | TA3IC<br>TA4IC | ? 0 0 0 | $\dashv$ | | 0059 <sub>16</sub> | | TB0IC | ? 0 0 0 | $\dashv$ | | 005B <sub>16</sub> | TIMER B1 interrupt control register | TB1IC | ? 0 0 0 | $\dashv$ | | | Reset interrupt control register | RSTIC | ? 0 0 0 | $\dashv$ | | | INT0 interrupt control register | INTOIC | 0 0 ? 0 0 0 | П | | 005E <sub>16</sub> | INT1 interrupt control register | INT1IC | 0 0 ? 0 0 0 | | | 005F <sub>16</sub> | USB function interrupt control register | USBFIC | ? 0 0 0 | | | 0300 <sub>16</sub> | USB address register | TUSBA | 0016 | $\neg$ | | | USB power management register | USBPM | 0016 | $\dashv$ | | 030216 | USB interrupt status register 1 | USBIS1 | 0016 | $\dashv$ | | 030316 | USB interrupt status register 2 | USBIS2 | 0016 | - | | 030416 | USB interrupt enable register 1 | USBIE1 | FF <sub>16</sub> | T | | 030516 | USB interrupt enable register 2 | USBIE2 | 3316 | П | | 0306 <sub>16</sub> | USB frame number register low | USBSOFL | 0016 | | | 0307 <sub>16</sub> | USB frame number register high | USBSOFH | 0016 | | | 0308 <sub>16</sub> | USB ISO control register | USBISOC | 0016 | | | 0309 <sub>16</sub> | USB DMA0 source register | USBSAR0 | 0016 | _ | | 030A <sub>16</sub> | USB DMA1 source register | USBSAR1 | 0016 | | | 030B <sub>16</sub> | USB endpoint enable | USBEPEN | FF <sub>16</sub> | 4 | | 030C <sub>16</sub><br>030D <sub>16</sub> | | - | | | | 030D <sub>16</sub> | | 1 | | | | 030E <sub>16</sub> | | 1 | | | | | USB reserved | | | | | 0311 <sub>16</sub> | USB EP 0 control/status register | EP0CS | 0016 | | | | USB reserved | | | | | | USB EP 0 max packet size register | EP0MP | 08 <sub>16</sub> | | | | USB reserved | EDOM: | 00 | _ | | | USB EP 0 OUT write count | EP0WC | 0016 | - | | 0316 <sub>16</sub> | USB reserved USB reserved | - | | | | | USB reserved | 1 | | | | | USB EP 1 IN control/status register | EP1ICS | 0016 | $\dashv$ | | | USB EP 1 OUT control/status register | EP10CS | 0016 | $\dashv$ | | | USB EP 1 IN max packet size register | EP1IMP | 0016 | $\dashv$ | | | USB EP 1 OUT max packet size register | EP10MP | 0016 | ╗ | | | USB EP 1 OUT write count | EP1WC | 0016 | | | | USB reserved | | | | | 031F <sub>16</sub> | USB reserved | _ | | $\sqcup$ | | | | | | | | Address | Register name | Acronym | Value after reset | | |------------------------------------------|---------------------------------------|---------|-------------------|--| | | USB reserved | 7 | Value alter recet | | | | USB EP 2 IN control/status register | EP2ICS | 0016 | | | 032216 | USB EP 2 OUT control/status register | EP2OCS | 0016 | | | 0323 <sub>16</sub> | USB EP 2 IN max packet size register | EP2IMP | 0016 | | | 0324 <sub>16</sub> | USB EP 2 OUT max packet size register | EP2OMP | 0016 | | | 032516 | USB EP 2 OUT write count | EP2WC | 0016 | | | 032616 | USB reserved | 7 | | | | 0327 <sub>16</sub> | USB reserved | | | | | 0328 <sub>16</sub> | USB reserved | | | | | 0329 <sub>16</sub> | USB EP 3 IN control/status register | EP3ICS | 0016 | | | 032A <sub>16</sub> | USB EP 3 OUT control/status register | EP3OCS | 0016 | | | 032B <sub>16</sub> | USB EP 3 IN max packet size register | EP3IMP | 0016 | | | 032C <sub>16</sub> | USB EP 3 OUT max packet size register | EP3OMP | 0016 | | | 032D <sub>16</sub> | USB EP 3 OUT write count | EP3WC | 0016 | | | 032E <sub>16</sub> | | _ | 0016 | | | | USB reserved | 1 | | | | | USB reserved | 4 | | | | 0331 <sub>16</sub> | | EP4ICS | 0016 | | | | USB EP 4 OUT control/status register | EP40CS | 00 <sub>16</sub> | | | 0333 <sub>16</sub> | · · · | EP4IMP | 00 <sub>16</sub> | | | | USB EP 4 OUT max packet size register | EP40MP | 00 <sub>16</sub> | | | | USB EP 4 OUT write count | EP4WC | 00 <sub>16</sub> | | | 0336 <sub>16</sub> | USB reserved USB reserved | 4 | | | | | USB EP 0 FIFO | EP0 | | | | | USB EP 1 FIFO | EP1 | | | | | USB EP 2 FIFO | EP2 | | | | | USB EP 3 FIFO | EP3 | | | | | USB EP 4 FIFO | EP4 | | | | 033D <sub>16</sub> | reserved | 1 | | | | 033E <sub>16</sub> | reserved | | | | | 033F <sub>16</sub> | reserved | | | | | 0340 <sub>16</sub> | | 1 | | | | 0341 <sub>16</sub> | | 4 | | | | 0342 <sub>16</sub> | | 4 | | | | 0343 <sub>16</sub><br>0344 <sub>16</sub> | | 4 | | | | 0344 <sub>16</sub> | | + | | | | 0346 <sub>16</sub> | | + | | | | 0347 <sub>16</sub> | | † | | | | 0348 <sub>16</sub> | | † | | | | 034916 | | 1 | | | | 034A <sub>16</sub> | | 7 | | | | 034B <sub>16</sub> | | | | | | 034C <sub>16</sub> | | 1 | | | | 034D <sub>16</sub> | | 1 | | | | 034E <sub>16</sub> | | 4 | | | | 034F <sub>16</sub> | | 4 | | | | 0350 <sub>16</sub> | | 4 | | | | 0351 <sub>16</sub><br>0352 <sub>16</sub> | | 4 | | | | 0352 <sub>16</sub> | | 1 | | | | 0354 <sub>16</sub> | | † | | | | 035516 | | 1 | | | | 0356 <sub>16</sub> | | 1 | | | | 0357 <sub>16</sub> | | 1 | | | | 0358 <sub>16</sub> | | | | | | 0359 <sub>16</sub> | | | | | | 035A <sub>16</sub> | | ] | | | | 035B <sub>16</sub> | | _ | | | | 035C <sub>16</sub> | | _ | | | | 035D <sub>16</sub> | | 4 | | | | 035E <sub>16</sub> | | 4 | | | | 035F <sub>16</sub> | | J | | | | | | | | | | Address | Register name | Acronym | Value after reset | | |--------------------|---------------------------------------------|---------|-------------------|--| | 0370 <sub>16</sub> | | ] | | | | 0371 <sub>16</sub> | | | | | | 0372 <sub>16</sub> | | | | | | 0373 <sub>16</sub> | | | | | | 0374 <sub>16</sub> | | | | | | 0375 <sub>16</sub> | | | | | | 0376 <sub>16</sub> | | | | | | 0377 <sub>16</sub> | Reserved | | | | | 0378 <sub>16</sub> | UART2 transmit / receive mode register | U2MR | 0016 | | | 0379 <sub>16</sub> | UART2 bit rate generator | U2BRG | | | | 037A <sub>16</sub> | UART2 transmit buffer register | U2TB | | | | 037B <sub>16</sub> | | | 00 | | | 037C <sub>16</sub> | UART2 transmit /receive control register 0 | U2C0 | 08 <sub>16</sub> | | | 037D <sub>16</sub> | UART2 transmit / receive control register 1 | U2C1 | 02 <sub>16</sub> | | | 037E <sub>16</sub> | UART2 receive buffer register | U2RB | | | | 037F <sub>16</sub> | _ | | 00 | | | 0380 <sub>16</sub> | Count start flag | TABSR | 0016 | | | 0381 <sub>16</sub> | Reserved | ONOF | | | | 0382 <sub>16</sub> | One-shot start flag | ONSF | 0 0 0 0 0 0 0 | | | 0383 <sub>16</sub> | Trigger select register | TRGSR | 0016 | | | 0384 <sub>16</sub> | Up-down flag | UDF | 0016 | | | 0385 <sub>16</sub> | | | | | | 0386 <sub>16</sub> | Timer A0 | TA0 | | | | 0387 <sub>16</sub> | | | | | | 0388 <sub>16</sub> | Timer A1 | TA1 | | | | 0389 <sub>16</sub> | - | | | | | 038A <sub>16</sub> | Timer A2 | TA2 | | | | 038B <sub>16</sub> | - | | | | | 038C <sub>16</sub> | Timer A3 | TA3 | | | | 038D <sub>16</sub> | | | | | | 038E <sub>16</sub> | Timer A4 | TA4 | | | | 038F <sub>16</sub> | - | | | | | 0390 <sub>16</sub> | Timer B0 | тво | | | | 0391 <sub>16</sub> | | | | | | 0392 <sub>16</sub> | Timer B1 | TB1 | | | | 0393 <sub>16</sub> | | | | | | 0394 <sub>16</sub> | Timer B2 | TB2 | | | | 0395 <sub>16</sub> | | | | | | 0396 <sub>16</sub> | Timer A0 mode register | TAOMR | 0016 | | | 0397 <sub>16</sub> | Timer A1 mode register | TA1MR | 0016 | | | 0398 <sub>16</sub> | Timer A2 mode register | TA2MR | 0016 | | | 0399 <sub>16</sub> | Timer A3 mode register | TA3MR | 0016 | | | 039A <sub>16</sub> | Timer A4 mode register | TA4MR | 0016 | | | 039B <sub>16</sub> | Timer B0 mode register | TB0MR | 0 0 ? 0 0 0 0 | | | 039C <sub>16</sub> | Timer B1 mode register | TB1MR | 0 0 ? 0 0 0 0 | | | 039D <sub>16</sub> | Timer B2 mode register | TB2MR | 0 0 ? 0 0 0 0 | | | 039E <sub>16</sub> | | | | | | 039F <sub>16</sub> | | l | | | | 03A0 <sub>16</sub> | UART0 transmit / receive mode register | U0MR | 0016 | | | 03A1 <sub>16</sub> | UART0 bit rate generator | U0BRG | | | | 03A2 <sub>16</sub> | UART0 transmit buffer register | U0TB | | | | 03A3 <sub>16</sub> | | | 00 | | | 03A4 <sub>16</sub> | UART0 transmit / receive control register 0 | U0C0 | 08 <sub>16</sub> | | | 03A5 <sub>16</sub> | UART0 transmit / receive control register 1 | U0C1 | 02 <sub>16</sub> | | | 03A6 <sub>16</sub> | UART0 receive buffer register | U0RB | | | | 03A7 <sub>16</sub> | | | | | | 03A8 <sub>16</sub> | UART1 transmit / receive mode register | U1MR | 0016 | | | 03A9 <sub>16</sub> | UART1 bit rate generator | U1BRG | | | | 03AA <sub>16</sub> | UART1 transmit buffer register | U1TB | | | | 03AB <sub>16</sub> | | | | | | 03AC <sub>16</sub> | UART1 transmit / receive control register 0 | U1C0 | 08 <sub>16</sub> | | | 03AD <sub>16</sub> | UART1 transmit / receive control register 1 | U1C1 | 02 <sub>16</sub> | | | 03AE <sub>16</sub> | UART1 receive buffer register | U1RB | | | | 03AF <sub>16</sub> | | ] | | | | | | | | | | Address | Register name | Acronym | Value after reset | | |------------------------------------------|--------------------------------------------|-----------|-------------------|--| | 03B0 <sub>16</sub> | UART transmit / receive control register 2 | UCON | 00000000 | | | 03B1 <sub>16</sub><br>03B2 <sub>16</sub> | | + | | | | 03B3 <sub>16</sub> | | † | | | | 03B4 <sub>16</sub> | | | | | | 03B5 <sub>16</sub> | | 1 | | | | 03B6 <sub>16</sub> | | 4 | | | | 03B7 <sub>16</sub><br>03B8 <sub>16</sub> | DMA0 cause select register | DMOSL | 00 <sub>16</sub> | | | 03B9 <sub>16</sub> | 2to cauco co.cot regioto. | | 2.10 | | | 03BA <sub>16</sub> | DMA1 cause select register | DM1SL | 0016 | | | 03BB <sub>16</sub> | | | | | | 03BC <sub>16</sub><br>03BD <sub>16</sub> | CRC data register | CRCD | | | | 03BE <sub>16</sub> | CRC input register | CRCIN | | | | 03BF <sub>16</sub> | | | | | | 03C0 <sub>16</sub> | A-D register 0 | AD0 | | | | 03C1 <sub>16</sub> | 7. 2 | 1 | | | | 03C2 <sub>16</sub><br>03C3 <sub>16</sub> | A-D register 1 | AD1 | | | | 03C4 <sub>16</sub> | A.B. and interest | 1,50 | | | | 03C5 <sub>16</sub> | A-D register 2 | AD2 | | | | 03C6 <sub>16</sub> | A-D register 3 | AD3 | | | | 03C7 <sub>16</sub><br>03C8 <sub>16</sub> | | - | | | | 03C0 <sub>16</sub> | A-D register 4 | AD4 | | | | 03CA <sub>16</sub> | A D register 5 | 1,55 | | | | 03CB <sub>16</sub> | A-D register 5 | AD5 | | | | 03CC <sub>16</sub> | A-D register 6 | AD6 | | | | 03CD <sub>16</sub><br>03CE <sub>16</sub> | | - | | | | 03CF <sub>16</sub> | A-D register 7 | AD7 | | | | 03D0 <sub>16</sub> | | | | | | 03D1 <sub>16</sub> | | | | | | 03D2 <sub>16</sub> | | - | | | | 03D3 <sub>16</sub><br>03D4 <sub>16</sub> | A-D control register 2 | ADCON2 | 0 | | | 03D5 <sub>16</sub> | 7. D common regioner 2 | 1,200,12 | | | | 03D6 <sub>16</sub> | A-D control register 0 | ADCON0 | 0 0 0 0 0 ? ? ? | | | 03D7 <sub>16</sub> | A-D control register 1 | ADCON1 | 0016 | | | 03D8 <sub>16</sub> | | 4 | | | | 03D9 <sub>16</sub><br>03DA <sub>16</sub> | | - | | | | 03DB <sub>16</sub> | Frequency synthesizer clock control | FSCCR | 0016 | | | 03DC <sub>16</sub> | Frequency synthesizer control | FSC | 6016 | | | 03DD <sub>16</sub> | | FSM | FF <sub>16</sub> | | | 03DE <sub>16</sub> | | FSP | FF <sub>16</sub> | | | 03DF <sub>16</sub><br>03E0 <sub>16</sub> | | FSD<br>P0 | FF <sub>16</sub> | | | 03E0 <sub>16</sub> | | P1 | | | | 03E2 <sub>16</sub> | | PD0 | 0016 | | | 03E3 <sub>16</sub> | | PD1 | 0016 | | | 03E4 <sub>16</sub> | | P2 | | | | 03E5 <sub>16</sub><br>03E6 <sub>16</sub> | | P3<br>PD2 | 0016 | | | 03E7 <sub>16</sub> | | PD3 | 0016 | | | 03E8 <sub>16</sub> | | 1 | 10 | | | 03E9 <sub>16</sub> | | | | | | 03EA <sub>16</sub> | | 4 | | | | 03EB <sub>16</sub><br>03EC <sub>16</sub> | Port P6 | P6 | | | | 03EC <sub>16</sub> | | P7 | | | | 03EE <sub>16</sub> | | PD6 | 0016 | | | 03EF <sub>16</sub> | | PD7 | 0016 | | | | | | | | | Address | Register name | Acronym | |--------------------|-------------------------------|---------| | 03F0 <sub>16</sub> | Port P8 | P8 | | 03F1 <sub>16</sub> | | | | 03F2 <sub>16</sub> | Port P8 direction register | PD8 | | 03F3 <sub>16</sub> | | | | 03F4 <sub>16</sub> | Port P10 | P10 | | 03F5 <sub>16</sub> | | | | 03F6 <sub>16</sub> | Port P10 direction register | PD10 | | 03F7 <sub>16</sub> | | | | 03F8 <sub>16</sub> | | | | 03F9 <sub>16</sub> | | | | 03FA <sub>16</sub> | P2 drive capacity | P2DR | | 03FB <sub>16</sub> | Timer A Output Drive Capacity | TADR | | 03FC <sub>16</sub> | Pull-up control register 0 | PUR0 | | 03FD <sub>16</sub> | Pull-up control register 1 | PUR1 | | 03FE <sub>16</sub> | | | | 03FF16 | | 1 | | | Value after reset | | | | | | | | |----------|--------------------------------------|--|----|----|---|---|---|---| | | | | | | | | | | | 0 | 0 | | 0 | 0 | 0 | 0 | 0 | - | | | | | | | | | | | | | | | | | | | | | | | | | 00 | 16 | | | | _ | | | 10 | | | | | | | _ | | | | | | | | | | | | | 00 | | | | | | | | | - | 00 <sub>16</sub><br>00 <sub>16</sub> | | | | | | | | | | 0016 | | | | | | _ | | | | 0016 | | | | | | _ | | | - | | | 00 | 16 | | | | _ | | $\vdash$ | | | | | | | | _ | | | | | | | | | | | Reset #### 2.5 Reset There are two types of resets: hardware and software. In both cases, operation is the same after the reset. (See "Software Reset" for further details regarding software resets.) This section explains on hardware resets. When the supply voltage is within the range where operation is guaranteed, a reset is effected by holding the reset pin level "L" (0.2VCC max.) for at least 20 f(XIN) cycles. When the reset pin level is then returned to the "H" level while main clock is stable, the reset status is cancelled and program execution resumes from the address in the reset vector table. Figure 1.9 shows an example of a reset circuit. Figure 1.10 shows the reset sequence. Figure 1.9: Reset circuit Figure 1.10: Reset sequence Software Reset When the RESET pin level = "L", all ports change to input mode (floating.) Table 1.4 shows the status of the other pins while the RESET pin level is "L". Table 1.4: Main clock-generating circuits | Functions | Main clock-generating circuit | | |-------------------------------------------|------------------------------------------------------------------------------------|--| | Use of clock | CPU's operating clock source Internal peripheral units' operating clock source | | | Usable oscillator | Ceramic or crystal oscillator | | | Pins to connect oscillator | Xin, Xout | | | Oscillation stop/restart function | Available | | | Oscillator status immediately after reset | Oscillating | | #### 2.6 Software Reset Writing a "1" to bit 3 of the processor mode register 0 (address 0004<sub>16</sub>) applies a (software) reset to the microcomputer. A software reset has almost the same effect as a hardware reset with the following exceptions: - The contents of internal RAM are preserved - All USB, DC-DC converter, and PLL SFR values are preserved. (See Section 2.4) ## 2.7 Clock-Generating Circuit The clock-generating circuit contains one oscillator circuit that supplies the operating clock sources to the CPU and internal peripheral units. Example of oscillator circuit Figure 1.11 shows some examples of the main clock circuit, one using an oscillator connected to the circuit, and the other one using an externally derived clock for input. Circuit constants in Figure 1.11 vary with each oscillator used. Use circuit constant values recommended by the oscillator manufacturer. Figure 1.11: Examples of clock source **Clock Control** #### 2.8 Clock Control Figure 1.12 shows the block diagram of the clock-generating circuit. Figure 1.12: Clock-generating circuit The following paragraphs describe the clocks generated by the clock-generating circuit. #### 2.8.1 Main clock The main clock is generated by the main clock oscillation circuit. After a reset, the clock is divided by 8 to the internal clock $\Phi$ . The clock can be stopped using the main clock stop bit (bit 5 at address 0006<sub>16</sub>). Stopping the clock reduces the power dissipation. After the oscillation of the main clock oscillation circuit has stabilized, the drive capacity of the f(Xout) pin can be reduced using the f(Xin)-f(Xout) drive capacity select bit (bit 5 at address 0007<sub>16</sub>). Reducing the drive capacity of the f(Xout) pin reduces the power dissipation. This bit defaults to "1" when shifting to stop mode and after a reset. #### 2.8.2 Internal clock $\Phi$ The internal clock $\Phi$ is the clock that drives the CPU, and is either the main clock or is derived by dividing the main clock by 2, 4, 8, or 16. The internal clock $\Phi$ is derived by dividing the main clock by 8 after a reset. When shifting to stop mode, the main clock division select bit (bit 6 at 0006<sub>16</sub>) is set to "1". Clock Control #### 2.8.3 Peripheral function clock #### 2.8.3.1 • f1, f8, f32 The clock for the peripheral devices is derived from the main clock or by dividing it by 8 or 32. The peripheral function clock is stopped by stopping the main clock or by setting the WAIT peripheral function clock stop bit (bit 2 at $0006_{16}$ ) to "1" and then executing a WAIT instruction. #### 2.8.3.2 • fAD This clock has the same frequency as the main clock and is used for A-D conversion. #### 2.8.4 Clock Output In single-chip mode, the clock output function select bits (bits 0 and 1 at address $0006_{16}$ ) enable f8 or f32 to be output from the P37/CLKOUT pin. When the WAIT peripheral function clock stop bit (bit 2 at address $0006_{16}$ ) is set to "1", the output of f8 and f32 stops when a WAIT instruction is executed. Figure 1.13 shows the system clock control registers 0 and 1. Figure 1.13: System clock control registers 0 and 1 Stop Mode ## 2.9 Stop Mode Writing "1" to the all-clock stop control bit (bit 0 at address 0007<sub>16</sub>) stops all oscillation and the microcomputer enters stop mode. In stop mode, the content of the internal RAM is retained provided that VCC remains above 2V. Because the oscillation of internal clock $\Phi$ , f1 to f32, and fAD stops in stop mode, peripheral functions such as the A-D converter and watchdog timer do not function. However, timer A operates, provided that the event counter mode is set to an external pulse, and UARTi (i = 0 to 2) functions provided an external clock is selected. Table 1.5 shows the status of the ports in stop mode. Stop mode is cancelled by a hardware reset or interrupt. If an interrupt is to be used to cancel stop mode, that interrupt must first have been enabled. The I flag must also be set prior to stopping for an interrupt to cancel it. After coming out of stop mode, it is recommended that five "NOP" instructions be executed to clear the instruction queue. When shifting to stop mode, the main clock division select bit 0 (bit 6 at 0006<sub>16</sub>) is set to "1". Table 1.5: Port status during stop mode | Pin | Single-chip mode | |--------|---------------------------------| | Port | Retains status before stop mode | | CLKOUT | Retains status before stop mode | #### 2.10 Wait Mode When a WAIT instruction is executed, the internal clock $\Phi$ stops and the microcomputer enters the wait mode. In this mode, oscillation continues but the internal clock $\Phi$ and watchdog timer stop. Writing "1" to the WAIT peripheral function clock stop bit and executing a WAIT instruction stops the clock being supplied to the internal peripheral functions, allowing power dissipation to be reduced. Table 1.6 shows the status of the ports in wait mode. Wait mode is cancelled by a hardware reset or interrupt. If an interrupt is used to cancel wait mode, the microcomputer restarts using as internal clock $\Phi$ the clock that had been selected when the WAIT instruction was executed Table 1.6: Port status during wait mode | Pin | Single-chip mode | |--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Port | Retains status before stop mode | | CLKout | Does not stop when the WAIT peripheral function clock stop bit is "0" When the WAIT peripheral function clock stop bit is "1", the status immediately prior to entering wait mode is maintained. | #### 2.11 Status Transition Of the Internal Clock $\Phi$ Power dissipation can be reduced and low-voltage operation achieved by changing the count source for internal clock $\Phi$ . Table 1.7 shows the operating modes corresponding to the settings of system clock control registers 0 and 1. After a reset, operation defaults to division by 8 mode. When shifting to stop mode, the main clock division select bit 0 (bit 6 at address $0006_{16}$ ) is set to "1". The following shows the operational modes of internal clock #### 2.11.1 Division by 2 mode The main clock is divided by 2 to obtain the internal clock $\Phi$ . Power Control #### 2.11.2 Division by 4 mode The main clock is divided by 4 to obtain the internal clock $\Phi$ . #### 2.11.3 Division by 8 mode The main clock is divided by 8 to obtain the internal clock $\Phi$ . Note that oscillation of the main clock must have stabilized before transferring from this mode to another mode. #### 2.11.4 Division by 16 mode The main clock is divided by 16 to obtain the internal clock $\Phi$ . #### 2.11.5 No-division mode The main clock is used as internal clock. Table 1.7: Operating modes dictated by settings of system clock control registers 0 and 1 | CM17 | CM16 | CM06 | Operating mode of internal clock | |---------|---------|------|----------------------------------| | 0 | 1 | 0 | Division by 2 mode | | 1 | 0 | 0 | Division by 4 mode | | Invalid | Invalid | 1 | Division by 8 mode | | 1 | 1 | 0 | Division by 16 mode | | 0 | 0 | 0 | No-division mode | #### 2.12 Power Control The following is a description of the three available power control modes: #### 2.12.0.1 Normal Operation Mode · High-speed mode Divide-by-1 frequency of the main clock become the internal clock $\Phi$ . The CPU operates with the internal clock selected. Each peripheral function operates according to its assigned clock. · Medium-speed mode Divide-by-2, divide-by-4, divide-by-8, or divide-by-16 frequency of the main clock becomes the internal clock $\Phi$ . The CPU operates according to the internal clock selected. Each peripheral function operates according to its assigned clock. #### 2.12.0.2 Wait mode The CPU operation is stopped. The oscillators do not stop. #### 2.12.0.3 Stop Mode All oscillators stop. The CPU and all built-in peripheral functions stop. Of the three modes listed, this mode is the most effective in decreasing power consumption. Protection #### 2.13 Protection The protection function is provided so that the values in important registers cannot be changed in the event that the program runs out of control. Figure 1.14 shows the protect register. The values in the processor mode register 0 (address 0004<sub>16</sub>), processor mode register 1 (address 0005<sub>16</sub>), system clock control register 0 (address 0006<sub>16</sub>), system clock control register 1 (address 0007<sub>16</sub>) and frequency synthesizer registers can only be changed when the respective bit in the protect register is set to "1". The system clock control registers 0 and 1 write-enable bit (bit 0 at $000A_{16}$ ) and processor mode register 0 and 1 write-enable bit (bit 1 at $000A_{16}$ ) do not automatically return to "0" after a value has been written to an address. The program must therefore be written to return these bits to "0". Figure 1.14: Protect register ## 2.14 Interrupts Table 1.8 and Table 1.9 show the interrupt sources and vector table addresses. When an interrupt is received, the program is executed from the address shown by the respective interrupt vector. The vector table addresses for the interrupts in Table 7 are fixed (interrupt vector addresses). These interrupts are not affected by the interrupt enable flag (I flag) (non-maskable interrupts). The vector table addresses for the interrupts in Table 8 are variable, being determined as relative to the fixed address in the interrupt table register (INTB). These interrupts can be enabled or disabled using the interrupt enable flag (I flag) (maskable interrupts). Sixty four vectors can be set in the interrupt table register (INTB). Any of software interrupts 0 to 63 can be assigned to each vector. By using the INT instruction to specify a software interrupt number, the program can be executed starting at the address indicated by the respective vector. The BRK instruction interrupt has interrupt vectors in both the fixed vector address and variable vector address. When the contents of FFFE4<sub>16</sub> through FFFE7<sub>16</sub> are all "FF<sub>16</sub>), the program is executed from the address shown in the BRK instruction interrupt vector in the variable vector address. Specify the starting address of the interrupt program in the interrupt vector. Figure 1.15 shows the format for specifying the address. Table 1.8: Interrupt vectors (fixed interrupt vector addresses) | Interrupt source Vector table addresses Address(L) to Address(H) | | Remarks | | | |------------------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Undefined instruction | FFFDC <sub>16</sub> to FFFDF <sub>16</sub> | Interrupt on UND instruction | | | | Overflow FFFE0 <sub>16</sub> to FFFE3 <sub>16</sub> | | Interrupt on INTO instruction | | | | BRK instruction FFFE4 <sub>16</sub> to FFFE7 <sub>16</sub> | | If the vector is filled with FF <sub>16</sub> , program execution starts from the address shown by the vector in the variable vector table | | | | Address Match FFFE8 <sub>16</sub> to FFFEB <sub>16</sub> | | There is an address-matching interrupt enable bit | | | | Single Step (Note) | FFFEC <sub>16</sub> to FFFEF <sub>16</sub> | Do not use | | | | Watchdog timer | FFFF0 <sub>16</sub> to FFF3 <sub>16</sub> | | | | | DBC (Note) | FFFF4 <sub>16</sub> to FFFF7 <sub>16</sub> | Do not use | | | | NMI | FFFF8 <sub>16</sub> to FFFFB <sub>16</sub> | External interrupt by NMI pin | | | | Reset | FFFFC <sub>16</sub> to FFFFF <sub>16</sub> | | | | Note: Interrupts used for debugging purposes only Figure 1.15: Format for specifying interrupt vector addresses Table 1.9: Interrupt vectors (variable interrupt vector addresses) | Software interrupt number | Vector table addresses<br>Address(L) to Address(H) | Interrupt source | Remarks | | |--------------------------------------------------------------------|----------------------------------------------------|-------------------------|----------------------------|--| | Software interrupt number 0 | oftware interrupt number 0 +0 to +3 (Note 1) | | Cannot be masked by I flag | | | Software interrupt number 4 | +16 to +19 | USB Suspend | | | | Software interrupt number 6 | +24 to +27 | USB Resume | | | | Software interrupt number 7 | +28 to +31 | USB Start of Frame | | | | Software interrupt number 10 | +40 to +43 | Bus collision detection | | | | Software interrupt number 11 | +44 to +47 | DMA0 | | | | Software interrupt number 12 | +48 to +51 | DMA1 | | | | Software interrupt number 13 | +52 to +55 | Key input interrupt | | | | Software interrupt number 14 | +56 to +59 | A-D | | | | Software interrupt number 15 | +60 to +63 | UART2 transmit | | | | Software interrupt number 16 | +64 to +67 | UART2 receive | | | | Software interrupt number 17 | +68 to +71 | UART0 transmit | | | | Software interrupt number 18 | +72 to +75 | UART0 receive | | | | Software interrupt number 19 | +76 to +79 | UART1 transmit | | | | Software interrupt number 20 | +80 to +83 | UART1 receive | | | | Software interrupt number 21 | +84 to +87 | Timer A0 | | | | Software interrupt number 22 | +88 to +91 | Timer A1 | | | | Software interrupt number 23 | +92 to +95 | Timer A2 | | | | Software interrupt number 24 | +96 to +99 | Timer A3 | | | | Software interrupt number 25 | +100 to +103 | Timer A4 | | | | Software interrupt number 26 | +104 to +107 | Timer B0 | | | | Software interrupt number 27 | +108 to +111 | Timer B1 | | | | Software interrupt number 28 | +112 to +115 | USB Reset | | | | Software interrupt number 29 | +116 to +119 | INT0 | | | | Software interrupt number 30 | +120 to +123 | INT1 | | | | Software interrupt number 31 | +124 to +127 | USB Function | | | | Software interrupt number 32<br>to<br>Software interrupt number 63 | +252 to +255 | Software interrupt | Cannot be masked by I flag | | Note 1:Address relative to address in interrupt table base address register (INTB) #### 2.14.1 Interrupt control registers Peripheral I/O interrupts have their own interrupt control registers. Table 1.10 shows the addresses of the interrupt control registers. Figure 1.16 shows the interrupt control registers. The interrupt request bit is set by hardware to "0" when an interrupt request is received. The interrupt request bit can also be set by software to "0". (Do not set to "1".) INTO and INT1 are triggered by the edges of external inputs. The edge polarity is selected using the polarity select bit. (Other interrupts are described elsewhere.) An interrupt must first be enabled before it can be used to cancel stop mode. Table 1.10: Addresses in interrupt control register | Interrupt control register | Symbol name | Address | Interrupt control register | Symbol name | Address | |----------------------------|-------------|--------------------|----------------------------|-------------|--------------------| | USB Suspend Interrupt | SUSPIC | 0044 <sub>16</sub> | UART1 receive | S1RIC | 0054 <sub>16</sub> | | USB Resume interrupt | RSMIC | 0046 <sub>16</sub> | Timer A0 | TA0IC | 0055 <sub>16</sub> | | USB Start Of Frame | SOFIC | 0047 <sub>16</sub> | Timer A1 | TA1IC | 0056 <sub>16</sub> | | Bus collision detection | BCNIC | 004A <sub>16</sub> | Timer A2 | TA2IC | 0057 <sub>16</sub> | | DMA0 | DM0IC | 004B <sub>16</sub> | Timer A3 | TA3IC | 0058 <sub>16</sub> | | DMA1 | DM1IC | 004C <sub>16</sub> | Timer A4 | TA4IC | 0059 <sub>16</sub> | | Key input interrupt | KUPIC | 004D <sub>16</sub> | Timer B0 | TB0IC | 005A <sub>16</sub> | | A-D | ADIC | 004E <sub>16</sub> | Timer B1 | TB1IC | 005B <sub>16</sub> | | UART2 transmit | S2TIC | 004F <sub>16</sub> | USB Reset | RSTIC | 005C <sub>16</sub> | | UART2 receive | S2RIC | 0050 <sub>16</sub> | INT0 | INT0IC | 005D <sub>16</sub> | | UART0 transmit | S0TIC | 0051 <sub>16</sub> | INT1 | INT1IC | 005E <sub>16</sub> | | UART0 receive | SORIC | 0052 <sub>16</sub> | USB Function | USBFIC | 005F <sub>16</sub> | | UART1 transmit | S1TIC | 0053 <sub>16</sub> | | | | Figure 1.16: Interrupt control registers #### **Preliminary Specifications REV. E** Specifications in this manual are tentative and subject to change Interrupts #### 2.14.2 Interrupt priority The order of priority when two or more interrupts are generated simultaneously is determined by both hardware and software. The interrupt priority levels determined by hardware are reset $> \overline{\text{NMI}} > \overline{\text{DBC}} > \text{watchdog timer} > \text{peripheral I/O interrupts} > \text{single-step} > \text{address matching interrupt}.$ The interrupt priority levels determined by software are set in the interrupt control registers. Figure 1.17 shows the circuit that judges the interrupt hardware priority level. When two or more interrupts are generated simultaneously, the interrupt with the higher software priority is selected. However, if the interrupts have the same software priority level, the interrupt is selected according to the hardware priority set in the circuit. The selected interrupt is accepted only when the priority level is higher than the processor interrupt priority level (IPL) in the flag register (FLG) and the interrupt enable flag (I flag) is "1". Note that the reset, $\overline{\text{NMI}}$ , $\overline{\text{DBC}}$ , watchdog timer, single-step, address-match, BRK instruction, overflow, and undefined instruction interrupts are accepted regardless of the interrupt enable flag (I flag). Figure 1.17: Interrupt resolution circuit NMI Interrupt #### 2.14.3 Flag changes When an interrupt request is received, the stack pointer select flag (U flag) changes to "0" and the flag register (FLG) and program counter (PC) are saved to the stack area indicated by the interrupt stack pointer (ISP). Thereafter, the interrupt enable flag (I flag) and debug flag (D flag) change to "0" and the processor interrupt priority level (IPL) at the flag register (FLG) is replaced by the priority level of the received interrupt. However, when interrupt requests are received for software interrupts 32 to 63, the flag register (FLG) and program counter (PC) are saved to the stack shown by the stack pointer select flag (U flag) at the time the interrupt was received. The stack pointer select flag (U flag) does not change. The value of the processor interrupt priority level (IPL) in the flag register (FLG) differs in the case of reset, $\overline{\text{NMI}}$ , $\overline{\text{DBC}}$ , watchdog timer, single-step, address-match, BRK instruction, overflow, and undefined instruction interrupts. Table 1.11 shows how the IPL changes when interrupt requests are received. Table 1.11: Change of IPL state when interrupt request are accepted | Interrupt | Change of IPL | |--------------------|--------------------------------------| | Reset | Level 0 ("000 <sub>2</sub> ), is set | | NMI | Level 7 ("111 <sub>2</sub> ), is set | | DBC | Does not change | | Watchdog timer | Level 7 ("111 <sub>2</sub> ), is set | | Single step | Does not change | | Address match | Does not change | | Software interrupt | Does not change | ### 2.13 NMI Interrupt An $\overline{\text{NMI}}$ interrupt is generated when the input to the P85/ $\overline{\text{NMI}}$ pin changes from "H" to "L". The $\overline{\text{NMI}}$ interrupt is a non-maskable external interrupt. The pin level can be checked in the Port P85 register (bit 5 at address 03F0<sub>16</sub>). This pin cannot be used as a normal port input. #### 2.13.1 Notes: - (1) When not intending to use the $\overline{\text{NMI}}$ function, be sure to connect the $\overline{\text{NMI}}$ pin to VCC. Because the $\overline{\text{NMI}}$ interrupt is non-maskable, it cannot be disabled. - (2) When the NMI pin input is "L", do not set the microcomputer in stop mode or wait mode. The NMI interrupt is triggered by the falling edge, so the "L" level does not need to be maintained longer than necessary. **Key-Input Interrupt** #### 2.14 Key-Input Interrupt If the direction register of any of pin of Port0 or Port1 is set for input and a falling edge is input to that port, a key-input interrupt is generated. A key-input interrupt can also be used as a key-on wakeup function for cancelling the wait mode or stop mode. Figure 1.18 shows the block diagram of the key-input interrupt. Figure 1.18: Block diagram of key input interrupt #### 2.14.1 Enabling/disabling the key-input interrupt The key-input interrupt can be enabled and disabled using the key-input interrupt register (004D<sub>16</sub>). The key-input interrupt is affected by the interrupt priority level (IPL) and the interrupt enable flag (I flag). #### 2.14.2 Occurrence timing of the key-input interrupt With key-input interrupt acceptance enabled, ports P0 and P1, which are set to input, become key-input interrupt pins ( $\overline{\text{K10}}$ through $\overline{\text{K115}}$ ). A key-input interrupt occurs when a falling edge is input to a key-input interrupt pin. At this moment, the level of other key-input interrupt pins must be "H". No interrupt occurs when the level of any other key-input interrupt pins is "L". #### 2.14.3 How to determine a key-input interrupt A key-input interrupt occurs when a falling edge is input to one of 16 pins, but each pin has the same vector address. Therefore, read the input level of ports P0 and P1 in the key-input interrupt routine to determine the interrupted pin. **Key-Input Interrupt** # 2.14.4 Registers related to the key-input interrupt Figure 1.19 shows the memory map of key-input interrupt-related registers Figure 1.19: Memory Map of key input interrupt related registers Address Match Interrupt # 2.15 Address Match Interrupt An address match interrupt is generated when the address match interrupt address register contents match the program counter value. Two address match interrupts can be set, each of which can be enabled and disabled by an address match interrupt enable bit. Address match interrupts are not affected by the interrupt enable flag (I flag) and processor interrupt priority level (IPL). Figure 1.20 shows the address match interrupt-related registers. Figure 1.20: Address match interrupt-related registers Watchdog Timer # 2.16 Watchdog Timer The watchdog timer has the function of detecting when the program is out of control. The watchdog timer is 39a 15-bit counter that decrements using the clock derived by dividing the internal clock $\Phi$ using the prescaler. A watchdog timer interrupt is generated when an underflow occurs in the watchdog timer. Bit 7 of the watchdog timer control register (address $000F_{16}$ ) selects the prescaler division ratio (by 16 or 128). Table 1.12 shows the periodic table for the watchdog timer. Table 1.12: Watchdog timer periodic table (f(XIN)=10MHz) | CM06 | CM17 | CM16 | Internal<br>clock Φ | WDC7 | Period | |------|---------|---------|---------------------|-----------------|-----------------| | 0 | 0 | 0 | 10MHz | 0 | Approx. 52.4ms | | | | | | 1 | Approx. 419.2ms | | 0 0 | 1 | EMU- | 0 | Approx. 104.9ms | | | | U | ' | 5MHz | 1 | Approx. 838.8ms | | 0 | 1 | 0 | 2.5MHz | 0 | Approx. 209.7ms | | | | | | 1 | Approx. 1.68s | | 0 | 1 | 1 | 0.625MHz | 0 | Approx. 838.8ms | | | ' | | | 1 | Approx. 6.71s | | 1 | Invalid | Invalid | 1.25MHz | 0 | Approx. 419.2ms | | | | | | 1 | Approx. 3.35s | The watchdog timer is initialized by writing to the watchdog timer start register (address $000E_{16}$ ) and when a watchdog timer interrupt request is generated. The prescaler is initialized only when the microcomputer is reset. After a reset is cancelled, the watchdog timer and prescaler are both stopped. The count is started by writing to the watchdog timer start register (address $000E_{16}$ ). Figure 1.21 shows the block diagram of the watchdog timer. Figure 1.22 shows the watchdog timer-related registers. Watchdog Timer Figure 1.21: Block diagram of watchdog timer Figure 1.22: Watchdog timer control and start registers Frequency Synthesizer Circuit # 2.17 Frequency Synthesizer Circuit The Frequency Synthesizer Circuit generates a 48MHz clock needed by the USB block and a clock $f_{SYN}$ that are both a multiple of the external input reference clock f(Xin). A block diagram of the circuit is shown in Figure 1.23. Figure 1.23: Frequency Synthesizer Circuit The frequency synthesizer consists of a prescaler, frequency multiplier macro, a frequency divider macro, and five registers, namely FSP, FSM, FSC, FSD, and FSCCR. Clock f(Xin) is prescaled down using FSP to generate $f_{PIN}$ . $f_{PIN}$ is multiplied using FSM to generate an $f_{VCO}$ clock which is then divided using FSD to produce the clock $f_{SYN}$ . The $f_{VCO}$ clock is optimized for 48 MHz operation and is buffered and sent out of the frequency synthesizer block as signal $f_{USB}$ . This signal is used by the USB block. # 2.17.1 Prescaler Clock $f_{PIN}$ is a divided down version of clock f(Xin) (see Figure 1.24). The relationship between $f_{PIN}$ and the clock input to the prescaler f(Xin) is as follows: - f<sub>PIN</sub> = f(Xin) / 2(n+1) where n is a decimal number between 0 and 254. Setting FSP to 255 disables the prescaler and f<sub>PIN</sub> = f(Xin). - Note: f(Xin) frequency below 1 MHz is not recommended. Figure 1.24: Frequency Synthesizer Prescaler Register (FSP) Frequency Synthesizer Circuit # nthesizer Circuit ## 2.17.2 Multiplier Clock $f_{VCO}$ is a multiplied up version of clock $f_{PIN}$ (See Figure 1.25). The relationship between $f_{VCO}$ and the clock input to the multiplier ( $f_{PIN}$ ) from the prescaler is as follows: • $f_{VCO} = f_{PIN} \times 2(n+1)$ where n is the decimal equivalent of the value loaded in FSM. Setting FSM to 255 disables the multiplier and $f_{VCO} = f_{PIN}$ . Note 1: n must be chosen such that f<sub>VCO</sub> equals 48 MHz. Note 2: Minimum f<sub>PIN</sub> is 1 MHz. Figure 1.25: Frequency Synthesizer Multiply Register (FSM) # **2.17.3 Divider** Clock $f_{SYN}$ is a divided down version of clock $f_{VCO}$ (See Figure 1.26). The relationship between $f_{SYN}$ and the clock input to the divider ( $f_{VCO}$ ) from the multiplier is as follows: • $f_{SYN} = f_{VCO} / 2(m+1)$ where m is the decimal equivalent of the value loaded in FSD. Setting FSD to 255 disables the divider and $f_{SYN} = f_{VCO}$ . Figure 1.26: Frequency Synthesizer Divide Register (FSD) Frequency Synthesizer Circuit The FSC0 bit in the FSC Control Register enables the frequency synthesizer block. When disabled (FSC0 = "0"), $f_{VCO}$ is held at either a high or low state. When the frequency synthesizer control bit is active (FSC0 = "1"), a lock status (LS = "1") indicates that $f_{SYN}$ and $f_{VCO}$ are the correct frequency. The LS and FSCO control bits in the FSC Control register are shown in Figure 1.27. When using the frequency synthesizer, a low-pass filter must be connected to the LPF pin. Once the frequency synthesizer is enabled, a delay of 2-5ms is recommended before the output of the frequency synthesizer is used. This is done to allow the output to stabilize. It is also recommended that none of the registers be modified once the frequency synthesizer is enabled as it will cause the output to be temporarily (2-5ms) unstable. The MCU clock source is selected via the Frequency Synthesizer Clock Control register (FSCCR). See Figure 1.28. Note: None of the registers must be written to once the frequency synthesizer is enabled and used as the system clock source (FSCCR register, address $03DB_{16}$ , bit '0' set to '1') because it will cause the output of the PLL to freeze. Switch system back to $f(X_{IN})$ and disable before modifying PLL registers. Figure 1.27: Frequency Synthesizer Control Register (FSC) Figure 1.28: Frequency Synthesizer Clock Control Register (FSCCR) ## 2.18 Universal Serial Bus The Universal Serial Bus (USB) has the following features: - Complete USB Specification (version 1.1) Compatibility - Error-handling capabilities - FIFOs: - Endpoint 0: IN/OUT 32-byte - Endpoint 1: IN 128-byte OUT 128-byte Endpoint 2: IN 32-byte OUT 32-byte Endpoint 3: IN 32-byte OUT 32-byte - Endpoint 4: IN 32-byte OUT 32-byte - Nine endpoints control endpoint (Endpoint 0 bi-directional) plus four IN and four OUT endpoints - · Complete device configuration - · Support of all device commands - Supports of full-speed functions - · Support of all USB transfer types: - Isochronous - Bulk - Control - Interrupt - Suspend/Resume operation - On-chip USB transceiver with voltage converter - · Start-of-frame interrupt and output pin ### 2.18.1 USB Function Control Unit (USB FCU) The implementation of the USB by this device is accomplished chiefly through the device's USB Function Control Unit (See Figure 1.29). The Function Control Unit's overall purpose is to handle the USB packet protocol layer. The Function Control Unit notifies the MCU that a valid token has been received. When this occurs, the data portion of the token is routed to the appropriate FIFO. The MCU transfers the data to, or from, the host by interacting with that endpoint's FIFO and CSR register. The USB Function Control Unit is composed of five sections: - Serial Interface Engine (SIE) - Generic Function Interface (GFI) - Serial Engine Interface Unit (SIU) - Microcontroller Interface (MCI) - USB Transceiver #### 2.18.1.1 Serial Interface Engine The SIE interfaces to the USB serial data and handles deserialization/serialization of data, NRZI encoding decoding, clock extraction, CRC generation and checking, bit stuffing, and other items pertaining to the USB protocol such as handling inter-packet time-outs and packet ID (PID) decoding. ### 2.18.1.2 Generic Function Interface The GFI handles all USB standard requests from the host through the control endpoint (endpoint zero), handles Bulk, Isochronous and Interrupt transfers through endpoints 1-4. The GFI handles read pointer reversal for re-transmission the current data set; write pointer reversal for reception of the last data set again and data toggle synchronization. ## 2.18.1.3 Serial Engine Interface Unit The SIU block decodes the Address and Endpoint fields from the USB host. #### 2.18.1.4 Microcontroller Interface The MCI block handles the Microcontroller interface and performs address decoding and synchronization of control signals. #### 2.18.1.5 USB Transceiver The USB transceiver, designed to interface with the physical layer of the USB, is compliant with the USB Specification (version 1.1) for full-speed devices. It consists of two 6-ohm drivers, a receiver, and Schmitt triggers for single-ended receive signals. The transceiver also includes a voltage converter. The voltage converter can supply 3.0 - 3.6V to the transmitter when the rest of the chip (CPU, USB FCU) operates at 4.15 - 5.25V. To enable the voltage converter, set bit 4 of the USB Control Register (USBC) to a "1". To disable the voltage converter, set bit 4 of the USBC to a "0". Refer to Section 5.4 "USB Transceiver" for more detailed information. Figure 1.29: USB Function Control Unit Block Diagram # 2.18.2 USB Interrupts There are five USB interrupts in this device: - · USB Function interrupt - USB Reset interrupt - USB Suspend interrupt - USB Resume interrupt - USB Start-of-Frame (SOF) interrupt. The first four interrupts are used to control the data flow and USB power. The SOF interrupt is used to monitor the transfer of isochronous (ISO) data. Each of the five USB interrupts is enabled by setting the corresponding bit in the Interrupt Control Register of the Interrupt Control Unit. Because the USB Function Interrupt has multiple interrupt sources, another level of enabling is within the USB Interrupt Registers 1 & 2. ### 2.18.2.1 USB Function Interrupt The USB Function Interrupt can be triggered by 10 sources; many of these may be cause by several different events. Interrupt status flags associated with each source are contained in USBIS1 and USBIS2. Endpoints 1-4 have two interrupt status flags associated with it to control data transfer or to report a STALL/UNDER RUN/OVER RUN condition. The USB Endpoint x Out Interrupt Status Flag is set when - USB FCU successfully receives a packet of data OR - USB FCU sets the FORCE\_STALL bit or OVER\_RUN bit of the Endpoint x OUT CSR. The USB Endpoint x In Interrupt Status is set when - · USB FCU successfully sends a packet of data OR - USB FCU sets the UNDER\_RUN bit of the Endpoint x IN CSR. The USB Endpoint 0 (control endpoint) has one interrupt status bit associated with it to control data transfer or report a STALL condition. The USB Endpoint 0 Interrupt Status Flag is set when - · USB FCU successfully receives/sends a packet of data - Sets the SETUP\_END bit or the FORCE\_STALL bit, OR clears the DATA\_END bit in the Endpoint 0 IN CSR. The Overrun/Underrun Interrupt Status Flag is set when (applicable to endpoints used for isochronous data transfer) - Overrun condition occurs in a endpoint (CPU is too slow to unload the data from the FIFO), OR - Underrun condition occurs in an endpoint (CPU is too slow to load the data to the FIFO). Each endpoint interrupt and overrun/underrun interrupt is enabled by setting the corresponding bit in the USB Interrupt Enable Register 1 and 2. # 2.18.2.2 USB Reset Interrupt The USB Reset Interrupt Status Flag is set when the USB FCU sees a SE0 present on D+/D- for at least 2.5μs. When this bit is set, all USB internal registers except INTST13 (bit5 of USBIS2) are reset to their default values. INTST13, the USB reset Interrupt Status Flag, is set to a "1" when the USB Reset is detected. When the CPU recognizes a USB Reset Interrupt, it needs to re initialize the USB FCU so that the USB operation can behave properly. It must also clear INTST13 by writing a "1" to this bit to allow a USB Reset Interrupt request to occur the next time a USB Reset is detected. Register RSTIC contains the USB Reset Interrupt's request bit and its interrupt priority select bits which are used to enable the interrupt and set its software priority level. # 2.18.2.3 USB Suspend and Resume Interrupts The USB Suspend Interrupt is set when the USB FCU does not detect any bus activity on D+/D- (in J-state) for at least 3ms. The USB Suspend Signaling Interrupt Status Flag (INTST15, bit 7 of USBIS2) is set to a "1" when the USB Suspend is detected. The CPU must clear INTST15 by writing a "1" to this bit to allow a USB Suspend Interrupt request to occur the next time a USB Suspend is detected. The USB Resume Signaling Interrupt Status Flag is set when a USB FCU is in the suspend state and detects non-idle signaling on the D+/D-. Register SUSPIC contains the USB Suspend Interrupt's request bit and its interrupt priority select bits which are used to enable the interrupt and set its software priority level. The USB Resume Interrupt request is set when the USB FCU is in the suspend state and detects non-idle signaling on D+/D-. The USB Signaling Interrupt Status Flag (INTST14, bit 6 of USBIS2) is set to a "1" when the USB Resume is detected. The CPU must clear INTST14 by writing a "1" to this bit to allow a USB Resume Interrupt request to occur the next time a USB Resume is detected. Register RSMIC contains the USB Resume Interrupt's request bit and its interrupt priority select bits, which are used to enable the interrupt an set its software priority level. ## 2.18.2.4 USB SOF Interrupt The USB SOF (Start-Of-Frame) Interrupt is used to control the transfer of isochronous data. The USB FCU generates a USB SOF Interrupt request when a start-of-frame packet is received. Register SOFIC contains the USB SOF Interrupt's request bit and its interrupt priority select bits, which are used to enable the interrupt and set its software priority level. # 2.18.3 USB Endpoint FIFOs The USB FCU has an IN (transmit) FIFO and an OUT (receive) FIFO for each endpoint. Each endpoint (except endpoint 0) can be configured to support either single packet mode (in which only a single data packet is allowed to reside in the endpoint's FIFO) or dual packet mode (in which up to two data packets are allowed to reside in the endpoint's FIFO). Dual packet mode provides support for back-to-back transmission or back-to-back reception. The mode is automatically determined by the MAXP value. When MAXP > 1/2 of the endpoint's FIFO size, single packet mode is set. When MAXP <= 1/2 of the endpoint's FIFO size, dual packet mode is set. In the event of a bad transmission/reception, the USB FCU handles all the FIFO read/write pointer reversal and data set management tasks required. Throughout this specification, the terms "IN FIFO" and "OUT FIFO" usually refer to the FIFOs associated with a specific endpoint. ## 2.18.3.1 IN (Transmit) FIFOs The CPU/DMA writes data to the endpoint's IN FIFO location specified by the FIFO write pointer, which automatically increments by "1" after a write. The CPU/DMA should only write data to the IN FIFO when the IN\_PKT\_RDY bit of the associated IN CSR is a "0". ### Endpoint 0 IN FIFO Operation: The CPU writes a "1" to the IN\_PKT\_RDY bit of Endpoint 0 CSR after it finishes writing a packet of data to the IN FIFO. The USB FCU clears the IN\_PKT\_RDY bit after the packet has been successfully transmitted to the host (i.e., ACK is received from the host) or the SETUP\_END bit of the IN CSR is set to a "1". # • Endpoint 1-4 IN FIFO Operation when AUTO\_SET (bit 7 of Endpoint x IN CSR) = "0" (disabled): MAXP > 1/2 of the IN FIFO size: The CPU writes a "1" to the IN\_PKT\_RDY bit of the associated IN CSR after the CPU/DMAC finishes writing a packet of data to the IN FIFO. The USB FCU clears the IN\_PKT\_RDY bit after the packet has been successfully transmitted to the host (which is assumed for isochronous transfers and is concluded when an ACK is received from the host for non-isochronous transfers). MAXP <= 1/2 of the IN FIFO size: The CPU writes a "1" to the IN\_PKT\_RDY bit of the associated IN CSR after the CPU/DMAC finishes writing a packet of data to the IN FIFO. The USB FCU clears the IN\_PKT\_RDY bit as soon as the IN FIFO is ready to accept another data packet. (The FIFO can hold up to two data packets at the same time in this configuration for back-to-back transmission.) #### • Endpoint 1-4 IN FIFO Operation when AUTO SET (bit 7 of Endpoint x IN CSR) = "1" (enabled): MAXP > 1/2 of the IN FIFO size: When the number of bytes of data equal to the MAXP (maximum packet size) has been written to the IN FIFO by the CPU/DMAC, the USB FCU sets the IN\_PKT\_RDY bit of the associated IN CSR to a "1" automatically. The USB FCU clears the IN\_PKT\_RDY bit after the packet has been successfully transmitted to the host (which is assumed for isochronous transfers and is concluded when an ACK is received from the host for non-isochronous transfers). MAXP <= 1/2 of the IN FIFO size: When the number of bytes of data equal to the MAXP (maximum packet size) has been written to the IN FIFO by the CPU/DMAC, the USB FCU sets the IN\_PKT\_RDY bit to a "1" automatically. The USB FCU clears the IN\_PKT\_RDY bit as soon as the IN FIFO is ready to accept another data packet. (The FIFO can hold up to two data packets at the same time in this configuration for back-to-back transmission.) A software or a hardware flush causes the USB FCU to act as if a packet has been successfully transmitted out to the host. When there is one packet in the IN FIFO, a flush causes the IN FIFO to be empty. When there are two packets in the IN FIFO, a flush causes the older packet to be flushed out from the IN FIFO. A flush also updates the IN FIFO status bits IN\_PKT\_RDY and TX\_NOT\_EMPTY of the associated IN CSR. The status of endpoint 1-4 IN FIFOs for both of the above cases can be obtained from the IN CSR of the corresponding IN FIFO as shown in Table 1.13. Table 1.13: TA FIFO Status | IN_PKT_RDY | TX_NOT_EMPTY | IN FIFO Status | |------------|--------------|--------------------------------------------------------------------------------------------------------------------------| | 0 | 0 | No data packet in IN FIFO | | 0 | | One data packet in IN FIFO if MAXP <= 1/2 of the FIFO size./ Invalid when MAXP>1/2 of the FIFO size | | 1 | 0 | Invalid | | 1 | 1 | Two data packets in IN FIFO when MAXP <=1/2 of the FIFO size One data packet in IN FIFO when MAXP > 1/2 of the FIFO size | # 2.18.3.2 Out (Receive) FIFOs The USB FCU writes data to the endpoint's OUT FIFO location specified by the FIFO write pointer, which automatically increments by one after a write. When the USB FCU has successfully received a data packet, it sets the OUT\_PKT\_RDY bit of the corresponding OUT CSR to a "1". The CPU/DMAC should only read data from the OUT FIFO when the OUT\_PKT\_RDY bit of the OUT CSR is a "1". ### • Endpoint 0 OUT FIFO Operation: The USB FCU sets the OUT\_PKT\_RDY bit to a "1" after it has successfully received a packet of data from the host. The CPU sets bit SERVICED\_OUT\_PKT\_RDY to a "1" to clear the OUT\_PKT\_RDY bit after the packet of data has been unloaded from the OUT FIFO by the CPU. ### Endpoint 1-4 OUT FIFO Operation when AUTO\_CLR (bit 7 of Endpoint x OUT CSR) = "0" (disabled): MAXP > 1/2 of the OUT FIFO size: The USB FCU sets the OUT\_PKT\_RDY bit of the associated IN CSR to a "1" after it has successfully received a packet of data from the host. The CPU writes a "0" to the OUT\_PKT\_RDY bit after the packet of data has been unloaded from the OUT FIFO by the CPU/DMAC. MAXP <= 1/2 of the OUT FIFO size: The USB FCU sets the OUT\_PKT\_RDY bit of the associated IN CSR to a "1" after it has successfully received a packet of data from the host. The CPU writes a "0" to the OUT\_PKT\_RDY bit after the packet of data has been unloaded from the OUT FIFO by the CPU/DMAC. If another packet is in the OUT FIFO, the OUT\_PKT\_RDY bit will be set to a "1" again almost immediately (such that it may appear that the OUT\_PKT\_RDY bit remains a "1"). In this configuration, the FIFO can store up to two data packets at the same time for back-to-back reception. ## • Endpoint 1-4 OUT FIFO Operation when AUTO\_CLR (bit 7 of Endpoint x OUT CSR) = "1" (enabled): MAXP > 1/2 of the OUT FIFO size: The USB FCU sets the OUT\_PKT\_RDY bit of the associated IN CSR to a "1" after it has successfully received a packet of data from the host. The USB FCU clears the OUT\_PKT\_RDY bit to a "0" automatically when the number of bytes of data equal to the MAXP (maximum packet size) has been unloaded from the OUT FIFO by the CPU/DMAC. MAXP <= 1/2 of the OUT FIFO size: The USB FCU sets the OUT\_PKT\_RDY bit of the associated IN CSR to a "1" after it has successfully received a packet of data from the host. The USB FCU clears the OUT\_PKT\_RDY bit to a "0" automatically when the number of bytes of data equal to the MAXP (maximum packet size) has been unloaded from the OUT FIFO by the CPU/DMAC. If another packet is in the OUT FIFO, the OUT\_PKT\_RDY bit will be set to a "1" again almost immediately (such that it may appear that the OUT\_PKT\_RDY bit remains a "1"). In this configuration, the FIFO can store up to two data packets at the same time for back-to-back reception. A software flush causes the USB FCU to act as if a packet has been unloaded from the OUT FIFO. If there is one packet in the OUT FIFO, a flush will cause the OUT FIFO to be empty. If there are two packets in the OUT FIFO, a flush will cause the older packet to be flushed out from the OUT FIFO. ### 2.18.3.3 Interrupt Endpoints: Any endpoint can be used for interrupt transfers. For normal interrupt transfers, the interrupt transactions behave the same as bulk transactions, i.e., no special setting is required. The IN endpoints may also be used to communicate rate feedback information for certain types of isochronous functions. This is done by setting the INTPT bit in the IN CSR register of the corresponding endpoint. The following outlines the operation sequence for an IN endpoint used to communicate rate feedback information: - 1. Set MAXP > 1/2 of the endpoint's FIFO size; - 2. Set INTPT bit of the IN CSR: - 3. Flush the old data in the FIFO; - Load interrupt status information and set IN\_PKT\_RDY bit in the IN CSR; - 5. Repeat steps 3 & 4 for all subsequent interrupt status updates. # 2.18.4 USB Special Function Registers The MCU controls USB operation through the use of special function registers (SFR). This section describes each USB related SFR. Some USB special function registers have a mix of read/write, read only, and write only register bits. Additionally, the bits may be configured to allow the user to write only a "0" or a "1" to individual bits. - When accessing these registers, writing a "0" to a register that can only be set to a "1" by the CPU has no effect on that register bit. - Writing a "1" to a register that can only be set to a "0" by the CPU has not effect on that register bit. Each figure and description of the special function registers details this operation. All USB Special Function Registers, with the exception of USB Attach/Detach ( $001F_{16}$ ) and USB control ( $000C_{16}$ ) must use byte access. Work access is prohibited for USB internal registers ( $0300_{16}$ - $033C_{16}$ ). The contents of all USB Special Functions Registers, including USB Attach/Detach and USB Control, are preserved on a software reset. # 2.18.4.1 USB Attach/Detach Register The USB Attach / Detach Register is shown in Figure 1.30. The register is used to attach and detach the USB function from a USB host without physically disconnecting the USB cable. This functionality is enabled by setting P83\_SECOND to a "1". Doing this forces P83 to operate as a pull-up for D+ (through an external 1.5k ohm resistor). The port driver is tri-stated and a "1" is always read from the port bit in this mode. When the ATTACH/DETACH bit is a "1" (and P83\_SECOND is a "1"), P83 is driven with the voltage on EXTCAP, causing D+ to be pulled up and the host to detect an attach. When the ATTACH/DETACH bit is a "0" (and P83\_SECOND is a "1"), P83 is tri-stated, causing D+ to be pulled down (through the cable and 15k ohm resistor on the host/hub side) and a detach to be registered by the host. A 1.5k ohm pull-up resistor must be connected externally from P83 to D+ when this functionality is used. When it is not used, the 1.5k ohm resistor should be placed between EXTCAP and D+. Figure 1.30: USB Attach/Detach Register # 2.18.4.2 USB Control Register The USB Control Register, shown in Figure 1.31, is used to control the USB FCU. This register is not reset by a USB reset signaling. After the USB is enabled (USBC7 set to "1"), a minimum delay of 250ns (three 12 MHz clock periods) is needed before performing any other USB register read/write operations. Figure 1.31: USB Control Register # 2.18.4.3 USB Function Address Register The USB Function Address Register, shown in Figure 1.32, maintains the 7-bit USB address assigned by the host. The USB FCU uses this register value to decode USB token packet addresses. At reset, when the device is not yet configured, the value is $00_{16}$ . For the procedures on how to update this register, refer to Application Notes USB Consecutive Set Address. Figure 1.32: USB Function Address Register ### 2.18.4.4 The USB Power Management Register The USB Power Management Register, shown in Figure 1.33, is used for power management in the USB FCU. ### SUSPEND Detection Flag: When the USB FCU does not detect any bus activity on D+/D- for at least 3ms (and D+/D- are in the J-state), it sets the Suspend Detection Flag and generates an interrupt. This bit is cleared when signaling from the host is detected on D+/D- (which sets the Resume Detection Flag and generates an interrupt), or the Remote Wake-up Bit is set and then cleared by the CPU. If the USB clock was disabled during the suspend state, the SUSPEND Detection Flag is not cleared until after the USB clock is re-enabled. ### RESUME Detection Flag: When the USB FCU is in the suspend state and detects activity on D+/D- from the host, it sets the Resume Detection Flag and generates an interrupt. The CPU writes a "1" to INTST14 (bit 6 of USB Interrupt Status Register 2) to clear this flag. #### • WAKEUP Control Bit: The CPU writes a "1" to the WAKEUP Control Bit for remote wake-up. While this bit is set and the USB FCU is in suspend mode, resume signaling is sent to the host. The CPU must keep this bit set for a minimum of 10ms and a maximum of 15ms before writing a "0" to this bit. Figure 1.33: USB Power Management Register ## 2.18.4.5 USB Interrupt Status Registers 1 and 2 USB Interrupt Status Registers 1 and 2, shown in Figure 1.34 and Figure 1.35, are used to indicate the condition that caused a USB function interrupt and USB Reset, Suspend and Resume Interrupts to the CPU. A "1" indicates the corresponding condition caused an interrupt. The USB Interrupt Status Register bits can be cleared by writing a "1" to the corresponding bit. INTST0 is set to a "1" by the USB FCU when (in Endpoint 0 CSR): - •A packet of data is successfully received (EP0CSR0 OUT\_PKT\_RDY is set by the USB FCU) - A packet of data is successfully sent (EPOCSR IN\_PKT\_RDY is cleared by the USB FCU) - •EP0CSR3 (DATA\_END) bit is cleared by the USB FCU - •EP0CSR4 (FORCE\_STALL) bit is set by the USB FCU - •EP0CSR5 (SETUP\_END) bit is set by the USB FCU INTST2, INTST4, INTST6 or INTST8 is set to a "1" by the USB FCU when (in Endpoint x IN CSR): - •A packet of data is successfully sent (INXCSR0 IN\_PKT\_RDY is cleared by the USB FCU) - •INXCSR1 (UNDER\_RUN) bit is set by the USB FCU INTST3, INTST5, INTST7 or INTST9 is set to a "1" by the USB FCU when (in Endpoint xOUT CSR): - •A packet of data is successfully received (OUTXCSR0 OUT\_PKT\_RDY is set by the USB FCU) - •OUTXCSR1 (OVER\_RUN) bit is set by the USB FCU - •OUTXCSR4 (FORCE\_STALL) bit is set by the USB FCU INTST12 is set to a "1" by the USB FCU when an overrun or underrun condition occurs in any of the endpoints. INTST13 is set to a "1" by the USB FCU when a USB reset signaling from the host is received. All internal register bits except this bit are reset to their default values when the USB reset is received. INTST14 is set to a "1" by the USB FCU when the USB FCU is in the suspend state and non-idle signaling is received from D+/D-. INTST15 is set to a "1" by the USB FCU when D+/D- are in the idle state for more than 3ms. Figure 1.34: USB Interrupt Status Register 1 Figure 1.35: USB Interrupt Status Register 2 ### 2.18.4.6 Clearing of the USB Interrupt Status Registers The USB Interrupt Status Register 1 and 2 are used to indicate pending interrupts for a given source. The USB FCU sets the interrupt status bits. The CPU writes a "1" to each status bit to clear it. Because the USB Function Interrupt has multiple sources that can generate an interrupt, it is recommended that the user first read the two status registers and store them in variables then write back the same value for clearing all the existing interrupts that were pending when the status registers were read. This procedure prevents any interrupt that occurs after the status registers are read from being cleared by the 'write-back' operation. The CPU must read, then write both status registers, writing to status register 1 first and status register 2 second to guarantee proper operation. The upper three bits of the value written back to USBIS2 should always be "000" to prevent any of the USB Reset, Suspend and Resume Status Flags from being cleared. The USB Reset, Suspend and Resume Status Flags are contained in USBIS2 along with the USB Endpoint 4 In/Out Interrupt Status Flags and the USB Overrun/Underrun Interrupts Status Flag. Because the flags are not all sources for the same interrupt, use caution when clearing one or more of the flags to avoid inadvertently clearing other flags. The Reset, Suspend and Resume Status Flags should be cleared individually by writing a byte value with at "1" only at the position corresponding to the flag to be cleared. The USB Endpoint 4 In/Out Interrupt status Flags and the USB Overrun/Underrun Interrupt Status Flag should be cleared as described in the preceding paragraph because they are sourced for the USB Function Interrupt. "Read-modify-write' instructions, such as "BCLR' and 'BSET', should not be used to clear any of the interrupt status bits in USBIS1 or USBIS2. Using these instructions could cause pending interrupts to be cleared without the firmware's knowledge. ### 2.18.4.7 The USB Function Interrupt Enable Registers 1 and 2 The USB Function Interrupt Enable Registers 1 and 2, shown in Figure 1.36 and Figure 1.37, are used to enable the corresponding interrupt status conditions that can generate a USB Function Interrupt. When the bit to a corresponding interrupt condition is "0", that condition does not generate a USB function interrupt. When the bit is a "1", that condition can generate a USB function interrupt. At reset, all USB function interrupt status conditions are enabled. Figure 1.36: USB Interrupt Enable Register 1 Figure 1.37: USB Interrupt Enable Register 2 ## 2.18.4.8 USB Frame Number Registers The USB Frame Number Low Register, shown in Figure 1.38, contains the lower 8 bits of the 11-bit frame number received from the host. The USB Frame Number High Register, shown in Figure 1.39 contains the upper 3 bits of the 11-bit frame number received from the host. Figure 1.38: USB Frame Number Low Register Figure 1.39: USB Frame Number High Register ### 2.18.4.9 USB ISO Control Register The USB ISO Control Register, shown in Figure 1.40, contains two global bits, ISO\_UPD and AUTO\_FL for controlling endpoints 1-4 isochronous data transfer. When ISO\_UPD = "0", a data packet in an endpoint's IN FIFO is always 'ready to transmit' upon receiving the next IN\_TOKEN from the host (with matched address and endpoint number) if the endpoint's IN\_PKT\_RDY is set. When ISO\_UPD = "1" and the ISO/TOGGLE\_INIT bit of the corresponding endpoint's IN CSR is set, the internal 'ready to transmit' signal to the transmit control logic is not activated when the endpoint's IN\_PKT\_RDY is set. Instead, it is activated when the next SOF is received, this way, the data loaded in frame n is transmitted out in frame n+1. The ISO\_UPD bit is a global bit for endpoints 1-4 and works with isochronous pipes only. When AUTO\_FL = "1", ISO\_UPD = "1", a particular IN endpoint's ISO/TOGGLE\_INIT bit is set, and the IN endpoint's IN\_PKT\_RDY = "1", the USB FCU detects a SOF packet and the USB FCU automatically flushes the oldest packet from the IN FIFO. In this case, IN\_PKT\_RDY = "1", indicates that two data packets are in the IN FIFO. Because double buffering is a requirement for ISO transfer, MAXP must be set to less than or equal to 1/2 of the FIFO size. Figure 1.40: USB ISO Control Register # 2.18.4.10 USB DMAx Request Registers The USB DMAx Request Registers, shown in Figure 1.41 and Figure 1.42, are used to select which USB Endpoint x FIFO read/write requests are selected as the DMAC channel 0 or channel 1 request source. The USB DMA0 (DMA1) Request Register should have only one bit set at any given time. When multiple bits are set, no request is selected. Figure 1.41: USB DMA0 Request Register Figure 1.42: USB DMA1 Request Register # 2.18.4.11 USB Endpoint Enable Register The USB Endpoint Enable Register, shown in Figure 1.43, is used to enable/disable an individual endpoint. Endpoint 0 is always enabled and cannot be disabled by firmware. All endpoints are enabled after reset. Figure 1.43: USB Endpoint Enable Register ## 2.18.4.12 Endpoint 0 CSR (Control and Status Register) The Endpoint 0 CSR (Control and Status Register), shown in Figure 1.44 contains the control and status information of Endpoint 0. ### •EP0CSR0 (OUT\_PKT\_RDY): The USB FCU sets this bit to a "1" after it receives a valid SETUP/OUT token from the host. The CPU clears this bit after unloading the packet from the FIFO by writing a "1" to EP0CSR6. The CPU should not clear the OUT\_PKT\_RDY bit before it finishes decoding the host request. When EP0CSR2 (SEND\_STALL) needs to be set (because the CPU decodes an invalid or unsupported request) a "1" should be written to EP0CSR6 and EP0CSR2 at the same time using the same instruction. #### EP0CSR1 (IN\_PKT\_RDY): The CPU writes a "1" to this bit after it finishes writing a packet of data to the endpoint 0 FIFO. The USB FCU clears this bit after the packet is successfully transmitted to the host, or the EP0CSR5 (SETUP\_END) bit is set. #### EP0CSR2 (SEND STALL): The CPU writes a "1" to this bit when it decodes an invalid or unsupported standard device request from the host. When the OUT-PKT\_RDY bit is a "1" at the time the CPU wants to set the SEND\_STALL bit to a "1", the CPU must also set SERVICED\_OUT\_PKT\_RDY to a "1" to clear the OUT-PKT\_RDY at the same time as setting the SEND\_STALL bit. The USB FCU returns a STALL handshake for all subsequent IN/OUT transactions (during control transfer data or status stages) while this bit is set. The CPU writes a "0" to clear it after it receives a new SETUP packet. It is up to the firmware to decide what SETUP packet should lead the clearing of the SEND\_STALL bit. #### EP0CSR3 (DATA\_END): The CPU writes a "1" to this bit when it writes (IN data phase) or reads (OUT data phase) the last packet of data to or from the FIFO. The CPU sets this bit at the same time as it sets the last IN\_PKT\_RDY bit or sets the last SERVICED\_OUT\_PKT\_RDY bit. This bit indicates to the USB FCU that the specific amount of data in the setup phase is transferred. The USB FCU advances to the status phase once this bit is set. When the status phase completes, the USB FCU clears this bit. When this bit is set to a "1", and the host requests or sends more data, the USB FCU returns a STALL handshake and terminates the current control transfer. #### • EP0CSR4 (FORCE STALL): The USB FCU sets this bit to a "1" to report an error status when one of the following occur: - · Host sends an IN token in the absence of a SETUP stage - Host sends a bad data toggle in the STATUS stage, (i.e. DATA0 is used) - Host sends a bad data toggle in the SETUP stage, (i.e. DATA1 is used) - Host request more data than specified in the SETUP state, - (i.e. IN token comes after DATA\_END bit is set) - Host sends more data than specified in the SETUP state, - (i.e. OUT token comes after DATA\_END bit is set) - · Host sends larger data packet than MAXP size All of the conditions stated (except bad data toggle in the SETUP stage) cause the device to send a STALL handshake for the current IN/OUT transaction. For the bad data toggle in the SETUP state, the device sends ACK for the SETUP stage and then sends STALL for the next IN/OUT transaction. A STALL handshake caused by the above listed conditions lasts for one transaction and terminates the ongoing control transfer. Any packet after the STALL handshake will be seen as the beginning of a new control transfer. The CPU writes a "0" to clear the FORCE\_STALL status bit. ### EP0CSR5 (SETUP\_END): The USB FCU sets this bit to a "1" if a control transfer has ended before the specific length of data is transferred during the data phase (status phase starts before DATA\_END bit is set) or a control transfer has ended before a new SETUP has arrived and before successfully completing the status phase. The CPU clears this bit by writing a "1" to IN0CSR7. Once the CPU detects the SETUP\_END bit as set, it should stop accessing the FIFO to service the previous setup transaction. If the SETUP\_END is caused by the reception of the SET-UP packet prior to the end of the current control transfer, the OUT\_PKT\_RDY bit is set once the reception of the SETUP packet has completed (without errors). After the OUT\_PKT\_RDY bit is set, the new SETUP packet data will be in the FIFO. For this case, because the SETUP\_END bit is set near the beginning of the packet when the SETUP PID is encountered and the OUT\_PKT\_RDY bit is set at the end of the packet, the value read from EP0IN\_CSR in the USB functional interrupt routine may only show that the SETUP\_END bit as "1" instead of both the SETUP\_END and OUT\_PKT\_RDY bits. #### EP0CSR6 and EP0CSR7: These bits are used to clear EP0CSR0 and EP0CSR5 respectively. Writing a "1" to these bits clears the corresponding register bit. Figure 1.44: USB Endpoint 0 CSR ### 2.18.4.13 USB Endpoint 0 MAXP Register The USB Endpoint 0 MAXP Register, shown in Figure 1.45, indicates the maximum packet size (MAXP) of Endpoint 0 IN/OUT packet. The default value for Endpoint 0 MAXP is 8 bytes. Figure 1.45: USB Endpoint 0 MAXP # 2.18.4.14 USB Endpoint 0 OUT WRT CNT Register The USB Endpoint 0 OUT WRT CNT Register, shown in Figure 1.46, contains the number of bytes of the current data set in the OUT FIFO. The USB FCU sets the value in the Write Count Register after having successfully received a packet of data from the host. The CPU reads the register to determine the number of bytes to be read from the FIFO. Figure 1.46: USB Endpoint 0 OUT WRT CNT ### 2.18.4.15 USB Endpoint x IN CSR (Control & Status Register) The USB Endpoint x IN CSR (Control and Status Register), shown in Figure 1.47, contains control and status information of the respective IN endpoint 1-4. ### INxCSR0 (IN\_PKT\_RDY) and INxCSR5 (TX\_FIFO\_NOT\_EMPTY): These two bits are for IN FIFO status when in read operation (see "IN (Transmit) FIFO" operation for details). The CPU writes a "1" to the INxCSR0 bit to inform the USB FCU that a packet of data is written to the FIFO. The USB FCU updates the pointers up on this bit set. The USB FCU also updates the pointers upon a packet of data successfully sent to the host. When the pointer updates are completed, the IN FIFO status is shown on INxCSR0 and INxCSR5 bits for the CPU to read. The CPU must allow at least one wait state between writing and reading these bits for proper FIFO status. #### • INxCSR1 (UNDER RUN): This bit is used in ISO mode only to indicate to the CPU that a FIFO underrun has occurred. The USB FCU sets this bit to a "1" at the beginning of an IN token if no data packet is in the FIFO. Setting this bit causes the INST12 bit of the Interrupt Status Register 2 to set. The CPU writes a "0" to clear this bit. ### INxCSR2 (SEND\_STALL): The CPU writes a "1" to this bit when the endpoint is stalled (transmitter halt). The USB FCU returns a STALL handshake while this bit is set. The CPU writes a "0" to clear this bit. #### INxCSR3 (ISO/TOGGLE INIT): When the endpoint is used for isochronous data transfer, the CPU sets this bit to a "1" for the entire duration of the isochronous transfer. With the ISO bit set to a "1", the device uses DATA0 as the pid for all packets sent back to the host. When the endpoint is required to initialize the data toggle, this set/reset of the TOGGLE\_INIT bit method assumes that there is no activity IN transaction to the respective endpoint on the bus at the time the initialization process is ongoing. Set/reset of the TOGGLE\_INIT bit is performed only when an endpoint experiences a configuration event. ### • INxCSR4 (INTPT): The CPU writes a "1" to this bit to initialize this endpoint as a status change endpoint for IN transactions. This bit is set only when the corresponding endpoint is to be used to communicate rate feedback information (see Chapter. IN (Transmit) FIFOs for details). # INxCSR5 (TX\_FIFO\_NOT\_EMPTY): The USB FCU sets this bit to a "1" when there is at least one data packet in the IN FIFO. This bit, in conjunction with IN\_PKT\_RDY bit, provides the transmit IN FIFO status information (see "IN (Transmit) FIFO" for details). #### INxCSR6 (FLUSH): The CPU writes a "1" to this bit to flush the IN FIFO. When there is one packet in the IN FIFO, a flush causes the IN FIFO to be empty. When there are two packets in the IN FIFO, a flush causes the older packet to be flushed out from the IN FIFO. Setting the INXCSR6 (FLUSH) bit during transmission could produce unpredictable results. ### •INxCSR7 (AUTO\_SET): When the CPU sets this bit to a "1", the IN\_PKT\_RDY bit is set automatically by the USB FCU after the number of bytes of data equal to the maximum packet size (MAXP) is written into the IN FIFO (see "IN (Transmit) FIFO" operation for details). Figure 1.47: USB Endpoint x IN CSR # 2.18.4.16 USB Endpoint x OUT Control and Status Register The USB Endpoint x OUT CSR (Control and Status Register), shown in Figure 1.48 contains control and status information of the respective OUT endpoint 1-4. ### OUTxCSR0 (OUT\_PKT\_RDY): The OUTxCSR0 bit for the OUT FIFO status (see "OUT (Receive) FIFOs" for details). The USB FCU sets this bit to a "1" and updates the FIFO pointers after a data packet has been successfully received from the host. The CPU writes a "0" to this bit to inform the USB FCU that a data packet has been unloaded. The USB FCU updates the FIFO pointers when this occurs. The CPU must allow at least one clock cycle between writing and reading bit OUTxCSR0. #### OUTXxCSR1 (OVER RUN): This bit is used in ISO mode only to indicate to the CPU that a FIFO overrun has occurred. The USB FCU sets this bit to a "1" at the beginning of an OUT token when two data packets are already present in the FIFO. Setting this bit causes the INST12 bit of the Interrupt Status Register 2 to set. The CPU writes a "0" to clear OUTXCSR1. #### OUTxCSR2 (SEND\_STALL): The CPU writes a "1" to this bit when the endpoint is stalled. The USB FCU returns a STALL handshake while this bit is set. The CPU writes a "0" to clear this bit. ## OUTxCSR3 (ISO/TOGGLE\_INIT): When the endpoint is used for isochronous data transfer, the CPU sets this bit to a "1" for the entire duration of the isochronous transfer. With the ISO/TOGGLE\_INIT bit set to a "1", the device accepts either DATA0 or DATA1 for the PID sent by the host. When endpoint is required to initialize the data toggle sequence bit (i.e. reset to DATA0 for the next data packet), the CPU sets this bit to a "1" and then resets it to a "0" to initialize the respective endpoint's data toggle. Successful initialization of the data toggle sequence bit can only be guaranteed if no active OUT transaction to the respective endpoint is ongoing when the initialization process is taking place. Set/reset of the ISO/TOGGLE\_INIT bit should only be performed when an endpoint experiences a configuration event. #### OUTxCSR4 (FORCE\_STALL): The USB FCU sets this bit to a "1" when the host sends out a larger data packet than the MAXP size. The USB FCU returns a STALL handshake while this bit is set. The CPU writes a "0" to clear this bit. #### OUTxCSR5 (DATA\_ERR): The USB FCU sets this bit to a "1" to indicate that a CRC error or a bit stuffing error was received in an ISO packet. The CPU writes a "0" to clear this bit. #### OUTxCSR6 (FLUSH): The CPU writes a "1" to this to flush the OUT FIFO. When there is one packet in the OUT FIFO, a flush causes the OUT FIFO to be empty. When there are two packets in the OUT FIFO, a flush causes the older packet to be flushed out from the OUT FIFO. Setting the OUTXCSR6 (FLUSH) bit during reception could produce unpredictable results. ### OUTxCSR7 (AUTO\_CLR): When the CPU sets this bit to a "1", the OUT\_PKT\_RDY bit is cleared automatically by the USB FCU after the number of bytes of data equal to the maximum packet size (MAXP) is unloaded from the OUT FIFO (see "OUT (Receive) FIFO" for details). Figure 1.48: USB Endpoint x OUT CSR ### 2.18.4.17 USB Endpoint x IN MAXP Register The USB Endpoint x IN MAXP Register, shown in Figure 1.49, indicates the maximum packet size (MAXP) of an Endpoint x IN packet. The default values for Endpoints 1-4 are 0 bytes. The setting of this register also affects the configuration of single/dual packet operation. When MAXP > 1/2 of the FIFO size, single packet mode is set. When MAXP <= 1/2 of the FIFO size, dual packet mode is set. Figure 1.49: USB Endpoint x IN MAXP # 2.18.4.18 USB Endpoint x OUT MAXP Register The USB Endpoint x OUT MAXP Register, shown in Figure 1.50, indicates the maximum packet size (MAXP) of an Endpoint x OUT packet. The default values for endpoints 1-4 are 0 bytes. The setting of this register also affects the configuration of single/dual packet operation. When MAXP > 1/2 of the FIFO size, single packet is set. When MAXP <= 1/2 of the FIFO size, dual packet mode is set. Figure 1.50: USB Endpoint x OUT MAXP # 2.18.4.19 USB Endpoint x OUT WRT CNT Register The USB Endpoint x OUT WRT CNT Register, shown in Figure 1.51, contains the number of bytes of the current data set in the OUT FIFO. The USB FCU sets the value in the Write Count Register after having successfully received a packet of data from the host. The CPU reads the register to determine the number of bytes to be read from the FIFO. Figure 1.51: USB Endpoint x OUT WRT CNT # 2.18.4.20 USB Endpoint x FIFO Register The USB Endpoint x FIFO Register, shown in Figure 1.52 is the USB IN (transmit) and OUT (receive) FIFO data register. The CPU writes data to this register for the corresponding Endpoint IN FIFO and reads data from this register for the corresponding Endpoint OUT FIFO. Figure 1.52: USB Endpoint x FIFO Register # 2.19 **DMAC** This microcomputer has two DMAC (direct memory access controller) channels that allow data to be sent to memory without using the CPU. Table 1.14 shows the DMAC specifications. Figure 1.53 shows the block diagram of the DMAC. Figure 1.54, Figure 1.55 and Figure 1.56 show the registers used by the DMAC. Table 1.14: DMAC specifications | Item | Specification | |----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Number of channels | 2 (cycle steal method) | | Transfer memory space | •From any SFR, RAM, or ROM address to a fixed address •From a fixed address to any SFR or RAM address •From a fixed address to a fixed address (Note that DMA-related registers [0020 <sub>16</sub> to 003F <sub>16</sub> ] cannot be accessed) | | Maximum number of bytes transferred | 128K bytes (with 16-bit transfers) or 64K bytes (with 8-bit transfers) | | DMA request sources | Falling edge of INT0 or INT1 (INT0 can be selected by DMA0, INT1 by DMA1) Timer A0 to timer A4 Timer B0 to timer B1 UART0 transmission and reception UART1 transmission and reception UART2 transmission and reception A-D conversion complete USB function Software triggers | | Channel priority | DMA0 takes precedence if DMA0 and DMA1 requests are generated simultaneously | | Transfer unit | 8 bits or 16 bits | | Transfer address direction | forward/fixed (forward direction cannot be specified for both source and destination simultaneously) | | Transfer modes | Single transfer mode The DMA enable bit is cleared and transfer ends when an underflow occurs in the transfer counter. Repeat transfer mode When an underflow occurs in the transfer counter, the value in the transfer counter reload register is loaded into the transfer counter and the DMA transfer is repeated | | DMA interrupt request generation timing | When an underflow occurs in the transfer counter | | DMA startup | Single transfer mode Transfer starts when the DMA is requested after "1" is written to the DMA enable bit Repeat transfer mode Transfer starts when the DMA is requested after "1" is written to the DMA enable bit or after an underflow occurs in the transfer counter | | DMA shutdown | When "0" is written to the DMA enable bit When, in single transfer mode, an underflow occurs in the transfer counter | | Forward address pointer and reload timing for transfer counter | When DMA transfer starts, the value of whichever of the source or destination pointer that is set up as the forward pointer is loaded into the forward address pointer. The value in the transfer counter reload register is loaded into the transfer counter. | | Writing to register | Registers specified for forward direction transfer are always write-enabled. Registers specified for fixed address transfer are write-enabled when the DMA enable bit is "0". | | Reading the register | Can be read at any time. However, when the DMA enable bit is "1", reading the register sets up as the forward register is the same as reading the value of the forward address pointer. | Figure 1.53: Block diagram of DMAC Figure 1.54: DMAC register (1) Figure 1.55: DMAC register (2) Figure 1.56: DMAC register (3) ### CINCLE OF III TO BIT CINICO MICROCOMI OTER ## 2.19.1 Transfer cycle The transfer cycle consists of the bus cycle in which data is read from memory or from the SFR area (source read) and the bus cycle in which the data is written to memory or to the SFR area (destination write). The number of read and write bus cycles depends on the source and destination addresses and the software waits are inserted. #### 2.19.1.1 Effect of source and destination addresses When 16-bit data is transferred on a 16-bit data bus, and the source and destination both start at odd addresses, there is one more source read cycle and destination write cycle than when the source and destination both start at even addresses. ### 2.19.2 DMAC transfer cycles Any combination of even or odd transfer read and write addresses is possible. Table 1.15 show the number of DMAC transfer cycles. Table 1.16 shows the corresponding coefficient values. Figure 1.57 shows an example of the transfer cycle for a source read. The number of DMAC transfer cycles can be calculated as follows: Number of transfer cycles per transfer unit = Number of read cycles x j + Number of write cycles x k Table 1.15: Number of DMAC transfer cycles | | Access | Single-chip mode | | | |------------------|---------|-----------------------|------------------------|--| | Transfer unit | address | Number of read cycles | Number of write cycles | | | 8-bit transfers | Even | 1 | 1 | | | (DMBIT="1") | Odd | 1 | 1 | | | 16-bit transfers | Even | 1 | 1 | | | (DMBIT="0") | Odd | 2 | 2 | | Table 1.16: Coefficients j,k | Internal memory | | | | |------------------------------|--------------------------------|----------|--| | Internal ROM/<br>RAM No wait | Internal ROM/<br>RAM with wait | SFR area | | | 1 | 2 | 2 | | Figure 1.57: Example of the transfer cycle for a source read **Timers** # 2.20 Timers There are eight 16-bit timers. These timers can be classified by function into timers A (five) and timers B (three). All these timers function independently. Figure 1.58 shows the block diagram of Timers A and B. Figure 1.58: Timer A and Timer B block diagram # 2.21 Timer A Figure 1.59, Figure 1.60, Figure 1.61, and Figure 1.62 show the timer A-related registers. Except in event counter mode, timers A0 through A4 all have the same function. Use the timer Ai mode register (i = 0 to 4) bits 0 and 1 to choose the desired mode. Timer A has the four operation modes listed as follows: - Timer mode: The timer counts an internal count source. - Event counter mode: The timer counts pulses from an external source or a timer over flow. - One-shot timer mode: The timer stops counting when the count reaches "0000<sub>16</sub>". - Pulse width modulation (PWM) mode: The timer outputs pulses of a given width. Figure 1.59: Block diagram of Timer A Figure 1.60: Timer A related Registers (1) Figure 1.61: Timer A-related registers (2) Figure 1.62: Timer A-related registers (3) # 2.21.1 Timer mode In this mode, the timer counts an internally generated count source. See Table 1.17 below. Figure 1.63 shows the timer Ai mode register in timer mode. Table 1.17: Specifications of timer mode | Item | Specification | |-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count source | f1, f8, f32 | | Count operation | Down count When the timer underflows, it loads the reload register contents before continuing counting | | Divide ratio | 1/(n+1) n: Set value | | Count start condition | Count start flag is set (= 1) | | Count stop condition | Count start flag is reset (= 0) | | Interrupt request generation timing | When the timer underflows | | TAilN pin function | Programmable I/O port or gate input | | TAiOUT pin function | Programmable I/O port or pulse output | | Read from timer | Count value can be read out by reading timer Ai register | | Write to timer | When counting is stopped and a value is written to timer Ai register, it is written to both reload register and counter When counting is in progress and a value is written to timer Ai register, it is written only to reload register (to be transferred to counter at the next reload time) | | Select function | Gate function Counting can be started and stopped by TAilN pin's input signal Pulse output function Each time the timer underflows, the TAiOUT pin's polarity is reversed | Figure 1.63: Timer Ai mode register in timer mode #### 2.21.2 Event counter mode In this mode, the timer counts an external signal or an internal timer's overflow. Timers A0 and A1 can count a single-phase external signal. Timers A2, A3, and A4 can count a single-phase and a two-phase external signal. Table 1.18 lists the timer specifications when counting a single-phase external signal. Figure 1.64 shows Timer Ai mode register in event counter mode, single-phase signal. Table 1.18: Timer specification in event counter mode (when not processing two-phase pulse signal) | Item | Specification | |-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count source | •External signals input to TAiIN pin (effective edge can be selected by software<br>•TB2 overflow, TAj overflow | | Count operation | •Up count or down count can be selected by external signal or software •When the timer overflows or underflows, it loads from the reload register contents before continuing counting. (However, this does not apply when the free-run function is selected.) | | Divide ratio | 1/ (FFFF <sub>16</sub> - n+1) for up count<br>1/ (n + 1) for down count n: set value | | Count start condition | Count start flag is set (=1) | | Count stop condition | Count start flag is reset (=0) | | Interrupt request generation timing | Timer overflows or underflows | | TAilN pin function | Programmable I/O port or count source input | | TAiOUT pin function | Programmable I/O port, pulse output, or up/down count select input | | Read from timer | Count value can be read out by reading timer Ai register | | Write to timer | When counting is stopped and a value is written to timer Ai register, it is written to both reload register and counter When counting is in progress and a value is written to timer Ai register, it is written to only reload register | | Select function | •Free-run count function When the timer overflows or underflows, the reload register content is not reloaded. •Pulse output function Each time the timer overflows, the TAiOUT pin's polarity is reversed | Figure 1.64: Timer Ai mode register in event counter mode, single signal Table 1.19 shows the Timer specification in event counter mode when processing two-phase signal with timers A2, A3, and A4. Figure 1.65 shows Timer Ai mode register in event counter mode when processing two-phase signal. Table 1.19: Timer specification in even counter mode (when processing two-phase pulse signal with timers A2, A3, and A4) | Item | Specification | | | |-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Count Source | •Two-phase pulse signals input to TAilN or TAiOUT pin | | | | Count operation | •Up count or down count can be selected by two-phase pulse signal •When the timer overflows or underflows, the reload register content is loaded and the timer starts over again (Note 1) | | | | Divide ratio | 1/ (FFFF <sub>16</sub> - n + 1) for up count<br>1/ (n+1) for down count n: Set value | | | | Count start condition | Count start flag is set (=1) | | | | Count stop condition | Count start flag is reset (=0) | | | | Interrupt request generation timing | Timer overflow or underflows | | | | TAin pin function | Two-phase pulse input | | | | TAiout pin function | Two-phase pulse input | | | | Read from timer | Count value can be read out by reading timer A2, A3, or A4 register | | | | Writer to timer | •When counting is stopped and a value is written to timer A2, A3, or A4 register, it is written to both the reload register and counter •When counting is in progress and a value is written to timer A2, A3, or A4 register, it is written to only reload register to be transferred to counter at the next reload time. | | | | Select function | •Normal processing operation The timer counts up rising edges or counts down falling edges on the TAinn pin when input signal on the TAiout pin is "H" TAiout TAinn (i=2,3) Up Count Count Count Up Down Count Down Count Down Count •Multiply-by-4 processing operation If the phase relationship is such that the TAinn pin goes "H" when the input signal on the TAiout pin is "H", the timer counts up rising and falling edges on the TAiout and TAinn pins. If the phase relationship is such that the TAinn pin goes "L" when the input signal on the TAiout pin is "H", the timer counts down rising and falling edges on the TAiout and TAinn pins. TAiout Count up all edges Count down all edges Count down all edges Count down all edges | | | Note 1 This does not apply when the free-run function is selected. # SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER Note 1: The settings of the corresponding port register and port direction register are invalid. Note 2: This bit is valid when only counting an external signal. Note 3: Set the corresponding port direction register to "0". Note 4: This bit is valid for the timer A3 mode register. For timer A2 and A4 mode registers, this bit can be "0" or "1". Note 5: When performing two-phase pulse signal processing, make sure the two-phase pulse signal processing operation select bit (address 0384 16) is set to "1". Also, always be sure to set the event/trigger select bit (addresses 0382 16 and 038316) to "00". Note 6: This value can be indeterminate when the count starts. #### Timer Ai mode register (When using two-phase pulse signal processing) Note 1: This bit is valid for timer A3 mode register. For timer A2 and A4 mode registers, this bit can be "0" or "1". Note 2: When performing two-phase pulse signal processing, make sure the two-phase pulse signal processing operation select bit (address 0384 16) is set to "1". Also, always be sure to set the event/trigger select bit (addresses 0382 16 and 038316) to "00". Note 3: This value can be indeterminate when the count starts. Figure 1.65: Timer Ai mode register in event counter mode, two-phase signal #### 2.21.3 One-shot timer mode In this mode, the timer operates only once (See Table 1.20). When a trigger occurs, the timer starts up and continues operating for a given period. Figure 1.66 shows the timer Ai mode register in one-shot mode. Table 1.20: Timer specifications in one-shot timer mode | Item | Specification | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count source | f1, f8, f32 | | Count operation | •The timer counts down •When the count reaches 000016, the timer stops counting after reloading a new count • If a trigger occurs when counting, the timer reloads a new count and restarts counting | | Divide ratio | 1/n n: Set value | | Count start condition | <ul> <li>An external trigger is input</li> <li>The selected timer overflows</li> <li>The one-shot start flag is set (= 1)</li> </ul> | | Count stop condition | <ul> <li>A new count is reloaded after the count has reached 000016</li> <li>The count start flag is reset (= 0)</li> </ul> | | Interrupt request generation timing | The count reaches 000016 | | TAilN pin function | Programmable I/O port or trigger input | | TAiOUT pin function | Programmable I/O port or pulse output | | Read from timer | When timer Ai register is read, it indicates an indeterminate value | | Write to timer | When counting is stopped and a value is written to timer Ai register, it is written to both reload register and counter When counting is in progress and a value is written to timer Ai register, it is written to the reload register to be transferred to counter at next load time | Figure 1.66: Timer Ai mode register in one-shot mode #### 2.21.4 Pulse-width modulation (PWM) mode In this mode, the timer outputs pulses of a given width in succession (See Table 1.21). In this mode, the counter functions as either a 16-bit pulse-width modulator or an 8-bit pulse-width modulator. Figure 1.67 shows the timer Ai mode register in pulse-width modulation mode. Figure 1.68 shows the example of how a 16-bit pulse-width modulator operates. Figure 1.69 shows the example of how an 8-bit pulse width modulator operates. Table 1.21: Timer specifications in pulse-width modulation mode | Item | Specification | |-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Count source | f1, f8, f32 | | Count operation | •The timer counts down (operating as an 8-bit or a 16-bit pulse-width modulator) •The timer reloads a new count at a rising edge of PWM pulse and continues counting • The timer is not affected by a trigger that occurs when counting | | 16-bit PWM | •High level width n / f <sub>i</sub> n: Set value •Cycle time (216-1) / f <sub>i</sub> fixed | | 8-bit PWM | •High level width n (m+1) /f <sub>i</sub> n: values set to timer Ai register's high-order address •Cycle time (28-1) (m+1) /f <sub>i</sub> m: values set to timer Ai register's low-order address | | Count start condition | •External trigger is input •The timer overflows •The count start flag is set (= 1) | | Count stop condition | •The count start flag is reset (= 0) | | Interrupt request generation timing | PWM pulse goes "L" | | TAilN pin function | Programmable I/O port or trigger input | | TAiOUT pin function | Pulse output | | Read from timer | When timer Ai register is read, it indicates an indeterminate value | | Write to timer | •When counting is stopped and a value is written to timer Ai register, it is written to both reload register and the counter •When counting in progress and a value is written to timer A register, it is written to only reload register to be transferred to the counter at next reload timer. | Figure 1.67: Timer Ai mode register in pulse-width modulation mode Figure 1.68: Example of how a 16-bit pulse-width modulator operates Note: n = 000016 to FFFE16. Figure 1.69: Example of how an 8-bit pulse-width modulator operates Timer B #### 2.22 Timer B Figure 1.70 shows the block diagram of timer B. Figure 1.71 and Figure 1.72 show the timer B-related registers. Use the timer Bi mode register (i = 0 to 2) bits 0 and 1 to choose the desired mode. Timer B works in Timer mode only (i.e., the timer counts an in internal count source). Figure 1.70: Block diagram of Timer B Figure 1.71: Timer B-related registers Timer B Figure 1.72: Timer B-related registers #### 2.22.1 Timer mode In this mode, the timer counts an internally generated count source. (See Table 1.22 ) Figure 1.73 shows the Timer Bi mode register in timer mode. Table 1.22: Timer specifications in timer mode | Item | Specification | |-------------------------------------|---------------------------------------------------------------------------------------------------------------| | Count source | f1, f8, f32 | | Count operation | Counts down When the timer underflows, it reloads the reload register contents before continuing counting | | Divide ratio | 1/(n+1) n: Set value | | Count start condition | Count start flag is set (= 1) | | Count stop condition | Count start flag is reset (= 0) | | Interrupt request generation timing | The timer underflows (see Note) | Note: Timer B2 does not generate an interrupt; it is used only as a prescaler. Timer B Figure 1.73: Timer Bi mode register in timer mode #### 2.23 UART0 through UART2 Serial I/O is configured as three channels: UART0, UART1, and UART2. UART0, UART1, and UART2 each have an exclusive timer to generate a transfer clock, so they operate independently of each other. Figure 1.74 shows the block diagram of UART0, UART1, and UART2. Figure 1.74: Block diagram of UARTi (i=0 to 2) Figure 1.75 and Figure 1.76 show the block diagram of the transmit/receive unit. Figure 1.75: Block diagram of UARTi (i=0,1) transmit/receive circuit Figure 1.76: Block diagram of UART2 transmit/receive circuit SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER UARTi (i = 0 to 2) has two operation modes: a clock synchronous serial I/O mode and a clock asynchronous serial I/O mode (UART mode). The contents of the serial I/O mode select bits (bits 0 to 2 at addresses 03A0<sub>16</sub>, 03A8<sub>16</sub> and 0378<sub>16</sub>) determine whether UARTi is used as a clock synchronous serial I/O or as a UART. Although a few functions are different, UART0 and UART1 have almost the same functions. UART0 through UART2 are almost equal in their functions with minor exceptions. Table 1.23 shows the comparison of functions of UART0 through UART2, and Figure 1.77, Figure 1.78, Figure 1.79, Figure 1.80, and Figure 1.81 show the registers related to UARTi. Table 1.23: Comparison of functions of UART0 through UART2 | Function | UART0 | UART1 | UART2 | |----------------------------------------------------|-------------------|-------------------|-------------------| | CLK polarity selection | Possible (Note 1) | Possible (Note 1) | Possible (Note 1) | | LSB first / MSB first selection | Possible (Note 1) | Possible (Note 1) | Possible (Note 2) | | Continuous receive mode selection | Possible (Note 1) | Possible (Note 1) | Possible (Note 1) | | Transfer clock output from multiple pins selection | Impossible | Possible (Note 1) | Impossible | | Serial data logic switch | Impossible | Impossible | Possible (Note 4) | | Sleep mode selection | Possible (Note 3) | Possible (Note 3) | Impossible | | TxD, RxD I/O polarity switch | Impossible | Impossible | Possible | | TxD, RxD port output format | CMOS output | CMOS output | CMOS output | | Parity error signal output | Impossible | Impossible | Possible (Note 4) | | Bus collision detection | Impossible | Impossible | Possible | Note 1: Only during clock synchronous serial I/O mode. Note 2: Only during clock synchronous serial I/O mode and 8-bit UART mode. Note 3: Only during UART mode. Note 4: Used for SIM interface. Figure 1.77: Serial I/O-related registers (1) Figure 1.78: Serial I/O-related registers (2) | b7 b6 b5 b4 b3 b2 b1 b0 | | Symbol Addres<br>C0(i=0,1) 03A416, 03 | | | | |-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------| | | Bit<br>symbol | Bit name | Function<br>(During clock synchronous<br>serial I/O mode) | Function<br>(During UART mode) | R W | | | CLK0<br>CLK1 | BRG count source select bit | 0 0 : f1 is selected<br>0 1 : f8 is selected<br>1 0 : f32 is selected<br>1 1 : Reserved | 0 0 : f1 is selected<br>0 1 : f8 is selected<br>1 0 : f32 is selected<br>1 1 : Reserved | 00 | | | CRS | CTS/RTS function select bit | Valid when bit 4 = "0" 0: CTS function is selected (Note 1) 1: RTS function is selected (Note 2) | Valid when bit 4 = "0" 0: CTS function is selected (Note 1) 1: RTS function is selected (Note 2) | 00 | | | TXEPT | Transmit register empty flag | D: Data present in transmit register (during transmission) No data present in transmit register (transmission completed) | Data present in transmit register (during transmission) No data present in transmit register (transmission completed) | o x | | | CRD | CTS/RTS disable bit | 0 : CTS/RTS function enabled<br>1 : CTS/RTS function disabled<br>(P6o and P64 function as<br>programmable I/O port) | 0 : CTS/RTS function enabled<br>1 : CTS/RTS function disabled<br>(P6o and P64 function as<br>programmable I/O port) | 00 | | | | is assigned.<br>can neither be set nor re | set. When read, the value o | of this bit is "0". | | | | CKPOL | CLK polarity select bit | Transmit data is output at<br>falling edge of transfer clock<br>and receive data is input at<br>rising edge Transmit data is output at<br>rising edge of transfer clock<br>and receive data is input at<br>falling edge | Must always be "0" | 00 | | | UFORM | Transfer format select bit | 0 : LSB first<br>1 : MSB first | Must always be "0" | 00 | | UART2 transmit/rece | Note 2: T | he settings of the corres | rt direction register to "0".<br>ponding port register and po | ort direction register are invalid. | | | | Note 2: T | he settings of the corres | ponding port register and posses When reset 6 0816 | | | | UART2 transmit/rece | Note 2: T | he settings of the correstrol register 0 symbol Address 037C1 Bit name | ss When reset 6 0816 Function (During clock synchronous serial I/O mode) | Function<br>(During UART mode) | R W | | UART2 transmit/rece | Note 2: T | he settings of the correstrol register 0 symbol Addres U2C0 037C1 | Function (During clock synchronous serial I/O mode) 58 When reset 6 0816 Function (During clock synchronous serial I/O mode) 50 0 1: fis is selected 1 1: fis is selected 1 0: fize is selected | Function (During UART mode) bt to 0 0 : f1 is selected 0 1 : fs selected 1 0 : fs2 is selected | R W O O O | | UART2 transmit/rece | Note 2: T | he settings of the correstrol register 0 Symbol Address U2C0 037C1 Bit name BRG count source | SS When reset 6 0816 Function (During clock synchronous serial I/O mode) 10 0: f1 is selected 0 1: f8 is selected | Function (During UART mode) 51 to Selected 0 1: fs is selected 0 1: fs is selected | 0 0 | | UART2 transmit/rece | Note 2: T | he settings of the correst trol register 0 symbol Addres 037C: Bit name BRG count source select bit CTS/RTS function | Function (During clock synchronous serial I/O mode) 50 0 1: fi is selected 0 1: fs is selected 1 1: Inhibited Valid when bit 4 = "0" 0: CTS function is selected (Note 1) | Function (During UART mode) b t b b c c c c c c c c c c c c c c c c | 00 | | UART2 transmit/rece | Note 2: Trive conditions and series are series and series and series and series are series and series and series are series and series and series are series and series and series are series and series and series are series and series and series are are series are series and series are series are series are series are seri | he settings of the correstrol register 0 symbol Addres U2CO 037C1 Bit name BRG count source select bit CTS/RTS function select bit Transmit register empty | SS When reset 6 0816 Function (During clock synchronous serial I/O mode) 10 1: fis is selected 10: faz is selected 11: Inhibited Valid when bit 4 = "0" 0: CTS function is selected (Note 1) 1: RTS function is selected (Note 2) 0: Data present in transmit register (during transmission) 1: No data present in transmit register (furnamission) | Function (During UART mode) 10 0 : f1 is selected 0 1 : fs is selected 1 0 : f3 2 is selected 1 1 : Inhibited Valid when bit 4 = "0" 0 : CTS function is selected (Note 1) 1 : RTS function is selected (Note 2) 0 : Data present in transmit register (during transmission) 1 : No data present in transmit | 000 | | UART2 transmit/rece | Note 2: T ive con' Bit symbol CLK0 CLK1 CRS TXEPT CRD | he settings of the correstrol register 0 symbol Addres 037C1 Bit name BRG count source select bit CTS/RTS function select bit Transmit register empty flag CTS/RTS disable bit is assigned. | Function (During clock synchronous serial I/O mode) Tunction (During clock synchronous serial I/O mode) To this selected To the (Note 1) The selected (Note 2) The selected (Note 2) The selected (Note 2) The selected (Note 2) The selected (Note 3) | Function (During UART mode) 0 0 : f1 is selected 0 1 : fs is selected 1 0 : f3 is selected 1 1 : Inhibited Valid when bit 4 = "0" 0 : CTS function is selected (Note 1) 1 : RTS function is selected (Note 2) 0 : Data present in transmit register (during transmission) 1 : No data present in transmit register (transmission completed) 0 : CTS/RTS function enabled 1 : CTS/RTS function disabled (P7s functions programmable I/O port) | 0 0<br>0 0<br>0 0 | | UART2 transmit/rece | Note 2: T ive con' Bit symbol CLK0 CLK1 CRS TXEPT CRD | he settings of the correstrol register 0 symbol Addres 037C1 Bit name BRG count source select bit CTS/RTS function select bit Transmit register empty flag CTS/RTS disable bit is assigned. | Function (During clock synchronous serial I/O mode) Tunction (During clock synchronous serial I/O mode) To it is selected (Note 1) To it is is selected (Note 2) | Function (During UART mode) 0 0 : f1 is selected 0 1 : fs is selected 1 0 : f3 is selected 1 1 : Inhibited Valid when bit 4 = "0" 0 : CTS function is selected (Note 1) 1 : RTS function is selected (Note 2) 0 : Data present in transmit register (during transmission) 1 : No data present in transmit register (transmission completed) 0 : CTS/RTS function enabled 1 : CTS/RTS function disabled (P7s functions programmable I/O port) | 0 0<br>0 0<br>0 0 | Figure 1.79: Serial I/O-related registers (3) | b7 b6 b5 b4 b3 b2 b1 b0 | | Symbol Addres<br>C1(i=0,1) 03A516,03 | | | | |-------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------| | | Bit<br>symbol | Bit name | Function<br>(During clock synchronous<br>serial I/O mode) | Function<br>(During UART mode) | R | | | . TE | Transmit enable bit | 0 : Transmission disabled<br>1 : Transmission enabled | 0 : Transmission disabled<br>1 : Transmission enabled | 0 | | | ТІ | Transmit buffer empty flag | Data present in transmit buffer register No data present in transmit buffer register | 0 : Data present in transmit buffer register 1 : No data present in transmit buffer register | 0 | | | RE | Receive enable bit | 0 : Reception disabled<br>1 : Reception enabled | 0 : Reception disabled<br>1 : Reception enabled | 0 | | | RI<br>- | Receive complete flag | 0 : No data present in receive buffer register 1 : Data present in receive buffer register | 0 : No data present in receive buffer register 1 : Data present in receive buffer register | 0 | | | | g is assigned.<br>bits can neither be set nor r | eset. When read, the value of | of these bits is "0". | - | | b7 b6 b5 b4 b3 b2 b1 b0 | _ | Symbol Addres | | | | | b7 b6 b5 b4 b3 b2 b1 b0 | ] | | 6 0216 | Function | | | b7 b6 b5 b4 b3 b2 b1 b0 | _ | Symbol Addres | 6 0216 | Function<br>(During UART mode) | R | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit | Symbol Addres<br>U2C1 037D1 | 6 0216 Function (During clock synchronous | | | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol | Symbol Addres<br>U2C1 037D1<br>Bit name | Function (During clock synchronous serial I/O mode) 0 : Transmission disabled | (During UART mode) 0 : Transmission disabled | 0 | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol | Symbol Addres U2C1 037D1 Bit name Transmit enable bit Transmit buffer | Function (During clock synchronous serial I/O mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in | (During UART mode) 0 : Transmission disabled 1 : Transmission enabled 0 : Data present in transmit buffer register 1 : No data present in | 0 | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol TE TI | Bit name Transmit enable bit Transmit buffer empty flag | Function (During clock synchronous serial I/O mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in transmit buffer register 0: Reception disabled | (During UART mode) 0 : Transmission disabled 1 : Transmission enabled 0 : Data present in transmit buffer register 1 : No data present in transmit buffer register 0 : Reception disabled | 0 | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol TE TI RE | Bit name Transmit enable bit Transmit buffer empty flag Receive enable bit | Function (During clock synchronous serial I/O mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in transmit buffer register 0: Reception disabled 1: Reception enabled 0: No data present in receive buffer register 1: Data present in receive buffer register | (During UART mode) 0 : Transmission disabled 1 : Transmission enabled 0 : Data present in transmit buffer register 1 : No data present in transmit buffer register 0 : Reception disabled 1 : Reception enabled 0 : No data present in receive buffer register 1 : Data present in | 0 0 | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol TE TI RE | Bit name Transmit enable bit Transmit buffer empty flag Receive enable bit Receive complete flag UART2 transmit interrupt cause select bit | Function (During clock synchronous serial I/O mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in transmit buffer register 0: Reception disabled 1: Reception enabled 0: No data present in receive buffer register 1: Data present in receive buffer register 0: Transmit buffer empty (TI = 1) 1: Transmit is completed | (During UART mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in transmit buffer register 0: Reception disabled 1: Reception enabled 0: No data present in receive buffer register 1: Data present in receive buffer register 0: Transmit buffer empty (TI = 1) 1: Transmit is completed | 0 | | b7 b6 b5 b4 b3 b2 b1 b0 | Bit symbol TE TI RE RI U2IRS | Bit name Transmit enable bit Transmit buffer empty flag Receive enable bit Receive complete flag UART2 transmit interrupt cause select bit UART2 continuous | Function (During clock synchronous serial I/O mode) 0: Transmission disabled 1: Transmission enabled 0: Data present in transmit buffer register 1: No data present in transmit buffer register 0: Reception disabled 1: Reception enabled 0: No data present in receive buffer register 1: Data present in receive buffer register 1: Data present in receive buffer register 0: Transmit buffer empty (TI = 1) 1: Transmit is completed (TXEPT = 1) 0: Continuous receive mode disabled 1: Continuous receive | (During UART mode) 0 : Transmission disabled 1 : Transmission enabled 0 : Data present in transmit buffer register 1 : No data present in transmit buffer register 0 : Reception disabled 1 : Reception enabled 0 : No data present in receive buffer register 1 : Data present in receive buffer register 0 : Transmit buffer empty (TI = 1) 1 : Transmit is completed (TXEPT = 1) | R O O O O O O | Figure 1.80: Serial I/O-related registers (4) CLKMD1 CLK/CLKS select Reserved Nothing is assigned. bit 1 (Note) 00 00 #### UART transmit/receive control register 2 Symbol UCON Address 03B016 When reset X00000002 Function Function (During UART mode) R W Bit name (During clock synchronous symbol serial I/O mode) UART0 transmit 0 : Transmit buffer empty (TI = 1) 1 : Transmission completed **U0IRS** 0 : Transmit buffer empty (TI = 1) 1 : Transmission completed 00 interrupt cause select bit (TXEPT = 1)(TXEPT = 1)0 : Transmit buffer empty (TI = 1) 1 : Transmission completed (TXEPT = 1) 0 : Transmit buffer empty (TI = 1) 1 : Transmission completed (TXEPT = 1) U1IRS UART1 transmit 0:0 interrupt cause select bit U0RRM UART0 continuous 0 : Continuous receive receive mode enable bit mode disabled 0.0 1: Continuous receive mode enable U1RRM UART1 continuous 0 : Continuous receive Invalid receive mode enable bit mode disabled 0:0 1: Continuous receive mode enabled CLKMD0 CLK/CLKS select bit 0 Valid when bit 5 = "1" Invalid 0 : Clock output to CLK1 1 : Clock output to CLKS1 0:0 This bit can neither be set nor reset. When read, its content is indeterminate. Note: When using multiple pins to output the transfer clock, the following requirements must be met: • UART1 internal/external clock select bit (bit 3 at address 03A8 16) = "0". 0 : Normal mode (CLK output is CLK1 only) Transfer clock output from multiple pins function selected Must always be "0" Must always be "0" Must always be "0" Figure 1.81: Serial I/O-related registers (5) # 2.23.1 Clock synchronous serial I/O mode The clock synchronous serial I/O mode uses a transfer clock to transmit and receive data. Table 1.24 and Table 1.25 list the specifications of the clock synchronous serial I/O mode. Figure 1.82 shows the UARTi transmit/receive mode register. Table 1.24: Specifications of clock synchronous serial I/O mode (1) | Item | Specification | |--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Transfer data format | Transfer data length: 8 bits | | Transfer clock | <ul> <li>When internal clock is selected (bit 3 at addresses 03A0<sub>16</sub>, 03A8<sub>16</sub>, 0378<sub>16</sub> = "0"): fi=2(n+1) (Note 1) fi = f1, f8, f32</li> <li>When external clock is selected (bit 3 at addresses 03A0<sub>16</sub>, 03A8<sub>16</sub>, 0378<sub>16</sub> = "1"): Input from CLKi pin (Note 2)</li> </ul> | | Transmission/reception control | CTS function/RTS function/CTS, RTS function chosen to be invalid | | Transmission start condition | To start transmission, the following requirements must be met: _ Transmit enable bit (bit 0 at addresses 03A5 <sub>16</sub> , 03AD <sub>16</sub> , 037D <sub>16</sub> ) = "1" _ Transmit buffer empty flag (bit 1 at addresses 03A5 <sub>16</sub> , 03AD <sub>16</sub> , 037D <sub>16</sub> ) = "0" _ When CTS function selected, CTS input level = "L" Furthermore, if external clock is selected, the following requirements must also be met: _ CLKi polarity select bit (bit 6 at addresses 03A4 <sub>16</sub> , 03AC <sub>16</sub> , 037C <sub>16</sub> ) = "0": CLKi input level = "H" _ CLKi polarity select bit (bit 6 at addresses 03A4 <sub>16</sub> , 03AC <sub>16</sub> , 037C <sub>16</sub> ) = "1": CLKi input level = "L" | | Reception start condition | <ul> <li>To start reception, the following requirements must be met: _ Receive enable bit (bit 2 at addresses 03A5<sub>16</sub>, 03AD<sub>16</sub>, 037D<sub>16</sub>) = "1" _ Transmit enable bit (bit 0 at addresses 03A5<sub>16</sub>, 03AD<sub>16</sub>, 037D<sub>16</sub>) = "0" _ Transmit buffer empty flag (bit 1 at addresses 03A5<sub>16</sub>, 03AD<sub>16</sub>, 037D<sub>16</sub>) = "0" • Furthermore, if external clock is selected, the following requirements must also be met: _ CLKi polarity select bit (bit 6 at addresses 03A4<sub>16</sub>, 03AC<sub>16</sub>, 037C<sub>16</sub>) = "0": CLKi input level = "H" _ CLKi polarity select bit (bit 6 at addresses 03A4<sub>16</sub>, 03AC<sub>16</sub>, 037C<sub>16</sub>) = "1": CLKi input level = "L" • When transmitting _ Transmit interrupt cause select bit (bits 0, 1 at address 03B0<sub>16</sub>, bit 4 at address 037D<sub>16</sub>) = "0": Interrupts requested when data transfer from UARTi _ Transmit interrupt cause select bit (bits 0, 1 at address 03B0<sub>16</sub>, bit 4 at address 037D<sub>16</sub>) = "1": Interrupts requested when data transmission from</li> </ul> | | Error detection | Overrun error (Note 3) This error occurs when the next data is ready before contents of UARTi receive buffer is read. | Note 1: "n" denotes the value $00_{16}$ to $FF_{16}$ that is set to the UART bit rate generator. Note 2: Maximum 5 Mbps. Note 3: If an overrun error occurs, the UARTi receive buffer will have the next data written in. Note also that the UARTi receive interrupt request bit is not set to "1". Table 1.25: Specifications of clock synchronous serial I/O mode (2) | Item | Specification | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Select function | <ul> <li>CLK polarity selection Whether transmit data is output/input at the rising edge or falling edge of the transfer clock can be selected</li> <li>LSB first/MSB first selection Whether transmission/reception begins with bit 0 or bit 7 can be selected</li> <li>Continuous receive mode selection Reception is enabled simultaneously by a read from the receive buffer register</li> <li>Transfer clock output from multiple pins selection (UART1) UART1 transfer clock can be chosen by software to be output from one of the two pins set</li> <li>Switching serial data logic (UART2) Whether to reverse data in writing to the transmission buffer register or reading the reception buffer register can be selected.</li> <li>Switching serial data logic (UART2) This function is reversing TxD port output and RxD port input. All I/O data level is reversed.</li> </ul> | Figure 1.82: UARTi transmit/receive mode register in clock synchronous serial I/O mode Table 1.26 lists the functions of the input/output pins during clock synchronous serial I/O mode. This table shows the pin functions when the transfer clock output from multiple pins function is not selected. Note that for a period from when the UARTi operation mode is selected to when transfer starts, the TxD pin outputs a "H". The typical clock synchronous timing diagrams are shown in Figure 1.83. Table 1.26: Input/output pin functions in clock synchronous serial I/O mode | Pin name | Function | Method of selection | |----------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TxDi<br>(P63, P67, P70) | Serial data output | (Outputs dummy data when performing reception only) | | RxDi<br>(P62, P66, P71) | Serial data input | Port P62, P66, and P71 direction register (bits 2 and 6 at address 03EE <sub>16</sub> bit 1 at address 03EF <sub>16</sub> )= "0" (Can be used as an input port when performing transmission only.) | | OLIC: | Transfer clock output | Internal/external clock select bit (bit 3 at address 03A0 <sub>16</sub> , 03A8 <sub>16</sub> , 0378 <sub>16</sub> ) = "0" | | CLKi<br>(P61, P65, P72) | Transfer clock input | Internal/external clock select bit (bit 3 at address $03A0_{16}$ , $03A8_{16}$ , $0378_{16}$ ) = "1" Port P61, P65, and P72 direction register (bits 1 and 5 at address $03EE_{16}$ , bit 2 at address $03EF_{16}$ ) = "0" | | CTSi/RTSi<br>(P60,P64,P73) | CTS input | | | | RTS output | $\overline{\text{CTS/RTS}} \text{ disable bit (bit 4 at address } 03\text{A4}_{16}, 03\text{AC}_{16}, 037\text{C}_{16}) = \text{``0''}$ $\overline{\text{CTS/RTS}} \text{ function select bit (bit 2 at address } 03\text{A4}_{16}, 03\text{AC}_{16}, 037\text{C}_{16}) = \text{``1''}}$ | | | Programmable I/O port | $\overline{\text{CTS/RTS}}$ disable bit (bit 4 at address 03A4 <sub>16</sub> , 03AC <sub>16</sub> , 037C <sub>16</sub> ) = "1" | Figure 1.83: Typical transmit/receive timings in clock synchronous serial I/O mode Polarity select function #### 2.23.1.1 Polarity select function As shown in Figure 1.84, the CLK polarity select bit (bit 6 at addresses $03A4_{16}$ , $03AC_{16}$ , $037C_{16}$ ) allows selection of the polarity of the transfer clock. Figure 1.84: Polarity of transfer clock #### 2.23.1.2 LSB first/MSB first select function As shown in Figure 1.85, when the transfer format select bit (bit 7 at addresses $03A4_{16}$ , $03AC_{16}$ , $037C_{16}$ ) = "0", the transfer format is "LSB first"; when the bit = "1", the transfer format is "MSB first". Figure 1.85: Transfer format #### 2.23.1.3 Transfer clock output from multiple pins function (UART1) This function allows the setting two transfer clock output pins and choosing one of the two to output a clock by using the CLK and CLKS select bit (bits 4 and 5 at address $03B0_{16}$ ). See Figure 1.86. The multiple pins function is valid only when the internal clock is selected for UART1. Note that when this function is selected, UART1 CTS/RTS function cannot be used. Figure 1.86: The transfer clock output from the multiple pins function usage #### 2.23.1.4 Continuous receive mode If the continuous receive mode enable bit (bits 2 and 3 at address $03B0_{16}$ , bit 5 at address $037D_{16}$ ) is set to "1", the unit is placed in continuous receive mode. In this mode, when the receive buffer register is read out, the unit simultaneously goes to a receive enable state without having to set dummy data to the transmit buffer register back again. #### 2.23.1.5 Serial data logic switch function (UART2) When the data logic select bit (bit6 at address $037D_{16}$ ) = "1", and writing to transmit buffer register or reading from receive buffer register, data is reversed. Figure 1.87 shows the example of serial data logic switch timing. Figure 1.87: Serial data logic switch timing #### SINGLE-CHIE TO-BIT CIVIOS IVIICACCOMPUTE #### 2.23.2 Clock asynchronous serial I/O (UART) mode The UART mode allows transmitting and receiving data after setting the desired transfer rate and transfer data format. Table 1.27 and Table 1.28 list the specifications of the UART mode. Figure 1.88 shows the UARTi transmit/receive mode register. Table 1.27: Specifications of UART Mode (1) | Item | Specification | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Transfer data format | Character bit (transfer data): 7 bits, 8 bits, or 9 bits as selected Start bit: 1 bit Parity bit: Odd, even, or nothing as selected Stop bit: 1 bit or 2 bits as selected | | Transfer clock | • When internal clock is selected (bit 3 at addresses 03A0 <sub>16</sub> , 03A8 <sub>16</sub> , 0378 <sub>16</sub> = "0"): fi/16(n+1) (Note 1) fi = f1, f8, f32 • When external clock is selected (bit 3 at addresses 03A0 <sub>16</sub> , 03A816, 0378 <sub>16</sub> = "1"): fEXT/16(n+1)(Note 1) (Note 2) | | Transmission/reception control | CTS function/RTS function/CTS, RTS function chosen to be invalid | | Transmission start condition | <ul> <li>To start transmission, the following requirements must be met:</li> <li>Transmit enable bit (bit 0 at addresses 03A5<sub>16</sub>, 03AD<sub>16</sub>, 037D<sub>16</sub>) = "1"</li> <li>Transmit buffer empty flag (bit 1 at addresses 03A5<sub>16</sub>, 03AD<sub>16</sub>, 037D<sub>16</sub>) = "0"</li> <li>When CTS function selected, CTS input level = "L"</li> </ul> | | Reception start condition | • To start reception, the following requirements must be met: - Receive enable bit (bit 2 at addresses 03A5 <sub>16</sub> , 03AD <sub>16</sub> , 037D <sub>16</sub> ) = "1" - Start bit detection | | Interrupt request generation timing | When transmitting Transmit interrupt cause select bits (bits 0,1 at address 03B0 <sub>16</sub> , bit4 at address 037D <sub>16</sub> ) = "0": Interrupts requested when data transfer from UARTi transfer buffer register to UARTi transmit register is completed Transmit interrupt cause select bits (bits 0, 1 at address 03B0 <sub>16</sub> , bit4 at address 037D <sub>16</sub> ) = "1": Interrupts requested when data transmission from UARTi transfer register is completed When receiving Interrupts requested when data transfer from UARTi receive register to UARTi receive buffer register is completed | | Error detection | Overrun error (Note 3) This error occurs when the next data is ready before contents of UARTi receive buffer register are read out Framing error This error occurs when the number of stop bits set is not detected Parity error This error occurs when if parity is enabled, the number of 1's in parity and character bits does not match the number of 1's set Error sum flag This flag is set (= 1) when any of the overrun, framing, and parity errors is encountered | Note 1: 'n' denotes the value $00_{16}$ to ${\rm FF}_{16}$ that is set to the UARTi bit rate generator. Note 2: fEXT is input from the CLKi pin. Note 3: If an overrun error occurs, the UARTi receive buffer will have the next data written in. Note also that the UARTi receive interrupt request bit is not set to "1" Table 1.28: Specifications of UART Mode (2) | Item | Specification | |--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Select<br>function | Sleep mode selection (UART0, UART1) This mode is used to transfer data to and from one of multiple slave micro-computers Serial data logic switch (UART2) This function is reversing logic value of transferring data. Start bit, parity bit and stop bit are not reversed. TxD, RxD I/O polarity switch This function is reversing TxD port output and RxD port input. All I/O data level is reversed. | Figure 1.88: UARTi transmit/receive mode register in UART mode Table 1.29 lists the functions of the input/output pins during UART mode. Note that for a period from when the UARTi operation mode is selected to when transfer starts, the TxDi pin outputs a "H". Table 1.29: Input/output pin functions in UART mode | Pin name | Function | Method of selection | | |-------------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | TxDi<br>(P63, P67, P70) | Serial data output | | | | RxDi<br>(P62, P66, P71) | Serial data input | Port P62, P66, and P71 direction register (bits 2 and 6 at address 03EE <sub>16</sub> bit 1 at address 03EF <sub>16</sub> )= "0" (Can be used as an input port when performing transmission only.) | | | 0116 | Programmable I/O port | Internal/external clock select bit (bit 3 at address 03A0 <sub>16</sub> , 03A8 <sub>16</sub> , 0378 <sub>16</sub> ) = "0" | | | CLKi<br>(P61, P65, P72) | Transfer clock input | Internal/external clock select bit (bit 3 at address $03A0_{16}$ , $03A8_{16}$ , $0378_{16}$ ) = "1" Port P61, P65, and P72 direction register (bits 1 and 5 at address $03EE_{16}$ , bit 2 at address $03EF_{16}$ ) = "0" | | | CTSi/RTSi | CTS input | | | | (P60,P64,P73) | RTS output | $\overline{\text{CTS/RTS}} \text{ disable bit (bit 4 at address } 03\text{A4}_{16}, 03\text{AC}_{16}, 03\text{7C}_{16}) = \text{``0''}$ $\overline{\text{CTS/RTS}} \text{ function select bit (bit 2 at address } 03\text{A4}_{16}, 03\text{AC}_{16}, 03\text{7C}_{16}) = \text{``1''}}$ | | | | Programmable I/O port | $\overline{\text{CTS}}/\overline{\text{RTS}}$ disable bit (bit 4 at address 03A4 <sub>16</sub> , 03AC <sub>16</sub> , 037C <sub>16</sub> ) = "1" | | Figure 1.89 and Figure 1.90 show the typical UART mode transmit and receive timing diagrams. Figure 1.89: Typical transmit timings in UART mode Figure 1.90: Typical receive timing in UART mode #### 2.23.2.1 Sleep mode (UART0, UART1) This mode is used to transfer data between specific microcomputers among multiple microcomputers connected using UARTi. The sleep mode is selected when the sleep select bit (bit 7 at addresses $03A0_{16}$ , $03A8_{16}$ ) is set to "1" during reception. In this mode, the unit performs receive operation when the MSB of the received data = "1" and does not perform receive operation when the MSB = "0". ### 2.23.2.2 Function for switching serial data logic (UART2) When the data logic select bit (bit 6 of address $037D_{16}$ ) is assigned 1, data is inverted in writing to the transmission buffer register or reading the reception buffer register. Figure 1.91 shows the example of timing for switching serial data logic. Figure 1.91: Timing for switching serial data logic #### 2.23.2.3 TxD, RxD I/O polarity reverse function (UART2) This function is to reverse TxD pin output and RxD pin input. The level of any data to be input or output (including the start bit, stop bit(s), and parity bit) is reversed. Set this function to "0" (not to reverse) for usual use. #### 2.23.2.4 Bus collision detection function (UART2) This function is to sample the output level of the TxD pin and the input level of the RxD pin at the rising edge of the transfer clock; if their values are different, then an interrupt request occurs. Figure 1.92 shows the example of detection timing of a buss collision (in UART mode). Figure 1.92: Detection timing of a bus collision (in UART mode) #### SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER #### 2.23.3 Clock-asynchronous serial I/O mode (compliant with the SIM interface) The SIM interface is used for connecting the microcomputer with a memory card I/C or the like; adding some extra settings in UART2 clock-asynchronous serial I/O mode allows the user to effect this function. Table 1.30 shows the specifications of clock-asynchronous serial I/O mode (compliant with the SIM interface). Figure 1.93 shows the typical transmit/receive timing in UART mode. Table 1.30: Specifications of clock-asynchronous serial I/O mode (compliant with the SIM interface) | Item | Specification | | | | |----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Transfer data format | <ul> <li>Transfer data 8-bit UART mode (bit 2 through bit 0 of address 0378<sub>16</sub> = "1012")</li> <li>One stop bit (bit 4 of address 0378<sub>16</sub> = "0")</li> <li>With the direct format chosen Set parity to "even" (bit 5 and bit 6 of address 0378<sub>16</sub> = "1" and "1" respectively) Set data logic to "direct" (bit 6 of address 037D<sub>16</sub> = "0").</li> <li>Set transfer format to LSB (bit 7 of address 037C<sub>16</sub> = "0").</li> <li>With the inverse format chosen Set parity to "odd" (bit 5 and bit 6 of address 037B<sub>16</sub> = "0" and "1" respectively) Set data logic to "inverse" (bit 6 of address 037D<sub>16</sub> = "1")</li> <li>Set transfer format to MSB (bit 7 of address 037C<sub>16</sub> = "1")</li> </ul> | | | | | Transfer clock | <ul> <li>With the internal clock chosen (bit 3 of address 0378<sub>16</sub> = "0"): fi / 16 (n + 1) (Note 1): fi=f1, f8, f32</li> <li>With an external clock chosen (bit 3 of address 0378<sub>16</sub> = "1"): fEXT / 16 (n+1) (Note 1) (Note 2)</li> </ul> | | | | | Transmission / reception control | Disable the CTS and RTS function (bit 4 of address 037C <sub>16</sub> = "1") | | | | | Other settings | <ul> <li>The sleep mode select function is not available for UART2</li> <li>Set transmission interrupt factor to "transmission completed" (bit 4 of address 037D<sub>16</sub> = "1")</li> </ul> | | | | | Transmission start condition | <ul> <li>To start transmission, the following requirements must be met:</li> <li>Transmit enable bit (bit 0 of address 037D<sub>16</sub>) = "1"</li> <li>Transmit buffer empty flag (bit 1 of address 037D<sub>16</sub>) = "0"</li> </ul> | | | | | Reception start condition | <ul> <li>To start reception, the following requirements must be met:</li> <li>Reception enable bit (bit 2 of address 037D<sub>16</sub>) = "1"</li> <li>Detection of a start bit</li> <li>When transmitting</li> <li>When data transmission from the UART2 transfer register is completed (bit 4 of address 037D<sub>16</sub> = "1")</li> <li>When receiving</li> <li>When data transfer from the UART2 receive register to the UART2 receive buffer register is completed</li> </ul> | | | | | Error detection | <ul> <li>Overrun error (see the specifications of clock-asynchronous serial I/O) (Note 3)</li> <li>Framing error (see the specifications of clock-asynchronous serial I/O)</li> <li>Parity error (see the specifications of clock-asynchronous serial I/O)</li> <li>On the reception side, an "L" level is output from the TxD2 pin by use of the parity error signal output function (bit 7 of address 037D<sub>16</sub> = "1") when a parity error is detected</li> <li>On the transmission side, a parity error is detected by the level of input to the RxD2 pin when a transmission interrupt occurs</li> <li>The error sum flag (see the specifications of clock-asynchronous serial I/O)</li> </ul> | | | | Note 1: 'n' denotes the value $00_{16}$ to ${\rm FF}_{16}$ that is set to the UARTi bit rate generator. Note 2: fEXT is input from the CLK2 pin. Note 3: If an overrun error occurs, the UART2 receive buffer will have the next data written in. Note also that the UARTi receive interrupt request bit is not set to "1". Figure 1.93: Typical transmit/receive timing in UART mode (compliant with the SIM interface) #### 2.23.3.1 Function for outputting a parity error signal With the error signal output enable bit (bit 7 of address 037D<sub>16</sub>) assigned "1", you can output an "L" level from the TxD2 pin when a parity error is detected. In step with this function, the generation timing of a transmission completion interrupt changes to the detection timing of a parity error signal. Figure 1.94 shows the output timing of the parity error signal. Figure 1.94: Output timing of the parity error signal #### 2.23.3.2 Direct format/inverse format Connecting the SIM card allows you to switch between direct format and inverse format. If you choose the direct format, D0 data is output from TxD2. If you choose the inverse format, D7 data is inverted and output from TxD2. Figure 1.95 shows the SIM interface format. Figure 1.95: SIM interface format Figure 1.96 shows the example of connecting the SIM interface with TxD2 and RxD2. Figure 1.96: Connecting the SIM interface A-D Converter #### 2.24 A-D Converter The A-D converter consists of one 10-bit successive approximation A-D converter circuit with a capacitive coupling amplifier. Pins P100 to P107 function as the analog signal input pins. The direction registers of these pins for A-D conversion must therefore be set to input. The Vref connect bit (bit 5 at address 03D7<sub>16</sub>) can be used to isolate the resistance ladder of the A-D converter from the reference voltage input pin (VREF) when the A-D converter is not used. Doing so stops any current flowing into the resistance ladder from VREF, reducing the power dissipation. When using the A-D converter, start A-D conversion only after setting bit 5 of 03D7<sub>16</sub> to connect VREF. The result of A-D conversion is stored in the A-D registers of the selected pins. When set to 10-bit precision, the low 8 bits are stored in the even addresses and the high 2 bits in the odd addresses. When set to 8-bit precision, the low 8 bits are stored in the even addresses. Table 1.31 shows the performance of the A-D converter. Figure 1.97 shows the block diagram of the A-D converter, and Figure 1.98 and Figure 1.99 show the A-D converter-related registers. Table 1.31: Performance of A-D Converter | Item | Performance | | | | | |----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Method of A-D conversion | Successive approximation (capacitive coupling amplifier) | | | | | | Analog input voltage (Note) | 0V to AVCC (VCC) | | | | | | Operating clock fAD | VCC = 5V | fAD/divide-by-2 or fAD/divide-by-4 or fAD, fAD=f(Xin) | | | | | Resolution | 8-bit or 10-bit (selectable) | | | | | | Absolute precision | VCC = 5V | Without sample and hold function 3LSB With sample and hold function (8-bit resolution) 2LSB With sample and hold function (10-bit resolution) 3LSB | | | | | Operating modes | One-shot mode, repeat mode, single sweep mode, repeat sweep mode 0, and repeat sweep mode 1 | | | | | | Analog input pins | 8pins (AN0 to AN7) | | | | | | A-D conversion start condition | Software trigger A-D conversion starts when the A-D conversion start flag changes to "1" External trigger (can be retriggered) A-D conversion starts when the A-D conversion start flag is "1" and the ADTRG/P87 input changes from "H" to "L" | | | | | | Conversion speed per pin | <ul> <li>•Without sample and hold function</li> <li>8-bit resolution: 49 φAD cycles, 10-bit resolution: 59 φAD cycles</li> <li>• With sample and hold function</li> <li>8-bit resolution: 28 φAD cycles, 10-bit resolution: 33 φAD cycles</li> </ul> | | | | | | Note Does not depend on use of sample and hold function. | | | | | | A-D Converter Figure 1.97: Block diagram of A-D converter #### A-D Converter Figure 1.98: A-D converter-related registers (1) Figure 1.99: A-D converter-related registers (2) ### 2.24.1 One-shot mode In one-shot mode, the pin selected using the analog input pin select bit is used for one-shot A-D conversion. Table 1.32 shows the specifications of one-shot mode. Figure 1.100 shows the A-D control register in one-shot mode. Table 1.32: One-shot mode specification | Item | Specification | |-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------| | Function | The pin selected by the analog input pin select bit is used for one A-D conversion | | Start condition | Writing "1" to A-D conversion start flag | | Stop condition | End of A-D conversion (A-D conversion start flag changes to "0", except when external trigger is selected) Writing "0" to A-D conversion start flag | | Interrupt request generation timing | End of A-D conversion | | Input pin | One of AN0 to AN7, as selected | | Reading of result of A-D converter | Read A-D register corresponding to selected pin | Figure 1.100: A-D conversion register in one-shot mode # 2.24.2 Repeat mode In repeat mode, the pin selected using the analog input pin select bit is used for repeated A-D conversion. Table 1.33 shows the specifications of repeat mode. Figure 1.101 shows the A-D control register in repeat mode. Table 1.33: Repeat sweep mode 0 specifications | Item | Specification | |-------------------------------------|-----------------------------------------------------------------------------------------| | Function | The pin selected by the analog input pin select bit is used for repeated A-D conversion | | Star condition | Writing "1" to A-D conversion start flag | | Stop condition | Writing "0" to A-D conversion start flag | | Interrupt request generation timing | None generated | | Input pin | One of AN0 to AN7, as selected | | Reading of result of A-D converter | Read A-D register corresponding to selected pin | Figure 1.101: A-D conversion register in repeat mode ### 2.24.3 Single sweep mode In single sweep mode, the pins selected using the A-D sweep pin select bit are used for one-by-one A-D conversion. Table 1.34 shows the specifications of single sweep mode. Figure 1.102 shows the A-D control register in single sweep mode. Table 1.34: Single sweep mode specification | Item | Specification | |-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------| | Function | The pins selected by the A-D sweep pin select bit are used for one-by-one A-D conversion | | Start condition | Writing "1" to A-D converter start flag | | Stop condition | •End of A-D conversion (A-D conversion start flag changes to "0", except when external trigger is selected) •Writing "0" to A-D conversion start flag | | Interrupt request generation timing | End of A-D conversion | | Input pin | AN0 and AN1 (2 pins), AN0 to AN3 (4 pins), AN0 to AN5 (6 pins), or AN0 to AN7 (8 pins) | | Reading of result of A-D converter | Read A-D register corresponding to selected pin | Figure 1.102: A-D conversion register in single sweep mode ### 2.24.4 Repeat sweep mode 0 In repeat sweep mode 0, the pins selected using the A-D sweep pin select bit are used for repeat sweep A-D conversion. Table 1.35 shows the specifications of repeat sweep mode 0. Figure 1.103 shows the A-D control register in repeat sweep mode 0. Table 1.35: Repeat sweep mode 0 specifications | Item | Specification | |-------------------------------------|--------------------------------------------------------------------------------------------| | Function | The pins selected by the A-D sweep pin select bit are used for repeat sweep A-D conversion | | Start condition | Writing "1" to A-D conversion start flag | | Stop condition | Writing "0" to A-D conversion start flag | | Interrupt request generation timing | None generated | | Input pin | ANO and AN1 (2 pins), AN0 to AN3 (4 pins), AN0 to AN5 (6 pins), or AN0 to AN7 (8 pins) | | Reading of result of A-D converter | Read A-D register corresponding to selected pin (at any time) | Figure 1.103: A-D conversion register in repeat sweep mode 0 ### 2.24.5 Repeat sweep mode 1 In repeat sweep mode 1, all pins are used for A-D conversion with emphasis on the pin or pins selected using the A-D sweep pin select bit. Table 1.36 shows the specifications of repeat sweep mode 1. Figure 1.104 show the A-D control in repeat sweep mode 1. Table 1.36: Repeat sweep mode 1 specification | Item | Specification | | | | | |-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Function | All pins perform repeat sweep A-D conversion, with emphasis on the pin or pins selected by the A-D sweep pin select bit Example: AN0 selected AN0 AN1 AN0 AN2 AN0 AN3, etc. | | | | | | Start condition | Writing "1" to A-D conversion start flag | | | | | | Stop condition | Writing "0" to A-D conversion start flag | | | | | | Interrupt request generation timing | None generated | | | | | | Input pin | AN0 (1 pin), AN0 and AN1 (2 pins), AN0 to AN2 (3 pins), AN0 to AN3 (4 pins) | | | | | | Reading of result of A-D converter | Read A-D register corresponding to selected pin (at any time) | | | | | Figure 1.104: A-D conversion register in repeat sweep mode 1 # **Preliminary Specifications REV. E** Specifications in this manual are tentative and subject to change A-D Converter ## 2.24.6 Sample and hold Sample and hold is selected by setting bit 0 of the A-D control register 2 (address $03D4_{16}$ ) to "1". When sample and hold is selected, the rate of conversion of each pin increases. As a result, a $28~\phi$ AD cycle is achieved with 8-bit resolution and $33~\phi$ AD with 10-bit resolution. Sample and hold can be selected in all modes. However, in all modes, be sure to specify before starting A-D conversion whether sample and hold is to be used. **CRC Calculation Circuit** # 2.25 CRC Calculation Circuit The Cyclic Redundancy Check (CRC) calculation circuit detects an error in data blocks. The microcomputer uses a generator polynomial of CRC\_CCITT (X16 + X12 + X5 + 1) to generate CRC code. The CRC code is a 16-bit code generated for a block of a given data length in multiples of 8 bits. The CRC code is set in a CRC data register each time one byte of data is transferred to a CRC input register after writing an initial value into the CRC data register. Generation of CRC code for one byte of data is completed in two machine cycles. Figure 1.105 shows the block diagram of the CRC circuit. Figure 1.106 shows the CRC-related registers. Figure 1.105: Block diagram of CRC circuit Figure 1.106: CRC-related registers # 2.26 Programmable I/O Ports There are 63 programmable I/O ports: P0 to P3, P6 to P8 (excluding P85), and P10. Each port can be set independently for input or output using the direction register. A pull-up resistance for each block of 4 ports can be set. P85 is an input-only port and has no built-in pull-up resistance. Figure 1.107, Figure 1.108 and Figure 1.109 show the programmable I/O ports. Each pin functions as a programmable I/O port and as the I/O for the built-in peripheral devices. To use the pins as the inputs for the built-in peripheral devices, set the direction register of each pin to input mode. When the pins are used as the outputs for the built-in peripheral devices, they function as outputs regardless of the contents of the direction registers. Unused I/O pins can be terminated as shown in Figure 1.114 and Table 1.37. ## 2.26.1 Direction registers Figure 1.110 shows the direction registers. These registers are used to choose the direction of the programmable I/O ports. Each bit in these registers corresponds one for one to each I/O pin. Note: There is no direction register bit for P85. ## 2.26.2 Port registers Figure 1.111 shows the port registers. These registers are used to write and read data for input and output to and from an external device. A port register consists of a port latch to hold output data and a circuit to read the status of a pin. Each bit in port registers corresponds one for one to each I/O pin. ## 2.26.3 Pull-up control registers Figure 1.112 shows the pull-up control registers. The pull-up control register can be set to apply a pull-up resistance to each block of 4 ports. When ports are set to have a pull-up resistance, the pull-up resistance is connected only when the direction register is set for input. ## 2.26.4 High drive capacity registers Figure 1.113 shows the Port 2 and PWM drive capacity register. Port 2 can be configured to drive an LED by increasing the drive strength of the corresponding bit's N-channel transistor. Each Timer output (TA0OUT~TA4OUT) can be configured for high-drive capability by increasing the drive strength of the corresponding bits. Figure 1.107: Programmable I/O ports (1) Figure 1.108: Programmable I/O ports (2) Figure 1.109: Programmable I/O Ports (3) Figure 1.110: Direction register Figure 1.111: Port register Figure 1.112: Pull-up control register Figure 1.113: Port 2 and Timer A Output drive capacity registers Figure 1.114: Example connection unused pins Table 1.37: Example connection of unused pins in single-chip mode | Pin name | Connection | |-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------| | Ports P0 to P3, P6 to P8, P10 (excluding P85) | After setting for input mode, connect every pin to Vss or Vcc via a resistor; or after setting for output mode, leave these pins open | | Xout | Open | | NMI | Connect via resistor to Vcc (pull-up) | | AVcc | Connect to Vcc | | Avss, Vref, BYTE | Connect to Vss | | USB D+, USB D- | Open | | ExtCap | Connect to Vcc (when DC-DC converter is disabled) Connect to Vss via cap (when DC-DC converter is enabled and using the ATTACH function) | | SOF | Open | | ATTACH | Open | # 3.0 Usage # 3.1 Usage Precautions #### 3.1.1 A-D Converter - Write to each bit (except bit 6) of A-D control register 0, to each bit of A-D control register 1, and to bit 0 of A-D control register 2 when A-D conversion is stopped (before a trigger occurs). In particular, when the Vref connection bit is changed from "0" to "1", start A-D conversion after an elapse of 1 s or longer. - When changing A-D operation mode, select analog input pin again. - Using one-shot mode or single sweep mode Read the corresponding A-D register after confirming the A-D conversion is finished. (It is known by A-D conversion interrupt request bit.) Using repeat mode, repeat sweep mode 0 or repeat sweep mode 1 Use the undivided main clock as the internal CPU clock. #### 3.1.2 Built-in PROM version • All built-in PROM versions High voltage is required to program to the built-in PROM. Be careful not to apply excessive voltage. Be especially careful during power-on. One Time PROM version One Time PROM versions shipped in blank, of which built-in PROMs are programmed by users, are also provided. For these microcomputers, a programming test and screening are not performed in the assembly process and the following processes. To improve their reliability after programming, we recommend to program and test as flow shown in Figure 115 before use. Wiring for the Vpp pin of the One-Time PROM version should be as follows (Vpp pin is also used as the CNVss pin): - Make the length of wiring between the Vpp pin and Vss pin or Vcc pin the shortest possible. - When the wiring length has to be longer, connect an approximately 5K ohm resistor in series from the Vpp pin to the Vss pin or Vcc pin with the shortest possible wiring. This is because the Vpp pin is the power source input pin for the built-in PROM. When programming in the built-in PROM, the impedance of the Vpp pin is low to allow the electric current for wiring flow into the PROM. Because of this, noise can enter easily. If noise enters the Vpp pin, abnormal instruction codes or data are read from the built-in PROM which may cause a program runaway. ### 3.1.3 Dedicated Input Pins If a dedicated input pin is connected to a power supply that is different than the supply that Vcc is connected to, a resistor (approximately 1k ohm) should be added between that input pin and the power supply it is connected to, otherwise, if the dedicated input pin voltage is higher than Vcc, latch up could occur. #### 3.1.4 DMAC When the DMA enable bit (bit 3 of DM0CON and DM1CON) is set to "1", the DMAC is in an active state. The DMA request bit (bit 2 of DM0CON and DM1CON) is set to "1" when a request for DMA transfer occurs, regardless of the state of the DMA enable bit. If the DMAC is active when the request bit becomes "1", the data transfer begins immediately. The request bit is cleared to "0" when the transfer begins. It is also possible for the DMA request bit to get set to a "1" due to the DMA request cause select bits being changed. Therefore, the DMA request bit should be cleared ("0") after changing the DMA request cause select bits. To best judge the state of the DMAC, the DMA enable bit should be read instead of the DMA request bit. ## 3.1.5 Interrupts - Reading address 00000<sub>16</sub> - When a maskable interrupts occurs, the CPU reads the interrupt information (the interrupt number and interrupt request level) in the interrupt sequence. - The interrupt request bit of the corresponding interrupt written in address $00000_{16}$ is then set to "0". Reading address $00000_{16}$ by software sets enabled highest priority interrupt source request bit to "0". Though the interrupt is generated, the interrupt routine may not be executed. Do not read address $00000_{16}$ by software. - Setting the stack pointer - The value of the stack pointer is initialized to 00000<sub>16</sub> immediately after reset. Accepting an interrupt before setting a value in the stack pointer may cause program runaway. Be sure to set a value in the stack pointer before accepting an interrupt. - When using the NMI interrupt, initialize the stack pointer at the beginning of a program. Concerning the first instruction immediately after reset, generating any interrupts including the NMI interrupt is prohibited. - Setting interrupts - Changing the Interrupt Priority Level select bit (ILVL) and clearing the Interrupt Request bit (IR) in the Interrupt Control Registers (ICR) while the Interrupt enable flag (I-FLAG) is "1", may result in unintended operations, such as BRK and other interrupts being generated. It is recommended that the interrupts be disabled by clearing the I-FLAG before setting ILVL or clearing the IR bit. To prevent the I-FLAG from being set before the ICR is rewritten due to the effects of the instruction queue, instructions that equal a minimum of 2 cycles should be inserted between writing to the ICR and setting the I-FLAG (2-NOPs, I MOV, I POP, etc.) - The NMI interrupt - As for the NMI interrupt pin, an interrupt cannot be prohibited. Connect it to the Vcc pin if unused. - Do not get into stop mode or wait mode with the NMI pin set to "0". #### **3.1.6 Noise** To reduce the possibility of noise problems: - Connect a bypass capacitor (approximately 0.1 uF) across the Vss pin and the Vcc pin with the shortest possible wiring - Use circuit traces with a larger diameter than other signal traces for Vss and Vcc. ## 3.1.7 Stop Mode and Wait Mode - When returning from stop mode by hardware reset, RESET pin must be set to "L" level until main clock oscillation is stabilized. - When entering either wait or stop mode, you must first enable any interrupts you want to cancel the wait or stop. Also, make sure to disable any interrupts that you don't want to cancel the wait or stop. If only hardware reset or NMI interrupts are desired to cancel wait or stop, all other interrupt priority levels should be set to "0". ### 3.1.8 Timer A (timer mode) Reading the Timer Ai register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the Timer Ai register with the reload timing gets "FFFF<sub>16</sub>". Reading the Timer Ai register after setting a value in the Timer Ai register with a count halted but before the counter starts counting gets a proper value. ## 3.1.9 Timer A (event counter mode) - Reading the Timer Ai register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the Timer Ai register with the reload timing gets "FFFF<sub>16</sub>" by underflow or "0000<sub>16</sub>" by overflow. Reading the Timer Ai register after setting a value in the Timer Ai register with a count halted but before the counter starts counting gets a proper value. - When counting is stopped in free-run type, set the timer again. - When using Free-run type, the timer's register contents may be unknown when counting starts. Set the timer value immediately after counting has started. ### 3.1.10 Timer A (pulse width modulation mode) - The Timer Ai interrupt request bit becomes "1" if setting operation mode of the timer in compliance with any of the following procedures: - · Selecting PWM mode after reset. - · Changing operation mode from timer mode to PWM mode. - Changing operation mode from event counter mode to PWM mode. Therefore, to use Timer Ai interrupt (interrupt request bit), set Timer Ai interrupt request bit to "0" after the above listed changes have been made. • Setting the count start flag to "0" while PWM pulses are being output causes the counter to stop counting. If the TAiOUT pin is outputting an "H" level in this instance, the output level goes to "L", and the Timer Ai interrupt request bit goes to "1". If the TAiOUT pin is outputting an "L" level in this instance, the level does not change, and the Timer Ai interrupt request bit does not become "1". ## 3.1.11 Timer B (timer mode) Reading the Timer Bi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the Timer Bi register with the reload timing gets "FFFF<sub>16</sub>". Reading the Timer Bi register after setting a value in the Timer Bi register with a count halted but before the counter starts counting gets a proper value. ### 3.1.12 UART2 When using UART2 in clock asynchronous serial I/O mode (UART), use the internal clock only, otherwise, one of the following may occur: - The interrupt may not be issued at the end of the data transmission when the hardware transfers the data from the transmit buffer to the transmit register. - Data may be corrupted when the hardware transfers data fro the transmit buffer register to the transmit register. This only applies to UART2 asynchronous serial I/O mode and does not apply to UART0 or UART1. ### 3.1.13 USB USB SFR refers to registers from 0x0300 to 0x033C. All these registers are physically inside the USB block and are affected by the USB reset. Also, these registers can only be accessed by 8-bit mode. USB related registers 0x00C, 0x03DB-0x3DF are not inside the USB block and are not affected by a USB reset and can be accessed by 8 or 16 bits. Figure 1.115: Programming and test flow for One-time PROM (OTP) version Electrical # 4.0 Specifications # 4.1 Electrical Table 1.38: Absolute maximum ratings only, not operating conditions | Symbol | Parameter | | Condition | Rated Value | Unit | |------------------|-------------------|----------------------------------------------------------------------------------------------|-----------|----------------------|------| | V <sub>cc</sub> | Supply voltage | | Vcc=AVcc | -0.3 to 6.5 | V | | AV <sub>CC</sub> | Analog supply vo | tage | Vcc=AVcc | -0.3 to 6.5 | V | | VI | Input voltage | Port0, Port1, Port2, Port3, Port6,<br>Port7, Port8, Port10, RESET, VREF,<br>XIN | | -0.3 to Vcc+0.3 | V | | VI | Input voltage | CNVss | | -0.3 to 6.5 (Note 1) | V | | V <sub>O</sub> | Output voltage | Port0, Port1, Port2, Port3, Port6,<br>Port7, Port8 (except P85),<br>Port10, RESET, VREF, XIN | | -0.3 to Vcc+0.3 | V | | $P_d$ | Power dissipation | | Ta=25° C | 760 | mW | | T <sub>opr</sub> | Operating ambier | nt temperature | | 0 to 70 | °C | | T <sub>stg</sub> | Storage temperat | ure | | -65 to 150 | °C | Note 1: When writing to EPROM, CNVss rated value is -0.3 to 13 volts Table 1.39: Recommended operating conditions | Cumbal | | Parameter | | Standard | | | | |------------------|--------------------------------|-----------------------------------------------------------------------------------|--------|----------|--------|------|--| | Symbol | | Parameter | Min | Тур | Max | Unit | | | V <sub>cc</sub> | Supply voltage | | 4.1 | 5.0 | 5.25 | V | | | AV <sub>CC</sub> | Analog supply voltage | | | Vcc | | V | | | Vss | Supply voltage | | | 0 | | V | | | Avss | Analog supply voltage | | | 0 | | V | | | V <sub>IH</sub> | High input voltage | Port 0, Port1, Port2, Port3, Port6, Port7, Port8, Port10, RESET, VREF, XIN, CNVSS | 0.8Vcc | | Vcc | V | | | V <sub>IL</sub> | Low input voltage | Port0, Port1, Port2, Port3, Port6, Port7, Port8, Port10, RESET, VREF, XIN, CNVSS | 0 | | 0.2Vcc | ٧ | | | loh (peak) | High peak output current | Port0, Port1, Port3, Port6, P71, P73, P75, P77, P81 to P87, Port10 | | | -10 | mA | | | " , | | P20 to P27, P70, P72, P74, P76, P80 | | | -20 | mA | | | loh (avg.) | High avg output current | Port0, Port1, Port3, Port6, P71, P73, P75, P77, P81 to P87, Port10 | | | -5 | mA | | | | | P20 to P27, P70, P72, P74, P76, P80 | | | -10 | mA | | | Σloh(peak) | High peak output current | P2, P3, P6, P7, P8 <sub>0</sub> ~P8 <sub>2</sub> | | | -80 | mA | | | Zion(peak) | r light peak output current | P0, P1, P8 <sub>3</sub> ~P8 <sub>7</sub> , P10 | | | -80 | mA | | | Flob (ova.) | High ava output ourront | P2, P3, P6, P7, P8 <sub>0</sub> ~P8 <sub>2</sub> | | | -40 | mA | | | Σloh (avg.) | High avg output current | P0, P1, P8 <sub>3</sub> ~P8 <sub>7</sub> , P10 | | | -40 | mA | | | lol (peak) | Low peak output current | Port0, Port1, Port3, Port6, P71, P73, P75, P77, P81 to P87, Port10 | | | 10 | mA | | | \(\frac{1}{2}\) | | P20 to P27, P70, P72, P74, P76, P80 | | | 20 | mA | | | lol (avg.) | Low avg output current | Port0, Port1, Port3, Port6, P71, P73, P75, P77, P81 to P87, Port10 | | | 5 | mA | | | ( 0 / | | P20 to P27, P70, P72, P74, P76, P80 | | | 10 | mA | | | Flat (page) | Low pook output ourset | P2, P3, P6, P7, P8 <sub>0</sub> ~P8 <sub>2</sub> | | | 80 | mA | | | Σlol (peak) | Low peak output current | P0, P1, P8 <sub>3</sub> ~P8 <sub>7</sub> , P10 | | | 80 | mA | | | Elel (eve | Low over output ourse | P2, P3, P6, P7, P8 <sub>0</sub> ~P8 <sub>2</sub> | | | 40 | mA | | | Σlol (avg. | Low avg output current | P0, P1, P8 <sub>3</sub> ~P8 <sub>7</sub> , P10 | | | 40 | mA | | | f(Xin) | Main clock input oscillation f | requency | 1 | | 12 | MHz | | Note: The total output current is the sum of all the currents flowing through all the applicable ports. The total average current is an average value measured over 100 ms. The total peak current is the peak value of all the currents. Electrical Table 1.40: Electrical characteristics (Vcc=4.1~5.25V, Vss=0V, Ta= 0°C~ 70°C, f(Xin) = 12MHz | | | | | | | 5 | Standar | rd | | |---------|-------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------------------------|----------------------------|-----------------------------------------------------|-----|---------|------|------| | Symbol | Pa | arameter | | Measurin | g condition | Min | Тур | Max | Unit | | Voн | High output voltage | Port0, Port1, Por<br>Port71, P73,P75<br>(except P85), Po | 5,P77,Port8 | IOH = -5mA | | 3.0 | | | V | | Voн | High output voltage | Port 70,P72,P74 | I,P76,P80 | Iон = -10mA | | 3.0 | | | V | | Vон | High output voltage | Port0, Port1, Port71, P73,P75<br>(except P85), Port71 | 5,P77,Port8 | Іон = -200μΑ | <b>.</b> | 4.7 | | | V | | Voн | High output voltage | High-drive mode | Port 2 | Iон = -10mA | | 3.0 | | | | | Vон | High output voltage | Xout | high power | IOH = -1mA<br>IOH = -0.5mA | | 3.0 | | | V | | VoL | Low output voltage | Port0, Port1, Por<br>Port71, P73,P75<br>(except P85), Po | rt2, Port3, Port6,<br>5,P77,Port8 | IOL = 5mA | | | | 2.0 | V | | Vol | Low output voltage | High-drive mode | Port 2 | IOL = 10mA | | | | 2.0 | V | | VoL | Low output voltage | Port 70,P72,P74<br>NOTE 1 | I,P76,P80 | IOL= 10mA | | | | 2.0 | V | | VoL | Low output voltage | Port0, Port1, Por<br>Port71, P73,P75<br>(except P85), Po | 5,P77,Port8 | IOL = 200μA | | | | 0.45 | V | | Vol | Low output voltage | | high power | IOH = 1mA | | | | 2.0 | V | | VOL | Low output voltage | Xout low power | | IOH = 0.5mA | | | | 2.0 | V | | VT+-VT- | Hysteresis | TA0in to TA4in, INTO to INT1, AD <sub>TRG</sub> , CTS0, CTS1, CLK0, CLK1, TA2out to TA4out, NMI, KIO to KI15 | | | | | | 0.8 | V | | VT+-VT- | Hysteresis | RESET | | | | 0.2 | | 1.8 | V | | lih | High input current | Port0, Port1, Por<br>Port7,Port8, Por<br>CNVss | | VI = 5V | | | | 5.0 | μА | | lil | Low input current | Port0, Port1, Port2, Port3, Port6,<br>Port7, Port8, Port10, RESET,<br>CNVss | | VI = 0V | | | | -5.0 | μΑ | | RPULLUP | Pull-up resistance | Port0, Port1, Por<br>Port7, Port8, Port8 | | VI = 0V | | 30 | 50 | 167 | kΩ | | RXIN | Feedback resistance | • | | | | | 1.0 | | MΩ | | VRAM | RAM retention voltag | je | | When clock is | <del> </del> | 2.0 | | | V | | | | | | | Icc run with USB ON (Mask) | | | 80 | mA | | | | | | | Icc run with<br>USB ON (OTP) | | | 95 | mA | | | | | | | Icc run with<br>USB OFF | | | 50 | mA | | | cc Power supply current | | Output pins | Ta=25°C<br>clock stopped | | | 1 | μΑ | | | Icc | | | open, other pins tied to | Ta=70°C<br>clock stopped | | | 20 | μΑ | | | | | Vss | Ta=25°C<br>wait mode<br>with internal<br>clocks ON | | | 8 | mA | | | | | | | | | Ta=25°C<br>wait mode<br>with internal<br>clocks OFF | | | 4 | mA | Note 1 Only high drive when Timer A is enabled and drive registers set for high drive mode. SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER Table 1.41: USB Electrical Characteristics (Vcc=4.1~5.25V, Vss=0V, Ta= 0°C~ 70°C, f(Xin) = 12MHz) | Symbol | Parameter | Measuring Condition | | Unit | | | |--------|-------------------------------|--------------------------------------------|-----|------|-----|-------| | Symbol | raiametei | Weasuring Condition | Min | Тур | Max | Offic | | Voн | D+, D- | I=18.3 mA, RX=33 Ω, VXcap =3.0 V | 2.2 | | | V | | Vol | D+, D- | I=18.3 mA, RX=33 Ω, VXcap =3.0 V | | | 0.8 | V | | Isusp | Suspend current | USB suspend mode, internal clock stopped | | | 175 | μΑ | | Хсар | DC-DC<br>converter<br>voltage | DC-DC converter output voltage on Xcap pin | 3.0 | 3.3 | 3.6 | V | Note: See Fig. 122 for recommended configuration. # 4.2 Timing Table 1.42: A-D conversion characteristics (Vcc, Avcc = 4.1~5.25V, Vss=0V, Ta= 0°C~70°C, f(Xin) = 12MHz) | Cymahal | /mbol Parameter | | Measuring | Standard | | | l lmit | |---------|----------------------------------------------------|--------------------------------------------|-----------------|----------|-----|------|--------| | Symbol | | | condition | Min | Тур | Max | Unit | | - | Resolution | | VREF = VCC | | | 10 | Bits | | | Absolute | Sample and hold function not available | VREF = Vcc = 5V | | | ±3 | LSB | | - | | Sample and hold function available (10bit) | VREF = Vcc = 5V | | | ±3 | LSB | | | accuracy | Sample and hold function available (8bit) | VREF = Vcc = 5V | | | ±2 | LSB | | R | Ladder resistance | | VREF = VCC | 10 | | 40 | kΩ | | Gonave | Conversion time (10bit) | | | 2.75 | | | μs | | tconv | Conversion time (8bit) | | | 2.34 | | | μs | | tSAMP | Sampling time | | | 0.25 | | | μs | | VREF | Reference voltage | | | 2 | | | V | | VIA | Analog input voltage (min. operating frequency =x) | | | 0 | | VREF | V | | φAD | A-D clock fr | equency | | 1 | | 12 | MHz | Timing requirements referenced to Vcc = 4.1~5.25V, Vss=0V, Ta=0°C~70°C unless otherwise specified. Table 1.43: External clock input | C | ъ . | | Standard | | | |--------|---------------------------------------|------|----------|------|--| | Symbol | Parameter | Min | Max | Unit | | | tc | External clock input cycle time | 83.3 | | ns | | | tw(H) | External clock input HIGH pulse width | 33 | | ns | | | tw(L) | External clock input LOW pulse width | 33 | | ns | | | tr | External clock rise time | | 15 | ns | | | tf | External clock fall time | | 15 | ns | | Timing # Table 1.44: Timer A input (counter input in event counter mode) | Cumbal | Dovernator | Standa<br>Min | dard | Linit | |---------|-----------------------------|---------------|------|-------| | Symbol | Parameter | | Max | Unit | | tc(TA) | TAiın input cycle time | 100 | | ns | | tw(TAH) | TAin input HIGH pulse width | 40 | | ns | | tw(TAL) | TAin input LOW pulse width | | | ns | # Table 1.45: Timer A input (gating input in timer mode) | Cumbal | Donomotor | Standard | | Unit | |---------|------------------------------|----------|-----|------| | Symbol | ymbol Parameter | | Max | | | tc(TA) | TAilN input cycle time | 400 | | ns | | tw(TAH) | TAilN input HIGH pulse width | 200 | | ns | | tw(TAL) | TAilN input LOW pulse width | 200 | | ns | # Table 1.46: Timer A input (external trigger input in one-shot timer mode) | Curebal | Dovementor | Standard | | Unit | |---------|------------------------------|----------|-----|------| | Symbol | Parameter | | Max | | | tc(TA) | TAilN input cycle time | 200 | | ns | | tw(TAH) | TAilN input HIGH pulse width | 100 | | ns | | tw(TAL) | TAilN input LOW pulse width | 100 | | ns | # Table 1.47: Timer A input (external trigger input in pulse width modulation mode) | Cy week al | Parameter | Standard | | 1.1 | |------------|------------------------------|----------|-----|------| | Symbol | | Min | Max | Unit | | tw(TAH) | TAilN input HIGH pulse width | | | ns | | tw(TAL) | TAilN input LOW pulse width | | | ns | # Table 1.48: Timer A input (up/down input in event counter mode) | Cumbal | Doromotor | Standard Min Max | | Linit | |-------------|-------------------------------|------------------|-----|-------| | Symbol | Symbol Parameter | | Max | Unit | | tc(UP) | TAio∪T input cycle time | 2000 | | ns | | tw(UPH) | TAiout input HIGH pulse width | 1000 | | ns | | tw(UPL) | TAiout input LOW pulse width | 1000 | | ns | | tsu(UP-TIN) | TAiout input setup time | 400 | | ns | | th(TIN-UP) | TAiout input hold time | 400 | | ns | # Table 1.49: A-D trigger input | Cy week al | Dovometer | Stan | dard | l lm:4 | |------------|----------------------------------------------------------|------|------|--------| | Symbol | Parameter | Min | Max | Unit | | tc(AD) | AD <sub>TRG</sub> input cycle time (triggerable minimum) | 1000 | | ns | | tw(ADL) | AD <sub>TRG</sub> input LOW pulse width | 125 | | ns | **Timing** #### Serial I/O Table 1.50: | Cumphal | Devenuetes | Standard | | Unit | |----------|-----------------------------|----------|-----|------| | Symbol | Symbol Parameter | | Max | | | tc(CK) | CLKi input cycle time | 200 | | ns | | tw(CKH) | CLKi input HIGH pulse width | 100 | | ns | | tw(CKL) | CLKi input LOW pulse width | 100 | | ns | | td(C-Q) | TxDi output delay time | | 80 | ns | | th(C-Q) | TxDi hold time | | | ns | | tsu(D-C) | RxDi input setup time | 30 | | ns | | th(C-D) | RxDi input hold time | | | ns | # Table 1.51: External interrupt INTi inputs | O. was boat | Doromotor | Standard | | 1.1 | |-------------|-----------------------------|----------|-----|------| | Symbol | Parameter | Min | Max | Unit | | tw(INH) | INTI input HIGH pulse width | | | ns | | tw(INL) | INTI input LOW pulse width | | | ns | # 4.3 Timing Diagrams- Peripheral/interrupt Figure 1.116: Peripheral / Interrupt timing diagram # 5.0 Applications # 5.1 Frequency Synthesizer Interface and DC-DC Converter This section presents the recommended method of setting up and using the frequency synthesizer that generates the 48MHz clock needed by the USB FCU and the DC-DC converter that provides power to the D+/D- drivers ## 5.1.1 Reset of USB Related Registers Figure 1.117: SFR Reset Venn Diagram The special function registers (SFRs) that govern the operation of the frequency synthesizer, DC-DC converter and USB FCU are affected by one or more reset events. The addresses of the special function registers (SFRs) that are affected by Hardware Reset, USB Reset, or both are shown in Figure 1.117. All resettable SFRs, including SFRs and other registers internal to the USB FCU, are affected by a Hardware Reset, which occurs when the RESET pin is brought low or an undefined opcode is fetched. See Section 2.4 for a complete listing of SFRs and their reset values. Only registers internal to the USB FCU are reset when a USB Reset sent by the Host/Hub is detected. These USB registers are reset to their default values except for bit 5 of USBIS2 (USB Reset Interrupt Status Flag), which is set to a "1". USB FCU registers are registers from address 300<sub>16</sub>to 33C<sub>16</sub> and all other registers within the USB FCU, many of which the MCU does not have direct access to (e.g. FIFO address pointers). The USB FIFO registers are empty after USB reset because the FIFO address pointers are reset. However, the physical contents of the FIFOs are not set to all '1's or all '0's. Other SFRs such as USBC, FSC, and CM0, CM1 are not affected by a USB Reset. ### 5.1.2 Set up of Frequency Synthesizer and DC-DC Converter Figure 1.118: PLL, DC-DC Converter and USB Functional Block Diagram A functional block diagram of the USB system on the M30240 which shows how the control signals affect operation is given in Figure 1.118 # 5.1.2.1 Set up after Hardware Reset A Hardware Reset occurs when either the $\overline{\text{RESET}}$ pin is brought low for more than 2 $\mu$ s or an invalid opcode is fetched by the CPU. The frequency synthesizer (PLL) and DC-DC converter should be set up as follows in the Hardware Reset routine (see Figure 1.119), - Power up the M30240 and other components on the peripheral device for less than 100 mA operation. The current limit only applies for bus powered devices. - Configure the PLL for 48MHz f(VCO) operation. - Enable the PLL by setting FSE (bit 0 of the Frequency Synthesizer Control Register (FSC)) to a "1", then wait for 2 ms. - Check the lock status bit (LS, bit 7 of FSC). - If the bit is a "1", go on. - If the bit is a "0", wait 0.1 ms longer and then re-check the bit. - Enable the DC-DC converter in high current mode by setting USBC4 (bit 4 of the USB Control Register (USBC)) to a "1" and keeping USBC3 (bit 3 of USBC) a "0". High current mode should always be used during normal USB operation. Low current mode should only be used during a USB suspend. - Wait (C + 1)ms (where C equals the external capacitance connected to the Ext Cap pin in μF) for the voltage on Ext Cap to reach a steady state voltage of approximately 3.3V. (Since the D+ pullup is connected to the Ext Cap pin, the upstream hub will detect that the peripheral device has been plugged in once the voltage on D+ reaches approximately 2.0 V.) - Example: A 2.2 μF capacitor connected to Ext Cap requires 3.2 ms for the voltage on Ext Cap to be stable. - Enable the USB clock by setting USBC5 (bit 5 of USBC) to a "1". (If the USB clock and FCU are enabled before the voltage on Ext Cap is stable, a phantom USB Reset may be detected, or the actual USB Reset may not be detected.) - Wait at least 4 cycles of Φ, then enable the USB FCU by setting USBC7 (bit 7 of USBC) to a "1". - · Enable other blocks as necessary. Figure 1.119: PLL and DC-DC Converter Set Up Timing after Hardware Reset #### 5.1.2.1.1 Precautions after Software Reset A software reset occurs after writing a '1' to bit '3' of the processor mode register 0 (address 0004<sub>16</sub>). During software reset, the contents of the internal RAM are preserved as well as all USB, DC-DC converter, and PLL registers. If the PLL is used as the system clock source, it is important to note that after a software reset occurs, any writes to the frequency synthesizer register will cause it to freeze. This can cause erratic device behavior. In order to avoid this, it is recommended that the following procedure be used: - Prior to software reset, switch device clock source from 'fsyn to f(Xin)'. Please see the Frequency Synthesizer specification for more details. - After software reset using firmware, evaluate the condition of the synthesizer control register (FSC register, address 03DC<sub>16</sub>, bit '0'). This bit is not effected by a software reset and can check to see if the PLL is still enabled. If so, any setup routine that involves writing to the PLL registers should not be called. At this point, the clock source can be changed back to fsyn. ### 5.1.2.2 Set up after USB Reset Signaling Detected A USB Reset is detected by the USB FCU when an SE0 is present on D+/D- for at least 2.5 $\mu$ s. Detection of a USB Reset results in bit 5 of USB Interrupt Status Register 2 (USBIS2) being set to a "1" and the registers within the USB FCU being reset to their default values. Register USBC and the PLL registers are not affected by a USB Reset. A USB Function Interrupt request is also generated when the USB Reset is detected. No modifications to the frequency synthesizer or DC-DC converter configuration should be made in the USB Function Interrupt routine. However, all USB FCU registers (addresses $300_{16}$ to $33C_{16}$ ) must be reconfigured to their pre-enumeration state. ### 5.1.2.3 Set up after USB Suspend Detected A USB Suspend occurs if the USB FCU does not detect any bus activity on D+/D- for at least 3 ms. Detection of a suspend results in bit 7 of USBIS2 and bit 0 of USBPM (SUSPEND) being set to a "1". This causes bit 3 of SUSPIC to be set to a "1". Bit 7 of USBIS2 then needs to be cleared by writing a "1" to the bit in order to allow a future suspend event. The configuration of the frequency synthesizer and DC-DC converter should be changed as follows in the USB Suspend Interrupt routine (if the device is bus powered): - Change the DC-DC converter from high current mode to low current mode by setting USBC3 (bit 3 of the USBC) to a "1" - Disable the USB clock by setting USBC5 (bit 5 of USBC) to a "0". Once the USB clock is disabled, registers internal to the USB FCU should not be written to. This includes all USB SFRs from address 0300<sub>16</sub> to 033C<sub>16</sub>. It does not include USBC or FSC. - Perform other tasks to reduce total current to below 500μA. - Disable the PLL by setting FSE (bit 0 of FSC) to a "0". - Make sure the I-FLAG is set to "1". - Stop the system clock by setting CM10 (bit 0 of CM1) to a "1". Make sure to first enable writing to the system clock control register by setting PRCO (bit 0 of PRCR) to "1". Also, make sure to enable the USB Resume Interrupt (RSMIC register) and clear or execute any pending interrupts prior to stopping the clock so the MCU can wake up once resume signaling is detected. If the clock is stopped using an interrupt routine, make sure to set the priority of the Resume Interrupt (RSMIC) higher than the current interrupt. - Note that no action may be necessary if the device is self powered. ## 5.1.2.4 Set up after USB Resume Signaling Detected A resume occurs when the USB FCU is in the suspend state and detects a non-idle signaling on D+/D-. Detection of a resume results in bit 6 of USBIS2 and bit 1 of USBPM (RESUME) being set to a "1". This causes bit 3 of RSMIC to also be set to "1". If the MCU was in the stop state prior to the detection of the resume, the USB Resume Interrupt request will cause the MCU to wake up from the stop state. Bit 6 of USBIS2 needs to be cleared (by writing a "1" to the bit) in order to allow a future resume event. See section 2.9 "Stop Mode" for details on waking up from the stop state. The configuration of the frequency synthesizer and DC-DC converter should be changed as follows in the USB Resume Interrupt routine (if the device is bus powered): - Re-enable the PLL for 48MHz f(VCO) by setting FSE (bit 0 of the FSC) to a "1", then wait for 2 ms. - Wait for 2 ms. - Check the lock status bit (LS, bit 7 of FSC). - If the bit is a "1", continue. - If the bit is a "0", wait 0.1 ms longer and then re-check the bit. - Enable the USB clock by setting USBC5 (bit 5 of USBC) to a "1". - Wait for a minimum of 4 cycles. - Change the DC-DC converter from low current mode to high current mode by setting USBC3 (bit 3 of the USBC) to a "0". - Enable other blocks as necessary. Registers internal to the USB FCU should not be written to until the USB clock is re-enabled. This includes all USB SFRs from address 0300<sub>16</sub> to 033C<sub>16</sub>. It does not include USBC or FSC. Note that the configuration changes described above may not need to be made if the MCU was not placed in a suspend state as described in section 5.1.2.3 Set up after USB Suspend Detected. Attach/Detach Function #### **5.1.2.5 PLL Lock Bit** The PLL lock bit is used to indicate when the PLL is first locked. Accordingly, after the PLL is enabled and it has been given 2.0 ms to stabilize, the lock bit status should be checked. Once the lock bit is HIGH, the USB check should be enabled. After this stage, the lock bit is no longer valid and should not be monitored, unless the PLL is re-enabled. # 5.2 Attach/Detach Function The Attach/Detach Function can be used to attach or detach a USB function from the host without disconnecting the cable. When attaching a USB function, the connect registers should be set to 3 Hex at the same time on or before the DC-DC Converter is enabled. Similarly, when detaching the connect register, it should be set to 1 Hex when powering down the DC-DC Converter. If you do not set the connect (address 1fh) to HIGH, the system will default to its normal mode. Note: If the D+ is connected to ExtCAP, this mode will not work. D+ is connected to ExtCAP through a 1.5 K resistor in compliance with the USB specification. USB Suspend/Resume Function Hardware connections are shown below Low Pass Filter Network ## 5.3 Low Pass Filter Network All passive components should be in close proximity to pin 78 (LPF), capacitors should be X7R dielectric or better. The recommended values are listed in Table 1.52 . See Figure 1.120 for schematic of the LPF. Table 1.52: Recommended Values | R 1000 Ω | 10% | |-------------|-----| | C2 = 680 pf | 10% | | C1 = 0.1 µf | 10% | Figure 1.120: LPF Filter Schematic Analog $V_{ss}$ and Analog $V_{cc}$ , pins 77 and 80 should have isolated connections to the digital $V_{ss}$ and $V_{cc}$ ground planes. Figure 1.121 illustrates the power supply isolation. Figure 1.121: Power Supply **USB** Transceiver ## 5.4 USB Transceiver When using the on-chip voltage converter to supply the necessary 3.3V to the driver circuit, a capacitor network must be connected between Ext. Cap (pin 6) and $V_{SS}$ (pin 13). Two capacitors are required as shown in Figure 1.122. The high frequency 0.1 $\mu$ F capacitor should be an X7R type or better. The low frequency decoupling capacitor of 2.2 $\mu$ F should be of tantalum di-electric or better. The startup time for this value of the capacitor is 3.2 ms, approximately (1ms/ $\mu$ F) + 1 ms. After enabling the on-chip voltage converter, a certain amount of time must pass before a wait or stop clock instruction is executed. The amount of time is given by (C+1) ms, when C is the value in $\mu$ F of the external capacitance connected to the Ext. Cap pin. For example, if the external capacitance is 2.2 $\mu$ F, at least 3.2 ms must elapse from the time that the on-chip voltage converter is enabled until a WAIT instruction or STOP command (CM10 = 1) is executed. In order to meet the impedance matching requirements of the USB Specification, a 33 $\Omega$ resistor must be added to USB D+ (pin 9) and to USB D- (pin 10). In addition, capacitors connected between USB D+ and USB D- or USB D+/D- and Vss may need to be added for rise/fall time matching and edge control. These capacitors should be placed after the 33 $\Omega$ resistors. Their configuration and values will depend on the PCs layout. The placement of external components is illustrated in Figure 1.122. Figure 1.122: Configuration of External USB components **Programming Notes** # SINGLE-CHIP 16-BIT CMOS MICROCOMPUTER # 5.5 Programming Notes ## 5.5.1 Accessing USB IN/OUT CSR Registers Do not use read-modify-write instruction on these registers because they contain control and status bits that can be changed by both hardware and software. There is a possibility that using a read-modify-write instruction might cause incorrect data to be written back to these registers. See Table 1.53 for a list of bits that may have incorrect data written to them and the value you should write back in order to prevent this from occurring. Table 1.53: Bits that might have incorrect data | Register name | Bit name | Value to write for "No change" | |------------------|------------------|--------------------------------| | | IN_PKT_RDY (b1) | "0" | | EP0CS | DATA_END (b3) | "0" | | | FORCE_STALL (b4) | "1" | | EPxICS (x = 1-4) | IN_PKT_RDY (b0) | "0" | | EFXICS (X = 1-4) | UNDER_RUN (b1) | "1" | | | OUT_PKT_RDY (b0) | "1" | | EPxOCS (x = 1-4) | OVER_RUN (b1) | "1" | | LFX003 (X = 1-4) | FORCE_STALL (b4) | "1" | | | DATA-ERR (b5) | "1" | The endpoint 1-4 IN CSR's (EPiICS, i = 1-4) have a bit IN\_PKT\_RDY (bit 0) that is set to a "1" by the firmware after a packet of data is loaded to the respective endpoint's FIFO. This signifies that a packet is ready for transmission. If the firmware wants to send a NULL packet to the host, it can simply write a "1" to the IN\_PKT\_RDY bit without loading data to the FIFO. This bit is cleared by the hardware. If the firmware manipulates (writes) the IN CSR for a purpose other than to signify to the hardware that a data packet is ready for transmission (for instance, set/reset ISO bit, set/reset SEND\_STALL bit), it must make sure that a "0" is written back to the IN\_PKT\_RDY bit. Failure to do so could cause improper operation of the device. Writing a "0" to the IN\_PKT\_RDY bit has no effect on its state. The endpoint 1-4 OUT CSRs (EPilCS, i = 1-4) have a bit OUT\_PKT\_RDY (bit 0) that is set to a "1" by the hardware after a packet of data is received from the host to the respective endpoint's FIFO. This signifies that a packet is ready for download. This bit is cleared by the firmware by writing a "0" to it after the data packet is unloaded from the FIFO. If the firmware manipulates (writes) the OUT CSR for a purpose other than to signify to the hardware that a data packet has been unloaded (for instance, set/reset ISO bit, set/reset SEND\_STALL bit), it must make sure that a "1" is written back to the OUT\_PKT\_RDY bit. Failure to do so could cause improper operation. Writing a "1" to the OUT\_PKT\_RDY bit has no effect on its state. **Programming Notes** Below is an example of how to set/reset the ISO bit of the IN CSR register (for initializing the respective endpoint as an isochronous endpoint): [R1L] = [EPilCS].B OR.B #08H, R1L ;set ISO bit = 1, write "1" back to UNDER\_RUN bit AND.B #0FEH, R1L ;write "0" back to IN\_PKT\_RDY bit [EPilCS].B = [R1L] [R1L] = [EPilCS].B OR.B #02, R1L ;write "1" back to UNDER\_RUN bit AND.B #0F6H, R1L ;reset ISO bit = 0, write "0" back to IN\_PKT\_RDY bit [EPilCS].B= [R1L] ### 5.5.2 USB Consecutive Set Address The USB Specification states that the host can send a SET\_ADDRESS request for the following cases: - 1. During enumeration when the device is in default state. (The host assigns a non-zero address.) - 2. When the device is in the address state. (The host can re-assign a new address.) The device handles case #1 (when the device is in the default state) and case #2 (when the device is in the address state) differently. The following is a segment of code to illustrate the program flow to properly deal with these cases. ``` DEFAULT_STATE: If [USBA].B == 0 ;If the device is in default state, update address before STATUS [USBA.].B = wValue _ lo completion :USB ENDPOINT 0 CSR R1L = [EP0CS].B OR.B #48H, R1L ;Set serviced_out_pkt_rdy & data_end [EP0CS].B = R1L wait for the completion of the JMP ADDR_END else ADDR_STATE R1L [EP0CS].B :USB ENDPOINT 0 CSR OR.B #48H, R1L ;Set serviced_out_pkt_rdy & data_end [EP0CS].B = R1L wait for the completion of the ;If the device is in address state, update address before STATUS [USBA].B= wValue_lo completion ADDR_END endif end of the set_address routine ``` Note: wValue\_lo = assigned address from the host in SET-ADDRESS request.