CMOS 8-Bit Single-Chip Microcontroller # **MSM80C31 MSM80C51** USER'S MANUAL First Edition December 1985 TRONIC 38, RUE DU VIEUX PONT DE SEVRES 92100 BOULOGNE TÉL. (1) 46 21 68 69 TÉLEX 203073 TÉLÉFAX (1) 46 09 99 92 # **MSM80C31 MSM80C51** **USER'S MANUAL** ### **CONTENTS** | PR | EFACE | |----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1. | INTRODUCTION 1.1 MSM80C31/MSM80C51 Outline 1.2 MSM80C31/MSM80C51 Features | | 2. | MSM80C31/MSM80C51 SYSTEM CONFIGURATION 2.1 MSM80C31/MSM80C51 Logic Symbols 2.2 MSM80C31/MSM80C51 Pin Layout 2.2.1 External dimensions 2.3 MSM80C31 Internal Block Diagram 2.4 MSM80C51 Internal Block Diagram 2.5 Timing and Control 2.5.1 Outline of MSM80C31/MSM80C51 timing 2.5.2 Major Synchronizing signals 2.5.3 MSM80C31 fundamental operation time chart 2.5.4 MSM80C31 fundamental operation time chart 2.5.4 MSM80C51 fundamental operation time chart 2.6 Instruction Register (IR) and Instruction Decoder (PLA) 2.7 Arithmetic Operation Section 2.8 Program Counter 2.9 Program Memory and External Data Memory 2.9.1 MSM80C31/MSM80C51 program area and external ROM connections 2.9.2 Procedures and circuit connections used when external data memory (RAM) is read/written by data pointer 2.9.3 Procedures and circuit connections used when external data memory (RAM) is read/written by resister R0 and R1 | | 3. | MSM80C31/MSM80C51 CONTROL 32 3.1 Oscillators: XTAL 1·2 32 3.2 CPU Resetting 32 3.2.1 Outline 34 3.2.2 Reset schmitt trigger circuit 35 3.2.3 CPU reset internal status 40 3.3 EA (CPU Memory Separate) 41 3.3.1 Outline 41 | | 4. | MSM80C31/MSM80C51 INTERNAL SPECIFICATIONS 4.1 Internal Data Memory (RAM) and Special Function Registers (SFR) 4.1.1 Outline 4.2 Internal Data Memory (RAM) 4.2.1 Internal data memory (RAM) 4.2.2 Internal data memory registers R0 thru R7 4.2.3 Stack 4.4 | | 4.3 Internal Data Memory (RAM) Operating Procedures | 50 | |--------------------------------------------------------------------|----| | 4.3.1 Internal data memory indirect addressing | 50 | | 4.3.2 Internal data memory register R0 thru R7 designation | 51 | | 4.3.3 Internal data memory 1-bit data designation | 52 | | 4.4 Special Function Registers (TCON, SCON, ACC, B) | 54 | | 4.4.1 Outline | 54 | | 4.4.2 Special function registers | 56 | | 4.4.2.1 Timer mode register (TMOD) | 56 | | 4.4.2.2 Power control register (PCON) | 57 | | 4.4.2.3 Timer control register (TCON) | 58 | | 4.4.2.4 Serial port control register (SCON) | 59 | | 4.4.2.5 Interrupt enable register (IE) | 60 | | 4.4.2.6 Interrupt priority register (IP) | 61 | | 4.4.2.7 Program status word register (PSW) | 62 | | 4.5 Timer/Counters 0 and 1 | 63 | | 4.5.1 Outline | 63 | | 4.5.2 Timer/counter 0 and 1 counting control | 63 | | 4.5.3 Timer/counter 0 and 1 clock designation | 65 | | 4.5.3.1 External clock detector circuit for timer/counters 0 and 1 | 65 | | 4.5.4 Counting control of timer/counters 0 and 1 by INT pin | 67 | | 4.5.5 Timer/counters 0/1 and timer modes | 69 | | 4.5.5.1 Outline | 69 | | 4.5.5.2 Mode 0 | 69 | | 4.5.5.3 Mode 1 | 71 | | 4.5.5.4 Mode 2 | 73 | | 4.5.5.5 Mode 3 | 75 | | 4.5.6 Timer/counter carry signal detector circuit | 76 | | 4.6 Serial Port | 77 | | 4.6.1 Outline | 77 | | 4.6.2 Special function registers for serial port | 78 | | 4.6.2.1 SCON (serial port control register) | 78 | | 4.6.2.2 SBUF (serial port buffer register) | 79 | | 4.6.2.3 SMOD (double baud rate bit) | 79 | | 4.6.3 Operating modes | 80 | | 4.6.3.1 Mode 0 | 80 | | 4.6.3.1.1 Outline | 80 | | 4.6.3.1.2 Mode 0 baud rate | 80 | | 4.6.3.1.3 Mode 0 output operation | 80 | | 4.6.3.1.4 Mode 0 input operation | 80 | | 4.6.3.2 Mode 1 | 84 | | 4.6.3.2.1 Outline | 84 | | 4.6.3.2.2 Mode 1 baud rate | 84 | | 4.6.3.2.3 Mode 1 transmit operation | 84 | | 4 6 3 2 4 Mode 1 receive operation | 87 | | 4.6.3.3 Mode 2 | 88 | |-----------------------------------------------------------------------|-----| | 4.6.3.3.1 Outline | 88 | | 4.6.3.3.2 Mode 2 baud rate | 88 | | 4.6.3.3.3 Mode 2 transmit operation | 88 | | 4.6.3.3.4 Mode 2 receive operation | 88 | | 4.6.3.4 Mode 3 | 92 | | 4.6.3.4.1 Outline | 92 | | 4.6.3.4.2 Mode 3 baud rate | 92 | | 4.6.3.4.3 Mode 3 transmit operation | 92 | | 4.6.3.4.4 Mode 3 receive operation | 95 | | 4.6.4 Serial port application examples | 96 | | 4.6.4.1 I/O extension | 96 | | 4.6.4.2 Multi-processor systems | 100 | | 4.7 Interrupts | 102 | | 4.7.1 Outline | 102 | | 4.7.2 Interrupt enable register (IE) | 104 | | 4.7.3 Interrupt priority register (IP) | 105 | | 4.7.3.1 Priority interrupt process flow | 106 | | 4.7.3.2 Interrupt priority when priority register (IP) contents | | | are all "0" | 107 | | 4.7.4 Detection of external interrupt signals INTO and INT1 | 108 | | 4.7.4.1 Outline of INT signal detection | 108 | | 4.7.4.2 External interrupt signal 0 and 1 level detection | 108 | | 4.7.4.3 External interrupt signal 0 and 1 trigger detection | 110 | | 4.7.5 MSM80C31/MSM80C51 interrupt response time charts | 111 | | 4.7.5.1 Interrupt response time chart when interrupt conditions | | | are satisfied during execution of ordinary instruction | 111 | | 4.7.5.2 Interrupt response time chart when interrupt conditions | | | are satisfied during execution of IE or IP register | | | operation instruction | 112 | | 4.7.5.3 Interrupt response time chart when an ordinary instruction is | | | executed after temporarily returning to the main routine from | | | continuous interrupt processing | 113 | | 4.7.5.4 Interrupt response time chart when an IE or IP manipulating | | | instruction is executed after temporarily returning to the main | | | routine from continuous interrupt processing | 114 | | 4.8 CPU "Power Down" | 115 | | 4.8.1 Outline | 115 | | 4.8.2 Idle mode (IDLE) setting | 115 | | 4.8.3 Power down mode (PD) setting | 119 | | 4.9 CPU Power Down (IDLE and PD) Cancellation (CPU Activation) | 123 | | 4.9.1 Outline | 123 | | 4.9.2 Cancellation by CPU resetting | 123 | | 4.9.3 Reactivation of CPU by an interrupt | 128 | | | ~ | | 5. | INPUT/OUTPUT PORTS 5.1 Outline 5.2 Port 0 5.3 Port 1 5.4 Port 2 5.5 Port 3 5.6 Port Output Timing 5.7 Port Data Manipulating Instructions | 132<br>132<br>132<br>134<br>137<br>139<br>141<br>143 | |----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 6. | MSM80C31/MSM80C51 ELECTRICAL CHARACTERISTICS 6.1 Absolute Maximum Ratings 6.2 Operation Ranges 6.3 DC Characteristics 6.4 External Program Memory Access AC Characteristics 6.5 External Data Memory Access AC Characteristics 6.6 Serial Port (I/O Extension Mode) AC Characteristics 6.7 AC Characteristics Measuring Conditions | 154<br>156 | | 7. | 7.1 Outline 7.2 Description of Instruction Symbols 7.3 List of Instructions 7.4 Simplified Description of Instructions 7.5 Detailed Description of MSM80C31/MSM80C51 Instructions | 159<br>160<br>161<br>173 | | 8. | MSM80C51VS PIGGT DACK | | #### **PREFACE** This manual describes the hardware and instructions for the MSM80C51RS, MSM80C51GS, MSM80C51JS, MSM80C31RS, MSM80C31GS, MSM80C31JS, and MSM80C51VS #### CMOS 8-bit microcontrollers. 37 39 ‡1 ‡3 16 16 16 17 50 52 54 56 36 58 59 60 61 )2 | RS | 40-pin plastic DIP package | |----|----------------------------------------------| | GS | 44-pin plastic flat package | | JS | 44-pin PLCC package | | VS | 40-pin ceramic DIP package (Piggy-back type) | These microcontrollers are represented in the manual by MSM80C31/ MSM80C51. # 1. INTRODUCTION #### 1. INTRODUCTION #### 1.1 MSM80C31/MSM80C51 Outline MSM80C31/MSM80C51 are single-chip 8-bit microcontrollers featuring high performance and low power consumption. 2 $\mu$ m silicon gate processing technology has been used in the manufacture of these microcontrollers. MSM80C31 is the same as MSM80C51 but without the internal program memory (ROM). MSM80C51VS is a device whose internal program memory is replaced by external EPROM which is piggy backed to the CPU. While the MSM80C51 microcontroller features an additional 4096-word $\times$ 8-bit program memory (ROM) mounted on a single chip, both the MSM80C31 and MSM80C51 include a 128-word $\times$ 8-bit data memory (RAM), 32 input/output ports, two 16-bit R/W timer/counters, five interrupts, a serial I/O, an 8-bit parallel processing circuit, and a clock generator integrated on a single chip. The internal operation in these CPUs is based on an instruction code address method for greater efficiency. The operations are specified in the instruction code (OP) section, and the objective registers are specified by part of the instruction code (OP) and the second or third byte following the instruction code. A feature of this method is the ability to enable several operations by only changing the operation register designation in a single instruction code. The inclusion of 8-bit multiplication and division instructions further increases the processing capacity of these CPUs. In addition to expansion of the bit processing area, a comprehensive range of bit processing instructions has also been included. Processing operations include logical processing of carry flag and specified bit within each register, transfer between carry flag and specified bit in certain register, setting, resetting, and complement of specified bit in each register, and execution of various bit tests within a wide area. To make a relative jump after the execution of a branch instruction (bit test instruction), jumps can be made within a wide address range between $-128 \sim +127$ relative to the address of the instruction. There is no page field restriction as in previous systems. (Jumps are made within pages in other systems.) The contents of specified registers can be saved in stack by using the PUSH instruction, and the saved contents can be returned from stack to specified register by the POP instruction. Allocation of absolute interrupt priority to any interrupt makes interrupt processing all the easier. Employing the low-power consumption feature of C-MOS devices, these CPUs are designed to operate in "CPU power down" modes. In idle mode (IDLE) the IDL bit in the power control register (PCON) is set to "1" to halt CPU operations while continuing XTAL1 and XTAL2 operations. In the power down mode (PD) the PD bit in the power control register (PCON) is set to "1" to halt CPU operations as well as the XTAL1 and XTAL2 operations. The CPU power down mode can be cancelled by a reset or an interrupt. Two built-in 16-bit timer/counters capable of a wide range of operational mode enable the CPUs to be used in many different ways. UART based serial interface can be executed at any baud rate by clock signals from timer/counter 1. The comprehensive range of functions on this CPU gives a highly integrated high performance solution in a very short time. #### 1.2 MSM80C31/MSM80C51 Features - Si gate C-MOS - Program memory (ROM) 4096 words×8 bits (MSM80C51) - Data memory (RAM) 128 words × 8 bits - Stack n Ν а d a١ d st 7 е g er d n е m Freely usable 128-word × 8-bit data memory area - Four sets of working registers (R0 thru R7×4) - Five types of interrupts (with priority) - (1) Two external interrupts - (2) Two timer interrupts - (3) Serial port interrupt - External data memory (RAM) Up to 64K bytes - External program memory Up to 64K bytes - Four Input/Output ports (8-bit×4) - CPU power down function - (1) Idle mode: CPU stopped while XTAL1 · 2 operations continued. (Software setting) - (2) Power Down mode: CPU and XTAL1 · 2 all stopped. (Software setting) - Two 16-bit timers/counters Timer mode - 1) 8-bit timer with 5-bit prescaler - 2) 16-bit timer - 3) 8-bit timer with 8-bit auto reloader - 4) 8-bit separate timer - Serial port (UART mode operation) Multiple baud rates - Direct initialization of input/output ports by RESET signal even if XTAL1 · 2 have been stopped ("1" data set) - Instruction execution cycle 1 $\mu$ sec. @12 MHz $(Vcc = +5 [V] \pm 20\%)$ Wide-range of clock operation (DC to 12 MHz) (XTAL1 · 2 operation frequency dependent on Vcc) - Wide-range of operating power supply - (1) When operating: Vcc = +2.5 to +6 V - (2) CPU internal data hold voltage (XTAL1 · 2 both stopped) Vcc = +2 to +6 V - Wide-range of operating temperature ( $-40 \sim +85^{\circ}$ C) - High noise margin (with Schmitt trigger input for each I/O) - 40-pin plastic DIP / 44-pin plastic flat package/44-pin PLCC - Software compatibility with Intel 80C31/80C51 #### 4.6.3.4.4 Mode 3 receive operation The receive circuit timing is generated by a hexadecimal counter which employs the halved timer/counter 1 overflow frequency when SMOD = 0 or the unchanged timer/counter 1 overflow frequency when SMOD = 1 as the clock. The input data received from the RXD is bit synchronized. That is, at the same time that reception is started following input of the start bit, the hexadecimal counter commences to count up, and with one complete round of the hexadecimal counter corresponding to one bit of received data, reception is continued by the receive circuit. Therefore, timer/counter 1 must be set so that the period of a single round of the hexadecimal counter is equal to the reception data baud rate. The RXD change from "1" to "0" is regarded as the beginning of the start bit for reception. When this "1" to "0" change in RXD is detected, the hexadecimal counter which had been in reset mode commences to count up. When the hexadecimal counter is in state 7, 8, and 9, the start bit is sampled, and is accepted as valid if at least two of the three sampled values are "0", thereby enabling data reception to continue. If two or three of the sampled values are "1", the start bit becomes invalid, and the receive circuit is reinitialized when the hexadecimal counter reaches state 10. The reception data is sampled when the hexadecimal counter is in state 7, 8, and 9, and the more common value of the three sampled values is read sequentially as data into the input shift register. If the conditions stated below are satisfied when the hexadecimal counter is in state 10 during the period of the multi-purpose data bit, the input shift register data (the LSB being read first) is loaded into SBUF, and the sampled multi-purpose data bit is read into RB8. And when the hexadecimal counter is in state 10 during the period of the stop bit, the receive circuit is initialized. Conditions: (1) RI = "0" (2) SM2 = "0", or SM2 = "1" and sampled multi-purpose data bit = "1" The RI flag is set at the first M1 · S3 cycle after that. If the above conditions are not satisfied when the hexadecimal counter is in state 10 during the multi-purpose data bit interval, the received data is disregarded, the SBUF, RB8, and RI flags remain unchanged, and the receive circuit is initialized when the hexadecimal counter is in state 10 during the stop bit interval. Since the receive circuit is divided into two stages (input shift register and SBUF), processing of the previous receive data may be completed within the interval up to the multi-purpose data bit period of the next frame. #### 4.6.4 Serial port application examples #### 4.6.4.1 I/O extension I/O extension can be achieved by using the serial port in mode 0. An input extension example is shown in Figure 4-30 and the corresponding timing chart is shown in Figure 4-31. The parallel input is latched into 74LS165 with the output of the latch pulse PX.X. Then, this is followed by REN = 1 and RI = 0 setting, and shift in of 74LS165 data. Figure 4-30 Input extension example Figure 4-31 Input extension example timing chart An output extension example is shown in Figure 4-32 and the corresponding timing chart is shown in Figure 4-33. After output data has been written into SBUF and the output sequence completed, the latch pulse output from PX.X is obtained and the 74LS164 data is shifted to 74LS373. Figure 4-32 Output extension example Figure 4-33 Output extension example timing chart An input/output extension example is shown in Figure 4-34 and the corresponding timing chart is shown in Figure 4-35. When input data is applied, INPUT CONTROL is changed from "0" to "1", and the parallel input is latched. This is then followed by REN = 1 and RI = 0 settings, and shift in of 74LS165 data. INPUT CONTROL is returned to "0" after the input has been completed. Since INPUT CONTROL is connected to the 74LS126 control pin, the MSM80C31/MSM80C51 switches the 74LS126 output to high impedance when 74LS165 input data is not being applied, thereby preventing collision between the 74LS126 and MSM80C31/MSM80C51 outputs. When output data is generated, after the output data is written into 74LS164, an output latch pulse is generated from OUTPUT CONTROL, and the 74LS164 data is transferred to 74LS373. Although the 74LS164 data is changed to parallel input data when 74LS165 data is passed to MSM80C31/MSM80C51, an output latch pulse is generated only when output data is obtained from MSM80C31/MSM80C51, thereby preserving the integrity of the data in 74LS373. Figure 4-34 Input/output extension example In all examples, additional multiple bit I/O extension is made possible by multiple cascade connections of 74LS164 or 74LS165. #### 4.6.4.2 Multi-processor systems Multi-processor systems can be configured with the MSM80C31/MSM80C51 using the serial port in mode 2 or mode 3 for inter-processor communications. If reception data bit 9 (multi-purpose bit) is "1" when SM2 is set in mode 2 or 3, reception data is received and an interrupt is generated. If the data bit is "0", however, the reception data is disregarded and no interrupt is generated. This function is employed in forming a multi-processor system when more than one MSM80C31/MSM80C51 device is coupled by a serial bus. An example of a multi-processor system with one master processor and a number of slave processors is shown in Figure 4-36. In this example, data is transmitted only from master to slave processors. Operation proceeds in accordance with the following protocol. - (1) Set SM2 = "1". All slave processors wait in standby mode for address data from the master processor specifying which slave is to be selected. - (2) With TB8 set to "1" to distinguish address data from other data, the master processor generates address data. - (3) At this stage, all slave processors generate interrupts and check whether the received address data was for them. - (4) The specified slave processor sets SM2 = "0" to prepare for reception of the subsequent data to be sent by the master processor. Slave processors which are not specified remain at SM2 = "1". - (5) With TB8 = "0", the master processor next sends data following the address data. - (6) Since the specified slave processor is changed to SM2 = "0", all of the data following the address data is received and processed. - (7) The slave processors which are not specified (that is, where SM2 = "1") disregard all data after the address data and wait in standby mode for the next address data. - (8) After transmitting all of the intended data the master processor generates a final special code (predetermined in advance). - (9) When this special code is received by the previously specified slave processor, SM2 = "1" is set and that slave processor is again put into standby mode awaiting the address data. Figure 4-36 Multi-processor system example #### 4.7 Interrupts #### 4.7.1 Outline MSM80C31/MSM80C51 is equipped with five interrupts. INTO : External interrupt 0 TMO : Timer interrupt 0 INT1 : External interrupt 1 TM1 : Timer interrupt 1 SI/O : Serial port interrupt These five interrupts are controlled by Interrupt Register (IE) and Priority Register (IP). When the relevant interrupt conditions are met, the respective interrupt address is called and the interrupt process is initiated. The interrupt addresses are listed in Table 4-15, and the interrupt control equivalent circuit is shown in Figure 4-37. Table 4-15 Interrupt addresses | | Interrupt source | Interrupt address | |---|----------------------|-------------------| | 1 | External interrupt 0 | 3[0003Н] | | 2 | Timer interrupt 0 | 11[000BH] | | 3 | External interrupt 1 | 19[0013H] | | 4 | Timer interrupt 1 | 27[001BH] | | 5 | Serial port | 35[0023H] | #### 4.7.2 Interrupt enable register (IE) The function of the interrupt enable register (IE, A8H) is to enable or disable interru processing whenever an interrupt request is made. To execute the intended interrupt processing, the interrupt is enabled by setting "1" the corresponding bit in the interrupt enable register, and on requested, the interru Requested interrupts are disabled if the corresponding bit is "0", and the interrupt pr cessing is not executed. The contents of the interrupt enable register (IE) are shown in Table 4-16. Table 4-16 Interrupt enable register (IE, A8H) | Bit | 7 | | <del></del> - | | | | | | |------|----|---|---------------|----|-----|-----|-----|-----| | F | | ь | 5 | 4 | 3 | 2 | 1 | 0 | | Flag | EA | | _ | ES | ET1 | EX1 | ETO | EXO | | | | | | | | | | | EXO : External interrupt 0 control bit Interrupt enabled when "1", disabled when "0". ET0 : Timer interrupt 0 control bit Interrupt enabled when "1", disabled when "0". EX1 : External interrupt 1 control bit Interrupt enabled when "1", disabled when "0". ET1 : Timer interrupt 1 control bit Interrupt enabled when "1", disabled when "0". ES : Serial port interrupt control bit Interrupt enabled when "1", disabled when "0". : Reserve bit for output of "1" when read. : Reserve bit for output of "1" when read. : Interrupt control bit for all five interrupts (EX0, ET0, EX1, ET1, and ES) EΑ When EA is "1", interrupt processing is commenced if interrupt conditions are met for any one of the five interrupts. When EA is "0", interrupt processing is not commenced even if interrupt conditions are met for any one of the five interrupts. # 2. MSM80C31/ MSM80C51 SYSTEM CONFIGURATION #### 4.7.3 Interrupt priority register (IP) The function of the interrupt priority register (IP, B8H) is to allocate rights to commence processing of interrupts on a priority basis when an interrupt is requested. Each interrupt source can be programmed to higher priority level by setting the bit corresponding to the interrupt source in the interrupt priority register (IP). When the interrupt conditions are satisfied for an interrupt with higher priority, even if another interrupt with lower priority (priority bit being "0") is already being processed, that processing is suspended, and the higher priority interrupt is serviced first. Note that once processing of a higher priority interrupt has been commenced, processing of the next interrupt cannot start until the current interrupt is completed. The contents of the interrupt priority register are given in Table 4-17. Table 4-17 Interrupt priority register (IP, B8H) | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|---|----|-----|-----|-----|-----| | Flag | _ | _ | | PS | PT1 | PX1 | PT0 | PX0 | PX0 : External interrupt 0 priority bit PTO: Timer interrupt 0 priority bit PX1: External interrupt 1 priority bit PT1: Timer interrupt 1 priority bit PS : Serial port interrupt priority bit : Reserve bit for output of "1" when read. Reserve bit for output of "1" when read. Reserve bit for output of "1" when read. #### 4.7.3.1 Priority interrupt process flow The flow of interrupt process when a priority interrupt is generated after processing has commenced on a non-priority interrupt generated during execution of a main routine program is outlined in Figure 4-38. Figure 4-38 Interrupt processing flow chart during priority circuit operation #### 4.7.3.2 Interrupt priority when priority register (IP) contents are all "0" The interrupt priority when the priority register (IP, B8H) contents are all "0" indicates the priority in which a certain interrupt is processed in preference to other interrupts when interrupt requests are generated simultaneously. As can be seen from Table 4-18, the external interrupt 0 has the highest priority while the serial port interrupt has the lowest priority. If all priority bits are "0" and a certain interrupt is in process, it will not be preempted by another interrupt regardless of its priority. The same operational preferences as described above also exist when all priority bits are "1". Table 4-18 Non-priority interrupt order of preference | Order of preference | Interrupt source | |---------------------|----------------------| | 1 | External interrupt 0 | | 2 | Timer interrupt 0 | | 3 | External interrupt 1 | | 4 | Timer interrupt 1 | | 5 | Serial port | #### 4.7.4 Detection of external interrupt signals INTO and INT1 #### 4.7.4.1 Outline of INT signal detection The external interrupt signals 0 and 1 can be set to level-detect or trigger-detect mode by the ITO and IT1 data values of bits 0 and 2 in the timer control register (TCON 88H) as indicated in Table 4-19. Timer INT1 INTO Bit 7 6 5 4 3 Flag TF1 TR1 TFO TRO IE1 IE0 IT1 IT0 Set • • Table 4-19 TCON [88H] register #### 4.7.4.2 External interrupt signal 0 and 1 level detection When the bit-0, ITO, in the timer control register (TCON 88H) is "0", external interrupt 0 is detected on the basis of the level of the signal. And when the bit 2, IT1, is "0", external interrupt 1 is also detected on the basis of the signal's level. In the level detection mode, external interrupts 0 and 1 are detected by the equivalent circuit shown in Figure 4-39. When the level of the external interrupt pin is "0" at S5 timing, the level is latched and the Q output becomes "1". The latched external interrupt signal sets the external interrupt flag in the timer control register (TCON) at the S3 timing. This interrupt flag set by external interrupt signal is always reset at S6 in the last machine cycle of instruction execution, effectively being equivalent to a "level sense" operation. The cycle width of the respective "0" and "1" levels of the external interrupt signal applied to the external interrupt pin in this case must be at least 12 times (12T) XTAL1·2 oscillator clock cycle time T. Figure 4-39 Interrupt level input equivalent circuit for IT bit "0" Figure 4-40 Interrupt edge input equivalent circuit for IT bit "1" #### 4.7.4.3 External interrupt signal 0 and 1 trigger detection When the bit 0 or 2, IT0 or IT1, in the timer control register (TCON 88H) is "1", external interrupt is transition-activated. With the external interrupt signals in the transition activated mode, external interrupts 0 and 1 are detected by the equivalent circuit shown in Figure 4-40. When the level of the external interrupt pin is "0" at S5, the level is latched at the first stage and the Q output becomes "1". The external interrupt signal stored in the first stage latch is transfered to the second stage and is subject to digital differentiation until the S3 signal becomes active. The RS-F/F in the next stage is then set by the differentiated output signal. The external interrupt signal applied to the RS-F/F is synchronized with the $\overline{\text{M2}}\cdot\text{S3}$ signal to be applied as a trigger for the external interrupt flag in the timer control register (TCON). The RS-F/F is subsequently reset at $\overline{\text{M2}}\cdot\text{S4}$ and it waits for the next interrupt. Note that the next interrupt signal cannot be detected until the first stage latch detects a level "0" to level "1" transition on the external interrupt signal. The cycle width of the respective "0" and "1" levels of the external interrupt signal applied to the external interrupt pin in this case must be at least 12 times (12T) XTAL1·2 oscillator clock cycle time T. #### 4.7.5 MSM80C31/MSM80C51 interrupt response time charts ## 4.7.5.1 Interrupt response time chart when interrupt conditions are satisfied during execution of ordinary instruction If interrupt conditions are satisfied during execution of a ordinary instruction (which do not manipulate IE or IP) in the main routine, the MSM80C31/MSM80C51 calls the interrupt address in the next cycle following completion of the ordinary instruction. The time chart is given in Figure 4-41. ## 4.7.5.2 Interrupt response time chart when interrupt conditions are satisfied during execution of IE or IP register operation instruction If interrupt conditions are satisfied during execution of an instruction used to manipulate the interrupt enable register (IE) or the interrupt priority register (IP) in the main routine, the MSM80C31/MSM80C51 reactivates the interrupt mask circuit in the next cycle following completion of the register manipulation instruction. If interrupt conditions are met as a result of the re-interrupt mask, the interrupt address is called in the next cycle. That is, if the interrupt conditions are satisfied during execution of the IE or the IP manipulating instruction, the interrupt address is called after the next instruction following the register manipulating instruction is executed. The time chart is given in Figure 4-42. \* In the MOV data address 1, data address 2 instructions, transfer of data to another register from IE or IP is an exception. Interrupt response time chart when interrupt conditions are satisfied during execution of IE or IP register manipulating instruction in main routine Figure 4-42 # 4.7.5.3 Interrupt response time chart when an ordinary instruction is executed after temporarily returning to the main routine from continuous interrupt processing If an ordinary instruction (that is, not an IE or IP manipulating instruction) is executed after returning to the main routine following execution of the interrupt processing end instruction RETI, and if the next interrupt conditions were met during execution of an interrupt processing routine, the MSM80C31/MSM80C51 calls the interrupt address in the next cycle following execution of one main routine instruction. The same occurs when interrupt conditions are satisfied during execution of the first main routine instruction after returning to that routine from the interrupt processing routine. The time chart is shown in Figure 4-43. # 4.7.5.4 Interrupt response time chart when an IE or IP manipulating instruction is executed after temporarily returning to the main routine from continuous interrupt processing If the "next" interrupt conditions are satisfied during execution of an interrupt processing routine, and if the interrupt terminating instruction RETI is then executed followed by a return to the main routine where an interrupt enable register (IE) or interrupt priority register (IP) manipulating instruction is executed, the MSM80C31/MSM80C51 activates the interrupt mask circuit in the next cycle following execution of the register manipulating instruction. And if interrupt conditions are met as a result of the reinterrupt mask, the interrupt address is called in the next cycle. That is, if the instruction executed in the main routine manipulates either IE or IP, the interrupt address is called after two instructions are executed. The time chart is shown in Figure 4-44. \* In the MOV data address 1, data address 2 instructions, transfer of data to another register from IE or IP is an exception. Interrupt response time chart when IE or IP manipulating instruction is executed after returning to main routine during continuous interrupt processing ### 2. MSM80C31/MSM80C51 SYSTEM CONFIGURATION #### 2.1 MSM80C31/MSM80C51 Logic Symbols Figure 2-1 MSM80C31/MSM80C51 logic symbols #### 4.8 CPU "Power Down" #### 4.8.1 Outline The CPU power down function operates in two modes — idle mode and power down mode. In the idle mode (IDLE) where "1" is set in bit 0 (IDL) of the power control register (PCON) by software, XTAL1·2 operation is continued but the clock to the CPU control section is stopped, thereby halting CPU operations. In the power down mode (PD) where "1" is set in bit 1 (PD) of the power control register (PCON) by software, both the XTAL1·2 operation and the CPU operation is stopped. The device can be forced out of the power down mode by either a reset or an interrupt. #### 4.8.2 Idle mode (IDLE) setting Idle mode is set when "1" is set in bit 0 (IDL) of the power control register (PCON 87H). The circuit connection involved in this setting is shown in Figure 4-45. In the idle mode, the clock to the CPU control section is stopped and the CPU operations are halted. But since XTAL1·2 operations are maintained, the serial port, interrupt circuits, and timer/counters 0 and 1 remain operative. The CPU pin status during the idle mode is outlined in Table 4-20, and the corresponding time charts for initiating the idle mode are shown in Figures 4-46 and 4-47. Figure 4-45 Idle mode equivalent circuit Table 4-20 CPU pin status in idle mode | Name | Internal ROM | External ROM | |------------------------|-----------------------------------------|----------------------| | P1.0 | Port data output | | | P1.1 | Port data output | Port data output | | P1.2 | Port data output | Port data output | | P1.3 | Port data output | Port data output | | P1.4 | <del></del> | Port data output | | P1.5 | Port data output | Port data output | | P1.6 | Port data output | Port data output | | P1.7 | Port data output | Port data output | | RESET | Port data output | Port data output | | | "0" level input | "0" level input | | P3.0/RXD | Port data output | Port data output | | P3.1/TXD | Port data output | Port data output | | P3.2/ <del>INT</del> 0 | Port data output | Port data output | | P3.3/INT1 | Port data output | Port data output | | P3.4/T0 | Port data output | Port data output | | P3.5/T1 | Port data output | Port data output | | P3.6/WR | Port data output | Port data output | | P3.7/RD | Port data output | Port data output | | XTAL 2 | Oscillator operation | Oscillator operation | | XTAL 1 | Oscillator operation | Oscillator operation | | Vss | 0 [V] | 0 [V] | | P2.0 | Port data output | Address 8 output | | P2.1 | Port data output | Address 9 output | | P2.2 | Port data output | Address 10 output | | P2.3 | Port data output | Address 11 output | | P2.4 | Port data output | Address 12 output | | P2.5 | Port data output | Address 13 output | | P2.6 | Port data output | Address 14 output | | P2.7 | Port data output | Address 15 output | | PSEN | "1" level output | "1" level output | | ALE | "1" level output | "1" level output | | EA | "1" level input | "O" level input | | P0.7 | Port data output | Floating | | P0.6 | Port data output | Floating | | P0.5 | Port data output | Floating | | P0.4 | Port data output | Floating | | P0.3 | Port data output | Floating | | P0.2 | Port data output | Floating | | P0.1 | Port data output | Floating | | P0.0 | Port data output | Floating | | Vcc | +2.5 ~ +6 [V] | +2.5 ~ +6 [V] | | | · · · — — — — — — — — — — — — — — — — — | | 117 Figure 4-47 Idle mode setting (external ROM mode) #### 4.8.3 Power down mode (PD) setting Power down mode is set when "1" is set in the PD bit of the power control register (PCON, 87H). The circuit connection involved in this setting is shown in Figure 4-48. In power down mode, both the XTAL1·2 and the CPU operations are halted. The integrity of the CPU data memory (RAM) and I/O port data, however, is preserved during this mode. The CPU pin status during the power down mode is outlined in Table 4-21, and the corresponding time charts for initiating the power down mode are shown in Figures 4-49 and 4-50. Figure 4-48 Power down mode equivalent circuit Table 4-21 CPU pin status in power down mode | Name | Internal ROM | External ROM | |------------------------|--------------------|--------------------| | P1.0 | Port data output | Port data output | | P1.1 | Port data output | Port data output | | P1.2 | Port data output | Port data output | | P1.3 | Port data output | Port data output | | P1.4 | Port data output | Port data output | | P1.5 | Port data output | Port data output | | P1.6 | Port data output | Port data output | | P1.7 | Port data output | Port data output | | RESET | "0" level input | "0" level input | | P3.0/RXD | Port data output | Port data output | | P3.1/TXD | Port data output | Port data output | | P3.2/ <del>INT</del> 0 | Port data output | Port data output | | P3.3/INT1 | Port data output | Port data output | | P3.4/T0 | Port data output | Port data output | | P3.5/T1 | Port data output | Port data output | | P3.6/WR | Port data output | Port data output | | P3.7/RD | Port data output | Port data output | | XTAL 2 | Oscillator stopped | Oscillator stopped | | XTAL 1 | Oscillator stopped | Oscillator stopped | | Vss | 0 [V] | 0 [V] | | P2.0 | Port data output | Port data output | | P2.1 | Port data output | Port data output | | P2.2 | Port data output | Port data output | | P2.3 | Port data output | Port data output | | P2.4 | Port data output | Port data output | | P2.5 | Port data output | Port data output | | P2.6 | Port data output | Port data output | | P2.7 | Port data output | Port data output | | PSEN | "O" level output | "0" level output | | ALE | "0" level output | "0" level output | | ĒĀ | "1" level input | "0" level input | | P0.7 | Port data output | Floating | | P0.6 | Port data output | Floating | | P0.5 | Port data output | Floating | | P0.4 | Port data output | Floating | | P0.3 | Port data output | Floating | | P0.2 | Port data output | Floating | | P0.1 | Port data output | Floating | | P0.0 | Port data output | Floating | | Vcc | +2.0 ~ +6 [V] | +2.0 ~ +6 [V] | Figure 4-49 Power down mode setting (internal ROM mode) #### 4.9 CPU Power Down (IDLE and PD) Cancellation (CPU Activation) #### 4.9.1 Outline CPU power down (IDLE and PD) can be cancelled (CPU activation) in two ways. One way is to reset the CPU and execute from address 0 (common method for both IDLE and PD modes), and the other is to generate a CPU interrupt and execute from the interrupt address. This method can only be used if device is in the IDLE mode. #### 4.9.2 Cancellation by CPU resetting The CPU is reset when a "1" is applied to the CPU RESET pin, and the CPU power down state (IDLE or PD mode) is cancelled. Programs are subsequently executed by the CPU from address 0. The reset time charts are outlined in Figures 4-51 thru 4-54. Figure 4-51 Restart from idle mode by 2000ttin 124 #### 2.2 MSM80C31/MSM80C51 Pin Layout #### MSM80C31GS/MSM80C51GS (Top View) 44 Lead Plastic Flat Package #### MSM80C31JS/MSM80C51JS (Top View) 44 Lead Plastic Leaded Chip Carrier Figure 2-2 MSM80C31/MSM80C51 pin layout 125 #### 4.9.3 Reactivation of CPU by an interrupt An interrupt control bit in the interrupt enable register (IE, A8H) is set prior to setting idle mode. And "1" is then set in bit 0 (IDL) of the power control register, PCON, to put the device in the idle mode. All five interrupts can thus be used to cancel the idle mode. When "1" is set in the interrupt flag in TCON and SCON, clock signals are then passed to the CPU, the interrupt address is called, and execution starts from the interrupt address. However, if all interrupts have been disabled, the idle mode cannot be cancelled by this method, the RESET pin has to be used. The idle mode cancellation equivalent circuit (cancellation by interrupt) is shown in Figure 4-55, and the time charts are shown in Figures 4-56 and 4-57. Figure 4-55 Equivalent circuit for idle mode cancellation by interrupt signal # 5. INPUT/OUTPUT PORTS #### 5. INPUT/OUTPUT PORTS #### 5.1 Outline MSM80C31/MSM80C51 is equipped with four 8-bit input/output ports. The functions of these four ports (port 0, 1, 2, and 3) are listed below - 1) Port 0: Input/output bus port, address output port, and data input/output port. - 2) Port 1: Quasi-bidirectional input/output port. - 3) Port 2: Quasi-bidirectional input/output port and address output port. - 4) Port 3: Quasi-bidirectional input/output port and control input/output pin. #### 5.2 Port 0 Port 0 is an 8-bit input/output port with circuit structure indicated in Figure 5-1. When port 0 is used as an input/output port in internal ROM mode (MSM80C51), the equivalent circuit of Port 0 is indicated in Figure 5-2. When operated as an output port, port 0 becomes an open drain output port, and when operated as an input port, "1" has to be set in the port 0 latch to put the port 0 pin into floating status prior to using the port for input purposes. When port 0 is used in external ROM mode (MSM80C31) and external RAM mode, the equivalent circuit is as shown in Figure 5-3 where addresses and data outputs are obtained as "1" and "0" by totem pole output driver. When data from external ROM or external RAM is input, port 0 automatically becomes a tri-state input port. When the CPU is reset or when an external ROM or external RAM is accessed, "1" is set automatically in the port 0 latch. The port 0 pin table is shown in Table 5-1. Figure 5-1 Port 0 internal equivalent circuit Figure 5-2 Port 0 input/output port equivalent circuit in internal ROM mode Figure 5-3 Port 0 equivalent circuit during address and data input/output when in external **ROM/RAM** mode | | PORT 0 | Accumulator bit | Ad | |---|--------|-----------------|----| | 1 | DO 0 | 400.0 | PC | Table 5-1 Port 0 pin table | | PORT 0 | Accumulator bit | Address | |---|--------|-----------------|------------------------| | 1 | P0.0 | ACC.0 | PC<br>RA-0 | | 2 | P0.1 | ACC.1 | PC<br>RA <sup>-1</sup> | | 3 | P0.2 | ACC.2 | PC<br>RA <sup>-2</sup> | | 4 | P0.3 | ACC.3 | PC <sub>BA</sub> -3 | | 5 | P0.4 | ACC.4 | PC<br>RA <sup>-4</sup> | | 6 | P0.5 | ACC.5 | PC<br>RA <sup>-5</sup> | | 7 | P0.6 | ACC.6 | PC<br>RA <sup>-6</sup> | | 8 | P0.7 | ACC.7 | PC<br>RA <sup>-7</sup> | #### 5.3 Port 1 Port 1 is a quasi-bidirectional port capable of handling input and output of 8-bit data in the circuit configuration outlined in Figure 5-4. A "quasi-bidirectional port" refers to a port which has internal pull-up resistance when it is used as an input port. The internal equivalent circuit is shown in Figure 5-5. If a quasi-bidirectional port is used exclusively as an output port, the port output driver becomes a totem-pole type for driving "1"s and "0"s. The output impedance, when the output is "1", is approximately 9 kohm, while a sink current is 1.6 mA during the output of "0"s. When used as an output port, the "1" data accelerator circuit is activated for a period equivalent to two XTAL1·2 oscillator clocks only when the output data is shifted from "0" to "1". During this data acceleration operation, the "1" output impedance is changed to about 500 ohms, the IOH current is increased, and the output signal's leading edge is speeded up. The accelerator circuit operation time chart is shown in Figure 5-6. If a quasi-bidirectional port is used exclusively as an input port, "1" is first set in the port in advance. When the input signal applied to the input port is changed from level "1" to level "0", the port 10 kohm pull-up resistance is disconnected from the Vcc, leaving only the 100 kohm pull-up resistance. And when the input signal is changed from level "0" to level "1", the 10 kohm resistance is reconnected to the Vcc power supply, thereby connecting the 10 kohm and 100 kohm resistances to the Vcc supply in parallel. The quasi-bidirectional port input equivalent circuit is outlined in Figure 5-7. The port 1 pin table is shown in Table 5-2. Figure 5-4 Port 1 internal equivalent circuit (C) When "0" data is held Figure 5-5 Quasi-bidirectional port equivalent circuit Figure 5-6 Quasi-bidirectional port accelerator circuit operation time chart #### MSM80C31/MSM80C51 USER'S MANUAL #### 2.2.1 External dimensions ### MSM80C31RS/MSM80C51RS [40 Lead Plastic DIP] #### MSM80C31GS/MSM80C51GS [44 Lead Plastic Flat Package] #### MSM80C31JS/MSM80C51JS [44 Lead Plastic Leaded Chip Carrier] All dimensions are typical value. #### MSM80C31/MSM80C51 USER'S MANUAL Figure 5-7 Quasi-bidirectional port input equivalent circuit Table 5-2 Port 1 pin table | | PORT 1 | Accumulator bit | |---|--------|-----------------| | 1 | P1.0 | ACC.0 | | 2 | P1.1 | ACC.1 | | 3 | P1.2 | ACC.2 | | 4 | P1.3 | ACC.3 | | 5 | P1.4 | ACC 4 | | 6 | P1.5 | ACC.5 | | 7 | P1.6 | ACC.6 | | 8 | P1.7 | ACC.7 | #### 5.4 Port 2 Port 2 can function as a quasi-bidirectional port capable of handling input and output of 8-bit data in the circuit configuration outlined in Figure 5-8. It can also be used for output of addresses 8 thru 15 in external ROM mode and external RAM mode using the data pointer DPTR. When port 2 is used as a quasi-bidirectional port, it functions in much the same way as port 1. Note, however, that the port 2 "1" data accelerator circuit operates for a period equivalent to four XTAL1.2 oscillator clocks. Output of addresses 8 thru 15 obtained from port 2 makes use of the circuit outlined in Figure 5-9. When the address output data is "1", the "1" data accelerator circuit is activated during the output of the data, resulting in a larger drive capability. The port 2 pin table is given in Table 5-3. Figure 5-8 Port 2 internal equivalent circuit Figure 5-9 Port 2 ROM/RAM address output equivalent circuit Table 5-3 Port 2 pin table | | PORT 2 | Accumulator bit | Address | |---|--------|-----------------|------------------------| | 1 | P2.0 | ACC.0 | PC<br>RA <sup>-8</sup> | | 2 | P2.1 | ACC.1 | PC<br>RA <sup>-9</sup> | | 3 | P2.2 | ACC.2 | PC<br>RA-10 | | 4 | P2.3 | ACC.3 | PC<br>RA-11 | | 5 | P2.4 | ACC.4 | PC<br>RA-12 | | 6 | P2.5 | ACC.5 | PC<br>RA -13 | | 7 | P2.6 | ACC.6 | PC<br>RA-14 | | 8 | P2.7 | ACC.7 | PC<br>RA-15 | #### 5.5 Port 3 Port 3 can function as a quasi-bidirectional port capable of handling input and output of 8-bit data in the circuit configuration outlined in Figure 5-10. It can also be used as a CPU control pin. When port 3 is used as a quasi-bidirectional port, all functions are identical to those described for port 1. And when used as a CPU control pin, the port is used after first setting "1" in the port. Note that if the port is used with "0" port data, the CPU control signal is ANDed with the port "0" data, resulting in the CPU control signal remaining at level "0". The port 3 pin table is given in Table 5-5. Figure 5-10 Port 3 internal equivalent circuit Table 5-4 Port 3 alternate function table | PORT 3 | PORT 3 PIN ALTERNATE FUNCTION | |--------|-------------------------------------------| | P3.0 | RXD [SERIAL INPUT PORT] | | P3.1 | TXD [SERIAL OUTPUT PORT] | | P3.2 | INTO [EXTERNAL INTERRUPT 0] | | P3.3 | INT1 [EXTERNAL INTERRUPT 1] | | P3.4 | TO [TIMER/COUNTER O CLOCK] | | P3.5 | T1 [TIMER/COUNTER 1 CLOCK] | | P3.6 | WR [EXTERNAL DATA MEMORY<br>WRITE STROBE] | | P3.7 | RD [EXTERNAL DATA MEMORY<br>READ STROBE] | Table 5-5 Port 3 pin table | | PORT 3 | Control | Accumulator bit | |---|--------|---------|-----------------| | 1 | P3.0 | RXD | ACC.0 | | 2 | P3.1 | TXD | ACC.1 | | 3 | P3.2 | ĪNTO | ACC.2 | | 4 | P3.3 | ĪNT 1 | ACC.3 | | 5 | P3.4 | ТО | ACC.4 | | 6 | P3.5 | T1 | ACC.5 | | 7 | P3.6 | WR | ACC.6 | | 8 | P3.7 | RD | ACC.7 | # 5 #### 5.6 Port Output Timing 1) One machine cycle instruction output timing Figure 5-11 One machine cycle instruction port output time chart #### MSM80C31/MSM80C51 USER'S MANUAL #### 2) Two machine cycle instruction output timing MOV data address, # data MOV data address 1, gata address 2 ORL data address, # data MOV bit address. C ANL data address. # data XRL data address, # data JBC bit address, Code address POP data address MOV data address, @Rr MOV data address, Rr Figure 5-12 Two machine cycle instruction port output time chart #### 5.7 Port Data Manipulating Instructions The MSM80C31/MSM80C51 port operation instructions for ports 0, 1, 2, and 3 are divided into two groups — one where external signals applied to the port pin are used according to the instruction to be executed, and the other where port latch data uneffected by the applied external signals is used. Instructions which use port latch data are listed below | INC | data address | |-----|--------------| | DEC | data address | | ORL | data address, # data | |-----|----------------------| | ANL | data address, # data | | XRL | data address, # data | | ORL | data address, A | | ANL | data address, A | XRL data address, A CPI bit address JBC bit address, Code address DJNZ data address, Code address PUSH data address 5 # 6. MSM80C31/ MSM80C51 ELECTRICAL CHARACTERISTICS #### 6. MSM80C31/MSM80C51 ELECTRICAL CHARACTERISTICS #### 6.1 Absolute Maximum Ratings | Parameter | Symbol | Condition | Rating | Unit | |------------------------|--------|-----------|-------------------|------| | Supply voltage | Vcc | Ta = 25°C | - 0.5 ~ 7 | V | | Input voltage | Vı | Ta = 25°C | - 0.5 ~ Vcc + 0.5 | V | | Storage<br>temperature | Tstg | | −55 ~ +150 | °C | #### 6.2 Operational Ranges | Parameter | Symbol | Condition | Rating | Unit | |------------------------|--------|-------------------|-----------|------| | Operating voltage | Vcc | *1 fosc=DC~16 MHz | 2.5 ~ 6 | V | | Memory hold voltage | Vcc | | 2 ~ 6 | V | | Ambient<br>temperature | Та | | -40 ~ +85 | °C | <sup>\*1</sup> DC and AC characteristics in the range of 12 MHz < f $\leq$ 16 MHz and 2.5 V $\leq$ Vcc < 4V will be specified elsewhere. #### 2.3 MSM80C31 Internal Block Diagram Figure 2-3 MSM80C31 internal block diagram #### 6.3 DC Characteristics $(Vcc = 5 V \pm 20\%, Vss = 0 V, Ta = 40^{\circ}C to +85^{\circ}C)$ | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | Measuring<br>Circuit | |-----------------------------------------------------------|--------------|-------------------------------------------------|---------------|-----|-------------|------|----------------------| | Input Low<br>Voltage | VIL | | -0.5 | | 0.2 Vcc 0.1 | V | | | Input High<br>Voltage | ViH | Except<br>XTAL1<br>and RESET | 0.2 Vcc + 0.9 | | Vcc+0.5 | V | | | Input High<br>Voltage | VIH1 | XTAL1 and<br>RESET | 0.7 Vcc | | Vcc+0.5 | V | - | | Output Low<br>Voltage<br>[PORT 1, 2, 3] | Vol | IOL = 1.6 mA | 1 | | 0.45 | V | | | Output Low<br>Voltage<br>[PORT 0, ALE,<br>PSEN] | Vol1 | lot = 3.2 mA | | | 0.45 | V | 1 | | Output High | Vон | $loh = -60 \mu A$<br>$Vcc = 5V \pm 10\%$ | 2.4 | | | V | | | Voltage<br>[PORT 1, 2, 3] | VOH | IOH = $-30 \mu A$ | 0.75 Vcc | | | V | | | | | IOH = -10 μA | 0.9 Vcc | | | V | | | Output High | <b>V</b> OH1 | $IOH = -400 \mu\text{A}$<br>$Vcc = 5V \pm 10\%$ | 2.4 | | | V | | | Voltage<br>[PORT 0, ALE,<br>PSEN] | VOHI | Iон = 150 μA | 0.75 Vcc | | | V | | | FOEINJ | | $IOH = -40 \mu A$ | 0.9 Vcc | | | V | | | Logical 0<br>Input<br>Current<br>[PORT 1, 2, 3] | hı. | VI = 0.45 V | | | -200 | μΑ | | | Logical 1 to 0<br>Transition<br>Current<br>[PORT 1, 2, 3] | Iτι | Vı = 2.0 V | | | 500 | μΑ | 2 | | Input Leakage<br>Current<br>[PORT 0_<br>floating, EA] | fLi | Vss < Vı < Vcc | | | <u>+</u> 10 | μΑ | 3 | | RESET<br>Pulldown<br>Resistor | RRST | | 20 | 40 | 125 | KΩ | 2 | | Pin<br>Capacitance | Сю | Ta=25°C,<br>f=1 MHz<br>5V [except<br>XTAL1] | | | 10 | рF | | #### MSM80C31/MSM80C51 USER'S MANUAL | Parameter | Symbol | Conditions | MIN | TYP | MAX | Unit | Measuring<br>Circuit | |--------------------------------------------------------------|--------|----------------|-----|-----|-----|------|----------------------| | Power Down<br>Current | lpD | Vcc = 2 V | | 1 | 50 | μΑ | | | Maximum<br>Power<br>Supply<br>Current<br>Normal<br>Operation | Icc | Vcc = | 4 | 5 | 6 | V | | | | | fosc = 12 MHz | 12 | 16 | 20 | mA | | | | | fosc = 8 MHz | 8.3 | 11 | 14 | mA | | | | | fosc = 3.5 MHz | 4.3 | 5.7 | 7.5 | mA | 4 | | | | fosc = 0.5 MHz | 1.6 | 2.2 | 3 | mA | | | Maximum<br>Power<br>Supply<br>Current<br>Idle Mode | Icc1 | fosc = 12 MHz | 2.5 | 3.7 | 5 | mA | | | | | fosc = 8 MHz | 1.8 | 2.7 | 3.7 | mA | | | | | fosc = 3.5 MHz | 1.1 | 1.6 | 2.2 | mA | | | | | fosc = 0.5 MHz | 0.6 | 0.9 | 1.2 | mA | | #### Measuring circuits Note 1. Repeated for specified input pins - 2. Repeated for specified output pins - 3. Input logic for specified status. #### 6.4 External Program Memory Access AC Characteristics $\label{eq:Vcc} Vcc=5~V~\pm20\%, Vss=0~V, 12~MHz, Ta=~-40^{\circ}C~to~85^{\circ}C$ PORT 0, ALE, and $\overline{PSEN}$ connected with 100 pF load, others connected with 80 pF load | | | Ratings | | | | | |---------------------------------|---------|--------------|-----|-------------------------------------|------------|------| | Parameter | Symbol | 12 MHz clock | | Variable clock<br>from DC to 12 MHz | | Unit | | | | MIN | MAX | MIN | MAX | 1 | | XTAL 1.2 Oscillator<br>Period | tCLCL | | | 83.3 | | ns | | ALE Pulse Width | tLHLL | 126 | | 2tCLCL-40 | | ns | | Address Valid to<br>ALE Low | tAVLL | 43 | | 1tCLCL-40 | | ns | | Address Hold After<br>ALE Low | tLLAX | 48 | | 1tCLCL -35 | | ns | | ALE Low to Valid<br>Instr In | tLLIV | | 183 | | 4tCLCL-100 | ns | | ALE Low to<br>PSEN Low | tLLPL | 58 | | 1tCLCL-25 | | ns | | PSEN Pulse Width | tPLPH | 215 | | 3tCLCL-35 | | ns | | PSEN Low to<br>Valid Instr In | tPLIV | | 100 | | 3tCLCL-105 | ns | | Input Instr Hold<br>After PSEN | tPXIX | 0 | , | 0 | | ns | | Input Instr Float<br>After PSEN | tPXIZ | | 63 | ··· | 1tCLCL-20 | ns | | PSEN to Address<br>Valid | . tPXAV | 75 | | 1tCLCL-8 | | ns | | Address to<br>Valid Instr In | tAVIV | | 266 | | 5tCLCL-105 | ns | | PSEN Low to<br>Address Float | tPLAZ | _ | 0 | | 0 | ns | ## 6 #### External program memory read cycle #### 6.5 External Data Memory Access AC Characteristics Vcc = 5 V $\pm 20\%$ , Vss = 0 V, 12 MHz, Ta = $-40^{\circ}$ C to 85°C PORT 0, ALE, and $\overline{PSEN}$ connected with 100 pF load, others connected with 80 pF load | | | Ratings | | | | | |--------------------------------|--------|--------------|-----|------------------------|------------|------| | Parameter | Symbol | 12 MHz clock | | Variable<br>from DC to | | Unit | | | | MIN | MAX | MIN | MAX | | | XTAL 1.2 Oscillator<br>Period | tCLCL | | | 83.3 | | ns | | ALE Pulse Width | tLHLL | 126 | | 2tCLCL-40 | | ns | | Address Valid to<br>ALE Low | tAVLL | 43 | | 1tCLCL-40 | | ns | | Address Hold After<br>ALE Low | tLLAX | 48 | | 1tCLCL-35 | | ns | | RD Pulse Width | tRLRH | 400 | | 6tCLCL-100 | | ns | | WR Pulse Width | tWLWH | 400 | | 6tCLCL~100 | | ns | | RD Low to Valid<br>Data In | tRLDV | | 251 | | 5tCLCL-165 | ns | | Data Hold After RD | tRHDX | 0 | | 0 | | ns | | Data Float After RD | tRHDZ | | 96 | | 2tCLCL-70 | ns | | ALE Low to Valid<br>Data In | tLLDV | | 516 | | 8tCLCL-150 | ns | | Address to Valid<br>Data In | tAVDV | | 585 | | 9tCLCL-165 | ns | | ALE Low to<br>RD or WR Low | tLLWL | 200 | 300 | 3tCLCL-50 | 3tCLCL+50 | ns | | Address to<br>RD or WR Low | tAVWL | 233 | | 4tCLCL-130 | | ns | | Data Valid to<br>WR Transition | tQVWX | 23 | | 1tCLCL-60 | | ns | | Data Valid to<br>WR High | tQVWH | 433 | | 7tCLCL-150 | | ns | | Data Hold After WR | tWHQX | 33 | | 1tCLCL-50 | | ns | | RD Low to Address<br>Float | tRLAZ | | 0 | | 0 | ns | | RD or WR High to<br>ALE High | tWHLH | 43 | 133 | 1tCLCL-40 | 1tCLCL+50 | ns | ## 6 #### External data memory read cycle #### External data memory write cycle # 6.6 Serial Port (I/O Extension Mode) AC Characteristics $Vcc = 5 V \pm 20\%$ , Vss = 0 V, Ta = 40°C to 85°C) | Parameter | Symbol | Min | Max | Unit | |---------------------------------------------|--------|-------------|---------------|-----------| | Serial Port Clock Cycle Time | tXLXL | 12tCLCL | | ⊢ —<br>μS | | Output Data Setup to Clock<br>Rising Edge | tQVXH | 10tCLCL-133 | | nS | | Output Data Hold After Clock<br>Rising Edge | tXHQX | 2tCLCL-177 | | nS | | Input Data Hold After Clock<br>Rising Edge | tXHDX | 0 | | nS | | Clock Rising Edge to Input<br>Data Valid | tXHDV | | 10tCLCL - 133 | nS | ## 6.7 AC Characteristics Measuring Conditions #### 1. Input/output signal \* The input signals in AC test mode are either VoH (logic "1") or VoL (logic "0") input signals where logic "1" corresponds to a CPU output signal waveform measuring point in excess of VIH, and logic "0" to a point below VIL. #### 2. Floating \* The port 0 floating interval is measured from the time the port 0 pin voltage drops below VIH after sinking to GND at 2.4 mA when switching to floating status from "1" output, and from the time the port 0 pin voltage exceeds VIL after connecting to a 400 $\mu$ A source when switching to floating status from "0" output. # 2.4 MSM80C51 Internal Block Diagram Figure 2-4 MSM80C51 internal block diagram #### 7.1 Outline MSM80C31/MSM80C51 is a microcontroller designed for parallel processing in an 8-bit ALU. The instructions consist of 8-bit units of data, and are available as 1-word 1-machine cycle, 2-machine cycle, and 4-machine cycle instructions as well as 2-word 1-machine cycle and 2-machine cycle instructions and 3-word 2-machine cycle instructions. There is a total of 111 instructions classified into the following groups. - (1) Arithmetic and logic instructions (15) - (2) Accumulator operation instructions (7) - (3) Increment & decrement instructions (9) - (4) Logical operation instructions (18) - (5) Immediate data setting instructions (5) - (6) Carry flag operation instructions (9) - (7) Bit operation instructions (3) - (8) Data transfer instructions (11) - (9) Constant value instructions (2) - (10) Data exchange instructions (4) - (11) Subroutine instructions (6) - (12) Jump instructions (4) - (13) Branching instructions (13) - (14) External data memory instructions (4) - (15) Other instruction (1) # 7 ## 7.2 Description of Instruction Symbols A description of the instruction symbols is listed below: A Accumulator AB Register pair AC Auxiliary carry B Arithmetic operation register C Carry (the bit 7 carry repres Carry (the bit 7 carry represented by CY is changed to C in Chap- ter 7.) DPTR Data pointer PC Program counter Rr Register representation (r = 0/1, or r = 0 thru 7) SP Stack pointer AND Logical AND OR Logical OR XOR Exclusive OR + Addition - Subtraction X Multiplication / Division (X) Representation of the contents of X ((X)) Representation of the contents addressed by contents of X # Symbol denoting immediate data © Symbol denoting indirect address = Equal Equal Not equal Substitution Substitution Negation (upper bar) Smaller than Larger than bit address RAM or special function register bit designated address code address Absolute address (A<sub>0</sub> thru A<sub>15</sub>, A<sub>0</sub> thru A<sub>11</sub>) data Immediate data (lo thru l7) relative offset Corrected relative jump address value direct address RAM or special function register data designated address ("direct address" representation changed to "data address" during detailed description of instructions) 7.3 List of Instructions MSM80C31/MSM80C51 instruction table | _ | 0 | - | 2 | n | 4 | - | 9 | 14 | u | 0 | | | | | | | |-------------|-------------------------|-------------------------------------------|---------------------|-----------------------------------------|-----------------|-----------------------------|-------------------------------|--------------------------------|------------------|----------------------|---------------|-----------|---------------------|-----------------------------------------------------------------|-----------|-------------------| | <u></u> | 0 | 0 | | | | | | | 0 | n | <b>1</b> | D<br> | ر | 2 | ш | ш | | Ε. | )<br>5<br>5 | | 0 - 0 | | 0 0 . | 0 1 0 1 | 0 0 | 0 | 1000 | - 0 0 - | 0 1 0 1 | . 0 - | 1100 | | 0 | | | 000 | 0000 NOP | AJMP<br>address 11<br>(page 0) | LJMP<br>address 16 | A RA | NC A | INC direct | INC . RO | NC - B | INC RO | NC R1 | INC R2 | ε a ONI - | INC R4 | INC R5 | INC R6 | INC R7 | | -000 | JBC bit | ACALL<br>address 11<br>(page 0) | LCALL<br>addrsss 16 | RRCA | DECA | DEC<br>direct | DEC "RO | DEC - R1 | DEC RO | DEC R1 | DEC R2 | DEC R3 | DEC R4 | DECRS | DECR6 | DEC R7 | | 00100 | JB bit | AJMP<br>address * FRET<br>(page 1) | RET | R. A | ADD A<br>#data | ADD A<br>arrect | ADDA<br>1.4 RO | ADDAR1 | , ADDA RO | ADD A R1 | ADD A R2 | ADD & H3 | ADD A R4 | ADD A RO ADD A RY ADD A R3 ADD A R4 ADD A R5 ADD A R6 | ADD A. RE | ADD A R7 | | 3 | 3 JNB bit | ACALL ACALL | EET | . ā | ADDC A | ADDC A. | ADDC A | ADDCA | i<br>ADDC | ADDC | ADDC . | ADDC | ADDC | ADDC | ADDC | ADDC | | | . rel | (page 1) | : | | #data | direct | , R0 | Ę. | A. R0 | A B | A R2 | A R3 | A R4 | A R5 | A R6 | A. B.7 | | 0100 | JC bit | AJMP<br>address 11<br>(page 2) | ORL<br>direct A | ORL<br>direct<br>#data | ORL A<br>#data | ORL A | ORLA<br>"R0 | ORL A | ORLA R0 | ORLA R1 | OPLA, 92 | OPLA R3 | OBLA R4 | ORLA R5 | ORLA R6 | ORLA R7 | | 2010 | 5<br>0101 JNC rel | ACALL<br>address 11<br>tpage 21 | ANE<br>direct A | ANL<br>direct<br>. #data | ANL A | ANL A<br>direct | ANL A | ANL A | ANLA RO | ANLA R1 | ANLA R2 | ANLA R3 | ANLA R4 | ANLA R5 | ANLA R6 | ANLA R7 | | 0110 | 6<br>0110 JZre: | AJMP<br>address 11<br>(page 3) | XRL<br>direct A | XRL<br>direct<br>#data | XRL A<br>#data | XRLA<br>direct | XRLA<br>"RG | XBLA . | XRLA HO "XRLA R1 | | XBLA R2 | XALA R3 | XALA R4 | XBLA R5 | XPLA R6 | XRLA H7 | | 0111 | 01*1 JNZ rel | ACAL1<br>address 11<br>(page 31 | ORLC | JMP MOVA<br>"A-DPTR ≠data | MOVA<br>P #data | MOV<br>direct<br>#data | 'MOV √R0<br>#data | MOV «RO MOV «RI<br>Frata #data | MCV RO<br>#data | MCV R1 # | MOV R2 | MOV R3 | MOV R4 | MCV R5 | MOVR6 | MOV R7 | | 1000 | S. S. | AJMP<br>address 11<br>(page 4) | ANL C. | MOVCA<br>"A.PC | ,<br>DIVAB | MOV<br>direct 1<br>direct 2 | MOV<br>direct | MOV<br>direct. | + | MOV<br>direct.<br>Ry | MOV<br>direct | - | MOV<br>direct<br>R4 | MOV<br>direct | MOV . | MOV<br>direct | | e 00<br>:00 | MOV<br>DPTR<br>#data 16 | ACALL<br>address 11<br>ipage 43 | MOVBit | MOVCA SUBB | SUBB A | SUBBA | SUBBA | SUBBA | SUBBA . | SUBB A | SUBB A | SUBBA | SUBBA | A 88 | SUBBA. | SUBBA | | 4.01 | C Dit | AJMP<br>address 11<br>(page 51 | MOV C | INC DPTR | MUL AB | | 98 | | , BO. | ф. | , CB . | MOV R3 | MOV R4 | . 5 | Mov Be | R7<br>MOVR7 | | E 0 | B ANL<br>1011 C bit | ACALL<br>Address 11 CPL bit<br>(page 5) | CPL bit | 2 Ta2 | CUNE A | CJNE A<br>direct.rel | CUNE / PD. | Ē. 8 | | | CUNER? | CUNE RG | CUNE P4 | CUNERS. | GUNE RE | Gunect<br>CUNE R7 | | . 001 | PUSH | AJMP<br>address 11 CLR bit<br>ipage 61 | CLRbit | CLAC | SWAFA | | | | | | | XCHA | R3 XCHA R4 XCHA | . & | XCHA R6 | xCHA B7 | | of: | POP | ACAL1<br>address 11 SE 1B bit<br>(page 6) | SE 1B bit | SETBC | DA A | DUNZ<br>direct, rel | xCHDA . | XCHD A | DUNZ RG | DJNZ R1 | DUNZ R2 | DUNZ R3 | DJNZ R4 | DUNZ R5 | DJNZ R6 | DJNZ R7 | | 1.10 | MOVX A DPTR | AJMP<br>address 11<br>tpage 73 | MOVX A | MOVX A | CLRA | MOVA | MOVA "R0 | MOVA | MOVA RO | MOVA R. | MCVA R2 | MOVA R3 | MOVA R4 | MOVA RG MOVA RT MOVA RZ MOVA R3 MOVA R4 MOVA R5 MOVA RE MOVA R7 | MOVA RE | MOV4 R7 | | - <u> </u> | MOVX<br>4 DPTR A | MOVX ACALL ADPTRA address11 | MOVX<br>"RO A | M S S S S S S S S S S S S S S S S S S S | CPLA | MOV direct. | MOV direct,MOV + R0, MOV + R1 | 1 | MCVR0.A | MOVR1 A | WOVR2 A | MCVR3A | MOVR4 A | MCVROA MOVRTA WOVRZA MCVRSA MOVRAA MOVRSA MOVRZA | MOVREA | MOVR7.A | 7.4 Simplified Description of Instructions Note that "data address" is represented as "direct address" in this description. | Page | 177 | 178 | 176 | 175 | 181 | 182 | 180 | 179 | 287 | 288 | 286 | 285 | 263 | 212 | 9,<br>on 206 | |---------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------|--------------------------------|-----------------------------------------------------------------------------------|----------------------------------------------|--------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------|-----------------------------------------|----------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Description | $(AC),(OV),(C),(A) \leftarrow (A)+(Rr)$ $r=0-7$ | $(AC)_{\cdot}(OV)_{\cdot}(C)_{\cdot}(A) \leftarrow (A) + (direct address)$ | $(AC).(OV).(C).(A) \leftarrow (A)+((Rr))$ r=0 or 1 | (AC),(OV),(C),(A) — (A) +#data | $(AC)_{\cdot}(OV)_{\cdot}(C)_{\cdot}(A) \leftarrow (A) + (C) + (Rr) r = 0 \sim 7$ | (AC),(OV),(C),(A) — (A)+(C)+(direct address) | $(AC),(OV),(C),(A) \leftarrow (A)+(C)+((Rr))$ r=0 or 1 | (AC),(OV),(C),(A) — (A)+(C)+#data | $(AC)_{*}(OV)_{*}(C)_{*}(A) - (A)_{*}(C)_{*}(R)_{*} = 0 - 7$ | (AC).(OV),(C).(A) (A)-((C)+(direct address)) | $(AC)_{r}(OV)_{r}(C)_{r}(A) \leftarrow (A)_{r}(C)_{r}(Rr)_{r}(Rr)_{r}$ | (AC),(OV),(C),(A) — (A)—((C)+#data) | $(AB) \leftarrow (A) \times (B)$ | (A) quotient, (B) remainder — (A)/(B) | If the contents of accumulator bits 0 thru 3 exceed 9, or the auxiliary carry (AC) is 1, 6 is added to bits 0 thru 3. And if examination of bits 4 thru 7 shows that the result of adding the carry following correction of the lower order bits 0 thru 3 by 6 is in excess of 9, or carry (C) is 1, 6 is added to bits 4 thru 7. If a carry | | Cycle | - | - | - | - | - | - | _ | <del>-</del> | - | - | - | <b>-</b> | 4 | 4 | - | | Byte | - | 2 | - | 2 | - | 2 | - | 5 | - | 2 | - | 2 | <br> - | - | - | | Instruction code<br>D7 D6 D5 D4 D3 D2 D1 D0 | 0 0 1 0 1 12 11 10 | 0 ; | 0 1 0 | 0 1 0 0 1 0 | 0 0 1 1 1 1 12 11 10 | 0 0 1 1 0 1 0 1 0 1 av av av av av | 0 0 1 1 0 1 1 0 | 0 0 1 1 0 1 0 0<br>17 le ls l4 l3 l2 l1 l0 | 1 0 0 1 1 12 1 10 | 1 0 0 1 0 1 0 1 a7 a6 a5 a4 a3 a2 a1 a0 | 10010116 | 1 0 0 1 0 1 0 0 0 1 1 1 1 1 1 1 1 1 1 1 | 1 0 1 0 0 1 0 0 | 10000100 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | Mnemonic | ADD A, Rr | ADD A, direct | ADD A, @Rr | ADD A, # data | ADDC A, Rr | ADDC A, direct | ADDC_A, @Rr | ADDC A, # data | SUBB A, Rr | SUBB A, direct | SUBB A, @Rr | SUBB A, #data | MUL AB | DIV AB | DA A | | CPL A 1 1 1 0 0 1 0 0 1 1 1 (A) -0 CPL A 1 1 1 1 0 1 0 0 1 1 1 (A) -(A) | |--------------------------------------------------------------------------| | A 1 1 1 1 0 1 0 0 1 1 $(A) - \overline{(A)}$ | | | | | | RLC A 0 0 1 1 0 0 1 1 1 1 Carry Accumulator | | RR A 00000011 1 1 Carry | | A 0 0 0 0 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 | | A A | | A A A A A A A A A A A A A A A A A A A | | | | A A A | | 4 4 | | 0 0 | | 4 4 | | | | RLC<br>RRC | | | | | Page | 218 | 220 | 1 | 221 | 217 | 0.10 | 506 | 210 | 2 | 211 | 208 | 2 2 2 | 2 | 187 | 185 | ) | 184 | | 191 | | 190 | 787 | 107 | 268 | 266 | 004 | 265 | |------------------|-------------------------|--------------------------|-------------------------------------|-----------------|----------------------------------------------------|----------------------------------------------------|---------------------|--------------------------|-----------------------------------------|-----------------|-----------------------------------------|---------------------------------------------|----------------------------------------|-----------------|-------------------------------------------|------------------------------------------------------------------|-----------------|-------------------------|-----------------|---------------------------------------------|-------------------|------------------------------------------------------|---------------------------------------|-----------------|------------------------------------------|------------------------------|-----------------|-------------------------| | | Description | $(A) \leftarrow (A) + 1$ | $(Rr) \leftarrow (Rr)+1$ $r=0\sim7$ | | (direct address) $\leftarrow$ (direct address) + 1 | $((Rr)) \leftarrow ((Rr)) + 1$ $r=0 \text{ or } 1$ | (DPTR) ← (DPTR) + 1 | $(A) \leftarrow (A) - 1$ | $(Rr) \leftarrow (Rr) - 1$ $r=0 \sim 7$ | | (direct address) → (direct address) → 1 | $((Rr)) \leftarrow ((Rr)) - 1$ $r = 0$ or 1 | (A) $\leftarrow$ (A) AND (Rr) $r=0$ ~7 | | (A) $\leftarrow$ (A) AND (direct address) | $(A) \leftarrow (A) \text{ AND ((Rr))} \qquad r=0 \text{ or } 1$ | | (A) ← (A) AND #data | | (direct address) ← (direct address) AND (A) | | (direct address) ← (direct address) AND #data | (A) $\leftarrow$ (A) OB (Br) $r=0.27$ | | $(A) \leftarrow (A) OR (direct address)$ | (A) — (A) OR ((Rr)) r=0 or 1 | | (A) ← (A) OR #data | | - | Cycle | - | - | , | - | - | 2 | - | - | , | _ | - | - | , | _ | - | ļ , | _ | , | _ | | 2 | - | | | - | | | | | Byte | - | - | | N | - | - | - | - | | N | - | - | | N | - | | N | C | ٧ | | က | - | | N | - | , | 7 | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 0 0 0 0 0 0 0 0 0 | 0 0 0 0 1 12 11 10 | 0 0 0 0 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 0 0 0 0 1 1 10 | 1010011 | 0 0 0 1 0 1 0 0 | 0 0 0 1 1 12 11 10 | 0 0 0 1 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 0 0 1 0 1 1 ro | 0 1 0 1 1 1 1 1 10 | 0 1 0 1 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 1 0 1 0 1 1 10 | 0 1 0 1 0 1 0 0 | 17 le 15 14 13 12 11 10 | 0 1 0 1 0 0 1 0 | a7 a6 a5 a4 a3 a2 a1 a0 | 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0<br> 17 6 5 4 3 2 1 0 | 0 1 0 0 1 12 11 10 | 0 1 0 0 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 1 0 0 0 1 1 ro | 0 1 0 0 0 1 0 0 | 17 16 15 14 13 12 11 10 | | Momorpio | | NC A | INC Rr | INC direct | | INC @Rr | INC DPTR | DEC A | DEC Rr | DEC direct | | DEC @Rr | ANL A, Rr | ANL A, direct | | ANL A, @Rr | ANL A, #data | | ANL direct, A | | ANL direct, #data | | ORL A, Rr | ORL A, direct | | ORL A, @Rr | ORL A, #data | | | Classifi- | cation | | | n zęk | ni 1 | | | | | | ı.eu | | * | <del>*</del> | | 1 | | .nc | | i uc | | ıədo | Ш. | L. | l<br>7 | J | | - | | | Page | 010 | 2/2 | | 271 | | 296 | | 297 | 295 | | 294 | 0 | 662 | | 298 | | 242 | | <br>α4. | | 252 | | 0 | 239 | | 247 | |-------------|-------------------------|-----------------|--------------------------------------------|-----------------|----------------------------------------------|------------------|-----------------------------|-----------------|--------------------------------|-------------------------------|-----------------|-------------------------|-----------------|---------------------------------------------|---------------|-----------------------------------------------|-----------------|------------------------|------------------------|------------------------|-----------------|--------------------------|-------------|------------------|-------------------------|---------|----------------------| | | Description | | (direct address) — (direct address) On (A) | | (direct address) ← (direct address) OR #data | | (A) — (A) XOR (Rr) $r=0$ ~7 | | (A) — (A) AOR (direct address) | (A) — (A) XOR ((Rr)) r=0 or 1 | | (A) — (A) XOR #data | | (direct address) — (direct address) AOR (A) | | (direct address) ← (direct address) XOR #data | | (A) — #data | | (RI) — #dala | | (direct address) — #data | | | ((hf)) ← #data | | (DF K) ← #data 6 | | | Cycle | • | - | | 2 | | - | , | - | - | ļ., | _ | | - | | 2 | , | _ | | - | | 2 | | | _ | , | N | | | Byte | c | Ŋ | | က | | - | | 7 | - | - | 2 | C | V | | က | | N | c | V | | ო | | c | V | ( | n | | Instruction | D7 D6 D5 D4 D3 D2 D1 D0 | 0 1 0 0 0 0 1 0 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 1 0 0 0 0 1 1 | as a4 a3 a2 | 6 5 4 3 2 1 | 0 1 1 0 1 12 11 10 | 0 1 1 0 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 0 1 1 0 0 1 1 10 | 0 1 1 0 0 1 0 0 | 17 16 15 14 13 12 11 10 | 0 1 1 0 0 0 1 0 | a/ a6 a5 a4 a3 a2 a1 a0 | 1 1 0 0 0 1 | az as | 0 1 1 1 0 1 0 0 | 17 6 15 14 13 12 11 10 | 0 1 1 1 1 1 1 2 1 1 10 | 17 6 15 14 13 12 11 10 | 0 1 1 1 0 1 0 1 | as a4 a3 | 6 5 4 3 2 1 | 0 1 1 1 0 1 1 10 | 17 16 15 14 13 12 11 10 | 1001000 | | | | Mnemonic | direct, A | | . direct, #data | | | A, Br | A, direct | | A, @Rr | A, #data | | direct, A | | direct, #data | | / A, #data | | / Rr, #data | | / direct, #data | | | / @Rr, #data | | | #uala lo | | | ÷ c | ORL | | ORL | | 211 | XRL | XRL | | XRL | XRL | | XRL | | XRL | | MOV | 0110 | NOW<br>No. | · · · · · · | MOV | 129 | c p | MOV | מוב ו | MOV | | | | Cation | | | | o u ( | oit: | JULA. | tani | uO | iten | <del>o</del> u( | י וע: | ogio | ' | | | Suc | vita | i i at S | uir | -ui | 40: | J 5 | +αh | ote | ibə | u c | | ( | Page | 201 | 281 | 204 | 188 | 189 | 569 | 270 | 246 | 251 | - 282 | 202 | 205 | |------------------|-------------------------|-----------------|-----------------|---------------------------------|--------------------------------------------|-------------------------------------------|--------------------------------------------|-----------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------| | | Description | 0 → (C) | (C) − 1 | $(C) \leftarrow \overline{(C)}$ | (C) — (C) AND (bit address) | (C) — (C) AND (bit address) | (C) ← (C) OR (bit address) | (C) — (C) OR (bit address) | (C) ← (bit address) | (bit address) ← (C) | (bit address) — 1 | (bit address) — 0 | (bit address) — (bit address) | | | Cycle | - | - | - | 2 | 2 | 2 | 2 | - | 2 | ,- | - | - | | | Byte | - | - | - | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | 2 | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 1 1 0 0 0 0 1 1 | 1 1 0 1 0 0 1 1 | 10110011 | 1 0 0 0 0 0 1 0<br>b7 be b5 b4 b3 b2 b1 b0 | 1 0 1 1 0 0 0 0 0 b7 b6 b5 b4 b3 b2 b1 b0 | 0 1 1 1 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | 1 0 1 0 0 0 0 0 0 0 0 b7 b6 b5 b4 b3 b2 b1 b0 | 1 0 1 0 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | 1 0 0 1 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | 1 1 0 1 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | 1 1 0 0 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | 1 0 1 1 0 0 1 0<br>b7 b6 b5 b4 b3 b2 b1 b0 | | | Minemonic | CLR C | SETB C | CPL C | ANL C, bit | ANL C, /bit | ORL C, bit | ORL C, /bit | MOV C, bit | MOV bit, C | SETB bit | CLR bit | CPL bit | | Classifi- | cation | | | | enoitor | unstru<br>, | operatio | rry flag | БЭ | | | operati<br>structio | | | Page | ) | 244 | 245 | | 243 | 249 | 250 | | 254 | | 255 | | | 256 | | 253 | | 240 | 241 | 7 | 257 | 258 | | |------------------|-------------------------|------------------------|-----------------------------------|-------------------------|---------------------------------------------|-----------------------------------------|-----------------------------------------|-------------------------|-----------------------------------|-------------------------|---------------------------------------------------|-------------------------|---------------|-----------------------------------------|--------------------------|-------------------------------------------------------------------------------------------------------|-------------------------|-----------------------|------------------------------------|-------------------------|---------------------------------|---------------------------------------|---| | Description | | (A) - (Rr) $r = 0 - 7$ | $(A) \leftarrow (direct address)$ | | $(A) \leftarrow ((Rr))$ $r=0 \text{ or } 1$ | $(Rr) \leftarrow (A)$ $r=0 \sim 7$ | $(Rr) \leftarrow (direct address) r=0$ | | $(Airect address) \leftarrow (A)$ | | (direct address) $\leftarrow$ (Br) $r=0$ $\sim$ 7 | 1 | | (direct address 1) ← (direct address 2) | | $ (\operatorname{direct} \operatorname{address}) \leftarrow ((\operatorname{Rr})) r=0 \text{ or } 1$ | | ((Rr)) ← (A) r=0 or 1 | ((Rr)) — (direct address) r=0 or 1 | | $(A) \leftarrow ((A) + (DPTR))$ | (PC) - (PC) + 1<br>(A) - ((A) + (PC)) | | | oloy C | Cycle<br>Display | _ | - | | - | - | ٥ | , | <del>,</del> | - | 0 | 1 | <u> </u> | 7 | | · | 1 | - | · - | ı | 2 | N | | | t t | و<br>م<br>م | - | 2 | | - | - | 6 | J | c | ٧ | | 1 | | ო | | c | 1 | - | ۰<br>د | ۷ | ļ <b>,</b> - | - | | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 1 1 1 0 1 12 11 10 | | a7 a6 a5 a4 a3 a2 a1 a0 | 1 1 1 0 0 1 1 10 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 0 1 0 1 12 11 10 | a7 a6 a5 a4 a3 a2 a1 a0 | 1 1 1 1 0 1 0 1 | a7 a6 a5 a4 a3 a2 a1 a0 | 1 0 0 0 1 12 11 10 | a7 a6 a5 a4 a3 a2 a1 a0 | 10000101 | a72 a62 a52 a42 a32 a22 a 12 a 02 | a,1ae1a51a41a31a21a11a01 | 1 0 0 0 0 1 1 ro | a7 a6 a5 a4 a3 a2 a1 a0 | 1 1 1 1 0 1 1 10 | 10100110 | a7 a6 a5 a4 a3 a2 a1 a0 | 1 0 0 1 0 0 1 1 | 1 0 0 0 0 0 1 1 | | | | Mnemonic | MOV A, Rr | MOV A, direct | | MOV A, @Rr | MOV Rr, A | MOV Rr, direct | | MOV direct, A | | MOV direct, Rr | <u> </u> | MOV direct 1, | direct 2 | | MOV direct, @Rr | | MOV @Rr, A | MOV @Rr, direct | | MOVC A, @A+DPTR | MOVC A, @A+PC | | | assift- | cation | 2 | | | | | | suc | | stru | ni 19 | lsni | - | Dat<br>——— | | 1 | | | <u> </u> | | su | Constant<br>Salue<br>Satructic | ! | #### 2.5 Timing and Control #### 2.5.1 Outline of MSM80C31/MSM80C51 timing The MSM80C31/MSM80C51 is equipped with a built-in inverter (see Figure 2-5) for use in the generation of clock pulses by external crystal or ceramic resonator. These clock pulses are passed to the timing counter and control circuits where the basic timing and control signals required for internal control are generated. The basic timing consists of S1 thru S6 (see Figure 2-6) where each timing cycle is based on the 2 XTAL1 $\cdot$ 2 fundamental clock pulses. The interval from S1 thru S6 forms a single machine cycle with a total of 12 clock pulses. 1-byte 1-machine cycle and 2-byte 1-machine cycle instructions are fetched by instruction register during M1 $\cdot$ S1 cycle, decoded during M1 $\cdot$ S2 cycle, and executed during M1 $\cdot$ S3 thru M1 $\cdot$ S6 cycle. The second byte is fetched during M1 $\cdot$ S4 cycle. 1-byte 2-machine cycles, 2-byte 2-machine cycles, and 3-byte 2-machine cycles instructions are also fetched during M1 · S1, decoded during M1 · S2, and executed during M1 · S3 thru M2 · S6. The second byte and third byte is fetched during M1 · S4, M2 · S1, or M2 · S4. The number of clocks used is 24. 1-byte 4-machine cycles instructions are involved in multiplication and division operations where 48 clocks are used. Figure 2-5 Oscillator, timing counter, and control stage block diagram | | Page | | 291 | 000 | 1 | 290 | 293 | 274 | | 273 | | | - | | 174 | | | | | | 237 | | | |------------------|-------------------------|-----------------|-------------------------|-------------------------|------------------|------------------|-----------------------------|----------------------------------------------|--------------------------------------------------|----------------------------|-----------------------|-----------------|----------------------------|--------------------------------|----------------------------|---------------------------------|------------------|-----------------|--------------------------|--------------------------------|----------------------------|------------------------------------|--| | | Description | | $(A) = (Rr)$ $r=0\sim7$ | (A) = (direct address) | (V) | | (Ao-3) = ((Hro-3)) r=0 or 1 | (SP) - (UP) + <br>((SP)) - (direct address) | (Constant to | $(SP) \leftarrow (SP) - 1$ | | (PC) - (PC) + 2 | $(SP) \leftarrow (SP) + 1$ | $((SP)) \leftarrow (PC_{0-7})$ | $(SP) \leftarrow (SP) + 1$ | $((SP)) \leftarrow (PC_{8-15})$ | (PC₀-10) ← A₀-10 | (PC) ← (PC) + 3 | (SP) ← (SP) + 1 | $((SP)) \leftarrow (PC_{0-7})$ | $(SP) \leftarrow (SP) + 1$ | $((SP)) \leftarrow (PC_{8^{-1}5})$ | | | | Cycle | | - | - | | - - | - | α, | | 8 | | | | | <u> </u> | | | | | | 2 | _= | | | | Byte | - | - | 8 | - | - | | 7 | | ~ - | | | | | <br>v | | | | | C | უ | | | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 1 1 0 0 1 5 7 5 | | a7 a6 a5 a4 a3 a2 a1 a0 | 1 1 0 0 0 1 1 10 | 1 1 0 1 0 1 1 10 | 1 1 0 0 0 0 0 0 0 | a <sub>2</sub> a <sub>1</sub> | 1 1 0 1 0 0 0 0 | a7 a6 a5 a4 a3 a2 a1 a0 | Ατο Δο Δο 1 Ο Ο Ο ο 1 | | A7 A6 A5 A4 A3 A2 A1 A0 | | | | | 0 0 0 1 0 0 1 0 | A15A14A13A12A11A10 A9 AB | A7 A6 A5 A4 A3 A2 A1 A0 | | | | | Momoria | | XCH A, Rr | XCH A direct | | XCH A, @Rr | XCHD A, @Rr | PUSH direct | | POP direct | | ACALL addr 11 | | | | | | | LCALL addr 16 | | | | | | | Classifi | Callor | 6 | Suc | exchs<br>ructio | itani | | <u> </u> | | | | | | ניטכ | sui | əu | ļno | npr | | | | | _ | | | Classifi- | , | | Instru | Instruction code | 4 | 9 | C | | |----------------|--------------|---------|--------------------------------------------|-----------------------------------------------------------------------|--------------|-------|--------------------------------------------------------------------------------------------|--------------| | uo | MINIME | | D7 D6 D5 [ | D7 D6 D5 D4 D3 D2 D1 D0 | Буте | Cycle | Description | rage<br>Lage | | | RET | | 0 0 1 | 0 0 0 1 0 | | | $(PC_{8^{-1},5}) \leftarrow ((SP))$ | | | notruction<br> | | | | | <del>-</del> | 8 | $(SP) \leftarrow (SP) - 1$<br>$(PC_{0-7}) \leftarrow ((SP))$<br>$(SP) \leftarrow (SP) - 1$ | 275 | | | RETI | | 0 0 1 | 1 0 0 1 0 | | | $(PC_{8-15}) \leftarrow ((SP))$<br>$(SP) \leftarrow (SP) - 1$ | | | — — | | | = | | _ | 7 | (PC₀-₁) ← ((SP))<br>(SP) ← (SP) − 1<br>• INTERRUPT ENABLE | 276 | | | AJMP addr 11 | dr 11 | A 10 A 9 A 8 O O O A 7 A 8 A 5 A 4 A 3 A 2 | A 10 A 9 A 8 O O O O O 1<br>A 7 A 5 A 5 A 4 A 3 A 2 A 1 A 0 | 2 | 5 | (PC) - (PC) + 2<br>(PCo-10) - Ao-10 | 183 | | nstructions | LJMP addr 16 | dr 16 | 0 0 0<br>A15A14A13A<br>A7 A6 A5 | 0 0 0 0 0 0 1 0<br>A15A14A13A12A11A10A9 A8<br>A7 A6 A5 A4 A3 A2 A1 A0 | м | 2 | (PCo-15) — A0-15 | 238 | | ı dune | SJMP rel | | 1 0 0<br>R, R, R | 0 0 0 0 0 0 R4 R3 R2 R1 R0 | 8 | 8 | (PC) $-$ (PC) + 2<br>(PC) $-$ (PC) + relative offset | 283 | | | JMP @A | @A+DPTR | 0 | 1 0 0 1 1 | +- | 2 | (PC) ← (A) + (DPTR) | 228 | | 1 | | _ | Instruction code | ot. C | 0 | | nointintintin | O C C | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|--------|-------------------|-------|-------|----------|----------------------------|-----------| | (PC) - (PC) + 3 F | D7 D6 D5 | 6 D5 | D4 D3 D2 D1 D0 | e)(e | Cycle | | Describinon | rage<br>e | | 3 2 (PC) — (PC) + relative offset THEN (PC) — (PC) + relative offset THEN (C) — 1 (PC) — (PC) + 3 F (A) ≠ #data THEN (C) — 0 (PC) — (PC) + relative offset THEN (C) — 0 (PC) — (PC) + relative offset THEN (C) — 1 ELSE (C) — 0 (PC) — (PC) + relative offset THEN (C) — 1 ELSE (C) — 0 (PC) — (PC) + relative offset THEN (C) — 1 THEN (C) — 1 THEN (C) — 1 THEN (C) — 1 | A, direct, rel 1 0 1 | | 0 | - | | | PC) + 3 | | | 3 2 PC) - (PC) + relative offset | a, a6 a | o<br>a | a4 a3 a2 a1 | | | | A) $\neq$ (direct address) | | | 3 2 (PC) - (PC) + relative offset THEN (C) - 1 ELSE (C) - 0 (PC) - (PC) + 3 IF (A) ≠ #data THEN THEN (C) - 1 ELSE (C) - 0 (PC) - (PC) + falative offset THEN (C) - 1 ELSE (C) - 0 (C) - 0 (PC) - (PC) + 3 IF (RI) ≠ #data r=0~7 THEN (C) - 1 ELSE (C) - 0 (PC) - (PC) + 3 THEN (C) - 1 ELSE (C) - 0 THEN (C) - (PC) + 3 THEN (C) - (PC) + 4 THEN (C) - (PC) + 6 THEN (C) - (PC) + 7 THEN (C) - (PC) + 7 THEN (C) - 1 ELSE (C) - 0 | B, Re B | E B | 5 R4 R3 R2 R1 R0 | | | THEN | | | | 3 F (A) < (direct address) THEN (C)1 ELSE (C)0 (PC) (PC) + 3 F (A) ≠ # data THEN (C) (PC) + relative offset THEN (C)1 ELSE (C)0 (PC) (PC) + 3 F (RT) ≠ # data r=0~7 THEN (C) (PC) + relative offset 3 PC (PC) (PC) + 3 F (RT) ≠ # data r=0~7 THEN (C) 1 F (RT) < # data r=0~7 THEN (C) 1 ELSE (C) 0 | | | | C | C | | PC) + relative offset | | | 3 2 (C) - 1 ELSE (C) - 0 (PC) - (PC) + 3 IF (A) ≠ #data THEN THEN (C) - 1 ELSE (C) - 0 (C) - 1 ELSE (C) - 0 (C) - 1 FR (RT) ≠ #data r=0~7 THEN (C) - 1 ELSE (C) - 0 THEN (C) - 1 ELSE (C) - 0 THEN (C) - 1 ELSE (C) - 0 THEN (C) - 1 ELSE (C) - 0 | | | | n | N | | A) < (direct address) | - | | C() - 1<br> ELSE | | | | | | THEN | | 96 | | BLSE (C)0 (PC) - (PC) + 3 IF (A) ≠ #data THEN THEN (C)1 ELSE (C)0 (PC) - (PC) + relative offset (C)0 (PC) - (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN (C)1 ELSE (C)0 THEN THEN (C)1 ELSE (C)0 THEN (C)0 THEN (C)1 ELSE (C)0 (C)0 THEN (C)1 ELSE (C)0 (C)0 THEN (C)1 ELSE (C)0 | | | | | | | C) - 1 | | | (C) 0 (PC) - (PC) + 3 F (A) ≠ #data THEN THEN (C) 1 ELSE (C) 0 (PC) - (PC) + relative offset THEN (C) 1 ELSE (C) 0 (PC) - (PC) + 3 F (Rr) ≠ #data r=0~7 THEN THEN (C) 1 F (Rr) ≠ #data r=0~7 THEN (C) 1 F (Rr) ≠ #data r=0~7 THEN (C) 1 F (Rr) < #data r=0~7 THEN (C) 1 F (Rr) < #data r=0~7 THEN (C) 1 | | | | | | ELSE | | | | (PC) — (PC) + 3 F | | | | | | _ | 0 () | | | 3 2 F (A) # #data THEN THEN (PC) - (PC) + relative offset THEN (C) - 1 ELSE (C) - 0 (PC) - (PC) + 3 IF (Rr) # #data r=0~7 THEN (PC) - (PC) + relative offset THEN (C) - 0 (C) - 0 (C) - 0 (C) - 0 THEN (C) - 0 (C) - 1 ELSE (C) - 0 | A, #data, rel 1 0 | | 0 | | , | (PC) — ( | PC) + 3 | | | THEN (PC) ← (PC) + relative offset IF (A) < #data THEN (C) ← 1 ELSE (C) ← 0 (PC) ← (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN (PC) ← (PC) + relative offset IF (Rr) < #data r=0~7 THEN (C) ← 0 (C) ← 0 (C) ← 0 (DC) ← (PC) + relative offset (C) ← 0 (DC) ← (PC) + relative offset (C) ← 0 (C) ← 0 | 17 16 | 9 | 4 3 2 1 | - | | | (A) ≠ #data | | | 3 2 (PC) — (PC) + relative offset THEN (A) < #data THEN (C) — 1 ELSE (C) — 0 (PC) — (PC) + 3 IF (Rr) # #data r=0~7 THEN (C) — 1 THEN (C) — 1 ELSE (C) — 0 (C) — 0 THEN (C) — 1 ELSE (C) — 0 | B, B, B | ~<br>E | R5 R4 R3 R2 R1 R0 | | | THEN | | | | 3 F (A) < #data THEN (C)1 ELSE (C)0 (PC) (PC) +3 IF (Rr) ≠ #data r=0~7 THEN (C) (PC) + relative offset 1 F (Rr) < #data r=0~7 THEN (C) 1 ELSE (C) 0 | | | | C | | | (PC) + relative offset | | | THEN (C) — 1 ELSE (C) — 0 (PC) — (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN 3 2 (PC) — (PC) + relative offset IF (Rr) < #data r=0~7 THEN (C) — 1 ELSE (C) — 0 | _ | | | ກ | Ν | | (A) < #data | 194 | | (C) - 1 ELSE (C) - 0 (PC) - (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN (PC) - (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN (C) - 1 ELSE (C) - 0 | | | | | | THEN | | | | ELSE (C)0 (PC) (PC) + 3 IF (Rr) # #data r=0~7 THEN (PC) (PC) + relative offset (PC) (PC) + relative offset THEN (C) 1 ELSE (C)0 | | | | | | _ | (C) → 1 | | | (C) 0 (PC) (PC) + 3 IF (Rr) ≠ #data r=0~7 THEN (PC) (PC) + relative offset (PC) (PC) + relative offset THEN (C) 1 ELSE (C) 0 | - | | | | | ELSE | | | | (PC) — (PC) + 3 IF (Rr) # #data r=0~7 THEN (PC) — (PC) + relative offset IF (Rr) < #data r=0~7 THEN (C) — 1 ELSE (C) — 0 | | | | | | - | 0 - (C) | | | 3 2 $ F $ (Rr) ##data $r=0 \sim 7$ THEN (PC) — (PC) + relative offset IF (Rr) < #data $r=0 \sim 7$ THEN (C) — 1 ELSE (C) — 0 | Rr,#data, rel 1 0 | 0 | ت | | | 1 | (PC) + 3 | | | 3 2 (PC) — (PC) + relative offset 1 (PC) — (PC) + relative offset 1 | | 9 | 15 4 13 12 11 | | | | | | | $ \begin{array}{c c} PC) - (PC) + relative offset \\ \hline PC & (Rr) < \#data & r=0 \sim 7 \\ \hline THEN & (C) \leftarrow 1 \\ \hline ELSE & (C) \leftarrow 0 \\ \end{array} $ | R <sub>7</sub> R <sub>6</sub> | ů, | Rs R4 R3 R2 R1 R0 | | | THEN | | _ | | IF (Rr) < #data $r=0$ ~7<br>THEN (C) $\leftarrow$ 1<br>ELSE (C) $\leftarrow$ 0 | | | | | | | (PC) + relative offset | | | | | | | უ | N | | | 198 | | | | | | | | THEN | | | | | | | | | | | $(C) \leftarrow 1$ | | | 0 → (O) | | | | | | ELSE | | | | | | | | | | | 0 → (O) | | | | Page | | | | | 0 | 192 | | _ | | | | | ر<br>ا<br>ا | _ | | | 215 | | | |------------------|-------------------------|----------------------------|----------------------------|-------------------------|-------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|---------|--------------------|-------------------------------------|-----|-------------|-------------------------------|------------------|----------------------------------------------------|------------------------------|------|------------------------------------------| | | Description | $(PC) \leftarrow (PC) + 3$ | IF ((Rr)) ≠ #data r=0 or 1 | NHEN | (PC) ← (PC) + relative offset | IF ((Rr)) < #data r=0 or 1 | THEN THE PROPERTY OF PROPE | (C) — 1 | ELSE | 0 — (O) | (PC) - (PC) + 2 | $(Rr) \leftarrow (Rr)-1$ $r=0\sim7$ | | ZHE | (PC) ← (PC) + relative offset | (PC) (PC) + 3 | $(direct address) \leftarrow (direct address) - 1$ | IF (direct address) $\neq 0$ | THEN | $(PC) \leftarrow (PC) + relative offset$ | | | Cycle | | | | C | N | | | | | | | 2 | | | | | 2 | | | | 4.0 | e) de | | | | c | ກ | | | | | | | α | | | | | ო | | | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 10110110 | 7 6 5 4 3 2 1 0 | R7 R6 R5 R4 R3 R2 R1 R0 | | | | | | | 1 1 0 1 1 12 11 10 | R7 R6 R5 R4 R3 R2 R1 R0. | | | | 11010101 | a7 a6 a5 a4 a3 a2 a1 a0 | R7 R6 R5 R4 R3 R2 R1 R0 | - | | | N omound | | CJNE @Rr, #data, | rel | | | | | | | | DJNZ Rr, rel | | | | | DJNZ direct, rel | | | | | | Classifi- | cation | | | | | | | su | oit:<br>_ | ינגחכ | sui E | buid | วนช | Bra | | | | | | | | Page | | 235 | 233 | 526 | - 231 | 222 | 529 | 224 | |------------------|-------------------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------| | Description | | (PC) — $(PC)$ + 2<br>IF $(A)$ = 0<br>THEN<br>(PC) — $(PC)$ + relative offset | $(PC) \leftarrow (PC) + 2$ IF $(A) \neq 0$ THEN $(PC) \leftarrow (PC) + relative offset$ | $\begin{array}{lll} (PC) \leftarrow & (PC) + 2 \\ IF & (C) = 1 \\ THEN \\ (PC) \leftarrow & (PC) + relative offset \end{array}$ | (PC) (PC) + 2<br>IF (C) = 0<br>THEN<br>(PC) (PC) + relative offset | (PC) — (PC) + 3 IF (bit address) = 1 THEN (PC) — (PC) + relative offset | (PC) ← (PC) + 3<br> F | (PC) ← (PC) + 3 IF (bit address) = 1 THEN (bit address) ← 0 (bit address) ← 0 (PC) ← (PC) + relative offset | | Cycle | , | 2 | N | 8 | α | α | N | α | | Byte | | N | ~ | 8 | 0 | ო | , m | n | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 1 1 1 0 0 0 0<br>B7 R6 R5 R4 R3 R2 R3 R0 | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | Mnemonic | rel | JNZ rel | le l | JNC rel | JB bit, rel | UNB bit, rel | JBC bit, rel | | - Howariti- | cation | Zr | ر ا | L | noing instruction | 1 — — | 1 1 | l | | | Page | 192 | 213 | 215 | |------------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | | Description | (PC) ← (PC) + 3<br>IF ((Rr)) ≠ #data r=0 or 1<br>THEN<br>(PC) ← (PC) + relative offset<br>IF ((Rr)) < #data r=0 or 1<br>THEN<br>(C) ← 1<br>ELSE<br>(C) ← 0 | $(PC) - (PC) + 2$ $(Rr) - (Rr) - 1$ $IF$ $(Rr) \neq 0$ $r = 0 - 7$ THEN $(PC) - (PC) + relative offset$ | (PC) — (PC) + 3 (direct address) — (direct address) − 1 IF (direct address) ≠ 0 THEN (PC) — (PC) + relative offset | | | Cycle | N | CV. | ~ | | | Byte | n | 8 | m | | Instruction code | D7 D6 D5 D4 D3 D2 D1 D0 | 1 0 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 1 0 1 1 12 11 10 R7 R6 R5 R4 R3 R2 R1 R0 | 1 1 0 1 0 1 0 1 0 1<br>a7 a6 a5 a4 a3 a2 a1 a0<br>B7 R6 R5 R4 R3 R2 R1 R0 | | Momoric | | CJNE @Rr, #data, rel | DJNZ Rr, rel | DJNZ direct, rel | | Classifi- | cation | structions | Branching in | | | A LOS COLORS | Instruction code | | | | | | | |---------------|-------------------------|-------------|-------|----------------|-----------------|----------|------| | Mnemonic | D7 D6 D5 D4 D3 D2 D1 D0 | Byte | Cycle | | Description | | Page | | MOVX A, @Rr | 1 1 1 0 0 0 1 10 | - | 2 | (A) — ((Rr)) | EXTERNAL RAM r= | r=0 or 1 | 262 | | MOVX A, @DPTR | 1 1 1 0 0 0 0 0 | - | 8 | (A) — ((DPTR)) | EXTERNAL RAM | | 261 | | MOVX @Rr, A | 1 1 1 1 0 0 1 10 | <del></del> | 5 | ((Rr)) ← (A) | EXTERNAL RAM r= | r=0 or 1 | 260 | | MOVX @DPTR, A | 1 1 1 1 0 0 0 0 | · | 5 | ((DPTR)) — (A) | EXTERNAL RAM | | 259 | | | 0 0 0 0 0 0 0 | - | - | (PC) ← (PC) +1 | | | 264 | | | | | | | | | | # 7.5 Detailed Description of MSM80C31/MSM80C51 Instructions Note: "direct address" is represented as "data address" in this detailed description. # 1. ACALL code address (Absolute call within 2K byte page) 0 Instruction code **A** 10 A<sub>9</sub> Aя 1 O O n 1 Byte 1 7 0 Call address **A** 7 Ae Аs Аз Αa Αı A٥ A<sub>4</sub> Byte 2 Operation : $(PC) \leftarrow (PC) + 2$ $(SP) \leftarrow (SP) + 1$ $((SP)) \leftarrow (PC_{0^{-7}})$ $(SP) \leftarrow (SP) + 1$ $((SP)) \leftarrow (PC_{8^{-15}})$ $(PC_{0^{-10}}) \leftarrow A_{0^{-10}}$ Number of bytes : 2 Number of cycles : 2 Flags : C AC F0 RS1 RS0 OV F1 P Description : This instruction stores the program counter value (return address) in the stack following an increment operation. The program counter data $PC_0 \sim PC_{10}$ following PC+2 is replaced by 11-bit page address data $A_0 \sim A_{10}$ . The destination address for this instruction must always be within the 2K byte page, but if the instruction is placed at address X7FEH or X7FFH, execution proceeds from the call address on the next page. Byte 1 ## 2. ADD A, #data (Add immediate data) Instruction code 7 0 0 1 0 0 1 0 0 # data Operation : (A) ← (A) + #data AC Number of bytes : 2 Number of cycles : 1 Flags (PSW) : C Description : An 8-bit immediate data value is added to the accumulator. The result is placed in the accumulator RS0 OV and the flags are updated. FO RS1 Example ADD A, #07H Instruction code Before execution After execution F1 Figure 2-6 MSM80C31/MSM80C51 fundamental timing #### 3. ADD A. @Rr (Add indirect address) 7 0 Instruction code : 0 0 1 0 0 1 1 r Operation : (A) $\leftarrow$ (A) + ((Rr)) r = 0 or 1 Number of bytes : 1 Number of cycles : 1 Flags : C AC F0 RS1 RS0 OV F1 P Description : The data memory location contents addressed by the register r are added to the accumulator. The result is placed in the accumulator and the flags are updated. Byte 1 Example ADD A, @RO (PSW) 7 0 Instruction code : 0 0 1 0 0 1 1 0 Byte 1 # 4. ADD A. Rr (Add register) Instruction code 0 0 0 1 Byte 1 r2 **r** 1 ro Operation : (A) ← (A) + (Br) $r = 0 \sim 7$ Number of bytes Number of cycles Flags : 1 (PSW) F0 OV F1 С AC RS1 RS0 Description : The register r contents are added to the accumulator. The result is placed in the accumulator and the flags are updated. Example ADD A, R6 Instruction code Before execution After execution Accumulator 1 0 1 1 0 0 0 1 #### 5. ADD A. data address (Add memory) Instruction code 7 0 0 1 0 0 1 0 1 Data address 7 0 a<sub>7</sub> a<sub>6</sub> a<sub>5</sub> a<sub>4</sub> a<sub>3</sub> a<sub>2</sub> a<sub>1</sub> a<sub>0</sub> Byte 2 Byte 1 Operation : (A) ← (A) + (data address) Number of bytes : 2 Number of cycles : 1 Flags . (PSW) C AC F0 RS1 RS0 OV F1 P Description : The specified data address contents are added to the accumulator. The result is placed in the accumulator and the flags are updated. Example ADD A, P1 Instruction code Byte 1 # 6. ADDC A. #data (Add carry plus immediate data to accumulator) Instruction code 7 0 1 1 0 1 0 0 Operation : $(A) \leftarrow (A) + (C) + \#data$ Number of bytes : 2 Number of cycles : 1 Number of cycles : Flags Flags : C AC F0 RS1 RS0 OV F1 P (PSW) • • • • • • Description : The carry flag is added to the accumulator, and an 8-bit immediate data is added to that result. The result is placed in the accumulator and the flags are updated. Example ADDC A, #76H Instruction code Before execution After execution Carry flag # 2.5.2 Major synchronizing signals (1) ALE (Address Latch Enable) The ALE signal is used as clock signal where the output address signals 0 thru 7 from CPU port 0 can be latched externally when external program memory or external data memory (RAM) is used. Although two ALE signal outputs are obtained in a single machine cycle during normal operations, no output is obtained during output of the RD/WR signal when an external memory instruction (MOVX ......) is executed. (2) PSEN (Program Store Enable) The PSEN output signal is generated during execution of an external program. This output is obtained during the fetch of instructions and data. The PSEN signal is a low active signal, and external program data is enabled when this signal is active. Although two PSEN signal outputs are obtained in a single machine cycle during normal operations, no output is obtained during output of the RD/WR signal when an external memory instruction (MOVX ......) is executed. (3) WR (Write Strobe) The WR output signal is obtained when an external memory instruction (MOVX @Rr. A or MOVX @DPTR, A) is executed. CPU port 0 output data is written in the external RAM when the $\overline{\text{WR}}$ signal is low. (4) RD (Read Strobe) The $\overline{RD}$ output signal is obtained when an external memory instruction (MOVX A.@Rr or MOVX A.@DPTR) is executed. The external RAM is enabled and output data is passed to CPU port 0 when the RD signal is low. # 2.5.3 MSM80C31 fundamental operation time chart Figure 2-7 MSM80C31 external program memory read cycle timing chart Figure 2-8 MSM80C31 MOVX A, @Rr execution Figure 2-9 MSM80C31 MOVX WRr, A execution Figure 2-10 MSM80C31 MOVX A, # DPTR execution Figure 2-11 MSM80C31 MOVX @DPTR, A execution Figure 2-12 MSM80C31 MOV direct, PORT[0, 1, 2, 3] execution # 2 #### 2.5.4 MSM80C51 fundamental operation time chart Figure 2-13 MSM80C51 MOVX A, @Rr execution Figure 2-14 MSM80C51 MOVX @Rr, A execution Figure 2-15 MSM80C51 MOVX A, "DPTR execution Figure 2-16 MSM80C51 MOVX at DPTR, A execution Figure 2-17 MSM80C51 MOV direct, PORT[0, 1, 2, 3] execution ### 2.6 Instruction Register (IR) and Instruction Decoder (PLA) MSM80C31/MSM80C51 operations are based on an instruction code address method. Hence, in addition to the instruction code instruction register (IR) and instruction decoder (PLA), these devices also include an instruction register (AIR) and an instruction decoder (PLA) for data addresses and bit addresses. Operation codes are passed to the IR, and data and bit addresses are passed to the AIR. CPU control signals are formed at the respective PLA, thereby activating the CPU. The block diagram is outlined in Figure 2-18. Figure 2-18 IR and PLA block diagram ethod. uction struc- to the CPU. 2.7 Arithmetic Operation Section (1) Outline The MSM80C31/MSM80C51 arithmetic operation section consists of - (1) an arithmetic operation instruction decoder, and - (2) an arithmetic and logic unit [ALU]. - (2) Arithmetic operation instruction decoder: Arithmetic operation instruction decoder. Arithmetic operation instruction decoder. Arithmetic operation instruction decoder. Arithmetic operation instruction decoder. And the instruction register (IR) and then to the PLA where they are converted into control signals. The control signals from the PLA are used to control ALU peripheral circuits and ALU internal arithmetic operation (AND, OR, ADD, EOR). (3) Arithmetic and logic unit [ALU]: Upon reception of 8-bit data from one or two data sources the ALU processes that data in accordance with control signals from the PLA. The ALU is capable of executing the following processes: - · Additions and subtractions with and without carry - Increments (+1) and decrements (-1) - · Bit complements - Rotations (either direction with and without çarry) - BCD (decimal adjust) - · Carry, auxiliary carry, and overflow signal output - Multiplications and divisions - · Bit detection - Exchange of low and high order nibbles - Logical AND, OR, XOR If a bit-3 auxiliary carry (AC), a bit-7 carry (CY), or an overflow (OV) is generated as a result of the arithmetic operation executed by the ALU, that result is set in the program status word (PSW). #### PSW(D0H) Figure 2-19 Program status word 2 ### 2.8 Program Counter The MSM80C31/MSM80C51 program counter has a 16-bit configuration PC $_{0}$ thruas shown in Figure 2-20. Figure 2-20 MSM80C31/MSM80C51 program counter This program counter is a binary up-counter which is incremented by 1 each time one byte of instruction code is fetched. When the program counter is counted by 1 after counter contents have reached FFFFH, the counter is returned to 0000H. MSM80C51 is automatically switched to external ROM mode when the counter contents exceed 0FFFH, and executes external instructions. 22 MSM80C31 external ROM area 2. **2**. Si de pr Si st by th ar ne 2- ### 2.9 Program Memory and External Data Memory ### 2.9.1 MSM80C31/MSM80C51 program area and external ROM connections Since MSM80C31/MSM80C51 are equipped with a 16-bit program counter, these devices can execute programs of up to 64K bytes (including both internal and external programs). Since the MSM80C31 is not equipped with an internal program ROM, only external instructions are executed. The MSM80C51, on the other hand, is equipped with a 4K byte program ROM which enables it to execute internal instructions from address 0 thru to address 4095. When the address is greater than 4095, external instructions are executed. The program area is outlined in Figure 2-21, and a diagram of ROM connections made when external instructions are executed is shown in Figure 2-22. Figure 2-21 MSM80C31/MSM80C51 program area one after C51 ceed Co thru Figure 2-22 MSM80C31/MSM80C51 external ROM connection diagram S S T t C C t V F S C C C T C # 2.9.2 Procedures and circuit connections used when external data memory (RAM) is read/written by data pointer The MSM80C31/MSM80C51 can be connected to an external 64K word×8-bit data memory (RAM) when accessing the memory by data pointer (DPTR). The data pointer (DPTR) consists of DPL and DPH registers. The DPL register contents serves as addresses 0 thru 7 of the external data memory, the DPH register contents serves as addresses 8 thru 15. The MOVX @DPTR, A instruction is used when accumulator contents are transferred to an external data memory, and the MOVX A, @DPTR instruction is used when external data memory contents are transferred to the accumulator. The external data memory connection diagram is shown in Figure 2-23 and the external data memory access time chart is shown in Figure 2-24. When the data pointer indirect external memory instruction is executed, the CPU passes the DPL register contents to port 0, and the port 0 contents are then latched externally by the ALE signal. Data stored in the latch serves as the lower order addresses 0 thru 7 of the external data memory (RAM), while the DPH register contents output from port 2 serves as the higher order addresses 8 thru 15 for direct addressing of the external data memory. The WR or RD external data memory control signal is subsequently generated by the CPU to enable transfer of data between port 0 and the external data memory. Figure 2-23 Connection circuit for external data memory addressed by DPTR 27 ### MSM80C31/MSM80C51 USER'S MANUAL # 2.9.3 Procedures and circuit connections used when external data memory (RAM) is read/written by registers R0 and R1 The MSM80C31/MSM80C51 can be connected to an external 256 word $\times$ 8-bit data memory (RAM) when addressing the memory by the contents of registers R0 and R1 in the internal data memory (RAM). The MOVX @Rr, A instruction is used when accumulator contents are transferred to an external data memory, and the MOVX A, @Rr instruction is used when external data memory contents are transferred to the accumulator. The external data memory connection diagram is shown in Figure 2-25 and the external data memory access time chart is shown in Figure 2-26. When the register indirect external memory instruction is executed, the CPU passes the R0 or R1 register contents to port 0, and the port 0 contents are then latched externally by the ALE signal. Data stored in the latch serves as the addresses 0 thru 7 of the external data memory. The WR or RD external data memory control signal is subsequently generated by the CPU to enable transfer of data between port 0 and the external data memory. However, if the port 2 latched data is used in addresses 8 thru 15 of the external data memory, the circuit connections are the same as when the data pointer (DPTR) is used, thereby enabling a 64K word×8-bit data memory to be accessed. it data d R1 in rred to al data y cons time exterexterru 7 of subseexter- al data 'TR) is Figure 2-25 Connection circuit for external data memory addressed by register R0 or R1 ## MSM80C31/MSM80C51 USER'S MANUAL 30 # 3. MSM80C31/ *MSM80C51* CONTROL 131 # 3. MSM80C31/MSM80C51 CONTROL # 3.1 Oscillators: XTAL 1 XTAL 2 An oscillator is formed by connecting a crystal or ceramic resonator between the XTAL1 and XTAL2 pins of the MSM80C31/MSM80C51 devices. If an external clock is applied to XTAL1 $\cdot$ 2, the input should be at 50% duty and C-MOS level. - \* The capacity of the compensating capacitor depends on the crystal resonator. - \* The XTAL1 2 frequency depends on Vcc. Figure 3-1 Crystal resonator connection diagram \* Th f = DC \* Th \* Th \* Su en the ty and - \* The capacity of the compensating capacitor depends on the ceramic resonator. - \* The XTAL1 · 2 frequency depends on Vcc. Figure 3-2 Ceramic resonator connection diagram - \* The external clock frequency depends on Vcc. - \* Supply of 50% duty clock Figure 3-3 External clock supply circuit ### 3.2 CPU Resetting ### 3.2.1 Outline If a reset signal (kept at "1" level for at least 1 $\mu$ sec) is applied to the RESET pin when the correct voltage (in terms of the various specifications) is applied to the MSM80C31/MSM80C51 Vcc pin, a reset signal is stored in the CPU even if the XTAL1 · 2 oscillators have been stopped. The internally stored reset signal is used in direct initialization (setting to "1") of ports 0, 1, 2, and 3. All of the special function registers are then initialized (set to "0") two machine cycles after the XTAL1 $\cdot$ 2 oscillator commences regular operation. When the reset is released, instruction execution is started in the third machine cycle if the reset signal is changed from "1"level to "0" level before the M1 · S1 signal leading edge, and in the fifth machine cycle if the reset signal is changed from "1" to "0" after the leading edge. The reset circuit block diagram is shown in Figure 3-4, the reset start time charts in Figures 3-5 and 3-6, and the reset release time charts in Figures 3-7 and 3-8. Figure 3-4 MSM80C31/MSM80C51 reset circuit block diagram 3 n when to the XTAL1 of ports O'') two e cycle eading )" after arts in Figure 3-5 Reset execution time chart (internal ROM mode) Figure 3-6 Reset execution time chart (external ROM mode) Figure 3-7 Reset release time chart (internal ROM mode) Figure 3-8 Reset release time chart (external ROM mode) ### 3.2.2 Reset schmitt trigger circuit The Schmitt trigger circuit connected to the RESET pin shown in Figure 3-4 operates in the following way when the Vcc power supply voltage is +5 V. If the voltage of the input reset signal applied to the RESET pin exceeds 3 V when the level of that signal is changed from "0" to "1", the Schmitt trigger output level is changed from "0" to "1", and the reset signal is set in the CPU reset control circuit, resulting in the reset operation being started by the CPU. The CPU reset state is released when the "1" level on the RESET pin is changed to "0". An input signal level below 1.5 V is regarded as "0" level, and the Schmitt trigger output level is changed from "1" to "0". When the reset signal is changed to "0" level, the CPU reset control circuit is ready for reset release. The Schmitt trigger circuit operation time chart for changes in the reset input voltage is outlined in Figure 3-9. Figure 3-9 Reset schmitt trigger gate detector time chart ### MSM80C31/MSM80C51 USER'S MANUAL ### 3.2.3 CPU reset internal status When a reset signal is applied to the CPU with normal voltage applied to the MSM80C31/MSM80C51 Vcc power supply pin, the I/O port is set to "1" (input mode) directly even if XTAL1 $\cdot$ 2 has stopped. The CPU is then reset after normal XTAL1 $\cdot$ 2 oscillation has been resumed. The internal CPU status when the CPU is reset is shown in Table 3-1. Table 3-1 MSM80C31/MSM80C51 reset internal status | Register name | Register reset status | | | |---------------------|--------------------------------------|--|--| | PC | 0000Н | | | | SP | 07H | | | | IP | E0H ( $\times \times \times 00000$ ) | | | | IE | 60H (0××00000) | | | | PCON | 70H (0×××0000) | | | | PSW, DPH, DPL, A, B | | | | | SCON, TCON, TMOD | оон | | | | THO, TH1, TL0, TL1 | | | | | P1, P2, P3 | *FFH (input port) | | | | PO | *FFH (floating) | | | | SBUF | | | | | INTERNAL RAM | Undefined | | | <sup>\*</sup> denotes direct resetting even if XTAL1 · 2 has stopped. ### 3.3 EA (CPU Memory Separate) ### 3.3.1 Outline to the : mode) AL1 · 2 shown The function of the $\overline{\text{EA}}$ pin is to determine whether a CPU internal program memory (ROM) instruction is to be executed, or an external program instruction is to be executed. - (1) Internal ROM mode If the EA pin is connected to Vcc and a "1" reset signal is applied to the RESET pin to reset the CPU, an internal program memory (ROM) is executed from address 0. (MSM80C51 only) - (2) External ROM mode If the EA pin is connected to Vss and a "1" reset signal is applied to the RESET pin to reset the CPU, an external program memory is executed from address 0. # 4. MSM80C31/ MSM80C51 INTERNAL SPECIFICATIONS 14 # 4. MSM80C31/MSM80C51 INTERNAL SPECIFICATIONS ## 4.1 Internal Data Memory (RAM) and Special Function Registers (SFR) ### 4.1.1 Outline MSM80C31/MSM80C51 operation is based on an instruction code address method where operations are specified in an instruction code (OP) section, and the data memory (RAM) and special function registers (ACC, B, TCON, P0, ......) are specified directly by part of the instruction code and the second or third byte of data following that instruction code. According to this instruction code address method, all eight bits of data in the data memory and the special function register may be specified, or one bit of data memory and one bit of data in the special function register may be specified. Direct designation of all eight bits of data is called data addressing, and direct designation of one bit of data is called bit addressing. Since these CPU devices specify data memory (RAM) and special function register contents by the above method, specific addresses are assigned to the respective CPU data memory (RAM) and special function registers (ACC, B, TCON, P0, ....). Data addresses consist of eight bits, and range from 00 to FFH in binary (which correspond to 0 thru 255 in decimal). All data memory (RAM) and special function registers (ACC, B, TCON, P0, ....) exist in these 256 locations. The data memory contains 128 bytes in data addresses 00 thru 7FH, and can be specified directly by data address. Special function registers are located between addresses 80 thru FFH, and can also be specified directly by data address. Bit addresses consist of eight bits, the operation bits being specified by the three lower order bits and the data memory (RAM) or special function register (ACC, B, TCON, P0, ....) by the five higher order bits. The bit addresses which can be specified in data memory (RAM) are addresses 20 thru 2FH. Other areas cannot be specified by bit designation. Special function registers which can be specified by bit address include P0, P1, P2, P3, TCON, SCON, IE, IP, PSW, ACC, and B, a total of eleven registers. The data memory (RAM) and special function register address space layout is shown in Figure 4-1. thod data ified wing data nory ition it of ster CPU ad- d to ), B, eci- also tion cial 20 P2, ory Figure 4-1 Data memory and special function register layout ### MSM80C31/MSM80C51 USER'S MANUAL ### 4.2 Internal Data Memory (RAM) ### 4.2.1 Internal data memory (RAM) The storage capacity of the MSM80C31/MSM80C51 data memory is 128 words $\times$ 8 bits. The layout diagram is shown in Figure 4-2. The data memory can be accessed (R/W) in four different ways - direct register designation, indirect register designation, data addressing, and bit addressing. Registers R0 thru R7 consist of four banks within the data memory address range from 00 to 1FH. Banks are specified by RS0 and RS1 data combinations within the PSW. the PSW. The data memory address range from 20 to 2FH is an area where bit addressing is possible. Data operations can be executed directly one bit by bit operation instructions. The data memory address ranges from 00 to 7FH is an area where data addressing is possible. 8-bit data operations within the data memory can be executed directly by data address operation instructions. In addition to data storage in the CPU, the data memory is used as the place for saving stack data. This stack data storage area is addressed by a stack pointer (SP). Since any desired data can be set in the stack pointer (SP) by software, the stack can be used from any data memory address. Note that 07H data is set automatically in the stack pointer when the CPU is reset. Figure 4-2 RAM layout diagram ## MSM80C31/MSM80C51 USER'S MANUAL # 4.2.2 Internal data memory registers R0 thru R7 Registers R0 thru R7 in the data memory consist of four banks between memory addresses 00 thru 1FH. Banks are specified by RS0 and RS1 bit combinations within the program status word (PSW). Note that the register area R0 thru R7 can also be used as normal data memory. The PSW table is shown in Table 4-2, and the data memory register bank layout in Figure 4-3. Table 4-2 Program status word (PSW) | BIT | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|----|----|----|-----|-----|----|----|---| | FLAG | CY | AC | F0 | RS1 | RSO | OV | F1 | | | SET | | | | | | | | | | | L | | | | | | | | Figure 4-3 Internal data memory register bank layout #### 4.2.3 Stack The stack data save area is in the internal data memory (RAM), and is specified by stack pointer (SP 81H). Although 07H data is automatically set in the stack pointer when the CPU is reset, any desired data can be set by software to enable the data memory from any address to be used as the stack. Two addresses of data memory are used when the stack is used by interrupt or CALL instruction, and a single address is used when the PUSH instruction is used. The status where an interrupt is generated and the program counter contents are saved in the stack when the stack pointer contents are 5FH, and accumulator contents are pushed during interrupt routine are shown in Table 4-3. The stack status up to completion of interrupt processing upon execution of POP and RETI instructions is also included Table 4-3 Stack storage data RAM layout | Stack processing | Stack | ck RAM data bit | | | | | | | | | | |--------------------|---------|-----------------|------|------|------|------|------|-----|-----|--|--| | Stack processing | pointer | 7 | 6 | 5 | 4 | 3 | 2 1 | 1 | 0 | | | | Before execution | 5FH | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | | | Interrupt process | 60H | PC7 | PC6 | PC5 | PC4 | РС3 | PC2 | PC1 | PC0 | | | | | 61H | PC15 | PC14 | PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | | | | PUSH process (ACC) | 62H | Α7 | A6 | A5 | A4 | А3 | A2 - | A1 | AO | | | | POP process (ACC) | 62H | A7 | A6 | A5 | A4 | A3 | A2 | A1 | AO | | | | RETI process | 61H | PC15 | PC14 | PC13 | PC12 | PC11 | PC10 | PC9 | PC8 | | | | | 60H | PC7 | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 | | | | After execution | 5FH | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | | # 4.3 Internal Data Memory (RAM) Operating Procedures ## 4.3.1 Internal data memory indirect addressing Operation of the internal data memory indirect increment instruction is described here as an example. This instruction (INC @Rr) is a 1-byte 1-machine cycle instruction (see Figure 4-4), and the indirect address register is specified by instruction code bit 0 data r where r denotes either register 0 or 1 in the register group specified by PSW RSO and RS1 bank data. Register 0 is specified when the r data is 0, and register 1 is specified when the data is 1. When this instruction is executed, register data is read from the specified register 0 or 1, and the read out register data is written into the data pointer of the data memory. The data memory contents specified by the data pointer are read by the CPU into a temporary register. Then a subsequent increment (+1) by the ALU is followed by a return to the data memory at the address specified by the data pointer. In this way, the contents of the data memory at the address specified by the contents of R0 or R1 are incremented. Figure 4-4 INC @Rr bit arrangement ### 4.3.2 Internal data memory register R0 thru R7 designation Operation of the internal data memory register direct decrement instruction is described here as an example. This instruction (DEC Rr) is a 1-byte 1-machine cycle instruction (see Figure 4-5). Register R0 thru R7 is specified by r<sub>0</sub>, r<sub>1</sub>, and r<sub>2</sub> data of instruction code bit 0, 1, and 2. r<sub>0</sub>, r<sub>1</sub>, and r<sub>2</sub> are represented in binary code, r<sub>0</sub> being the LSB, and r<sub>2</sub> the MSB. The code is weighted 1, 2, and 4 from the LSB. Any one of the eight registers can be specified by combinations of this code. See Table 4-4 for the register designation combinations. When this instruction is executed, one of the registers R0 thru R7 from the register group specified by the PSW RSO and RS1 bank data is specified. The contents of the specified register is read by the CPU into a temporary register. Then a subsequent decrement (-1) by the ALU is followed by a return to the specified register. In this way, the register contents specified by ro, r1, and r2 are decremented. Figure 4-5 DEC Rr bit arrangement Table 4-4 Register designation table | Register name | r2 | r۱ | ro | |---------------|----|----|----| | Register 0 | 0 | 0 | 0 | | Register 1 | 0 | 0 | 1 | | Register 2 | 0 | 1 | 0 | | Register 3 | 0 | 1 | 1 | | Register 4 | 1 | 0 | 0 | | Register 5 | 1 | 0 | 1 | | Register 6 | 1 | 1 | 0 | | Register 7 | 1 | 1 | 1 | ### 4.3.3 Internal data memory 1-bit data designation In the MSM80C31/MSM80C51, 1-bit data operations (test, reset, set, complement, transfer) can be executed directly by bit operation instruction only between internal data memory addresses 20 thru 2FH. The operation of a bit reset instruction is described below as an example. This instruction (CLR bit address) is a 2-byte 2-machine cycle instruction (see Figure 4-6). The instruction code is indicated in byte 1. Byte 2 is the data memory address and bit designation. The operation bits are specified by the $b_0$ , $b_1$ , and $b_2$ data in bits 0, 1, and 2 of byte 2. Combinations of this code enable any one of eight bits to be specified. The bit designation combinations are listed in Table 4-5 below. The data memory is addressed by bits $b_3$ , $b_4$ , $b_5$ , $b_6$ and $b_7$ of byte 2. The data memory address is specified by the bits $b_3$ thru $b_6$ with $b_7$ being "0". The bits $b_3$ - $b_6$ can be expressed in binary numbers 0 thru 0FH. A total of 16 designations are possible. When data memory addresses are specified, the data memory bit operation start address 20H is added to the $b_3$ , $b_4$ , $b_5$ , and $b_6$ binary data to obtain the data memory address. The data memory address contents specified by the above method are read by the CPU into a temporary register, the bit specified data is reset to "0" by the ALU, and the CPU returns the result to the data memory where the data were read. One bit of the specified data memory is thus reset to "0". Figure 4-6 CLR bit address bit arrangement 4 Table 4-5 Bit designation table | Bit name | b <sub>2</sub> | bı | b₀ | |----------|----------------|----|----| | Bit 0 | 0 | 0 | 0 | | Bit 1 | 0 | 0 | 1 | | Bit 2 | 0 | 1 | 0 | | Bit 3 | 0 | 1 | 1 | | Bit 4 | 1 | 0 | 0 | | Bit 5 | 1 | 0 | 1 | | Bit 6 | 1 | 1 | 0 | | Bit 7 | 1 | 1 | 1 | Table 4-6 Addressing combination table | | b <sub>7</sub> | p <sub>e</sub> | b <sub>5</sub> | b4 | рз | RAM address | | |---|----------------|----------------|----------------|----|----|-------------|----| | 0 | 0 | 0 | 0 | 0 | 0 | 20H | 32 | | 1 | 0 | 0 | 0 | 0 | 1 | 21H | 33 | | 2 | 0 | 0 | 0 | 1 | 0 | 22H | 34 | | 3 | 0 | 0 | 0 | 1 | 1 | 23H | 35 | | 4 | 0 | 0 | 1 | 0 | 0 | 24H | 36 | | 5 | 0 | 0 | 1 | 0 | 1 | 25H | 37 | | 6 | 0 | 0 | 1 | 1 | 0 | 26H | 38 | | 7 | 0 | 0 | 1 | 1 | 1 | 27H | 39 | | 8 | 0 | 1 | 0 | 0 | 0 | 28H | 40 | | 9 | 0 | 1 | 0 | 0 | 1 | 29H | 41 | | А | 0 | 1 | 0 | 1 | 0 | 2AH | 42 | | В | 0 | 1 | 0 | 1 | 1 | 2BH | 43 | | С | 0 | 1 | 1 | 0 | 0 | 2CH | 44 | | D | 0 | 1 | 1 | 0 | 1 | 2DH | 45 | | E | 0 | 1 | 1 | 1 | 0 | 2EH | 46 | | F | 0 | 1 | 1 | 1 | 1 | 2FH | 47 | Table 4-7 List of special function registers | Register<br>name | | | | Data<br>address | | | | | | |------------------|----------------|----|----------------|-----------------|----|----------------|----|----|------------| | name | b <sub>7</sub> | pe | b <sub>5</sub> | b₄ | bз | b <sub>2</sub> | b₁ | bо | aduress | | В | F7 | F6 | F5 | F4 | F3 | F2 | F1 | F0 | 0F0H (240) | | ACC | E7 | E6 | <b>E</b> 5 | E4 | E3 | E2 | E1 | EO | 0E0H (224) | | PSW | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | ODOH (208) | | IP | BF | BE | BD | вс | BB | ВА | В9 | B8 | OB8H (184) | | Р3 | В7 | В6 | B5 | B4 | В3 | B2 | В1 | ВО | 0B0H (176) | | IE | AF | AE | AD | AC | AB | AA | A9 | A8 | 0A8H (168) | | P2 | A7 | A6 | A5 | A4 | АЗ | A2 | A1 | AO | 0A0H (160) | | SBUF | | | | | | | | | 99H (153) | | SCON | 9F | 9E | 9D | 9C | 9В | 9A | 99 | 98 | 98H (152) | | P1 | 97 | 96 | 95 | 94 | 93 | 92 | 91 | 90 | 90H (144) | | TH1 | | | | | | | | | 8DH (141) | | THO | | | | | | | | | 8CH (140) | | TL1 | | | | | | | | | 8BH (139) | | TLO | | | | | | | | İ | 8AH (138) | | TMOD | | | | | | | | | 89H (137) | | TCON | 8F | 8E | 8D | 8C | 8B | 8A | 89 | 88 | 88H (136) | | PCON | | | - | | | | | | 87H (135) | | DPH | | | | | | | | | 83H (131) | | DPL | | | - | | | | | | 82H (130) | | SP | | | | | | | | | 81H (129) | | PO | 87 | 86 | 85 | 84 | 83 | 82 | 81 | 80 | 80H (128) | ## 4.4.2 Special Function Registers ## 4.4.2.1 Timer mode register (TMOD) | Name | Address | MS<br>7 | В | 6 | 5 | 4 | 3 | 2 | 1 | LSB<br>0 | |--------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------|-----------|------------|----------------------------------------|-----------|-----------|--------------| | TMOD | 89H | GAT | rE | C/T | M1 | МО | GATE | C/T | M1 | Mo | | Bit location | Flag | | • | | | Fun | ction | | | J | | TMOD.0 | MO | M1 | МО | Time | r/counte | er 0 mod | e setting | ~ ~ | | | | | | 0 | 0 | 8-bit | timer/co | ounter w | ith 5-bit p | rescala | r | | | | | 0 | 1 16-bit timer/counter | | | | | | | , . | | | | 1 | 0 | 8-bit | timer/co | ounter w | th 8-bit a | uto relo | ading | | | TMOD.1 | M1 | 1 | 1 | coun | ter and 1 | ГНО (8-b | rated into<br>it) timer/o<br>set by Th | counter. | TF0 is s | er/<br>et by | | TMOD.2 | C/T | XTAL<br>0 whe<br>The e | 1 · 2<br>en C/<br>exterr | $\frac{\text{divided}}{T} = \text{``0''}$ | by 12 c | locks is d | gnation co | applied | to timer/ | | | TMOD.3 | GATE | When this bit is "0", the TRO signal is used to control the start and stop of timer/counter 0 counting. If this bit is "1", timer/counter 0 starts counting when both the TRO bit and INTO pin are "1", and stops counting when either is changed to "0". | | | | | | | he TRO | | | TMOD.4 | MO | M1 | МО | Timer | /counte | r 1 mode | setting | | | | | | | 0 | 0 | 8-bit | timer/co | unter wi | th 5-bit p | rescalar | | | | | | 0 | 1 | 16-bi | t timer/c | ounter | | | | | | TMOD.5 | M1 | 1 | 0 | 8-bit t | timer/co | unter wit | h 8-bit a | uto reloa | ıding | - | | | | 1 | 1 | Timer | /counte | r 1 opera | ition stop | ped | | | | TMOD.6 | C/T | Timer/counter 1 count clock designation control bit. XTAL1 · 2 divided by 12 clocks is the input applied to timer/counter 1 when $C/\overline{T}="0"$ . The external clock applied to the T1 pin is the input applied to timer/counter 1 when $C/\overline{T}="1"$ . | | | | | | | | | | TMOD.7 | GATE | When this bit is "0", the TR1 signal is used to control the start and stop of timer/counter 1 counting. If this bit is "1", timer/counter 1 starts counting when both the TR1 bit and INT1 pin are "1", and stops counting when either is change to "0". | | | | | | ne TR1 | | | # 4.4.2.2 Power control register (PCON) | Name | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB<br>0 | |--------------|---------|---------------------------------------------------------------|----------------------------------|--------------------------|------------------------|-------------------------|-----------------------|---------------------|---------------| | PCON | 87H | SMOD | = | - | _ | GF1 | GF0 | PD | IDL | | Bit location | Flag | | | | Fund | ction | | | | | PCON.0 | IDL | IDLE mod<br>stopped v<br>and 1, the<br>mode is o<br>generated | when IDI<br>e interru<br>ancelle | _E mode<br>pt circuit | is set, b<br>ts, and s | ut XTAL1<br>erial port | · 2, time<br>s remain | r/counte<br>active. | ers 0<br>IDLE | | PCON.1 | PD | PD mode<br>XTAL1 · 2<br>only whe | are sto | pped wh | en PD m | | | | | | PCON.2 | GF0 | Testing to<br>shows wi<br>release in | nether th | ne interru | | | | | | | PCON.3 | GF1 | This is a | user's fl | ag which | may be | used at | the user' | s discre | tion. | | PCON.4 | - | Reserved | bit. If th | ne bit is r | ead, the | output is | a "1". | | | | PCON.5 | - | Reserved | bit. If th | ne bit is r | ead, the | output is | a "1". | | | | PCON.6 | _ | Reserved | l bit. If th | ne bit is r | ead, the | output is | a "1". | | | | PCON.7 | SMOD | This bit h<br>1, 2, or 3<br>the bit is<br>serial por | . The se<br>"0" for c | rial port o<br>delayed p | operatior<br>processi | n clock is<br>ng. And w | reduced<br>when the | by 1/2<br>bit is "1 | when | # 4.4.2.3 Timer control register (TCON) | Name | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 1 | LSB | |--------------|---------|--------------------------------------------|------------------------|-------------------------|-------------------------|------------------------|----------------|--------------------------------|----------| | TCON | 88H | TF1 | — — —<br>TR1 | TFO | TR0 | <br>IE1 | | IEO | ITO | | Bit location | Flag | | | L——— | I— — —<br>Fund | | 1 | | | | TCON.0 | ITO | External<br>"0", and | interrup<br>is used | t 0 signa<br>in trigger | l used in<br>detect n | level de | tect mod | de when t | oit is | | TCON.1 | IEO | Interrupt<br>Bit is res<br>Bit can b | flag bit t<br>et autom | for exteri | nal interr<br>when the | | <br>ot is serv | | | | TCON.2 | IT1 | External "0", and | ———<br>interrup | t 1 signa | — — — -<br>I used in | – —— -<br>level de | <br>tect mod | | oit is | | TCON.3 | IE1 | Interrupt<br>Bit is reso<br>Bit can be | flag bit f<br>et autom | or exterr<br>atically v | ial interru<br>when the | <br>ipt 1.<br>interrun | - | | | | TCON.4 | TRO | Counting<br>Timer/co<br>counting | start an<br>unter 0 s | d stop co<br>starts cou | ntrol bit | or timer | | | <br>ps | | TCON.5 | TFO | Interrupt<br>Bit is rese<br>"1" when | t autom: | atically w | hen the | interrun | t is servi | —— —-<br>ced. Bit is<br>ter 0. | s set to | | TCON.6 | TR1 | Counting<br>Timer/cou<br>counting v | start and | d stop co<br>tarts cou | ntrol bit f | or timer | /counter | 1 | <br>os | | TCON.7 | | Interrupt f<br>Bit is rese<br>Bit is set t | t automa | tically w | hen the i | nterrunt | is servic | | | # 4.4.2.4 Serial port control register (SCON) | Name | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB<br>0 | |--------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------|----------------------------------------------|-----------------------------------------------|-------------------------------------------------|---------------------------------|--------------------| | SCON | 98H | SM0 | SM1 | SM2 | REN | ТВ8 | RB8 | TI | RI | | Bit location | Flag | | <u> </u> | | Fun | ction | <u> </u> | 1 | _ | | SCON.0 | RI | be reset<br>This flag<br>in mode<br>3, howev | by softw<br>is set at<br>0, or by<br>ver, RI is | rt recepti<br>vare durir<br>fter the ei<br>the STOF<br>not set if<br>STOP bit i | ng interru<br>ghth bit<br>bit whe<br>the RB8 | upt proce<br>of data h<br>n in any<br>data is | essing.<br>as been i<br>other moo<br>'0" with S | received<br>de. In m<br>SM2 = " | d when<br>ode 2 or | | SCON.1 | ТІ | must be<br>This flag | reset by<br>is set af | rt transm<br>software<br>ter the ei<br>the last bi | during i<br>ghth bit | nterrupt<br>of data h | processi<br>as been s | ng.<br>sent whe | en in | | SCON.2 | RB8 | The ninth bit of data received in mode 2 or 3 is passed to the RB8. The STOP bit is input to the RB8 if SM2 = "0" when in mode 1. RB8 is not used in mode 0. | | | | | | | | | SCON.3 | TB8 | | | sent as th | | | | node 2 o | r 3. Any | | SCON.4 | REN | No recep | otion whe | e control<br>en REN =<br>ed when l | "0". | 1". | | | | | SCON.5 | SM2 | of recept<br>Nor is th | tion'' sig<br>e "end o | data is "C<br>nal is not<br>f receptic<br>M2 = "1" | set into<br>n'' signa | the RI bi<br>Il set into | t. | | | | | | SM0 | SM1 | MODE | | _ | - | | | | SCON.6 | SM1 | 0 | 0 | 0 | 8-bit s | hift regis | ster I/O | | | | | | 0 | 1 | 1 | 8-bit L | JART var | iable bau | ıd rate | | | SCON.7 | SMO | 1 | 0 | 2 | 9-bit U | | 32 XTAL1 | , 1/64 > | (TAL1 | | | | 1 | 1 | 3 | 9-bit L | JART var | iable bau | ıd rate | | # 4.4.2.5 Interrupt enable register (IE) | Name | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 1 | LSB<br>0 | |--------------|---------|---------------------------------------------|------------|------------|--------------------------------------------------|---------------|-----------|----------|----------| | IE. | A8H | EA | | | ES - | ————<br>ET1 | EX1 | +<br>ETO | EXO | | Bit location | Flag | | | .1 | ⊥ | l<br>ction | | | | | IE.O | EXO | Interrupt<br>Interrupt<br>Interrupt | disable | d when I | xternal in<br>bit is "0".<br>bit is "1". | terrupt 0 | | | | | IE.1 | ETO | Interrupt<br>Interrupt<br>Interrupt | disable | d when i | mer interroit is "0". it is "1". | upt 0. | | | | | IE.2 | EX1 | Interrupt<br>Interrupt<br>Interrupt | disable | d when t | ————<br>kternal int<br>bit is "0".<br>it is "1". | <br>errupt 1. | | | | | IE.3 | ET1 | Interrupt<br>Interrupt<br>Interrupt | disable | d when b | oit is "0". | <br>upt 1. | — — . — . | | | | IE.4 | ES | Interrupt<br>Interrupt<br>Interrupt | disable | d when b | it is "0". | | | | | | IE.5 | _ | Reserved | bit. If th | e bit is r | — —<br>ead out, '' | <br>1" is rea | d. | | | | IE.6 | | Reserved | bit. If th | e bit is r | ead out, " | 1" is rea | | | | | IE.7 | EA | Overall int<br>All interrup<br>All interrup | ots disa | bled whe | en bit is "( | )''.<br>''. | | | | ### 4.4.2.6 Interrupt priority register (IP) | Name | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 | LSB<br>0 | |--------------|---------|----------|-------------|--------------------------|----------|-------------------|------|-----|----------| | IP | В8Н | | | _ | PS | PT1 | PX1 | PT0 | PX0 | | Bit location | Flag | | | | Fun | ction | | | | | IP.0 | PXO | | | bit for ex<br>d when bi | | terrupt C | ). | | | | IP.1 | РТО | | | bit for tir<br>d when bi | | rupt 0. | | | | | IP.2 | PX1 | | | bit for ex | | iterrupt 1 | | | | | IP.3 | PT1 | | | bit for tir<br>d when bi | | rupt 1. | | | | | IP.4 | PS | | | bit for se | | | | | | | IP.5 | | Reserve | d bit. If t | the bit is | read out | , "1" is r∈ | ead. | | | | IP.6 | | Reserve | d bit. If t | he bit is i | ead out. | <br>. ''1'' is r∈ | ad. | | | | IP.7 | | Reserve | d bit. If | the bit is | read out | , "1" is re | ead. | | | # 4.4.2.7 Program status word register (PSW) | Name<br>—————— | Address | MSB<br>7 | 6 | 5 | 4 | 3 | 2 | 1 | LSE | |----------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------------------------------|---------------------------------------------------|---------------------------------------|------------|-----------|-------| | PSW | DOH | CY | AC | F0 | RS1 | RS0 | OV | | 0 | | Bit location | Flag | | L | | | ction | | F1 | Р | | PSW.0 | Р | Accumul<br>"1" when<br>and "0" v | the nun | nber of " | indicato | | ator is ar | odd nu | mber, | | PSW.1 | F1 | User flag | | | | or "1" as | desired | by the | | | PSW.2 | OV | Overflow or CY is " also set to instruction product is | flag which<br>1" as a r<br>5"1" if th<br>1 (MULA | ch is set<br>esult of<br>ne result<br>,, B) is gr | if the car<br>an arithm<br>ant produ<br>eater tha | ry C6 fro<br>letic oper<br>act of a m | m bit 6 c | of the AL | U | | | | RAM regis | ter bank | switch | | ——— | | | | | PSW.3 | RS0 | RS1 RS0 BANK RAM ADDRE | | | | | | DDRESS | <br>3 | | | | 0 | | 0 | 0 | | 00H | - 07H | | | | | 0 | | 1 | 1 | | 08H | <br>_ 0FH | | | PSW.4 | RS1 | 1 | | 0 | 2 | | 10H | <br>- 17H | | | | | 1 | | 1 | 3 | <del></del> | 18H - | <br>- 1FH | | | PSW.5<br> | F0 | User flag w | hich ma | y be set | to "0" or | <br>"1" as de | esired by | the use | | | PSW.6 | AC | User flag which may be set to "0" or "1" as desired by the user. Auxiliary carry flag. This flag is set to "1" if a carry C3 is generated from bit 3 of the ALI as a result of executing an arithmetic operation instruction. In all other cases, the flag is reset to "0". | | | | | | | | | PSW.7 | CY 7 | Main carry<br>his flag is a<br>s a result c<br>a all other c | flag.<br>set to "1<br>of execut | " if a car | ry C7 is g | tic opera | I from bit | 7 of the | : ALU | #### 4.5 Timer/Counters 0 and 1 #### 4.5.1 Outline Timer/counters 0 and 1 are both capable of independent 16-bit binary counting. All control of timer/counters 0 and 1 is handled by the timer control register (TCON) and the timer mode register (TMOD). Both timer/counter 0 and 1 can be set independently to modes 0 thru 3 for a diversity of applications. #### 4.5.2 Timer/counter 0 and 1 counting control The start and stop of counting in timer/counters 0 and 1 is controlled by the bit-4, TR0, and bit-6, TR1, in the timer control register (TCON 88H) as indicated in Table 4-8. TR0 controls timer/counter 0, and TR1 controls timer/counter 1. Timer/counter operation is stopped when the bit data is "0", and enabled when "1". The overall control circuit for timer/counters 0 and 1 is shown in Figure 4-7 (excluding timer mode 3). Table 4-8 Timer control register (TCON 88H) | | Tim | er 1 | Tim | er 0 | | | | | |------|-----|------|-----|------|-----|-----|-----|-----| | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Flag | TF1 | TR1 | TFO | TR0 | IE1 | IT1 | IEO | ITO | | Set | | • | | • | | | | | Figure 4-7 Overall clock input control for timer/counters 0 and 1 #### 4.5.3 Timer/counter 0 and 1 count clock designation Designation of count clock inputs to timer/counters 0 and 1 is controlled by the bit 2 and 6, $C/\overline{T}$ , in the timer mode register (TMOD 89H). Timer/counter 0 is controlled by the bit 2, $C/\overline{T}$ , and timer/counter 1 is controlled by the bit 6, $C/\overline{T}$ . The internal clock is applied to the timer/counter when the $C/\overline{T}$ bit is "0". This internal clock is the result of dividing XTAL1 · 2 by 12. The S3 timing signal becomes the clock. The external clock is applied to the timer/counter when the $C/\overline{T}$ bit is "1". The external clock applied to the T0 pin serves as the timer/counter 0 input, while the external clock applied to the T1 pin serves as the timer/counter 1 input. Timer 1 Timer 0 7 2 Bit 6 5 4 3 1 0 М1 GATE C/T Flag GATE C/T MO M1 M<sub>0</sub> • • Enable count Table 4-9 Timer mode register (TMOD 89H) #### 4.5.3.1 External clock detector circuit for timer/counters 0 and 1 The detector circuit shown in Figure 4-8 is inserted between the timer/counters and the external clock pin. This detector circuit operates in the following way. When the external clock applied to the T0 and T1 pins is changed from "1" to the "0" level, that clock is fetched by F/F1, and is then passed to F/F2 when the S5 timing signal appears. This F/F2 output is subsequently ANDed (logical product) with the S3 timing signal to form the timer/counter clock signal which then serves as the F/F1 reset signal. The reset F/F1 then waits for the next external clock. The "0" and "1" signal cycle widths of the respective external clocks applied to the T0 and T1 pins must be minimal and a period 12 times (12T) to XTAL1 · 2 oscillator clock cycle T is required. The operational time chart for this detector circuit is outlined in Figure 4-9. Figure 4-8 T0 and T1 external clock detector circuit Figure 4-9 Detector circuit operational time chart ### 4.5.4 Counting control of timer/counters 0 and 1 by INT pin In addition to control by timer control register, TCON TRO and TR1, timer/counter 0 and 1 counting start and stop can also be controlled by the signal level applied to the external interrupt pin. The GATE data values of bits 3 and 7 in the timer mode register (TMOD 89H) indicated in Table 4-10 are used to control this. Timer/counter 0 is controlled by the bit 3 GATE bit. When the GATE bit is "0", counting of timer/counter 0 is started and stopped only by TR0. When the GATE bit is "1", counting timer/counter 0 is enabled if the TRO signal and the signal applied to the INTO pin are both "1". Counting is subsequently stopped if either of the signals is changed to "0" level. Timer/counter 1 is controlled by the bit-7 GATE bit. The functional operation is the same as for timer/counter 0. The GATE $-\overline{\text{INT}}$ timer/counter counting control circuit is outlined in Figure 4-10, and the control table is given in Table 4-11. Table 4-10 Timer mode register (TMOD 89H) | - | | Tim | er 1 | | Timer 0 | | | | | |---------------|------|-----|------|----|---------|-----|----|----|--| | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | Flag | GATE | C/T | M1 | МО | GATE | C/T | M1 | мо | | | Count Control | • | | | | • | | | | | Figure 4-10 INTO and INT1 timer/counter start/stop control circuit Table 4-11 GATE INT TR timer/counter control tables | | | TIMER 0 | | | | | | | |------|---|---------|---|---|---|--|--|--| | GATE | 0 | 0 | 1 | 1 | 1 | | | | | TRO | 0 | 1 | 0 | 1 | 1 | | | | | ĨNTO | × | × | 0 | 0 | 1 | | | | | RUN | | • | | | • | | | | | STOP | • | | • | • | | | | | | | | TI | MER | 1 | | |------|---|----|-----|---|---| | GATE | 0 | 0 | 1 | 1 | 1 | | TR1 | 0 | 1 | 0 | 1 | 1 | | ĪNT1 | × | × | 0 | 0 | 1 | | RUN | | • | | | • | | STOP | • | | • | • | | Note: • implies timer/counter state. M1 • MO • #### 4.5.5 Timer/counters 0/1 and timer modes #### 4.5.5.1 Outline The timer/counter 0 and 1 timer modes are set by combinations of M0 and M1 bit data in the timer mode register (TMOD 89H). The timer modes which can be set are 0, 1, 2, Timer/counter 0 modes are specified by M0 and M1 of bits 0 and 1, and timer/counter 1 modes are specified by M0 and M1 of bits 4 and 5. TIMER COUNTER 1 TIMER COUNTER 0 Bit 7 6 5 4 3 2 1 0 GATE C/T GATE C/T MO • M1 • Table 4-12 Timer mode register (TMOD 89H) #### 4.5.5.2 Mode 0 Flag Mode set In mode 0, timer/counters 0 and 1 both become 13-bit timer/counters by the circuit connection shown in Figures 4-11 and 4-12. TŁO and TL1 in timer/counters 0 and 1 serve as the counter for the five lower bits, and THO and TH1 serve as the counter for the eight upper bits. Timer flag 0 is set by the timer/counter 0 carry signal, and timer flag 1 is set by the timer/counter 1 carry signal. Timer/counter 1 carry signal can be used as the serial port clock source. Although the three upper bits of TLO and TL1 are operative, they are invalid as signals. | M1 | МО | |----|----| | 0 | 0 | Figure 4-11 Timer/counter 0 mode 0 Figure 4-12 Timer/counter 1 mode 0 # 4.5.5.3 Mode 1 In mode 1, timer/counters 0 and 1 both become 16-bit timer/counters by the circuit connection shown in Figures 4-13 and 4-14. TLO and TL1 in timer/counters 0 and 1 serve as the counter for the eight lower bits, and THO and TH1 serve as the counter for the eight upper bits. Timer flag 0 is set by the timer/counter 0 carry signal, and timer flag 1 is set by the timer/counter 1 carry signal. Timer/counter 1 carry signal can be used as the serial port clock source. | M1 | МО | |----|----| | 0 | 1 | 4 Figure 4-13 Timer/counter 0 mode 1 Figure 4-14 Timer/counter 1 mode 1 #### 4.5.5.4 Mode 2 In mode 2, timer/counters 0 and 1 both become 8-bit timer/counters with 8-bit auto reloader registers by the circuit connection shown in Figures 4-15 and 4-16. THO and TH1 in timer/counters 0 and 1 serve as the 8-bit auto reloader section, and TL0 and TL1 serve as the timer/counter section. If a carry signal is generated by the 8-bit timer/counter TLO and TL1, the respective auto reloader register data is preset in the timer/counter, and counting proceeds from the preset value. Timer flag 0 is set by the timer/counter 0 carry signal, and timer flag 1 is set by the timer/counter 1 carry signal. Timer/counter 1 carry signal can be used as the serial port clock source. | M1 | МО | | |----|----|--| | 1 | 0 | | Figure 4-15 Timer/counter 0 mode 2 Figure 4-16 Timer/counter 1 mode 2 #### 4.5.5.5 Mode 3 In mode 3, timer/counter 0 TLO and THO become independent 8-bit timer/counters by the circuit connection shown in Figure 4-17. Timer/counter 1 does not operate when mode 3 is set. The TLO 8-bit timer/counter is controlled in the same way as the regular timer/counter 0, timer flag 0 being set if a carry signal is generated from TLO. The THO 8-bit timer/counter is controlled only by TR1, and the control covers only the start and stop of the counting. Timer flag 1 is set by a carry signal generated from THO. When timer/counter 0 is set to mode 3, timer/counter 1 can operate in modes 0, 1, or 2, and be used as the serial port clock source. Control of timer/counter 1 counting start and stop in this case is handled between the operating mode and mode 3. If mode 3 is set, the timer/counter 1 counting operation is stopped. | M1 | МО | |----|----| | 1 | 1 | Figure 4-17 Timer/counter 0 mode 3 # 4.5.6 Timer/counter carry signal detector circuit The detector circuit shown in Figure 4-18 is inserted between the MSM80C31/MSM80C51 timer/counter carry output and the timer flag. The purpose of this detector is to prevent loss of the timer flag by operation data when execution of the OR, AND, EOR, RESET bit, or MOV bit instruction which destination operand is the timer control register is completed. If a timer carry is generated during execution of one of these instructions on the timer control register (TCON), the timer flag may be lost. Hence, even if a timer carry signal is generated during execution of an instruction, that flag will not be set while the instruction is still being executed. The flag is set at $\overline{M2} \cdot S1$ during execution of the next instruction. If a timer carry is generated during M1 thru M3 when executing a 4-machine cycles instruction, the timer flag is set during M3 or M4. See Figure 4-19 for the time chart. Figure 4-18 Timer/counter detector circuit Figure 4-19 Timer flag setting time chart # 4 #### 4.6 Serial Port #### 4.6.1 Outline MSM80C31/MSM80C51 is equipped with a serial port which can be used in I/O extension and UART (Universal Asynchronous Receiver/Transmitter) applications. In I/O extension mode, 8-bit serial data input/output is synchronized with the MSM80C31/MSM80C51 output clock. In UART mode, 10-bit and 11-bit frame lengths can be selected, and baud rate settings up to a maximum of 375K baud are enabled during 12 MHz (XTAL1 $\cdot$ 2) operations. In 11-bit frame mode, ninth bit of data is used to form a multi-processor communication system based on the serial bus. A block diagram of the serial port is shown in Figure 4-20. Figure 4-20 Serial port #### 4.6.2 Special function registers for serial port #### 4.6.2.1 SCON (Serial Port Control Register) SCON is an 8-bit special function register consisting of control bits for specifying serial port operation modes and enabling/disabling data reception, storage bits for the 9th bit of data sent and received during 11-bit frame UART mode, and the serial port status flag. In addition to specifying SCON by data address 98H, each bit can be specified individually. The functions of each SCON bit are listed in Table 4-13, and the functions of each operational mode specified by SCON are indicated in Table 4-14. Table 4-13 SCON | Bit | Symbol | Function | | | |-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | RI | "End of reception" flag. This is the interrupt request flag set by hardware when reception of one frame has been completed. The interrupt is generated by ORing with the TI flag. Since the flag cannot be cleared by hardware, it must be cleared by software. | | | | 1 | ТІ | "End of transmission" flag. This is the interrupt request flag set by hardware when transmission of one frame has been completed. The interrupt is generated by ORing with the RI flag. Since the flag cannot be cleared by hardware, it must be cleared by software. | | | | 2 | RB8 | Storage of the 9th bit of the data received during 11-bit frame UART mode (mode 2 or 3). When in 10-bit frame UART mode (mode 1), the stop bit is stored, instead. | | | | 3 | TB8 | Storage of the 9th bit of the data to be sent during 11-bit frame UART mode (mode 2 or 3). | | | | 4 | REN | Receive enable bit. Reception is not activated if REN is not set. | | | | 5 | SM2 | If SM2 is set when in 11-bit frame UART mode (mode 2 or 3), and the 9th bit of the received data is "1", the received data is accepted and loaded into SBUF and RB8, and the RI flag is set. If the 9th bit of the received data is "0", the received data is disregarded and the SBUF RB8, and RI flags remain unchanged. This function is used to enable communication between processors in multi-processor systems. If SM2 is set when in 10-bit frame UART mode (mode 1) and the stobit "1" cannot be received, the received data is disregarded, and the SBUF, RB8, and RI flags remain unchanged. When SM2 = "0", however, data is received irrespective of the "0"/"1" status of the stoit. SM2 must be cleared when in I/O extension mode (mode 0). | | | | 6 | SM1 | Used in setting serial port operation mode. See Table 4-14. | | | | 7 | SMO | Used in setting serial port operation mode. See Table 4-14. | | | 4 Table 4-14 Serial port operation modes | SM0 | SM1 | Mode | Function | Baud rate | |-----|-----|------|-------------------|------------------------| | 0 | 0 | 0 | I/O extension | 1/12 Fosc | | 0 | 1 | 1 | 10-bit frame UART | Variable | | 1 | 0 | 2 | 11-bit frame UART | 1/32 Fosc or 1/64 Fosc | | 1 | 1 | 3 | 11-bit frame UART | Variable | Note: Fosc denotes frequency of fundamental oscillator (XTAL1 · 2) #### 4.6.2.2 SBUF (serial port buffer register) SBUF is an 8-bit special function register used to store sending and receiving data. Although the SBUF is specified by the same data address 99H for both writing and reading, physically separate registers are specified. That is, the sending circuit SBUF is specified by instructions where SBUF is used as a destination operand, and the receiving circuit SBUF is specified by instructions where SBUF is used as a source operand. #### 4.6.2.3 SMOD (double baud rate bit) SMOD controls the division of the baud rate clock source when the serial port is in UART mode (mode 1, 2, or 3). If SMOD is cleared to "0" when in mode 1 or 3, the timer/counter 1 overflow frequency divided by 2 becomes the baud rate clock source. And if SMOD is set to "1", the timer/counter 1 overflow frequency becomes the baud rate clock source. If SMOD is cleared to "0" when in mode 2, 1/2XTAL1 · 2 divided by 2 becomes the baud rate clock source. And if SMOD is set to "1", 1/2XTAL1 · 2 becomes the baud rate clock source. SMOD corresponds to bit 7 of PCON (Power Control Register) specified by data address 87H. Designation by bit address is not possible. ### 4.6.3 Operating modes #### 4.6.3.1 Mode 0 #### 4.6.3.1.1 Outline Mode 0 is the I/O extension mode where input and output of 8-bit data via RXD (P3.0) is enabled synchronized with the output clock from RXD (P3.1). The baud rate in mode 0 is fixed to 1/12 of the fundamental oscillator (XTAL1 $\cdot$ 2) frequency to enable the serial port to operate synchronized with the basic MSM80C31/MSM80C51 timing. A block diagram of the mode 0 serial port is shown in Figure 4-21, the operational timing chart is shown in Figure 4-22, and the serial port operation timing in relation to the basic MSM80C31/MSM80C51 timing is shown in Figure 4-23. #### 4.6.3.1.2 Mode 0 baud rate In mode 0, the baud rate is determined by the following equation to synchronize operations with the basic MSM80C31 /MSM80C51 timing. $$B = Fosc \times \frac{1}{12}$$ where B is baud rate, and Fosc is the fundamental (XTAL1.2) frequency. #### 4.6.3.1.3 Mode 0 output operation Data output is commenced by writing data in SBUF. The SBUF data is obtained sequentially from RXD one machine cycle after completion of the SBUF data write instruction, the LSB appearing first. Two states after starting the LSB output, output of the TXD synchronizing clock is commenced. This synchronized clock is at level "0" from the latter half of S3 thru to the first half of S6, and at "1" level from the latter half of S6 thru to the first half of S3. The transmit circuit is initialized immediately following completion of output of the MSB, and the TI flag is set at the first M1 · S3 cycle after that. ### 4.6.3.1.4 Mode 0 input operation Data input is initiated when REN = "1" and RI = "0". This is achieved by an instruction used to set REN or by an instruction used to clear the RI flag or by an instruction which does both simultaneously. Output of the TXD synchronizing clock is initiated nine states after REN = "1" and RI = "0". The synchronized clock is at level "0" from the latter half of S3 thru to the first half of S6, and at level "1" from the latter half of S6 thru to the first half of S3. The RXD data is read sequentially into an input shift register in the serial port just before the synchronized clock is changed from "0" to "1". When input of the 8-bit data is completed, loading of the input shift register data into SBUF (with the LSB at the beginning of the input data) occurs at the same time that the receiving circuit is initialized. The RI flag is then set at the first M1 · S3 cycle after completion of input of the 8-bit data. Figure 4-22 Serial port (mode 0) timing chart #### 4.6.3.2 Mode 1 #### 4.6.3.2.1 Outline Mode 1 is the 10-bit frame UART mode (with one start bit, eight data bits, and one stop bit) where the baud rate may be set to any value depending on the timer/counter 1 setting. A block diagram of the serial port in mode 1 is shown in Figure 4-24, and the operational timing chart is given in Figure 4-25. #### 4.6.3.2.2 Mode 1 baud rate Since the timer/counter 1 overflow becomes the baud rate clock source in mode 1, the baud rate is determined by the timer/counter 1 overflow frequency and SMOD value according to the following equations. $$B = Ftim \times \frac{1}{2} \times \frac{1}{16} \qquad (SMOD = 0)$$ $$B = Ftim \times \frac{1}{16} \qquad (SMOD = 1)$$ where B is the baud rate and Ftim is the timer/counter 1 overflow frequency. When timer/counter 1 is used as a timer in auto reload mode (mode 2), the baud rate is determined by the following equations. B = Fosc × $$\frac{1}{12}$$ × $\frac{1}{256-D_{TH1}}$ × $\frac{1}{2}$ × $\frac{1}{16}$ (SMOD = 0) B = Fosc × $\frac{1}{12}$ × $\frac{1}{256-D_{TH1}}$ × $\frac{1}{16}$ (SMOD = 1) where B is the baud rate, Fosc the fundamental (XTAL1 $\cdot$ 2) frequency, and DTH1 the TH1 contents (expressed in decimal). # 4.6.3.2.3 Mode 1 transmit operation The basic clock, TXCLOCK in Figure 4-25, for transmitting purposes is obtained from a hexadecimal counter overflow which uses half of the timer/counter 1 overflow frequency when SMOD = 0 or the unchanged timer/counter 1 overflow frequency when SMOD = 1 as the clock. Transmission is initiated when transmission data is written in SBUF. The start bit, the eight SBUF data bits (with the LSB first), and the stop bit are transmitted sequentially from the TXD synchronized with the basic clock. As soon as output of the eight data bits has been completed, the transmit circuit is initialized, and the TI flag is set at the first M1 · S3 cycle after the completion of that output. Figure 4-24 Serial port (mode 1) Figure 4-25 Serial port (mode 1) timing chart #### 4.6.3.2.4 Mode 1 receive operation The receive circuit timing is generated by a hexadecimal counter which employs the halved timer/counter 1 overflow frequency (when SMOD = 0) or the unchanged timer/ counter 1 overflow frequency (when SMOD = 1) as the clock, and the input data received from the RXD is bit synchronized. That is, at the same time that reception is started, following input of the start bit, the hexadecimal counter commences to count up, and with one complete round of the hexadecimal counter corresponding to one bit of received data, reception is continued by the receive circuit. Therefore, timer/counter 1 must be set so that the period of a single round of the hexadecimal counter is equal to the reception data baud rate. The RXD change from "1" to "0" is regarded as the beginning of the start bit for reception. When this "1" to "0" change in RXD is detected, the hexadecimal counter which had been reset starts to count up. When the hexadecimal counter is in state 7, 8, and 9, the start bit is sampled, and is accepted as valid if at least two of the three sampled values are "0", thereby enabling data reception to continue. If two or three of the sampled values are "1", the start bit becomes invalid, and the receive circuit is initialized when the hexadecimal counter reaches state 10. The reception data is sampled when the hexadecimal counter is in state 7, 8, and 9, and the more common value of the three sampled values is read sequentially as data into the input shift register. If the conditions stated below are satisfied when the hexadecimal counter is in state 10 during the period of the stop bit, the input shift register data (the LSB being read first) is loaded into SBUF, and the sampled stop bit is read into RB8, thereby initializing the receive circuit. - Conditions: (1) RI = "0" - (2) SM2 = "0", or SM2 = "1" and sampled stop bit = "1" The RI flag is set at the first M1 · S3 cycle after the initialization. If the above conditions are not satisfied, the received data is disregarded, and the receive circuit is initialized without change to the SBUF, RB8, and RI flags. Since the receive circuit is divided into two stages (input shift register and SBUF), processing of the previous receive data may be completed within the interval up to the stop bit period of the next frame. #### 4.6.3.3 Mode 2 ### 4.6.3.3.1 Outline Mode 2 is an 11-bit frame UART mode (with one start bit, eight data bits, one multipurpose bit, and one stop bit) where the baud rate is 1/64th or 1/32nd of the fundamental oscillator (XTAL1 · 2) frequency. A block diagram of the serial port in mode 2 is shown in Figure 4-26, and the operational timing chart is given in Figure 4-27. #### 4.6.3.3.2 Mode 2 baud rate Since the fundamental oscillator frequency divided by two serves as the baud rate clock source in mode 2, the baud rate is determined by the SMOD value according to the following equations. $$B = Fosc \times \frac{1}{2} \times \frac{1}{2} \times \frac{1}{16} \quad (SMOD = 0)$$ $$B = Fosc \times \frac{1}{2} \times \frac{1}{16} \quad (SMOD = 1)$$ where B is the baud rate and Fosc is the fundamental oscillator (XTAL1 · 2) frequency. ### 4.6.3.3.3 Mode 2 transmit operation The basic clock, TXCLOCK in Figure 4-27, for transmitting purposes is obtained from a hexadecimal counter overflow which employs the frequency of $1/2XTAL1 \cdot 2$ divided by 2 when SMOD = 0 or the unchanged $1/2XTAL1 \cdot 2$ frequency when SMOD = 1 as the clock. Transmission is started when transmission data is written in SBUF. The start bit, the eight SBUF data bits (with the LSB first), TB8, and the stop bit are thus transmitted sequentially from the TXD synchronized with the basic clock. As soon as the TB8 output has been completed, the transmit circuit is initialized, and the TI flag is set at the first M1 $\cdot$ S3 cycle after the completion of that output. #### 4.6.3.3.4 Mode 2 receive operation The receive circuit timing is generated by a hexadecimal counter which employs the clock frequency of 1/2XTAL1 · 2 divided by 2 when SMOD = 0 or the unchanged 1/2XTAL1 · 2 frequency when SMOD = 1 as the clock. The input data received from the RXD is bit synchronized. That is, at the same time that reception is started following input of the start bit, the hexadecimal counter commences to count up, and with one complete round of the hexadecimal counter corresponding to one bit of received data, reception is continued by the receive circuit. Therefore, the reception data baud rate must be equal to the period of a single round of the hexadecimal counter. The change in RXD from level "1" to "0" is regarded as the trigger to commence reception. When this "1" to "0" change in RXD is detected, the hexadecimal counter which had been in reset mode commences to count up. When the hexadecimal counter is in state 7, 8, and 9, the start bit is sampled, and is accepted as valid if at least two of the three sampled values are "0", thereby enabling data reception to continue. If two or three of the sampled values are "1", the start bit becomes invalid, and the receive circuit is initialized when the hexadecimal counter reaches state 10. The reception data is sampled when the hexadecimal counter is in state 7, 8, and 9. The most common value of the three sampled values is read sequentially as data into the input shift register. 4 If the conditions stated below are satisfied when the hexadecimal counter is in state 10 during the period of the multi-purpose data bit, the input shift register data (the LSB being read first) is loaded into SBUF and the sampled multi-purpose data bit is read into RB8. And when the hexadecimal counter is in state 10 during the period of the stop bit, the receive circuit is initialized. Conditions: (1) RI = "0" (2) SM2 = "0", or SM2 = "1" and sampled multi-purpose data bit = "1" The RI flag is set at the first M1 · S3 cycle after the initialization. If the above conditions are not satisfied when the hexadecimal counter is in state 10 during the multi-purpose data bit interval, the received data is disregarded, the SBUF, RB8, and RI flags remain unchanged, and the receive circuit is initialized when the hexadecimal counter is in state 10 during the stop bit interval. Since the receive circuit is divided into two stages, input shift register and SBUF, processing of the previous receive data may be completed within the interval up to the multi-purpose data bit period of the next frame. Figure 4-26 Serial port (mode 2) ### 4.6.3.4 Mode 3 ### 4.6.3.4.1 Outline Mode 3 is another 11-bit frame UART mode (with one start bit, eight data bits, one multi-purpose bit, and one stop bit). Whereas the baud rate is 1/64th or 1/32nd of the fundamental oscillator frequency in mode 2, the mode 3 baud rate can be freely selected depending on the timer/counter 1 setting. Apart from the ability to vary the baud rate, mode 3 is identical to mode 2. A block diagram of the serial port in mode 3 is shown in Figure 4-28, and the operational timing chart is given in Figure 4-29. # 4.6.3.4.2 Mode 3 baud rate Since the timer/counter 1 overflow frequency serves as the baud rate clock source in mode 3, the baud rate is determined by the same equations as in mode 1. $$B = Ftim \times \frac{1}{2} \times \frac{1}{16} \quad (SMOD = 0)$$ $$B = Ftim \times \frac{1}{16} \quad (SMOD = 1)$$ where B is the baud rate and Ftim is the timer/counter 1 overflow frequency. And when timer/counter 1 is used as a timer in auto reload mode (mode 2), the baud rate is determined by the following equations. B = Fosc $$\times \frac{1}{12} \times \frac{1}{256-D_{TH1}} \times \frac{1}{2} \times \frac{1}{16}$$ (SMOD = 0) B = Fosc $\times \frac{1}{12} \times \frac{1}{256-D_{TH1}} \times \frac{1}{16}$ (SMOD = 1) where B is the baud rate, Fosc the fundamental (XTAL1 $\cdot$ 2) frequency, and DTH1 the TH1 contents (expressed in decimal). # 4.6.3.4.3 Mode 3 transmit operation The basic clock, TXCLOCK in Figure 4-29, for transmitting purposes is obtained from a hexadecimal counter overflow which employs the halved timer/counter 1 overflow frequency when SMOD = 0 or the unchanged timer/counter 1 overflow frequency when Transmission is commenced when transmission data is written in SBUF. The start bit, the eight SBUF data bits (with the LSB first), TB8, and the stop bit are thus transmitted sequentially from the TXD synchronized with the basic clock. As soon as the TB8 output has been completed, the transmit circuit is initialized, and the TI flag is set at the first M1 · S3 cycle after the completion of that output. Figure 4-28 Serial port (mode 3)