## MITSUBISHI MICROCOMPUTERS # M37204MC-XXXSP M37204EC-XXXSP, M37204ECSP SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **DESCRIPTION** The M37204MC-XXXSP is a single-chip microcomputer designed with CMOS silicon gate technology. It is housed in a 64-pin shrink plastic molded DIP. In addition to their simple instruction sets, the ROM, RAM and I/O addresses are placed on the same memory map to enable easy programming. The M37204MC-XXXSP has a PWM function and an OSD function, so it is useful for a channel selection system for TV. The features of the M37204EC-XXXSP and the M37204ECSP are similar to those of the M37204MC-XXXSP except that these chips have a built-in PROM which can be written electrically. Accordingly, the following descriptions will be for the M37204MC-XXXSP unless otherwise noted. #### **FEATURES** | • | Number of basic instructions69 | |---|------------------------------------------------------------------| | • | Memory size | | | ROM48 K bytes | | | RAM704 bytes | | | ROM for display8 K bytes | | | RAM for display144 bytes | | • | The minimum instruction execution time | | | 0.5 \(\mu\)s (at 8 MHz oscillation frequency) | | • | Power source voltage | | • | Subroutine nesting 128 levels (Max.) | | ٠ | Interrupts 13 types, 13 vectors | | • | 8-bit timers 4 | | ٠ | Programmable I/O ports | | | (Ports P0, P1, P2, P30-P36, P4, P6)47 | | • | Output ports (Ports P52-P56)5 | | • | 12 V withstand ports10 | | | LED drive ports4 | | • | Serial I/O 8-bit × 2 channel (2 systems) | | • | Special serial I/O for master transmission and reception 1 | | ٠ | Power dissipation 110 mW | | | (at VCC = 5.5 V, 4 MHz oscillation frequency, CRT on) | | • | A-D comparator (6-bit resolution) 8 channels | | • | PWM output circuit 14-bit × 1, 8-bit × 10 | | • | Interrupt interval determination circuit1 | | • | CRT display function | | | Display characters24 characters × 3 lines | | | (16 lines max.) | | | Character kinds 256 kinds | | | Dot structure 12 X 16 dots | | | Character size 4 kinds | | | Character color kinds (It can be specified by the character) | | | max. 15 kinds (R, G, B, I) | | | Character background color(It can be specified by the character) | | | max. 7 kinds (R, G, B) | | | 1/2-character unit color specification is possible. | | | Raster color (max. 15 kinds) | | | Display layout | | | Horizontal 64 levels | | | Vertical 128 levels | | | Bordering (horizontal and vertical) | #### **APPLICATION** T 6249828 DO25287 329 I Scanning line double count mode display is possible. Wipe function SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER 6249828 0025288 265 SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **FUNCTIONS** | | ırameter | | Functions | | | |-------------------------------|---------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Number of basic instructions | | | 69 | | | | Instruction execution time | | | $0.5\mu\text{s}$ (the minimum instruction execution time, at 8 MHz oscillation frequency) | | | | Clock frequency | | | 8 MHz (maximum) | | | | Memory size ROM 4 | | | 48 K bytes | | | | | RAM | | 704 bytes | | | | | ROM for displa | ıy | 8 K bytes | | | | | RAM for displa | ıy | 144 bytes | | | | Input/Output ports | P00-P07 | 1/0 | 8-bit × 1 (CMOS input/output structure) | | | | | P10-P17 | 1/0 | 8-bit X 1 (CMOS input/output structure) | | | | | P20-P27 | 1/0 | 8-bit × 1 (CMOS input/output structure) | | | | • | P30, P31 | 1/0 | 2-bit X 1 (CMOS input/output structure) | | | | | P32-P36 | 1/0 | 5-bit × 1 (N-channel open-drain output structure, can be used as externa clock input pins, A-D input pins, INT input pins) | | | | | P40-P47 | I/O | 8-bit X 1 (N-channel open-drain output structure, can be used as serial I/C pins, A-D input pins, PWM output pins) | | | | | P52-P56 | Output | 5-bit × 1 (CMOS output structure, can be used as CRT output pins, ar external clock output pin) | | | | | P60-P67 | 1/0 | 8-bit × 1 (N-channel open-drain output structure, can be used as PWN outputs) | | | | | P70 | | 1-bit X 1 (can be used as a CRT display clock input pin, an A-D input pin | | | | | P71 | | 1-bit X 1 (can be used as a CRT display clock output pin, an A-D input pin | | | | Serial I/O | | | 8-bit × 2, special serial I/O (8-bit) × 1 | | | | A-D comparator | | | 8 channels (6-bit resolution) | | | | PWM output circuit | | | 14-bit × 1, 8-bit × 10 | | | | Timers | | | 8-bit timer × 4 | | | | Subroutine nesting | | | 128 levels (maximum) | | | | Interrupt interval determinat | ion circuit | | 1 | | | | Interrupt | | | External interrupt $\times$ 2, Internal timer interrupt $\times$ 4, Serial I/O interrupt $\times$ 1 CRT interrupt $\times$ 1, f(XIN)/4096 interrupt $\times$ 1, VSYNC interrupt $\times$ 1 BRK interrupt $\times$ 1 | | | | Clock generating circuit | | | 2 built-in circuits (externally connected a ceramic resonator or a quartz crystal oscillator) | | | | Power source voltage | | | 5 V ± 10 % | | | | Power dissipation | CRT ON | | 110 mW typ. (at oscillation frequency fCPU = 4 MHz, fCRT = 8 MHz) | | | | | CRT OFF | | 55 mW typ. (at oscillation frequency fCPU = 4 MHz) | | | | | In stop mo | de | 1.65 mW (maximum) | | | | Operating temperature rang | е | | -10 °C to 70 °C | | | | Device structure | | _ | CMOS silicon gate process | | | | Package | | | 64-pin shrink plastic molded DIP | | | | CRT display function | Number of cha | ıracter | 24 characters X 3 lines (maximum 16 lines by software) | | | | Character dot construction | | | 12 × 16 dots | | | | | | | 256 kinds | | | | | Character size | | 4 kinds | | | | | Kinds of color | | Maximum 15 kinds (R, G, B, I) | | | | • | Display position (I | norizontal vertical) | 64 levels (horizontal) × 128 levels (vertical) | | | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **PIN DESCRIPTION** | Pin | Name | Input/<br>Output | Name | | | | |-----------------------------|------------------------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Vcc, Vss | Power source | | Apply voltage of 5 V ± 10 % to Vcc and AVcc, and 0 V to Vss. | | | | | CNVss | CNVss | | This is connected to Vss. | | | | | RESET | Reset input | Input | To enter the reset state, the reset input pin must be kept at a "L" for 2 \(\mu\)s or more (unde normal VCC conditions). If more time is needed for the quartz-crystal oscillator to stabilize, this "L" condition should be maintained for the required time. | | | | | XIN | Clock input | Input | This chip has an internal clock generating circuit. To control generating frequency, an external ceramic resonator or a quartz-crystal oscillator is connected between pins XIN and | | | | | Xout | Clock output | Output | XOUT. If an external clock is used, the clock source should be connected to the XIN pin and the XOUT pin should be left open. | | | | | P00-P07 | I/O port P0 | 1/0 | Port P0 is an 8-bit I/O port with direction register allowing each I/O bit to be individually programmed as input or output. At reset, this port is set to input mode. The output structure is CMOS output. The note of this Table gives a full of port P0 function. | | | | | P10-P17 | I/O port P1 | I/O | Port P1 is an 8-bit I/O port and has basically the same functions as port P0. The output structure is CMOS output. | | | | | P20-P27 | I/O port P2 | 1/0 | Port P2 is an 8-bit I/O port and has basically the same functions as port P0. The output structure is CMOS output. | | | | | P30, P31 | I/O port P3 | · I/O | Ports P3o, P31 are a 2-bit I/O port and have basically the same functions as port P0. The output structure is CMOS output. | | | | | AD6/P32/<br>TIM2, | I/O port P3 | 1/0 | Ports P32-P36 are a 5-bit I/O port and basically the same functions as port P0. The output structure is N-channel open-drain output. | | | | | P33/TIM3, | Analog input | Input | Pins P32, P35, P36 are also used as analog input pins AD6, AD1 and AD2 respectively. | | | | | P34/INT1,<br>P35/AD1, | External clock input | Input | Pins P32, P33 are also used as external clock input pins TiM2, TIM3 respectively. | | | | | P36/INT2/<br>AD2 | External interrupt input | Input | Pins P34, P36 are also used as external interrupt input pins INT1, INT2. | | | | | P40/SOUT1,<br>P41/SCLK1, | I/O port P4 | I/O | Port P4 is an 8-bit I/O port and has basically the same functions as port P0. The output structure is N-channel open-drain output. | | | | | AD8/P42/ | Serial I/O data input/output | I/O | Pins P40, P42, P44, P46 are also used as serial I/O data input/output pins Sout1, Sin1, Sout2, Sin2 respectively. The output structure is N-channel open-drain output. | | | | | SIN1,<br>AD7/P43/<br>SRDY1, | Serial I/O synchro-<br>nizing clock input/<br>output | I/O | Pins P41, P45 are also used as serial I/O synchronizing clock input/output pins Sclk1, Sclk2 respectively. The output structure is N-channel open-drain output. | | | | | P44/Sout2/<br>SDA, | Serial I/O receive<br>enable signal output | Output | Pins P43, P47 are also used as serial I/O receive enable signal output pins Shdyi, Shdyz respectively. The output structure is N-channel open-drain output. | | | | | P45/SCLK2/<br>SCL, | Special serial I/O input/output | I/O | Pins P44, P45 are also used as SDA, SCL respectively when special serial I/O is used. The output structure is N-channel open-drain output. | | | | | P46/SIN2/<br>PWM9. | Analog input | Input | Pins P42, P43 are also used as analog input pins AD8, AD7 respectively. | | | | | P47/SRDY2/<br>PWM8 | PWM output | Output | Pins P46, P47 are also used as PWM output pins PWM9, PWM8 respectively. The output structure is N-channel open-drain output. | | | | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **PIN DESCRIPTION (continued)** | R/P52,<br>G/P53, | Output port<br>P5 | Output | Ports P52–P56 are a 5-bit output port. The output structure is CMOS output. | |---------------------------|------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------| | B/P54,<br>I/P55/TIM1, | CRT output | Output | Pins P52-P56 are also used as CRT output pins R, G, B, I, OUT respectively. The output structure is CMOS output. | | OUT/P56 | Timer 1 overflow signal output | Output | Pin P5s is also used as timer 1 overflow signal output pin TIM1. The output structure is CMOS output. | | P60/PWM0-<br>P67/PWM7 | I/O port P6 | 1/0 | Port P6 is an 8-bit I/O port and has basically the same functions as port P0. The output structure is N-channel open-drain output. | | | PWM output | Output | Pins P60–P67 are also used as PWM output pins PWM0–PWM7 respectively. The output structure is CMOS output. | | AD4/P70/ | Input port P7 | Input | Ports P70, P71 are 2-bit input port. | | OSC1,<br>AD5/P71/<br>OSC2 | Clock input<br>for CRT<br>display | Input | Pin P7o is also used as CRT display clock input pin OSC1. | | | Clock output<br>for CRT<br>display | Output | Pin P71 is also used as CRT display clock output pin OSC2. The output structure is CMOS output. | | | Analog input | Input | Pins P70, P71 are also used as analog input pins AD4, AD5 respectively. | | HSYNC | Hsync input | Input | This is a horizontal synchronizing signal input for CRT display. | | VSYNC | Vsync input | Input | This is a vertical synchronizing signal input for CRT display. | | φ | Timing output | Output | This is a timing output pin. This pin has reset-out output function. The output structure is CMOS output. | | AD3/D-A | DA output | Output | This is an output pin for 14-bit PWM. The output structure is CMOS output. | | | Analog input | Input | The D-A pin is also used as analog input pin AD3. | Note: As shown in the memory map (Figure 3), port P0 is accessed as a memory at address 00C0<sub>16</sub> of zero page. Port P0 has the port P0 direction register (address 00C1<sub>16</sub> of zero page) which can be used to program each bit as an input ("0") or an output ("1"). The pins programmed as "1" in the direction register are output pins. When pins are programmed as "0," they are input pins. When pins are programmed as output pins, the output data are written into the port latch and then output. When data is read from the output pins, the output pin level is not read but the data of the port latch is read. This allows a previously-output value to be read correctly even if the output "L" voltage has risen, for example, because a light emitting cliode was directly driven. The input pins are in the floating state, so the values of the pins can be read. When data is written into the input pin, it is written only into the port latch, while the pin remains in the floating state. 6249828 0025291 85T SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER FUNCTIONAL DESCRIPTION Central Processing Unit (CPU) The M37204MC-XXXSP uses the standard 740 family instruction set. Refer to the table of 740 family addressing modes and machine instructions or the SERIES 740 <Software> User's Manual for details on the instruction set. Machine-resident 740 family instructions are as follows: The FST, SLW instruction cannot be used. The MUL, DIV, WIT and STP instruction can be used. **CPU Mode Register** The CPU mode register contains the stack page selection bit and internal system clock output selection bit. The CPU mode register is allocated at address 00FB16. Fig. 1. Structure of CPU mode register SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **MEMORY** ### Special Function Register (SFR) Area The special function register (SFR) area in the zero page contains control registers such as I/O ports and timers. #### RAM RAM is used for data storage and for stack area of subroutine calls and interrupts. #### **ROM** ROM is used for storing user programs as well as the interrupt vector area #### **RAM for Display** RAM for display is used for specifying the character codes and colors to display. #### **ROM for Display** ROM for display is used for storing character data. #### Interrupt Vector Area The interrupt vector area contains reset and interrupt vectors. #### Zero Page The 256 bytes from addresses 000016 to 00FF16 are called the zero page area. The internal RAM and the special function registers (SFR) are allocated to this area. The zero page addressing mode can be used to specify memory and register addresses in the zero page area. Access to this area with only 2 bytes is possible in the zero page addressing mode. #### **Special Page** The 256 bytes from addresses FF0016 to FFFF16 are called the special page area. The special page addressing mode can be used to specify memory addresses in the special page area. Access to this area with only 2 bytes is possible in the special page addressing mode. Fig. 2. Memory map **6249828 0025293 622** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### ■SFR area (addresses C0<sub>16</sub> to DF<sub>16</sub>) : Nothing is allocated : Fix this bit to "0" (do not write "1") 0 : "0" immediately after reset 1 : "1" immediately after reset ? : undefined immediately after reset | Addre | ess Register | Bit allocation State immediately after reset | |------------------|---------------------------------------------------------|-----------------------------------------------| | C016 | Port P0 (P0) | b7 b0 b7 b0 | | C116 | Port P0 direction register (D0) | 0016 | | C216 | Port P1 (P1) | ? | | C316 | Port P1 direction register (D1) | 0016 | | C416 | Port P2 (P2) | ? | | C516 | Port P2 direction register (D2) | 0016 | | C616 | Port P3 (P3) | 0 ? ? ? ? ? ? | | C716 | Port P3 direction register (D3) | 0 0 0 0 0 0 0 | | C816 | Port P4 (P4) | ? | | C916 | Port P4 direction register (D4) | 0016 | | CA <sub>16</sub> | Port P5 (P5) | 0 ? ? ? ? ? ? | | CB <sub>16</sub> | Port P5 control register (C5) | 000000 | | CC <sub>16</sub> | Port P6 (P6) | ? | | CD <sub>16</sub> | Port P6 direction register (D6) | 0016 | | CE16 | DA-H register (DA-H) | ? | | CF <sub>16</sub> | DA-L register (DA-L) | ? 0 ? ? ? ? ? | | D016 | PWM0 register (PWM0) | ? | | D116 | PWM1 register (PWM1) | ? | | D216 | PWM2 register (PWM2) | ? | | D316 | PWM3 register (PWM3) | ? | | D416 | PWM4 register (PWM4) | ? | | D516 | PWM output control register 1 (PW) | PW7 PW6 PW5 PW4 PW3 PW2 PW1 PW0 0016 | | D616 | PWM output control register 2 (PN) | PN4 PN3 PN2 PN1 PN0 0 0 0 0 0 0 0 0 | | D716 | Interrupt interval determination register (RI) | ? | | D816 | Interrupt interval determination conotrol register (RE) | RE4 RE3 RE2 RE1 RE0 0 0 0 0 0 0 0 0 | | D916 | Special serial I/O register (SSIO) | ? | | DA <sub>16</sub> | Special mode register 1 (SB) | SB7 SB6 SB5 SB4 SB3 SB2 SB1 SB0 0016 | | DB16 | Special mode register 2 (SC) | SC7 SC6 SC5 SC4 SC3 SC2 SC1 SC0 0016 | | DC16 | Serial I/O1 mode register (SM1) | SM15 SM14 SM13 SM12 SM11 SM10 0 0 0 0 0 0 0 | | DD <sub>16</sub> | Serial I/O1 regsiter (SIO1) | ? | | <b>DE</b> 16 | Serial I/O2 mode register (SM2) | SM25 SM24 SM23 SM22 SM21 SM20 Q Q O O O O O O | | DF16 | Serial I/O2 regsiter (SIO2) | ? | | | | | Fig. 3. Memory map of special function register (SFR) (1) **6249828 0025294 569** Fig. 4. Memory map of special function register (SFR) (2) SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### ■SFR area (addresses 20016 to 20Å16) : Nothing is allocated : Fix this bit to "0" (do not write "1") 0 : "0" immediately after reset | Addres | s Register | b7 | Bit al | locati | on | . • | . ро | | State | imm | nedia | itely | afte | er re | set<br>60 | |-------------------|--------------------------------------------|----|----------|--------|------|------|------|----|-------|-----|-------|-------|------|-------|-----------| | 20016 | | | | | | | | | | | ? | | | | | | 20116 | | | | | | | | | | | 7 | | | | | | 20216 | | | | | | | | | | | ? | | | | | | 20316 | | | | | | | | | | | 7 | | | | | | 20416 | | | | | | | | | | | 7 | | | | | | 20516 | | | | | | | | | | | ? | | | | | | 20616 | Port conotrol reigster (P7D) | | | | DA | P71 | P70 | 0 | 0 | 0 | 0.1 | | 0 | ? | ? | | 20716 | Shift register input switch register (SIC) | | | | | SIC1 | SIC0 | 0 | 0 | 0 | 0 | | 0 | 0 | 0 | | 20816 | CRT control register 2 (CBR) | | CBF | 4 CBR3 | CBR2 | CBR1 | CBR0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 20916 | CRT clock selection register (OP | ) | | | | OP11 | OP10 | 19 | 0 | 0 | 0 | | 0 | 0 | 0 | | 20A <sub>16</sub> | AD control register 2 (ADC) | | ADC5 ADC | ADC3 | ADC2 | ADC1 | ADC0 | 0 | 1/9/ | 0 | 0 | 0 | 0 | 0 | 0 | Fig. 5. Memory map of 2 page register : Nothing is allocated 1 : "1" immediately after reset ? : undefined immediately after reset Register Bit allocation b0 b0 b7 State immediately after reset b0 b0 b7 Processor status register (PS) Program counter (PCH) Program counter (PCL) Bit allocation b0 b7 State immediately after reset b0 b0 b7 Contents of address FFFF16 Contents of address FFFF16 Fig. 6. Internal state of processor status register and program counter at reset **--** 6249828 0025296 331 **--** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### INTERRUPTS Interrupts can be caused by 13 different sources consisting of 3 external, 9 internal, 1 software, and reset. Interrupts are vectored interrupts with priorities shown in Table 1. Reset is also included in the table because its operation is similar to an interrupt. When an interrupt is accepted, - The contents of the program counter and processor status register are automatically stored into the stack. - (2) The interrupt disable flag I is set to "1" and the corresponding interrupt request bit is set to "0." - (3) The jump destination address is read from and the vector address enters the program counter. Other interrupts are disabled when the interrupt disable flag is set to "1." All interrupts except the BRK instruction interrupt have an interrupt request bit and an interrupt enable bit. The interrupt request bits are in interrupt request registers 1 and 2 and the interrupt enable bits are in interrupt control registers 1 and 2. Figure 7 shows the structure of the interrupt-related registers. Interrupts other than the BRK instruction interrupt and reset are accepted when the interrupt enable bit is "1," interrupt request bit is "1," and the interrupt disable flag is "0." The interrupt request bit can be set to "0" by a program, but not set to "1." The interrupt enable bit can be set to "0" and "1" by a program. Reset is treated as a non-maskable interrupt with the highest priority. Figure 8 shows interrupt control. #### **Interrupt Causes** (1) VSYNC and CRT interrupts The VSYNC interrupt is an interrupt request synchronized with the vertical sync signal. The CRT interrupt occurs after character block display to the CRT is completed. (2) INT1, INT2 interrupts With an external interrupt input, the system detects that the level of a pin changes from "L" to "H" or from "H" to "L," and generates an interrupt request. The input active edge can be selected by bits 3 and 4 of the interrupt interval determination control register (address 00D816): when this bit is "0," a change from "L" to "H" is detected; when it is "1," a change from "H" to "L" is detected. Note that all bits are cleared to "0" at reset. (3) Timer 1, 2, 3 and 4 interrupts An interrupt is generated by an overflow of timer 1, 2, 3 or 4. (4) Serial I/O1, serial I/O2 interrupts This is an interrupt request from the clock synchronous serial I/O function. (5) f(XIN)/4096 interrupt This interrupt occurs regularly with a f(XIN)/4096 period. Set bit 0 of the PWM output control register 1 to "0." (6) BRK instruction interrupt This software interrupt has the least significant priority. It does not have a corresponding interrupt enable bit, and it is not affected by the interrupt disable flag I (non-maskable). Table 1. Interrupt vector addresses and priority | Interrupt source | Priority | Vector addresses | Remarks | |---------------------------|----------|------------------|-----------------------------------| | Reset | 1 | FFFF16, FFFE16 | Non-maskable | | CRT interrupt | 2 | FFFD16, FFFC16 | | | INT2 interrupt | 3 | FFFB16, FFFA16 | Active edge selectable | | INT1 interrupt | 4 | FFF916, FFF816 | Active edge selectable | | Serial I/O2 interrupt | 5 | FFF716, FFF616 | | | Timer 4 interrupt | 6 | FFF516, FFF416 | | | f(XIN)/4096 interrupt | 7 | FFF316, FFF216 | | | Vsync interrupt | 8 | FFF116, FFF016 | Active edge selectable | | Timer 3 interrupt | 9 | FFEF16, FFEE16 | | | Timer 2 interrupt | 10 | FFED16, FFEC16 | | | Timer 1 interrupt | 11 | FFEB16, FFEA16 | | | Serial I/O1 interrupt | 12 | FFE916, FFE816 | | | BRK instruction interrupt | 13 | FFDF16, FFDE16 | Non-maskable (software interrupt) | Flg. 7. Structure of interrupt-related registers Fig. 8. Interrupt control SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **TIMERS** The M37204MC-XXXSP has 4 timers: timer 1, timer 2, timer 3, and timer 4. All timers are 8-bit timers with the 8-bit timer latch. The timer block diagram is shown in Figure 10. All of the timers count down and their divide ratio is 1/(n+1), where n is the value of timer latch. The value is set to a timer at the same time by writing a count value to the corresponding timer latch (addresses 00F016 to 00F316: timers 1 to 4). The count value is decremented by 1. The timer interrupt request bit is set to "1" by an timer overflow at the next count pulse after the count value reaches "0016." #### (1) Timer 1 Timer 1 can select one of the following count sources: - f(XIN)/16 - f(XIN)/4096 The count source of timer 1 is selected by setting bit 0 of the timer 12 mode register (address 00F416). Timer 1 interrupt request occurs at timer 1 overflow. And besides, the timer 1 overflow signal divided by 2 (TIM1) is output from the I/P5s/TIM1 pin. #### (2) Timer 2 Timer 2 can select one of the following count sources: - f(Xin)/16 - Timer 1 overflow signal - External clock from the AD6/P32/TIM2 pin The count source of timer 2 is selected by setting bits 4 and 1 of the timer 12 mode register (address 00F416). When timer 1 overflow signal is a count source for the timer 2, the timer 1 functions as an 8-bit prescaler. Timer 2 interrupt request occurs at timer 2 overflow. #### (3) Timer 3 Timer 3 can select one of the following count sources: - f(XIN)/16 - · External clock from the P33/TIM3 pin The count source of timer 3 is selected by setting bit 0 of the timer 34 mode register 2 (address 00F516). Timer 3 interrupt request occurs at timer 3 overflow. #### (4) Timer 4 Timer 4 can select one of the following count sources: - f(XIN)/16 - f(XIN)/2 - Timer 3 overflow signal The count source of timer 3 is selected by setting bits 4 and 1 of the timer 34 mode register (address 00F516). When timer 3 overflow signal is a count source for the timer 4, the timer 3 functions as an 8-bit prescaler. Timer 4 interrupt request occurs at timer 4 overflow. And besides, the timer 4 overflow signal is also used as the clock source of special serial I/O. At reset, timers 3 and 4 are connected by hardware and "FF16" is automatically set in timer 3; "0716" in timer 4. The f(XIN) /16 is selected as the timer 3 count source. The internal reset is released by timer 4 overflow at these state, the internal clock is connected. At execution of the STP instruction, timers 3 and 4 are connected by hardware and "FF16" is automatically set in timer 3; "0716" in timer 4. However, the f(XIN) /16 is not selected as the timer 3 count source. So set bit 0 of the timer 34 mode register (address 00F516) to "0" before the execution of the STP instruction (f(XIN) /16 is selected as the timer 3 count source). The internal STP state is released by timer 4 overflow at these state, the internal clock is connected . Because of this, the program starts with stable clock. The structure of timer-related registers is shown in Figure 9. 6249828 0025299 040 Fig. 9. Structure of timer-related registers Flg. 10. Timer block diagram SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### SERIAL I/O The M37204MC-XXXSP has 2 built-in serial I/Os (serial I/O1, serial I/O2) which can either transmit or receive 8-bit data in the serial clock synchronous mode. Serial I/O1 has the same function as serial I/O2. Serial I/O1 and serial I/O2 are referred as "serial I/O1" hereafter. The serial I/O block diagram is shown in Figure 11. The synchronizing clock I/O pin (SCLKI), and data I/O pins (SOUTI, SINI), receive enable signal output pin (SRDVI) also function as port P4. Bit 2 of the serial I/O/ mode register (addresses 00DC16, 00DE16) selects whether the synchronizing clock is supplied internally or externally (from the pins P4s/SCLK2/SCL, P41/SCLK1). When an internal clock is selected, bits 1 and 0 select whether f(XIN) is divided by 4, 16, 32, or 64. To use pins for serial I/O, set the corresponding bits of the port P4 direction register (address 00C916) to "0." Also to use the serial I/O2 with internal clock, set bit 1 of the special mode register 1 (address 00DA16) to "1." The operation of the serial I/O function is described below. The function of the serial I/O differs depending on the clock source; external clock or internal clock. Fig. 11. Serial I/O block diagram SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Internal clock—the SRDV/signal goes to "H" during write cycle by writing data into the serial I/O/ register (addresses 00DD16, 00DF16). After the write cycle, the SRDV/signal goes to "L" (receive enable state). The SRDV/signal goes to "H" at the next falling edge of the transfer clock for the serial I/O/ register. The serial I/O counter *i* is set to "7" during write cycle into the serial I/O*i* register (address 00DD16), and transfer clock goes "H" forcibly. At each falling edge of the transfer clock after the write cycle, serial data is output from the SOUT*i* pin. Transfer direction can be selected by bit 5 of the serial I/O*i* mode register. At each rising edge of the transfer clock, data is input from the SIN*i* pin and data in the serial I/O*i* register is shifted 1 bit. After the transfer clock has counted 8 times, the serial I/O counter becomes "0" and the transfer clock stops at "H." At this time the interrupt request bit is set to "1." External clock—when an external clock is selected as the clock source, the interrupt request is set to "1" after the transfer clock has counted 8 times. However, transfer operation does not stop, so control the clock externally. Use the external clock of 1 MHz or less with a duty cycle of 50%. The serial I/O timing is shown in Figure 12. When using an external clock for transfer, the external clock must be held at "H" for initializing the serial I/O counter i. When switching between an internal clock and an external clock, do not switch during transfer. Also, be sure to initialize the serial I/O counter after switching. - Notes 1: On programming, note that the serial I/O counter/ is set by writing to the serial I/O register with the bit managing instructions as SEB and CLB instructions. - When an external clock is used as the synchronizing clock, write transmit data to the serial I/Oi register at "H" of the transfer clock input level. Fig. 12. Serial I/O timing (for LSB first) Fig. 13. Structure of serial I/O mode register Fig. 14. Structure of serial I/Oi mode registers SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### SPECIAL SERIAL I/O The M37204MC-XXXSP has a special serial I/O circuit that can be reception or transmission of serial data in conformity with $\rm I^2C$ (Inter IC) bus format. I<sup>2</sup>C bus is a two line directional serial bus developed by Phillips to transfer and control data among internal ICs of a machinery. Ports of special serial I/O are also used as those of serial I/O2. So special I/O cannot be used when using serial I/O2. The M37204MC-XXXSP's special serial I/O is not included the clock synchronization function and the arbitration detectable function at multi-master. Figure 15 shows the special serial I/O block diagram. Operations of master transmission and master reception with special serial I/O are explained in the following: Fig. 15. Special serial I/O block diagram #### (1) Master transmission example - ① To generate an interrupt at the end of transmission, set bit 7 of the special mode register 2 (address 00DB<sub>16</sub>) to "1" (select the special serial I/O interrupt). - ② Then set bit 3 of the interrupt control register 2 (address 00FF16) to "1" (enable the serial I/O2 interrupt). Also, set the interrupt disable flag I to "0" by the CLI instruction. - ③ The output signals SDA and SCL at the master transmission are output form ports P44 and P45. Set all bits (bits 4 and 5) corresponding to P44 and P45 of the port P4 register (address 00C816) and the port P4 direction register (address 00C916) to "1." - Set the transmission clock. The transmission clock uses the overflow signal of timer 4. Set appropriate value in timer 4 and the timer mode register 2 (For instance, if f (XIN)/2 is selected as the clock source of timer 4 and 41e is set in timer 4, the master transmission clock frequency is 25 kHz at f (XIN) = 4 MHz). - Set contents value of the special mode register 2 (address 00DB<sub>16</sub>). (Ordinary, the value is "8316") - © Set bit 3 of the serial I/O2 mode register (address 00DE16). After that set the special mode register 1 (address 00DE16). Figure 17 shows the structure of special mode registers 1 and 2. - Write the next data to be transmitted in the special serial I/O register (address 00D916). Immediately after this, set "0" to bits 0 and 1 of the serial mode register 2 to make both SDA and SCL output to "L." This is for arbitration. The start signal has been completed. The hardware automatically sends out data of 9-clock cycle. The 9th clock is for ACK reception and output level becomes "H" at this clock. If other master outputs the start signal to transmit data simultaneously with this 9th clock, it is not detected as an arbitration lost When the ACK bit has been transmitted, bit 3 of the interrupt request register 2 is set to "1" (occurrence of interrupt request), notifying the end of data transmission. - To transmit data successively, write data to be sent to the special serial I/O register, and enable an interrupt again. By repeating this procedure, unlimited number of bytes can be transmitted. - To terminate data transfer set bits 0 and 1 of the special mode register 2 to "0." - 10 Set SCL (bit 1) to "1." - ① Then SDA (bit 0) to "1." This procedure transmits the stop signal. Figure 16 shows master transmission timing explained above. SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (2) Master reception example Master reception is carried out in the interrupt processing routine after master transmission. For master transmission and interrupt occurrence thereafter, refer to the preceding section (1) Master transmission (the process until ② in Figure 16). - ② In the interrupt routine, set master reception ACK provided (2616) in the special mode register 1 (address 00DA16). - (3) Set dummy data "FF16" in the special serial I/O register (address 00D916). This sets data line SDA to "H" to receive data for 8 clocks. Then, transmit "L" to data line SDA for receiving ACK. In the ACK provided mode, the above ACK is automatically sent out. - Repeat the above receiving operation for a necessary number of times. Then return to the master transmission mode and transmit the stop signal by the same procedure for the master transmission (the process from ® to ① in Figure 16). Figure 17 shows the master reception timing. #### (3) Wait function The wait function 1 holds the SCL line at "L" after the 8th clock falls in special mode. The wait function 2 holds the SCL line at "L" after the 9th clock falls in the same way. The wait functions can be released by setting the corresponding bits 5 and 6 of the special mode register 2 to "1." Fig. 16. Timing at master transmission Fig. 17. Timing at master receive Fig. 18. Structure of special mode registers SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### (1) Serial I/O Common Transmission/Reception Mode By writing "1" to bit 0 of the serial I/O control register, signals SIN and SOUT are switched internally to be able to transmit or receive the serial data. Figure 20 shows signals on serial I/O common transmission/reception mode. Note: When receiving the serial data after writing "FF16" to the serial I/O register. Fig. 19. Structure of shift register switch register Fig. 20. Signals on serial I/O common transmission/reception mode SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### PWM OUTPUT FUNCTION The M37204MC-XXXSP is equipped with a 14-bit PWM (DA) and ten 8-bit PWMs (PWM0-PWM9). DA has a 14-bit resolution with the minimum resolution bit width of 500 ns (for f(XIN) = 4 MHz) and a repeat period of 8192 us. PWM0-PWM9 have the same circuit structure and an 8-bit resolution with minimum resolution bit width of 8 $\mu$ s (for f(XIN) = 4 MHz) and repeat period of 2048 $\mu$ s. Figure 21 shows the PWM block diagram. The PWM timing generating circuit applies individual control signals to PWM0-PWM9 using f(XIN) divided by 2 as a reference signal. (1) Data Setting When outputting DA, first set the high-order 8 bits to the DA-H register (address 00CE16), then the low-order 6 bits to the DA-L register (address 00CF16). When outputting PWM0-PWM9, set 8-bit output data in the PWMi register (i means 0 to 9; addresses 00D016 to 00D416, 00F616 to 00FA16). #### (2) Transmitting Data from Register to PWM circuit The data written to the 8-bit PWM register is transferred to the PWM latch in each 8-bit PWM cycle period. For 14-bit PWM, the data transferred in the next high-order 8-bit period after the write. The signals output to the PWM pins correspond to the contents of these latches. When data in each PWM register is read, data in these latches has already been read allowing the data output by the PWM to be confirmed. However, bit 7 of the DA-L register indicated the completion of the data transfer from the DA register to the DA latch. When bit 7 if "0," the transfer has been completed. When bit 7 is "1," the transfer has not yet begun. (3) Operating of 8-bit PWM The following is the explanation about PWM operation. At first, set the bit 0 of PWM output control register 1 (address 00D516) to "0" (at reset, bit 0 is already set to "0" automatically), so that the PWM count source is supplied. PWM0-PWM7 are also used as pins P60-P67, PWM8, PWM9 are also used as ports pins P47, P46, respectively. For PWM0-PWM7, set the corresponding bits of the ports P4 or P6 direction register to "1" (output mode). And select each output polarity by bit 3 of the PWM output control register 2(address 00D616). Then, for PWM0-PWM5, set bits 2 to 7 of the PWM output control register 1 to "1" (PWM output). For PWM6 and PWM7, set bits 0 and 1 of the PWM output control register 2 to "1." For PWM8 and PWM9, set bits 3 and 4 of the special mode register 1 and bit 4 of the serial I/O2 mode register to "1." The PWM waveform is output from the PWM output pins by setting these registers. Figure 22 shows the 8-bit PWM timing. One cycle (T) is composed of 256 (28) segments. The 8 kinds of pulses relative to the weight of each bit (bits 0 to 7) are output inside the circuit during 1 cycle. Refer to Figure 22 (a). The 8-bit PWM outputs waveform which is the logical sum (OR) of pulses corresponding to the contents of bits 0 to 7 of the 8-bit PWM register. Several examples are shown in Figure 22 (b). 256 kinds of output ("H" level area: 0/256 to 255/256) are selected by changing the contents of the PWM register. A length of entirely "H" output cannot be output, i.e. 256/256. #### (4) Operating of 14-bit PWM As with 8-bit PWM, set the bit 0 of the PWM output control register 1 (address 00D516) to "0" (at reset, bit 0 is already set to "0" automatically), so that the PWM count source is supplied. Next, select the output polarity by bit 2 of the PWM output control register 2 (address 00D616). Then, the 14-bit PWM outputs from the D-A output pin by setting bit 1 of the PWM output control register 1 to "0" (at reset, this bit already set to "0" automatically) to select the DA output. The output example of the 14-bit PWM is shown in Figure 23. The 14-bit PWM divides the data of the DA latch into the low-order 6 bits and the high-order 8 bits. The fundamental waveform is determined with the high-order 8-bit data "DH." A "H" level area with a length τ X DH("H" level area of fundamental waveform) is output every short area of "t" = $256\tau$ = 128 $\mu$ s ( $\tau$ is the minimum resolution bit width of 0.5 $\mu$ s). The "H" level area increase interval (tm) is determined with the low-order 6-bit data "DL." The "H" level are of smaller intervals "tm" shown in Table 2 is longer by $\tau$ than that of other smaller intervals in PWM repeat period "T" = 64t. Thus, a rectangular waveform with the different "H" width is output from the D-A pin. Accordingly, the PWM output changes by $\boldsymbol{\tau}$ unit pulse width by changing the contents of the DA-H and DA-L registers. A length of entirely "H" output cannot be output, i. e. 256/ 256. #### (5) Output after Reset At reset, the output of ports P60-P67, P46 and P47 are in the highimpedance state, and the contents of the PWM register and the PWM circuit are undefined. Note that after reset, the PWM output is undefined until setting the PWM register. ■ 6249828 0025309 81T Table 2. Relation between the low-order 6-bit data and high-level area increase interval | Low-order 6 bits of data | Area longer by $\tau$ than that of other tm (m = 0 to 63) | |--------------------------|------------------------------------------------------------------| | 000000 | Nothing | | 000001 | m = 32 | | 000010 | m = 16, 48 | | 000100 | m = 8, 24, 40, 56 | | 001000 | m = 4, 12, 20, 28, 36, 44, 52, 60 | | 010000 | m = 2, 6, 10, 14, 18, 22, 26, 30, 34, 38, 42, 46, 50, 54, 58, 62 | | 100000 | m = 1, 3, 5, 7, 57, 59, 61, 63 | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ■ 6249828 0025311 478 SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 23. 14-bit PWM (DA) output example (at f(XIN) = 4 MHz) **■** 6249828 0025312 304 **■** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 24. Structure of PWM-related registers 6249828 0025313 240 **1** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### A-D COMPARATOR A-D comparator consists of 6-bit D-A converter and comparator. A-D . comparator block diagram is shown in Figure 25. The reference voltage "Vref" for D-A conversion is set by bits 0 to 5 of the A-D control register 2 (address 020A16). The comparison result of the analog input voltage and the reference voltage "Vref" is stored in bit 4 of the A-D control register 1 (address 00EF16). For A-D comparison, set "0" to corresponding bits of the direction register to use ports as analog input pins. Write the data for select of analog input pins to bits 0 to 2 of the A-D control register 1 and write the digital value corresponding to Vref to be compared to the bits 0 to 5 of the A-D control register 2. The voltage comparison starts by writing to the A-D control register 2, and it is completed after 16 machine cycles (NOP instruction × 8). Fig. 26. Structure of A-D control register 1 Fig. 27. Structure of A-D control register 2 Table 3. Relation between contents of A-D control register 2 and reference voltage "Vret" | | A-[ | Reference | | | | | |-------|-------|-----------|-------|-------|-------|----------------| | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | voltage "Vref" | | 0 | 0 | 0 | . 0 | 0 | 0 | 1/128 Vcc | | 0. | 0 | 0 | 0 | 0 | 1 | 3/128 Vcc | | 0 | 0 | 0 | 0 | 1 | 0 | 5/128 Vcc | | ; | : | : | : | ÷ | ÷ | : | | 1 | 1 | 1 | 1 | 0 | 1 | 123/128 Vcc | | 1 | 1 | 1 | 1 | . 1 | 0 | 125/128 VCC | | .1 | 1 | 1 | 1 | 1 | 1 | 127/128 Vcc | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **CRT DISPLAY FUNCTIONS** (1) Outline of CRT Display Functions Table 4 outlines the CRT display functions of the M37204MC-XXXSP. The M37204MC-XXXSP incorporates a CRT display control circuit of 24 characters × 3 lines. CRT display is controlled by the CRT control register. Up to 256 kinds of characters can be displayed. The colors can be specified for each character and up to 4 kinds of colors can be displayed on one screen. A combination of up to 15 colors can be obtained by using each output signal (R, G, B and I). Characters are displayed in a 12 × 16 dots configuration to obtain smooth character patterns (refer to Figure 28). The following shows the procedure how to display characters on the CRT screen. - ① Write the display character code in the display RAM. - ② Specify the display color by using the color register. - ③ Write the color register in which the display color is set in the display RAM. - Specify the vertical position by using the vertical position register. - ⑤ Specify the character size by using the character size register. - Specify the horizontal position by using the horizontal position register. - Write the display enable bit to the designated block display flag of the CRT control register. When this is done, the CRT display starts according to the input of the VSYNC signal. The CRT display circuit has an extended display mode. This mode allows multiple lines (4 lines or more) to be displayed on the screen by interrupting the display each time one line is displayed and rewriting data in the block for which display is terminated by software. Figure 29 shows the structure of the CRT display control register. Figure 30 shows the block diagram of the CRT display control circuit. Table 4. Outline of CRT display functions | Par | ameter | Functions | | | |----------------------------|-----------------|------------------------------------------------------------------|--|--| | Number of di<br>characters | splay | 24 characters × 3 lines | | | | Dot structure | | 12 X 16 dots (refer to Figure 27) | | | | Kinds of char | acters | 256 kinds | | | | Kinds of char | acter sizes | 4 kinds | | | | Color | Kinds of colors | 1 screen : 4 kinds, maximum 15 kinds | | | | 00:01 | Coloring unit | A character | | | | Display expa | nsion | Possible (multiline display) | | | | Raster colori | ng | Possible (maximum 15 kinds) | | | | Character ba<br>coloring | ckground | Possible (A character unit, 1 screen : 1 kinds, maximum 7 kinds) | | | 6249828 0025315 013 Fig. 28. CRT display character configuration Fig. 29. Structure of CRT control register SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 30. Block diagram of CRT display control circuit 6249828 0025316 T5T 📟 SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (2) Display Position The display positions of characters are specified in units called a "block." There are 3 blocks, blocks 1 to 3. Up to 24 characters can be displayed in each block (refer to (4) Memory for Display). The display position of each block can be set in both horizontal and vertical directions by software. The display position in the horizontal direction can be selected for all blocks in common from 64-step display positions in units of 4Tc (Tc = oscillating cycle for display). The display position in the vertical direction for each block can be selected from 128-step display positions in units of 4 scanning lines. Block 2 is displayed after the display of block 1 is completed (refer to Figure 31 (a)). Accordingly, if the display of block 2 starts during the display of block 1, only block 1 is displayed. Similarly, when multiline display, block 1 is displayed after the display of block 2 is completed (refer to Figure 31 (b)). The vertical position can be specified from 128-step positions (4 scanning lines per a step) for each block by setting values "0016" to "7F16" to bits 0 to 6 in the vertical position register (addresses 00E116 to 00E316). Figure 33 shows the structure of the vertical position register. Fig. 31. Display position SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER The display position in the vertical direction is determined by counting the horizontal sync signal (HSYNC). At this time, it starts to count the rising edge (falling edge) of HSYNC signal from after about 1 machine cycle of rising edge (falling edge) of VSYNC signal. So interval from rising edge (falling edge) of VSYNC signal to rising edge (falling edge) of HSYNC signal needs enough time (2 machine cycles or more) for avoiding jitter. The polarity of HSYNC and VSYNC signals can select with the CRT port control register (address 00EC1e). For details. refer to (12) CRT Output Pin Control. Note: When bits 0 and 1 of the CRT port control register (address 00EC16) are set to "1" (negative polarity), the vertical position is determined by counting falling edge of HSYNC signal after rising edge of VSYNC control signal in the microcomputer (refer to Figure 32). Fig. 32. Supplement explanation for display position Fig. 33. Structure of vertical position register The horizontal position is common to all blocks, and can be set in 64 steps (where 1 step is 4Tc, Tc being the display oscillation period) as values "0016" to "3F16" in bits 0 to 5 of the horizontal position register (address 00E016). The structure of the horizontal position register is shown in Figure 34. Fig. 34. Structure of horizontal position register 6249828 0025318 822 SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (3) Character Size The size of characters to be displayed can be from 4 sizes for each block. Use the character size register (address 00E416) to set a character size. The character size of block 1 can be specified by using bits 0 and 1 of the character size register; the character size of block 2 can be specified by using bits 2 and 3; that in block 3 can be specified by using bits 4 and 5. Figure 35 shows the structure of the character size register. The character size can be selected from 4 sizes: minimum size, medium size, large size and extra large size. Each character size is determined by the number of scanning lines in the height (vertical) direction and the oscillating cycle for display (Tc) in the width (horizontal) direction. The minimum size consists of [1 scanning line] $\times$ [1Tc]; the medium size consists of [2 scanning lines] $\times$ [2Tc]; the large size consists of [3 scanning lines] $\times$ [3Tc]; and the extra large size consists of [4 scanning lines] $\times$ [4Tc]. Table 5 shows the relation between the set values in the character size register and the character sizes. Fig. 36. Display start position of each character size (horizontal direction) Fig. 35. Structure of character size register Table 5. Relation between set values in character size register and character sizes | Set values of cha | racter size register | Character | Width (horizontal) direction | Height (vertical) direction | | |-------------------|----------------------|-------------|-----------------------------------|-----------------------------|--| | CSn1 | CSn0 | size | Tc: oscillating cycle for display | scanning lines | | | 0 | 0 | Minimum | 1Tc | 1 | | | 0 | 1 | Medium | 2Tc | 2 | | | 1 | 0 | Large | 3TC | 3 | | | 1 | 1 | Extra large | 4Tc | 4 | | Note: The display start position in the horizontal direction is not affected by the character size. In other words, the horizontal display start position is common to all blocks even when the character size varies with each block (refer to Figure 35). SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### (4) Memory for Display There are 2 types of memory for display: CRT display ROM (addresses 200016 to 3FFF16) used to store character dot data (masked) and CRT display RAM (addresses 100016 to 10D716) used to specify the colors and characters to be displayed. The following describes each type of display memory. #### 1 ROM for display (addresses 200016 to 3FFF16) The CRT display ROM contains dot pattern data for characters to be displayed. For characters stored in this ROM to be actually displayed, it is necessary to specify them by writing the character code inherent to each character (code based on the addresses in the CRT display ROM) into the CRT display RAM. The character code list is shown in Table 6. The CRT display ROM has a capacity of 8 K bytes. Since 32 bytes are required for 1 character data, the ROM can stores up to 256 kinds of characters. The CRT display ROM space is broadly divided into 2 areas. The [vertical 16 dots] × [horizontal (left side) 8 dots] data of display characters are stored in addresses 200016 to 27FF16 and 300016 to 37FF16; the [vertical 16 dots] × [horizontal (right side) 4 dots] data of display characters are stored in addresses 280016 to 2FF16 and 380016 to 3FFF16 (refer to Figure 37). Note however that the high-order 4 bits in the data to be written to addresses 280016 to 2FFF16 and 380016 to 3FFF16 must be set to "1" (by writing data "FX16"). Fig. 37. Display character stored data **■** 6249828 0025320 480 Table 6. Character code list (partially abbreviated) | | Character data | storage address | |---------------------------------------|-------------------|--------------------------| | Character code | Left 8 dots lines | Right 4 dots lines | | | 200016 | 280016 | | 0016 | to | 280016<br>to | | 5510 | 200F16 | 280F16 | | | 201016 | 281016 | | 0116 | 201016<br>to | 281016<br>to | | 0.10 | 201F16 | 281F16 | | | 202016 | | | 0216 | 202016<br>to | 2820 <sub>16</sub><br>to | | JE.10 | 202F16 | 282F16 | | ****** | 203016 | | | 0316 | 203016<br>to | 283016<br>to | | 56.0 | 203F16 | 283F16 | | | 200110 | 2001 10 | | <del></del> | 0750.0 | 0500 | | 7 <b>E</b> 16 | 27E016<br>to | 2F0016 | | 7 - 10 | 27EF16 | to<br>2F0F16 | | | 27F016 | | | 7F16 | 27F016 | 2F10 <sub>16</sub><br>to | | 71.10 | 27FF16 | 2F1F16 | | | 300016 | 380016 | | 8016 | to | 300016<br>to | | | 300F16 | 380F16 | | | 301016 | 381016 | | 81 16 | to | - to | | | 301F16 | 381F16 | | : | | : | | · · · · · · · · · · · · · · · · · · · | 37D016 | 3FD016 | | FD16 | to | to | | | 37DF16 | 3FDF16 | | | 37E016 | 3FE016 | | FE16 | to | to | | | 37EF16 | 3FEF16 | | | 37F016 | 3FF016 | | FF16 | to | to | | | 37FF16 | 3FFF16 | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### 2 RAM for display (addresses 100016 to 10D716) The CRT display RAM is allocated at addresses 100016 to 10D716, and is divided into a display character code specification part and display color specification part for each block. Table 7 shows the contents of the CRT display RAM. For example, to display 1 character position (the left edge) in block 1, write the character code in address 100016 and write the color register No. to the low-order 2 bits (bits 0 and 1) in address 108016. The color register No. to be written here is one of the 4 color registers in which the color to be displayed is set in advance. For details on color registers, refer to (5) Color Registers. The structure of the CRT display RAM is shown in Figure 37. Table 7. Contents of CRT display RAM | Block | Display position (from left) | Character code specification | Color specification | |---------|------------------------------|------------------------------|---------------------| | Block 1 | 1st character | 100016 | 108016 | | | 2nd character | 100116 | 108116 | | | 3rd character | 100216 | 108216 | | | 22nd character | 101516 | 109516 | | | 23rd character | 101616 | 109616 | | | 24th character | 101716 | 109716 | | , | Not used | 101816 | 109816 | | | Not used | 101F16 | 109F16 | | Block 2 | 1st character | 102016 | 10A016 | | | 2nd character | 102116 | 10A116 | | | 3rd character | 102216 | 10A216 | | | 22nd character | 103516 | 10B516 | | | 23rd character | 103616 | 10B616 | | | 24th character | 103716 | 10B716 | | | Not used | 103816 | 10B816 | | | | 103F16 | 10BF16 | | Block 2 | 1st character | 104016 | 10C016 | | | 2nd character | 104116 | 10C116 | | | 3rd character | 104216 | 10C216 | | | 22nd character | 105516 | 10D516 | | | 23rd character | 105616 | 10D616 | | | 24th character | 105716 | 10D716 | | | Not used | 105816 | 10D816 | | | .,. | 107F16 | 10FF16 | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 38. Structure of RAM for display | 6249828 0025323 19T SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (5) Color Registers The color of a displayed character can be specified by setting the color to one of the 4 registers (CO0 to CO3: addresses 00E616 to 00E916) and then specifying that color register with the CRT display RAM. There are 4 color outputs; R, G, B and I. By using a combination of these outputs, it is possible to set 2<sup>4</sup>–1 (when no output) = 15 colors. However, since only 4 color registers are available, up to 4 colors can be disabled at one time. R, G, B and I outputs are set by using bits 0 to 3 in the color register. Bit 4 is used to set whether character output and blank output are enabled or not . Bit 5 is used to specify whether a character output or blank output. Figure 39 shows the structure of the color register. Fig. 39. Structure of color registers SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### (6) Character Background coloring The background part of a character (its $12 \times 16$ -dot area) can be colored as specified by bits 4 and 5 of the color registers (addresses 00E616 to 00E916) and bits 2, 3, and 4 of the CRT control register 2 (address 020816). Set "1" in bits 4 and 5 of the color register of the character whose background is to be colored, and specify the background color with bits 2, 3, and 4 of the CRT control register 2. This means that the color of the character is paired with the background color of that character, so that up to 4 color pairs can be used in each screen (7 background colors are possible). The structure of the CRT control register 2 is shown in Figure 52. Table 8. Colorling to character background by R,G,B output signals | Color register | | | RGB output | |----------------|-----------|-----------|------------| | Bit 4 (B) | Bit 3 (G) | Bit 2 (R) | Color | | 0 | 0 | 0 | Black | | 0 | 0 | 1 | Red | | 0 . | 1 | 0 | Green | | 0 | 1 | 1 | Yellow | | 1 | 0 | 0 | Blue | | 1 | - 0 | 1 | Magenta | | 1 | 1 | 0 | Cyan | | 1 | 1 | 1 | White | Note: If border and background color are applied to a character in contact with a 12 × 16 -dot frame in the same block, the border (1 dot) is protruded from the frame. Fig. 40. Display example SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (7) 1/2-character Unit Color Specification Mode By setting "1" to bit 4 of the CRT control register 1 (address 00EA16) it is possible to specify colors, in units of a 1/2-character size (16 dots high $\times$ 6 dots wide), to characters in only block 1. In the 1/2-character unit color specification mode, colors of display characters in block 1 are specified as follows: - · The color on the left side : - this is set to the color of the color register which is specified by bits 0 and 1 at the color specification addresses (addresses 108016 to 109716) in the CRT display RAM. - The color on the right side : this is set to the color of the color register which is specified by bits 2 and 3 at the color specification addresses (addresses 108016 to 109716) in the CRT display RAM. Fig. 41. Difference between ordinary color specification mode and 1/2-character unit color specification mode SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (8) Character Border Function An border of 1 clock (1 dot) equivalent size can be added to a character to be displayed in both horizontal and vertical directions. The border is output from the OUT pin. In this case, bits 4 and 5 in the $\,$ color register (the OUT pin output contents) are ignored, and the border output is from the OUT pin. Border can be specified in units of block by using the border selection register (address 00E516). The setting of the border takes priority of the setting by bit 5 of the color register, however, the border of the character to which a background color has been set cannot be output. Figure 42 shows the structure of the border selection register. Table 9 shows the relationship between the values set in the border selection register and the character border function. Fig. 43. Example of border Fig. 42. Structure of border selection register Table 9. Relationship between set value in border selection register and character border function | Border selection register | | | | |---------------------------|------|----------------------------|-----------------------------------| | MDn1 | MDn0 | Functions | Example of output | | × | 0 | Ordinary | R, G, B, I output<br>OUT output | | 0 | 1 | Border including character | R, G, B, I output | | 1 | 1 | Border only | R, G, B, I output —————OUT output | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (9) Multiline Display The M37204MC-XXXSP can ordinarily display 3 lines on the CRT screen by displaying 3 blocks at different vertical positions. In addition, it can display up to 16 lines by using CRT interrupts. A CRT interrupt request occurs at the point at which display of each block has been completed. In other words, when a scanning line reaches the point of the display position (specified by the vertical position registers) of a certain block, the character display of that block starts, and an interrupt occurs at the point at which the scanning line exceeds the block. The display block counter counts the number of times the display of a block has been completed, and its contents are incremented by 1 each time the display of one block is completed. To provide multi-line display, enable CRT interrupts by clearing the interrupt disable flag to "0" and setting the CRT interrupt enable bit (bit 4 of address 00FE16) to "1." After that, process the following sequence within the CRT interrupt processing routine: - 1) Read the value of the display block counter. - ② The block for which display is terminated (i.e., the cause of CRT interrupt generation) can be determined by the value read in ①. - ③ Replace the display character data and vertical display position of that block with the character data (contents of CRT display RAM) and vertical display position (contents of vertical position register) to be displayed next. Figure 44 shows the structure of the display block counter. Note: A CRT interrupt does not occur at the end of display when the block is not displayed. In other words, if a block is set to off display with the display control bit of the CRT control register (address 00EA16), a CRT interrupt request does not occur (refer to Figure 45). Fig. 44. Structure of display counter Fig. 45. Timing of CRT interrupt request Fig. 46. Timing of CRT interrupt request SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (10) Scanning Line Double Count Mode 1 dot in a displayed character is normally shown with 1 scanning line. In the scanning double count mode, 1 dot can be shown with 2 scanning lines. As a result, the displayed dot is extended 2 times the normal size in the vertical direction only (that is to say, the height of a character is extended twofold.) In addition, because the scanning line count is doubled, the display start position of a character becomes also twofold position in the vertical direction. In other words, the contents of the vertical position register is as follows: - In ordinary mode 256 steps as values "0016" to "FF16" (4 scanning lines per step) - In scanning line double count mode 128 steps as values "0016" to "7F16" (8 scanning lines per step) If the contents of the vertical position register for a block are set in the range of "8016" to "FF16" in the scanning line double count mode, that block cannot be displayed (not output to the CRT screen). The scanning line double count mode is specified by setting bit 6 of the CRT control register 1 (address 00EA16) to "1." Since this function works in units of a screen, even if the mode is changed during display of 1 screen, the mode before the change remains until the display of the next screen. Fig. 47. Display in ordinary mode and in scanning line double count mode SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER ### (11) Wipe Function ① Wipe mode The M37204MC-XXXSP allows the display area to be gradually expanded or shrunk in the vertically direction in units of 1H (H: HSYNC signal). There are 3 modes for this wipe method. Each mode has DOWN and UP modes, providing a total of 6 modes. Table 10 shows the contents of each wipe mode. Table 10. Wipe operation in each mode and values of wipe mode register | | Mode Wipe operation | | w | ipe mode registe | er | | |-----|---------------------|---------------------------------------|----------------------------|------------------|-------|-------| | • | · | | write operation. | Bit 2 | Bit 1 | Bit 0 | | . 1 | DOWN | Appear from upper side | A B C D E F ON Down Up | 0 | 0 | 1 | | | UP | Erase from lower side | M N O P Q R<br>S T U V W X | 1 | 0 | 1 | | 2 | DOWN | Erase from upper side | ABCDEF OFF A | 0 | 1 | 0 | | | UP | Appear from lower side | M N O P Q R<br>S T U V W X | 1 | 1 | 0 | | 3 | DOWN | Erase from both upper and lower sides | ABCDEF OFF A GHIJKL | 0 | 1 | 1. | | 3 | UP | Appear to both upper and lower sides | M N O P Q R<br>S T U V W X | 1 | 1 | | SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### 2 Wipe speed done in units of 4H only. The wipe speed is determined by the vertical synchronization (VSYNC) signal. For the NTSC interlace method, assuming that VSYNC = 16.7 ms, 262.5 HSYNC signals (per field) we obtain the wipe speed as shown in Table 11. Wipe resolution varies with each wipe mode. In mode 1 and mode 2, one of 3 resolutions (1H, 2H, 4H) can be selected. In mode 3, wipe is Table 11. Wipe speed (NTSC interlace method, H = 262.5) | Wipe resolution | Wipe speed (entire screen) | |-----------------|----------------------------------------------------------| | 1H Unit | 16.7 (ms) × 262.5 ÷ 1 ≒ 4 (s) | | 2H Unit | 16.7 (ms) × 262.5 ÷ 2 ≒ 2 (s) | | 4H Unit | $16.7 (\text{ms}) \times 262.5 \div 4 \div 1 (\text{s})$ | Table 12. Wipe mode and wipe resolution | Mode | Wipe resolution | Wipespeed | |--------|-----------------|-------------| | Mode 1 | 1H Unit | about 4 (s) | | Mode 2 | 2H Unit | about 2 (s) | | Wode 2 | 4H Unit | about 1 (s) | | Mode 3 | 4H Unit | about 1 (s) | Fig. 48. Structure of scroll mode register SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (12) CRT Output Pin Control The CRT output pins R, G, B, I and OUT can also function as ports P52, P53, P54, P55 and P56. Set the corresponding bit of the port P5 control register (address O0CB16) to "0" to specify these pins as CRT output pins, or set it to "1" to specify it as a general-purpose port P5 pins. The input polarity of signals HSYNC and VSYNC and output polarity of signals R, G, B, I and OUT can be specified with the bits of the CRT port control register (address 00EC16). Set a bit to "0" to specify positive polarity: set it to "1" to specify negative polarity. The CRT clock I/O pins OSC1, OSC2 are controlled with the port control register (address 020616). The structure of the CRT port control register is shown in Figure 49. The structure of the port control register is shown in Figure 50. Fig. 50. Structure of port control register Fig. 49. Structure of CRT port control register SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (13) Raster Coloring Function An entire screen (raster) can be colored by switching each of the R, G, B, I and OUT pins to MUTE output. R, G, B are controlled with the CRT port control register; I is controlled with the CRT control register 2; OUT is controlled with the character size register. 15 raster colors can be obtained. If the OUT pin has been set to raster coloring output, a raster coloring signal is always output during 1 horizontal scanning period. This setting is necessary for erasing a background TV image. If the R, G, and B pins have been set to MUTE signal output, a raster coloring signal is output in the part except a no-raster colored character (in Figure 50, a character "O") during 1 horizontal scanning period. This ensures that character colors do not mix with the raster color. In this case, MUTE signal is output from the OUT pin. An example in which a magenta character "I" and a red character "O" are displayed with blue raster coloring is shown in Figure 51. Fig. 52. Structure of CRT control register Fig. 51. Example of raster coloring SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### (14) Clock for Display As a clock for display to be used for CRT display, it is possible to select one of the following 3 types. - Main clock supplied from the XIN pin - Clock from the LC or RC supplied from the pins OSC1 and OSC2. - Clock from the ceramic resonator or quartz-crystal oscillator supplied from the pins OSC1 and OSC2. This clock for display can be selected for each block by the CRT clock selection register (address 020916). When selecting the main clock, set the oscillation frequency to 8 $\,\mathrm{MHz}.$ Fig. 53. Structure of CRT clock selection register Table 13. Set value of CRT clock selection register and clock for display | b1 | b0 | Functions | Scanning line double count mode flag (CC6) | |----|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------| | 0 | 0 | The clock for display is supplied by connecting RC or LC across the pins OSC1 and OSC2. | CC6 = "0" or "1" | | 0 | 1 | Since the main clock is used as the clock for display, the oscillation frequency is limited. Because of this, the character size in width (horizontal) direction is also limited. In this case, pins OSC1 and OSC2 are also used as input ports P70 and P71 respectively. | CC6 = "0" | | 1 | 0 | Do not set | | | 1 | 1 | The clock for display is supplied by connecting the following across the pins OSC1 and OSC2. • a ceramic resonator only for CRT display and a feedback resistor • a quartz-crystal oscillator only for CRT display and a feedback resistor (Note) | | Note: It is necessary to connect other ceramic resonator or quartz-crystal oscillator across the pins XIN and XOUT. 6249828 0025334 T75 ■ SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER # INTERRUPT INTERVAL DETERMINATION FUNCTION The M37204MC-XXXSP incorporates an interrupt interval determination circuit. This interrupt interval determination circuit has an 8-bit binary up counter as shown in Figure 53. Using this counter, it determines an interval on the INT1 or INT2 (refer to Figure 55). The following describes how the interrupt interval is determined. - The interrupt input to be determined (INT1 input or INT2 input) is selected by using bit 2 in the interrupt interval determination control register (address 00D816). When this bit is cleared to "0," the INT1 input is selected; when the bit is set to "1," the INT2 input is selected. - When the INT1 input is to be determined, the polarity is selected by using bit 3 of the interrupt interval determination control register; when the INT2 input is to be determined, the polarity is selected by using bit 4 of the interrupt interval determination control register. - When the relevant bit is cleared to "0," determination is made of the interval of a positive polarity (rising transition); when the bit is set to "1," determination is made of the interval of a negative polarity (falling transition). - The reference clock is selected by using bit 1 of the interrupt interval determination control register. When the bit is cleared to "0," a - $64 \mu s$ clock is selected; when the bit is set to "1," a $32 \mu s$ clock is selected (based on an oscillation frequency of 4MHz in either case). - Simultaneously when the input pulse of the specified polarity (rising or falling transition) occurs on the INT1 pin (or INT2 pin), the 8-bit binary up counter starts counting up with the selected reference clock (64 μs or 32 μs). - 5. Simultaneously with the next input pulse, the value of the 8-bit binary up counter is loaded into the interrupt interval determination register (address 00D716) and the counter is immediately reset ("0016"). The reference clock is input in succession even after the counter is reset, and the counter restarts counting up from "0016." - 6. When count value "FE16" is reached, the 8-bit binary up counter stops counting. Then, simultaneously when the next reference clock is input, the counter sets value "FF16" to the interrupt interval determination register. The reference clock is generated by setting bit 0 of the PWM output control register 1 to "0." 6249828 0025335 901 SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 54. Block diagram of interrupt interval determination circuit Fig. 55. Structure of interrupt interval determination control register Fig. 56. Measuring interval SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### RESET CIRCUIT The M37204MC-XXXSP is reset according to the sequence shown in Figure 57. It starts the program from the address formed by using the content of address FFFF16 as the high-order address and the content of the address FFFE16 as the low-order address, when the RESET pin is held at "L" level for 2 $\mu$ s or more while the power source voltage is 5 V $\pm$ 10 % and the oscillation of a quartz-crystal oscillator or a ceramic resonator is stable and then returned to "H" level. The internal state of microcomputer at reset are shown in Figures 3 to 6. An example of the reset circuit is shown in Figure 58. The reset input voltage must be kept 0.6 V or less until the power source voltage surpasses 4.5 V. Fig. 58. Example of reset circuit Fig. 57. Reset sequence SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER rig. 59. 10 pin block diagram (1) SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER Fig. 60. I/O pin block diagram (2) 6249828 DD25339 557 **■** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **CLOCK GENERATING CIRCUIT** The built-in clock generating circuit is shown in Figure 63. When the STP instruction is executed, the internal clock $\phi$ stops at "H" level. At the same time, timers 3 and 4 are connected in hardware and "FF16" is set in the timer 3, "0716" is set in the timer 4. Select f(XIN)/16 as the timer 3 count source (set bit 0 of the timer 34 mode register to "0" before the execution of the STP instruction). And besides, set timer 3 and timer 4 interrupt enable bits to disabled ("0") before execution of the STP instruction. This connection is released when an external interrupt is accepted or at reset. The oscillator restarts when external interrupt is accepted, however, the internal clock $\phi$ keeps its "H" level until timer 4 overflows. Because this allows time for oscillation stabilizing when a ceramic resonator or a quartz-crystal oscillator is used. When the WIT instruction is executed, the internal clock $\phi$ stops in the "H" level but the oscillator continues running. This wait state is released when an interrupt is accepted (Note). Since the oscillator does not stop, the next instruction can be executed at once. When returning from the stop or the wait state, to accept an interrupt, set the corresponding interrupt enable bit to "1" before executing the STP or the WIT instructions. The circuit example using a ceramic resonator (or a quartz-crystal oscillator) is shown in Figure 61. Use the circuit constants in accordance with the resonator manufacture's recommended values. The circuit example with external clock input is shown in Figure 62. Input the clock to the XIN pin, and open the XOUT pin. Note: In the wait mode, the following interrupts are invalid. - (1) VSYNC interrupt - (2) CRT interrupt - (3) Timer 2 interrupt using AD6/P32/TIM2 pin input as count source - (4) Timer 3 interrupt using P33/TIM3 pin input as count source - (5) Timer 4 interrupt using f(XIN)/2 as count source Fig. 61. Ceramic resonator circuit example Fig. 62. External clock input circuit example Fig. 63. Clock generating circuit block diagram SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **DISPLAY OSCILLATION CIRCUIT** The CRT display clock oscillation circuit has a built-in clock oscillation circuits, so that a clock for CRT display can be obtained simply by connecting an LC, an RC, a quartz-crystal oscillator or a ceramic resonator across the pins OSC1 and OSC2. Select the clock for display with bits 0 and 1 of the CRT clock selection register (address 020916). Fig. 64. Display oscillation circuit #### **AUTO-CLEAR CIRCUIT** When power source is supplied, the auto-clear function can be performed by connecting the following circuit to the RESET pin. Fig. 65. Auto-clear circuit example #### ADDRESSING MODE The memory access is reinforced with 17 kinds of addressing modes. Refer to the SERIES 740 <Software> User's Manual for details. #### **MACHINE INSTRUCTIONS** There are 71 machine instructions. Refer to the SERIES 740 <Software> User's Manual for details. #### PROGRAMMING NOTES - (1) The divide ratio of the timer is 1/(n+1). - (2) Even though the BBC and BBS instructions are executed immediately after the interrupt request bits are modified (by the program), those instructions are only valid for the contents before the modification. At least one instruction cycle is needed (such as an NOP) between the modification of the interrupt request bits and the execution of the BBC and BBS instructions. - (3) After the ADC and SBC instructions are executed (in decimal mode), one instruction cycle (such as an NOP) is needed before the SEC, CLC, or CLD instruction is executed. - (4) An NOP instruction is needed immediately after the execution of a PLP instruction. - (5) In order to avoid noise and latch-up, connect a bypass capacitor (~ 0.1 µF) directly between the Vcc pin–Vss pin and the Vcc pin– CNVss pin using a thick wire. - (6) Note that the addresses of the M37204MC-XXXSP are different from the addresses of the M37204M8-XXXSP. 6249828 0025341 105 **E** SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### DATA REQUIRED FOR MASK ORDERS The following are necessary when ordering a mask ROM production: - (1) Mask ROM Order Confirmation Form - (2) Mark Specification Form - (3) Data to be written to ROM, in EPROM form (28-pin DIP type 27512, three identical copies) #### **PROM Programming Method** The built-in PROM of the One Time PROM version (blank) and built-in EPROM version can be read or programmed with a general-purpose PROM programmer using a special programming adapter. | | A STATE OF THE STA | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Product | Name of Programming Adapter | | M37204ECSP | PCA4762 | The PROM of the One Time PROM version (blank) is not tested or screened in the assembly process and following processes. To ensure proper operation after programming, the procedure shown in Figure 66 is recommended to verify programming. Fig. 66. Programming and testing of One Time PROM version SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### **ABSOLUTE MAXIMUM RATINGS** | Symbol | | Parameter | Conditions | Ratings | Unit | |--------|-----------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------------|-------------------|------| | Vcc | Power source voltage | Vcc | All voltages are based | -0.3 to 6 | | | Vı | Input voltage | CNVss | on Vss. Output transistors are | -0.3 to 6 | V | | Vı | Input voltage | P00-P07, P10-P17, P20-P27,<br>P30-P36, P40-P47, P60-P67,<br>P70, P71,OSC1, XIN, HSYNC,<br>VSYNC, RESET, AD1-AD8 | cut off. | -0.3 to Vcc + 0.3 | ٧ | | Vo | Output voltage | P00-P07, P10-P17, P20-P27,<br>P30-P36, P40-P45, R, G, B, I,<br>OUT, D-A, XOUT, OSC2 | | -0.3 to Vcc + 0.3 | ٧ | | Vo | Output voltage | P46, P47, P60-P67 | | -0.3 to 13 | V | | ЮН | Circuit current | R, G, B, I, OUT, P00–P07,<br>P10–P17, P20–P27, P30, P31,<br>D-A | | 0 to 1 (Note 1) | mA | | lOL1 | Circuit current | R, G, B, I, OUT, P00–P07,<br>P10–P17, P20–P23,P30–P36,<br>P40–P43, D-A | | 0 to 2 (Note 2) | mA | | lOL2 | Circuit current | P46, P47, P60-P67 | | 0 to 1 (Note 2) | mA | | lol3 | Circuit current | P24-P27 | | 0 to 10 (Note 3) | mA | | lOL4 | Circuit current | P44, P45 | | 0 to 3 (Note 2) | mA | | Pd | Power dissipation | | Ta = 25 °C | 550 | mW | | Topr | Operating temperature | , | | -10 to 70 | °C | | Tstg | Storage temperature | | | -40 to 125 | °C | # **RECOMMENDED OPERATING CONDITIONS** ( $T_a = -10$ °C to 70 °C, VCC = 5 V $\pm$ 10 %, unless otherwise noted) | Symbol | | arameter | | Limits | | | Limia | |--------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------|------|---------|-------| | | | | | Min. | Тур. | Max. | Unit | | Vcc | Power source voltage (Note 4), Duri | ng CPU, CRT o | peration | 4.5 | 5.0 | 5.5 | V | | Vss | Power source voltage | | | 0 | 0 | 0 | V | | ViH1 | "H" input voltage | P40-P43, P46, | P17, P20-P27, P30-P36,<br>P47, P60-P67, P70, P71,<br>RESET, XIN, OSC1 | 0.8Vcc | | Vcc | ٧ | | VIH2_ | "H" input voltage | P44, P45 | | 0.7Vcc | 7. | Vcc | V | | VIL1 | "L" input voltage | P00-P07, P10-<br>P40-P47, P60- | P17, P20–P27, P30–P36,<br>P67, P70, P71 | 0 | | 0.4 Vcc | ٧ | | VIL2 | "L" input voltage | HSYNC, VSYNC, RESET, TIM2, TIM3, INT1,<br>INT2, SOUT1, SCLK1, SIN1, SDA, SCL, XIN, OSC1 | | 0 | | 0.2 Vcc | ٧ | | Юн | "H" average output current (Note 1) | R, G, B, I, OUT, D-A, P00-P07, P10-P17, P20-P27, P30, P31 | | | | 1 | mA | | lOL1 | "L" average output current (Note 2) | R, G, B, I, OUT, D-A, P00–P07, P10–P17, P20–P23, P30–P36, P40–P43 | | | | 2 | mA | | lors | "L" average output current (Note 2) | | | | | 1 | mA | | IOL3 | "L" average output current (Note 3) | | | | | 10 | mA | | IOL4 | "L" average output current (Note 2) | The state of s | | | | 3 | mA | | fCPU | Oscillation frequency (for CPU operation | | | 3.6 | 4.0 | 8.1 | MHz | | fCRT | Oscillation frequency (for CRT displi | | | 6.0 | 7.0 | 8.0 | kHz | | | | , | In double count mode | 12.0 | 13.0 | 14.0 | MHz | | fhs1 | Input frequency | TIM2, TIM3, IN | | | | 100 | kHz | | fhs2 | Input frequency | SCLK1, SCLK2 | | 1 | | 1 | MHz | 6249828 0025343 T88 M SINGLE-CHIP 8-BIT CMOS MICROCOMPUTER for VOLTAGE SYNTHESIZER and ON-SCREEN DISPLAY CONTROLLER #### ELECTRIC CHARACTERISTICS (Vcc = 5 V ± 10 %, Vss = 0 V, f(XIN) = 4 MHz, Ta = -10 °C to 70 °C, unless otherwise noted) | | Parameter | | Test conditions | | Limits | | | Unit | |--------------|-----------------------------------------------|--------------------------------------------------------------|--------------------------------|----------|--------|------|------|---------| | Symbol | Parame | ter | l est cor | aditions | Min. | Typ. | Max. | ייייט ך | | Icc | Power source current | System operation | VCC = 5.5 V,<br>f(XIN) = 4 MHz | CRT OFF | | 10 | 20 | mA | | | | | | CRT ON | | 20 | 50 | ] | | | | | VCC = 5.5 V,<br>f(XIN) = 8 MHz | CRT OFF | | 20 | 40 | ] | | | · | | | CRT ON | | 30 | 60 | ] | | | | Stop mode | VCC = 5.5 V,<br>f(XIN) =0 | | , | | 300 | μA | | Voн | | , I, OUT, P00-P07,<br>I7, P20-P27, D-A, P30, | VCC = 4.5 V<br>IOH = -0.5 mA | | 2.4 | | | · v | | VoL | | i, I, OUT, P00P07,<br>17, P20P23, P30P36, ,<br>13, D-A | VCC = 4.5 V<br>IOL = 0.5 mA | | | | 0.4 | | | | "L" output voltage P46, P | 17, P60–P67 | VCC = 4.5 V<br>IOL = 0.5 mA | | | | 0.4 | V | | | "L" output voltage P24-P | 27 | VCC = 4.5 V<br>IOL = 10.0 mA | | | | 3.0 | 1 | | | "L" output voltage P44, P | 15 | VCC = 4.5 V<br>IOL = 3.0 mA | | | | 0.4 | ] . | | VT+-VT- | Hysteresis RESE | | Vcc = 5.0 V | | | 0.5 | 0:7 | V | | | | VSYNC, P32-P34, P36,<br>12, P44-P46 | VCC = 5.0 V | | | 0.5 | 1.3 | 1 | | lizh | "H" input leak current RESE<br>P20-P<br>AD1-A | 27, P30-P36, P40-P45, | VCC = 5.5 V<br>VI = 5.5 V | | | | 5 | μΑ | | lizL | | F, P00–P07, P10–P17,<br>27, P30–P36, P40–P47,<br>57, AD1–AD8 | VCC = 5.5 V<br>VI = 0 V | - | | | 5 | μA | | <b>I</b> OZH | "H" output leak current P46, | P47, P60-P67 | VCC = 5.5 V<br>VO = 12 V | | | | 10 | μA | Notes 1: The total current that flows out of the IC must be 20 mA or less. - 2: The total input current to IC (IOL1 + IOL2 + IOL4) must be 30 mA or less. - 3: The total average input current for ports P24-P27 to IC must be 20 mA or less. - 4: Connect 0.022 μ F or more capacitor externally across the power source pins Vcc–Vss so as to reduce power source noise. Also connect 0.068 μ F or more capacitor externally across the pins Vcc–CNVss. - 5: Use a quartz-crystal oscillator or a ceramic resonator for the CPU oscillation circuit. - 6: Use a RC or an LC for the CRT oscillation circuit. - 7: P32–P34 ,P36 have the hysteresis when these pins are used as interrupt input pins or timer input pins. P40–P42, P44–P46 have the hysteresis when these pins are used as serial I/O pins. 6249828 0025344 914 🗖 # M5M44100BJ,L,TP,RT-5,-6,-7,-8,-5S,-6S,-7S,-8S #### FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT)DYNAMIC RAM Note 28. Self refresh sequence Two refreshing ways should be used properly depending on the low pulse width (trass) of RAS signal during self refresh period. - 1. In case of trass < 300ms - 1.1 Distriduted refresh during Read/Write operation - (A) Timing Diagrams Table 2 | Read/Write Cycle | Read/Write→<br>Self Refresh | Self Refresh→<br>Read/Write | | |---------------------------------|-----------------------------|-----------------------------|--| | CBR distributed refresh | tnsD + tsnD ≤ 16.4ms | | | | RAS only<br>distributed refresh | tnsD ≦ 16 μ s | tsND ≦ 16 μs | | #### (B) Definition of refresh #### Definition of CBR distributed refresh The CBR distributed refresh performs more then 1024 discrete CBR cycles within 16.4 ms. ### Definition of RAS only distributed refresh All combination of ten row address signals ( $A_0 \sim A_9$ ) are selected during 1024 discrete $\overline{RAS}$ only refresh cycles within 16.4 ms. #### 1.1.1 CBR distributed Refresh - Switching from read/write operation to self refresh operation. The time interval from the falling edge of RAS signal in the last CBR refresh cycle during read/write operation period to the falling edge of RAS signal at the start of self refresh operation should be set within tNSD(shown in table 2). - Switching from self refresh operation to read/write operation. The time interval from the rising edge of RAS signal at the end of self refresh operation to the falling edge of RAS signal in the first CBR refresh cycle during read/write operation period should be set within tsnp(shown in table 2). #### 1.1.2 RAS only distributed refresh - Switching from read/write operation to self refresh operation. The time interval this from the falling edge of RAS signal in the last RAS only refresh cycle during read/write operation period to the falling edge of RAS signal at the start of self refresh operation should be set within 16 µs. - Switching from self refresh operation to read/write operation. The time interval tsND from the rising edge of RAS signal at the end of self refresh operation to the falling edge of RAS signal in the first CBR refresh cycle during read/write operation period should be set within 16 μs. # M5M44100BJ,L,TP,RT-5,-6,-7,-8,-5S,-6S,-7S,-8S #### FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT)DYNAMIC RAM #### 1.2 Burst refresh during Read/Write operation #### (A) Timing diagram #### Table 3 | Read/Write Cycle | Read / Write →<br>Self Refresh | Self Refresh→<br>Read/Write | | | | |------------------------|--------------------------------|-----------------------------|--|--|--| | CBR burst<br>refresh | tNSB ≦ 16.4ms | tsnB ≦ 16.4ms | | | | | RAS only burst refresh | tnsB + tsnB ≤ 16.4ms | | | | | # (B) Definition of burst refresh Definition of CBR burst refresh The CBR burst refresh performs more then 1024 continuous CBR cycles within 16.4ms. #### Definition of RAS only burst refresh All combination of ten row address signals (Ao~A9) are selected during 1024 continuous RAS only refresh cycles within 16.4 ms. #### 1.2.1 CBR distributed Refresh - Switching from read/write operation to self refresh operation. The time interval tyse from the falling edge of RAS signal in the first CBR refresh cycle during read/write operation period to the falling edge of RAS signal at the start of self refresh operation should be set within 16.4 ms. - Switching from self refresh operation to read/write operation. The time interval tsns from the rising edge of RAS signal at the end of self refresh operation to the falling edge of RAS signal in the last CBR refresh cycle during read /write operation period should be set within 16.4 ms. #### 1.2.2 RAS only distributed refresh - Switching from read/write operation to self refresh operation. The time interval from the falling edge of RAS signal in the first RAS only refresh cycle during read/write operation period to the falling edge of RAS signal at the start of self refresh operation should be set within tNSB (shown in table 3). - Switching from self refresh operation to read/write operation. The time interval from the rising edge of RAS signal at the end of self refresh operation to the falling edge of RAS signal in the last RAS only refresh cycle during read/ write operation period should be set within tsnB (shown in table 3). # M5M44100BJ,L,TP,RT-5,-6,-7,-8,-5S,-6S,-7S,-8S #### FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT)DYNAMIC RAM # In case of tRASS ≥ 300ms (A) Timing diagram #### Table 4 | Read/Write | Self Refresh→Read/Wirte | |-----------------------------------------------------------------------------------------------|-------------------------| | CBR distributed refresh RAS only distributed refresh CBR burst refresh RAS only burst refresh | tref ≤ 16.4ms | (B) Definition of refresh The same as 1.1-(B) and 1.2-(B) #### 2.1 Regardless of the refresh (CBR distributed refresh, RAS only distributed refresh, CBR burst refresh, RAS only burst refresh) during Read/Write operation the minimum of 1024 cycles refresh should be preformed within 16.4 ms from the rising edge of RAS signal at the end of self refresh operation.