## รายการอ้างอิง

- Larmarsh, J.R. <u>Introduction to nuclear engineering</u>. 2nd ed. California: Addison-wesley publishing company, 1983.
- 2. Hussein, E.M.A. Scattering of alpha, beta, and gamma radiation for chemical analysis.

  In Z.B. Alassi (ed.), Chemical Analysis by Nuclear Methods, pp. 417-430
- Robin, P.G. and Ralph L.F.Jr. Radiation Measurement Application in Engineering.
   United State of America: Reinhold Publishing, 1967.
- 4. Reed, S.J.B. Electron microprobe analysis. London: Cambridge university press, 1975.
- 5. Gonzalez, R.G. and Woods, R.E. <u>Digital image processing</u>. Massachusetts: Addision-wesley, 1992.
- 6. Gayler, W.D. The apple2 circuit decription. Indianapolis: Howward W. Sams ,1983.
- 7. Microprocessor data book MCS-51 microcontrollers. ETT.Bangkok:

### บรรณานุกรม

- 1. Jacob Millman, Ph.D. and Chirstos C. Halkias, Ph.D. Intergrated electronics. Singapore:

  Mcgraw-Hill Book, 1972.
- 2. Knoll ,G.F. Radiation detection and measurement. 2nd ed. New York: John Wiley & son, 1976.
- 3. Nicholson, J.W. Nuclear electronics. London: A wiley-interscience publishing, 1974.
- Tu, S. and Sato, O. locating the position of reinforcing bars in reinforced concrete
  using backscattered gamma rays. Applied Radiation and Isotopes.
  (September 1990): 1013-1018.
- 5. Stout, D.E. and Kaufman, M. Handbook of operational amplifier circuit design. New York: Mcgraw-Hill book.1976.
- 6. Linear circuit data book. USA: Texas instruments incorporated, 1992.
- 7. CMOS logic data. USA: Motolora incorporated, 1991.
- 8. Boylestad, R. and Nashelsky, L. <u>Electronic devices and circuit theory</u>. 4th ed. London: Prentice-Hall International, 1972.
- 9. Microprocessor data handbook. UAE: Micro-Tech, 1992.

### ภาคผนวก ก

# การออกแบบและคำนวณหม้อแปลงไฟฟ้าศักคาสูง

แหล่งจ่ายไฟฟ้าศักคาสูงที่ใช้สำหรับหัววัครังสีไกเกอร์ ซึ่งใช้กระแส 10 ไมโคร แอมแปร์ งานวิจัยนี้จึงเลือกใช้หม้อแปลงแกนเฟอร์ไรต์แบบ EP ขนาด 13 ตารางมิลลิเมตร ,  $A_{\rm e}$  = 0.195 cm 2 , $\Delta B$  = 1500 และกำหนดการทำงานต่างๆ ดังนี้ คือ ศักคาไฟฟ้าทางค้านเข้า 9 โวลต์ ให้ศักคาไฟฟ้าค้านขาออก 100 โวลต์ ช่วงเวลา  $t_{\rm m}$  = 9 ไมโครวินาทีและประสิทธิภาพ ของหม้อแปลง 80 เปอร์เซ็นต์ ขั้นตอนการออกแบบมีคังนี้

$$T = \frac{1}{f}$$

$$= \frac{1}{16kHz}$$

$$= 62.5 \,\mu s$$

$$t_{on(max)} = \frac{(V_O + V_D)(N_P / N_S)(0.8T)}{(V_{in(max)} - V_{CE(sat)}) + (V_O + V_D)(N_P / N_S)}$$

$$31.25 \times 10^{-6} = \frac{(100 + 0.7)(N_P / N_S)(0.8 \times 62.5 \times 10^{-6})}{9 + (100 + 0.7)(N_P / N_S)}$$

$$\frac{N_P}{N_S} = 0.1489$$

$$\frac{N_S}{N_P} = 6.713$$

$$L_P = \frac{\eta \left[ (v_{in(max)} - V_{CE(sat)}) \times t_{on(max)} \right]^2}{2T \times PoUT}$$

$$= \frac{0.8 \left[ (9 - 0.7) \times 31.25 \times 10^{-6} \right]^2}{2 \times 62.5 \times 10^{-6} \times 100 \times 10 \times 10^{-6}}$$

$$= 430 \,\text{mH}$$

$$I_P = \frac{(9 - 0.7) \times 31.25 \times 10^{-6}}{L_P}$$

$$= \frac{(9 - 0.7) \times 31.25 \times 10^{-6}}{430 \times 10^{-3}}$$

$$= 603 \,\mu\text{A}$$

$$N_{P} = \frac{(V_{in(max)} - V_{CE(sat)} \times t_{on(max)} \times 10^{8}}{\Delta B A_{e}}$$

$$= \frac{(9 - 0.7) \times 31.25 \times 10^{-6} \times 10^{8}}{1500 \times 0.195}$$

$$= 88 501$$

$$N_{S} = 6.7 \times N_{P}$$

$$= 595 501$$

ศูนย์วิทยทรัพยากร จุฬาลงกรณ์มหาวิทยาลัย

### ภาคผนวก ข

# วงจรอิเล็กทรอนิกส์ของระบบสแกนรังสึกระเจิงกลับเพื่อแสคงภาพสองมิติ



















ภ**าคผนวก ค** แบบโครงสร<sup>้</sup>างอุปกรณ**์**ขับเคลื่อนทางกล



#### ภาคผนวก ง

# ขอมูลทางเทคนิคของใมโครคอนโทรลเลอร์ 83C154

PRELIMINARY



AUGUST 1988

# DATA SHEET

83CT54

## CMOS SINGLE - CHIP 8 BIT MICROCONTROLLER

- 83C154 CMOS SINGLE-CHIP 8-BIT MICROCONTROLLER with factory mask-programmable ROM
- 83C154F-The internal ROM code cannot be read or dumped after activation of a special protection
- 80C154 ROMLESS version
- 83C154-1-16 MHz version
- 80C154-1-16 MHz ROMless version

#### **FEATURES**

- 16K x 8 BIT INTERNAL ROM
- 256 x BIT RAM
- 32 PROGRAMMABLE I/O LINES (PROGRAMMABLE IMPEDANCE)
- THREE 16-BIT TIMER/COUNTERS (INCLUDING WATCH DOG AND 32 BIT TIMER)
- 64K PROGRAM MEMORY SPACE
- · FULLY STATIC DESIGN
- POWER CONTROL MODES

- INTERRUPT PRIORITY CONTROL
- 0 TO 16 MHz
- BOOLEAN PROCESSOR
- 6 INTERRUPT SOURCES
- PROGRAMMABLE SERIAL PORT
- . 64K DATA MEMORY SPACE
- . TEMPERATURE RANGE:
- COMMERCIAL
- INDUSTRIAL

#### DESCRIPTION



The 83C154 retains all the features of the MHS 80C52 with extended ROM capacity (16K bytes). 256 bytes of RAM, 32 I/O lines, a 6-source 2-level interrupts, a full duplex serial port, an on-chip oscillator and clock circuits, three 16 bit timers with extra features: 32 bit timer and watch dog functions. Timer 0 and 1 can be configured by program to implement a 32 bit timer. The watch dog function can be activated either with timer 0, or timer 1 or both together (32 bit timer).

In addition, the 83C154 has two software selectable modes of reduced activity for further reduction of power consumption. In the Idle Mode, the CPU is frozen while the RAM is saved, and the timers, the serial port, and the interrupt system continue to function. In the Power Down Mode, the RAM is saved and the timers, serial port and interrupts continue to function when driven by external clocks. In addition as for the MHS 80C51/C52, the stop clock

mode is also available.

WWS





# IDLE AND POWER DOWN OPERATION

Figure 3 shows the internal Idle and Power Down clock configuration. As illustrated, Power Down operation stops the oscillator. The interrupt, serial port, and timer blocks continue to function only with external clock (INTO, INT1, TO, T1).



Idle Mode operation allows the interrupt, serial port, and timer blocks to continue to function with internal or external clocks, while the clock to CPU is gated off. The special modes are activated by software via the Special Function Register, PCON. Its hardware address is 87H. PCON is not bit addressable.

| (MSB) |     |     |   |     |     |    | (LSB) |
|-------|-----|-----|---|-----|-----|----|-------|
| SMOD  | HPD | RPD | - | GF1 | GF0 | PD | IDL   |

| Symbol | Position | Name and Function                                                                                                                                                                                                                                                                                        |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SMOD   | PCON.7   | Double Baud rate bit. When set to a 1, the baud rate is doubled when the serial port is being used in either modes 1, 2 or 3.                                                                                                                                                                            |
| HPD    | PCON.6   | Hard Power Down bit. Setting this bit allows CPU to enter in Power Down state on an external event (1 to 0 transition) on bit T1 (p. 3-5) the CPU quit the Hard Power Down mode when bit T1 (p. 3-5) go high or when reset is activated.                                                                 |
| RPD    | ·PCON.5  | Recover from Idle or Power Down bit. When 0 RPD has no effect. When 1, RPD permits to exit from idle or Power Down with any non enabled interrupt source (except timex 2). In this case the program start at the next address. When interrupt is enabled, the appropriate interrupt routine is serviced. |
| -      | PCON.4   | (Reserved)                                                                                                                                                                                                                                                                                               |
| GF1    | PCON.3   | General-purpose flag bit.                                                                                                                                                                                                                                                                                |
| GF0    | PCON.2   | General-purpose flag bit.                                                                                                                                                                                                                                                                                |
| PD     | PCON.1   | Power Down bit. Setting this bit activates power down opera-                                                                                                                                                                                                                                             |

tion.

. PCON.O Ide mode bit. Setting this bit

activates idle mode operation.



If 1's are written to PD and IDL at the same time. PD takes, precedence. The reset value of PCON is (000X0000).

#### IDLE MODE

The instruction that sets PCON.0 is the last instruction executed before the Idle mode is activated. Once in the Idle mode the CPU status is preserved in its entirety: the Stack Pointer, Program Counter, Program Status Word, Accumulator, RAM, and all other registers maintain their data during Idle. In the Idle mode, the internal clock signal is gated off to the CPU, but interrupt, timer and serial port functions are maintained. Table 1 describes the status of the external pins during Idle mode.

There are three ways to terminate the Idle mode. Activation of any enabled interrupt will cause PCON.0 to be cleared by hardware, terminating Idle mode. The interrupt is serviced, and following RETI, the next instruction to be executed will be the one following the instruction that wrote 1 to PCON.0.

The flag bits GFO and GFI may be used to determine whether the interrupt was received during normal execution or during the kile mode. For example, the instruction that writes to PCON.0 can also set or clear one or both flag bits. When kile mode is terminated by an enabled interrupt, the service routine can examine the status of the flag bits.

The second way of terminating the Idle mode is with a hardware reset. Since the oscillator is still running, the hardware reset needs to be active for only 2 machine cycles (24 oscillator periods) to complete the reset operation.

The third way to terminate the Idle mode is the activation of any disabled interrupt when recover is programmed (RPD=1). This will cause PCON.0 to be cleared. No interrupt is serviced. The next instruction is executed. If interrupt are disabled and RPD=0, only a reset can cancel the Idle mode.

#### POWER DOWN MODE

The instruction that sets PCON.1 is the last executed prior to entering power down. Once in power down, the oscillator is stopped. The contents of the onchip RAM and the Special Function Register is saved during power down mode. The three ways to terminate the Power Down mode are the same than the Idle mode. But since the onchip oscillator is stopped, the external interrupts, timers and serial port must be sourced by external docks only, via INTO, INT1, TO, T1.

In the Power Down mode, VCC may be lowered to

minimize circuit power consumption. Care must be taken to ensure the voltage is not reduced until the power down mode is entered, and that the voltage is restored before the hardware reset is applied which frees the oscillator. Reset should not be released until the oscillator has restarted and stabilized.

When using voltage reduction: interrupt, timers and serial port functions are guaranteed in the VCC specification limits.

Table 1 describes the status of the external pins while in the power down mode. It should be noted that if the power down mode is activated while in external program memory, the port data that is held in the Special Function Register P2 is restored to Port 2. If the port switches from 0 to 1, the port pin is held high during the power down mode by the strong pullup, T1, shown in Figure 4.



#### STOP CLOCK MODE

Due to static design, the MHS 83C154 clock speed can be reduced until 0 MHz without any data loss in memory or registers. This mode allows step by step utilization, and permits to reduce system power consumption by bringing the clock frequency down to any value. At 0 MHz, the power consumption is the same as in the Power Down Mode.

#### 83C154 I/O PORTS

The I/O drives for P1, P2, P3 of the 83C154 are impedance programmable. The I/O buffers for Ports 1.2 and 3 are implemented as shown in figure 4. When the port latch contains 0, all pFETS in figure 4 are off while the nFET is turned on. When the port latch makes a 0-to-1 transition, the nFET turns off The strong pullup pFET, T1, turns on for two oscillator periods, pulling the output high very rapidly. As the output line is

Table 1. Status of the external pins during Idle and Power Down modes

| Mode          | Program Memory | ALE | PSEN | PORTO     | PORTY     | PORT2     | PORT3     |
|---------------|----------------|-----|------|-----------|-----------|-----------|-----------|
| Idle          | Internal       | 1   | 1    | Port Data | Port Data | Port Data | Port Data |
| ldle          | External       | 1   | - 1  | Floating  | Port Data | Address · | Port Data |
| Power<br>Down | Internal       | 0   | 0    | Port Data | Port Data | Port Data | Port Data |
| Power<br>Down | External       | 0   | 0    | Floating  | Port Data | Port Data | Port Data |

drawn high, pFET T3 turns on through the inverter to supply the IOH source current. This inverter and T3 form a latch which holds the 1 and is supported by T2. When Port 2 is used as an address port, for access to external program of data memory, any address bit that contains a 1 will have his strong pullup turned on for the entire duration of the external memory access. When an I/O pin on Ports 1, 2 or 3 is used as an input. the user should be aware that the external circuit must sink current during the logical 1-to-0 transition. The maximum sink current is specified as ITL under the D.C. Specifications. When the input goes below approximately 2V,T3 turns off to save ICC current. Note. when returning to a logical 1, T2 is the only internal pullup that is on. This will result in a slow rise time if the user's circuit does not force the input line high. The input impedance of Port 1, 2, 3 are programmable through the register IOCON. The ALF bit (IOCON0) set all of the Port 1,2,3 floating when a Power Down mode occurs. The P1HZ, P2HZ, P3HZ bits (IOCON1, IOCON2, IOCON3) set respectively the Ports P1, P2, P3 in floating state. The IZC (IOCON4) allows to choose input impedance of all ports (P1, P2, P3). When IZC = 0, T2 and T3 pullup of I/O ports are active; the internal input impedance is approximately 10K. When IZC=1 only T2 pull-up is active. The T3 pull-up is turned off by IZC. The

#### PIN DESCRIPTIONS

#### VSS

Circuit ground potential.

Supply voltage during normal, Idle, and Power Down operation.

internal impedance is approximately 100K.

#### PORT 0

Port 0 is an 8-bit open drain bi-directional I/O port. Port 0 pins that have 1's written to them float, and in that state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external Program and

Data Memory. In this application it uses strong internal pullups when emitting 1's. Port 0 also outputs the code bytes during program verification in the 83C154 External pullups are required during program verification. Port 0 can sink eight LSTTL inputs.

Port 1 is an 8-bit bi-directional I/O port with internal pullups. Port 1 pins that have 1's written to them are pulled high by the internal pullups, an in that state can be used as inputs. As inputs, Port 1 pins that are externally being pulled low will source current (IIL, on the data sheet) because of the internal pullups. Port 1 also receives the low-order address byte during program verification. In the 83C154, Port 1 can sink/ source three LS TTL inputs. It can drive CMOS inputs without external pullups.

Port 2 is an 8-bit bi-directional I/O port with internal pullups. Port 2 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 2 pins that are externally being pulled low will source current (ILL, on

the data sheet) because of the internal pullups. Port 2 emits the high-order address byte during fetches from external Program Memory and during accesses to external Data Memory that use 16-bit addresses (MOVX @ DPTR). In this application, it uses strong internal pullups when emitting 1's. During accesses to external Data Memory that use 8-bit addresses (MOVX @Ri), Port 2 emits the contents of the P2 Special Function Register.

It also receives the high-order address bits and control signals during program verification in the 83C154. Port 2 can sink/source three LS TTL inputs. It can drive

CMOS inputs without external pullups.

Port 3 is an 8-bit bi-directional I/O port with internal pullups. Port 3 pins that have 1's written to them are pulled high by the internal pullups, and in that state can be used as inputs. As inputs, Port 3 pins that are externally being pulled low will source current (ILL, on the data sheet) because of the pullups. It also serves the functions of various special features of the MCS-51 Family, as listed below.

| Port Pin | Alternate Function |
|----------|--------------------|
|          |                    |

P3.0 RXD (serial input port) P3.1 TXD (serial output port)

P3.2 INTO (external interrupt 0) INT1 (external interrupt 1)

P3.3 P3.4 TO (Timer 0 external input)
T1 (Timer 1 external input)

P3.5 P3.6 WR (external Data Memory write strobe) P3.7 RD (external Data Memory read strobe)

Port 3 can sink/source three LSTTL inputs. It can drive CMOS inputs without external pullups.

A high level on this for two machine cycles while the oscillator is running resets the device. An internal pull-down resistor permits Power-On reset using only a capacitor connected to VCC.

Address Latch Enable output for latching the low byte of the address during accesses to external memory. ALE is activated as though for this purpose at a constant rate of 1/6 the oscillator frequency except during an external data memory access at which time one ALE pulse is skipped. ALE can sink/source 8 LS TTL inputs. It can drive CMOS inputs without an external pullup.

#### PSEN

Program Store Enable output is the read strobe to external Program Memory. PSEN is activated twice each machine cycle during fetches from external Program Memory. (However, when executing out of external Program Memory, two activations of PSEN are skipped during each access to external Data Memory). PSEN is not activated during fetches from internal Program Memory. PSEN can sink/source 8 LS-TTL inputs. It can drive CMOS inputs without an external pullup.

When EA is held high, the CPU executes out of internal Program Memory (unless the Program Counter



exceeds 3FFFH). When EA is held low, the CPU executes only out of external Program Memory. EA must not be floated.

#### XTAL1

Input to the inverting amplifier that forms the oscillator. Receives the external oscillator signal when an external oscillator is used.

#### XTAL2

Output of the inverting amplifier that forms the oscillator. This pin should be floated when an external oscillator is used.

#### OSCILLATOR CHARACTERISTICS

Sheet must be observed.

XTAL 1 and XTAL 2 are the input and output respectively, of an inverting amplifier which is configured for use as an on-chip oscillator, as shown in figure 5. Either a quartz crystal or ceramic resonator may be used. To drive the device from an external clock source, XTAL1 should be driven while XTAL2 is left unconnected as shown in figure 6. There are no requirements on the duty cycle of the external clock signal, since the input to the internal clocking circuitry is through a divide-by-two flip-flop, but minimum and maximum high and low times specified on the Data



#### PORT 1 SECONDARY FUNCTIONS

This is a quasi-bidirectional I/O port, internally pulled up when used as input ports. Two of the ports have been allocated a second function which are:

P1.0 [T2]: External clock input for timer/counter 2. P1.1 [T2EX]: A trigger input for timer/counter 2, to be reloaded or captured causing the timer/counter 2 interrupt.

#### INTERRUPT MODES

The MHS 80C154/83C154 is capable of handling two external interrupts, three interrupts from the timers, and, one interrupt from the serial port, through its incorporated six source, two-level interrupt structure.

SERIAL PORTTIMING
The interrupt is executed after the Stop Bit.



#### TIMER FUNCTIONS

In fact, timer 0 & 1 can be connected by a software instruction to implement a 32-bit timer function. Timer 0 (mode 3) or timer 1 (mode 0, 1, 2) or a 32-bit timer consisting of timer 0 + timer 1 can be employed in the watchdog mode, in which case a CPU reset is generated upon a TF1 flag.

generated upon a TF1 flag.

The internal pull-up resistances at ports 1 ~ 3 can be set to a ten times increased value simply by software.



#### TIMER/EVENT COUNTER 2

Timer 2 is a 16-bit timer/counter like Timers 0 and 1, it can operate either as a timer or as an event counter. This is selected by bit C/T2 in the Special Function Register T2CON (Fgure 7). It has three operating modes: "capture", "autoload" and "baud rate generator", which are selected by bits in T2CON as shown in Table 2.

Table 2. Timer 2 Operating Modes

| RCLK+ | TCLK | CP/RL2 | TR2 | MODE                |
|-------|------|--------|-----|---------------------|
| 0     |      | . 0    | 1   | 16 bit auto-reload  |
| 0     |      | 1      | 1   | 16-bit capture      |
| 1     |      | X      | 1   | baud rate generator |
| X     |      | X      | 0   | (off)               |



In the capture mode there are two options which are selected by bit EXEN2 in T2CON. If EXEN2 = 0, then Timer 2 is a 16-bit timer or counter which upon overflowing sets bit TF2, the Timer 2 overflow bit, which can be used to generate an interrupt. If EXEN2 = 1, then Timer 2 still does the above, but with the added feature that a 1-to-0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 ans TH2, to be captured into registers RCAP2L and RCAP2H, respectively. (RCAP2L and RCAP2H are new Special Function Registers in the 80C52). In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2, like TF2, can generate an interrupt. The capture mode is illustrated in Figure 8.

In the auto-reload mode there are again two options, which are selected by bit EXEN2 in T2CON.If EXEN2 = 0, then when Timer 2 rolls over it not only sets TF2 but also causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2L and RCAP2H, which are preset by software. If EXEN2=1, then Timer 2 still does the above; but with the added feature that a 1-to-0 transition at external input T2EX will also trigger the 16-bit reload and set EXF2.

The auto-reload mode is illustrated in Figure 9. The baud rate generator mode is selected by: RCLK=1 and/or TCLK=1.







83C154



#### DETAILED DIAGRAM OF DATA MEMORY (RAM) OFFH 7FH 2FH 7F 7E 7C **7B 7A** 2EH 2DH 6F 6C 6A 6E 2CH 28H 5F 5B 5E 5D 5C 5A DIRECT BYTE ADDRESSING DIRECT BIT ADDRESSING 2AH INDIRECT ADDRESSING 29H 4F 4E 4C 4B 4A 28H 27H 3F 3E 3C 3A 26H 25H 2F 2E 2C 2A 24H 23H 1F 1E 1C 1A 22H 21H OF 0E OD OC OA 20H .06 1FH Bank 3 REGISTER ADDRESSING 18H 17H Bank 2 10H OFH Bank 1 08H 07H Bank 0 00H

| 0 | 2 | ~ | 5 | , |
|---|---|---|---|---|

| · By | rect<br>rte<br>ddress |       |                        |      | Dit A    | ddress   |      |      |        | Special<br>Function<br>Register |
|------|-----------------------|-------|------------------------|------|----------|----------|------|------|--------|---------------------------------|
| ^(   |                       | (MSB) |                        |      | DIL AL   | Juless   |      |      | (LSB)  | Symbol                          |
|      |                       | WDT   | T32                    | SERR | IZC      | P3HZ     | P2HZ | P1HZ | ALF    |                                 |
| OF   | F8H                   | FF    | FE                     | FD   | FC       | FB       | FA   | F9   | F8     | IOCON                           |
| OF   | -он                   | F7    | F6                     | F5   | F4       | F3       | F2   | F1   | FO     | В                               |
| 08   | ЕОН                   | E7    | E6                     | E5   | E4       | E3       | E2   | E1   | EO     | ACC                             |
|      |                       | CY    | AC                     | FO   | RS1      | RSO      | OV   | F1   | Р      |                                 |
| 00   | ЮН                    | D7    | D6                     | D5   | D4       | D3       | D2   | D1   | DO     | PSW                             |
| 00   | . HOX                 |       |                        | No   | t Bit Ac | dressat  | nle  |      |        | TH2                             |
|      | CH                    |       |                        |      |          | Idressal |      |      |        | TL2                             |
| 00   | XBH                   |       |                        |      |          | dressat  |      |      |        | RCAP2H                          |
| 00   | AH                    |       |                        | No   | t Bit Ac | dressat  | ole  |      |        | RCAP2L                          |
|      |                       | TF2   | EXF2                   | RCLK | TCLK     | EXEN2    | TR2  | C/T2 | CP/RL2 |                                 |
| 00   | BH [                  | CF    | Œ                      | CD   | CC       | CB       | CA   | C9   | C8     | T2CON                           |
|      |                       | PCT   |                        | PT2  | PS       | PT1      | PX1  | PTO  | PXO    |                                 |
| 08   | 8H [                  | BF    | -                      | BO   | 8C       | 88       | BA   | 89   | 88     | IP                              |
| 08   | он [                  | 87    | B6                     | 85   | 84       | 83       | 82   | B1   | 80     | P3                              |
|      | 0                     | EA    |                        | ET2  | ES       | ET1      | EX1  | ETO  | EXO    |                                 |
| 0A   | 8H [                  | AF    | -                      | AD   | AC       | AB       | AA   | A9   | A8     | IE                              |
| 0A   | он [                  | A7    | A6                     | A5   | A4       | A3       | A2   | A1   | AO     | P2                              |
| 99   | н Г                   |       |                        | No   | t Bit Ad | dressab  | ile  |      |        | SEUF                            |
|      | L                     | SMO   | SM1                    | SM2  | REN      | TB8      | R88  | TI   | RI     |                                 |
| 98   | н Г                   | 9F    | 9E                     | 9D   | 9C       | 98       | 9A   | 99   | 98     | SCON .                          |
| 90   | н [                   | 97    | 96                     | 95   | 94       | 93       | 92   | 91   | 90     | P1                              |
|      | [                     |       |                        | 33   | J 7      | 30       | 32   | 01   | 50     |                                 |
| 80   | н Г                   |       | TWY STORY OF THE STORY | No   | t Bit Ad | dressat  | ile  |      |        | TH1                             |
| 80   | H                     |       |                        |      |          | dressab  |      |      |        | THO                             |
| 88   | Н                     |       | 0.10                   | No   | t Bit Ad | dressab  | le   |      |        | TL1                             |
| 8A   | н [                   |       |                        | No   | t Bit Ad | dressab  | le   | 2    |        | TLO                             |
| 89   | н [                   |       |                        | No   | t Bit Ad | dressab  | le   |      |        | TMOD                            |
|      |                       | TF1   | TR1                    | TFO  | TRO      | IE1      | IT1  | IEO  | ПО     |                                 |
| 88   | H [                   | 8F    | 8E                     | 8D   | 8C       | 88       | 8A   | 89   | 88     | TCON                            |
| 871  | 4                     |       |                        | No   | t Bit Ad | dressab  | le   |      |        | PCON                            |
| 83   | ц г                   |       |                        | No   | Rit Ad   | dressab  | Ja   |      |        | DPH                             |
| 82   | -                     |       |                        |      |          | dressat  |      |      |        | OPL                             |
| 81   | -                     |       |                        |      |          | dressab  |      |      |        | SP                              |
| 80   |                       | 87    | 86                     | 85   | 84       | 83       | 82   | 81   | 80     | P0                              |

|  | C |  |
|--|---|--|
|  |   |  |
|  |   |  |

# SPECIAL FUNCTION REGISTERS TIME MODE REGISTER (TMOD)

| NAME         | ADDRESS | TMSB                                                                                                                                                                                                                                                                                                          | 6              | 1 5                    | 1 4                         | 3            |                       |             | LSE    |  |
|--------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------------|-----------------------------|--------------|-----------------------|-------------|--------|--|
| TMOD         | 89H     | GATE                                                                                                                                                                                                                                                                                                          | C/T            | M1                     | MO                          | GATE         | C/T                   | 1<br>M1     | MO     |  |
| BIT LOCATION | FLAG    |                                                                                                                                                                                                                                                                                                               |                |                        |                             | CTION        | 1 01                  | 1 1111      | 1 1410 |  |
| TMOD.0       | МО      | M1                                                                                                                                                                                                                                                                                                            | МО             | Timer/co               | unter 0 mc                  |              |                       |             |        |  |
|              |         | 0                                                                                                                                                                                                                                                                                                             |                | +                      | er/counter                  |              |                       |             |        |  |
|              |         | 0 1 1 116-bit timer/counter.                                                                                                                                                                                                                                                                                  |                |                        |                             |              |                       |             |        |  |
|              |         | 1                                                                                                                                                                                                                                                                                                             | - 0 -          | 8-bit time             | auto reloa                  | ading.       |                       |             |        |  |
| TMOD.1       | M1      | 1                                                                                                                                                                                                                                                                                                             | 1              | Timer/cooland THO      | unter 0 sep<br>(8-bit) time | parated in   | to TLO (8-            | bit) timer/ | counte |  |
| TMOD.2       | Сл̄     | Timer/co<br>XTAL1 · 2<br>C/T=*0*                                                                                                                                                                                                                                                                              | divided        | count cloc             | k designat                  | ion contro   | ol bit.<br>ed to time | r/counter   | 0 wher |  |
|              |         | The exte                                                                                                                                                                                                                                                                                                      | rnal clos      | ck applied to C/T="1". | o the TO p                  | in is the in | nput applie           | ed to time  | r/     |  |
| TMOD.3       | GATE    | When this bit is "0", the TR0 bit of TCON (timer control register) 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 TR0 bit of TCON and INTO pin input signal are "1", and stops counting when either is changed to "0". |                |                        |                             |              |                       |             |        |  |
| TMOD.4       | МО      | M1 M0 Timer/counter 1 mode setting.  0   0   18-bit timer/counter with 5-bit prescalar.  0   1   16-bit timer/counter.                                                                                                                                                                                        |                |                        |                             |              |                       |             |        |  |
| TMOD.5       | M1      |                                                                                                                                                                                                                                                                                                               | $-\frac{0}{1}$ |                        | nter 1 ope                  |              |                       | ding.       |        |  |
| TMOD.6       | СЛ ·    | 1   1   Timer/counter 1 operation stopped.  Timer/counter 1 count clock designation control bit.  XTAL 2 divided by 12 clocks is the input applied to timer/counter 1 when C/T = "0".  The external clock applied to the T1 pin is the input applied to timer/counter 1 when C/T = "1".                       |                |                        |                             |              |                       |             |        |  |
| TMOD.7       | GATE    | When this bit is "0", the TR1 bit of TCON is used to control to stop of timer/counter 1 counting.  If this bit is "1", timer/counter 1 starts counting when both to TCON and INT1 pin input signal are "1", and stops counting changed to "0".                                                                |                |                        |                             |              |                       |             | cf     |  |

## POWER CONTROL REGISTER (PCON)

| NAME         | ADDRESS | MSB<br>7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 6                                                                | 5                                                    | 4                                                | 3                                                       | 2                                                                            | 1                                                      | LSE                                    |  |
|--------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------|--|
| PCON         | 87H     | SMOD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HPD                                                              | RPD                                                  | -                                                | GF1                                                     | GF0                                                                          | PD                                                     | IDL                                    |  |
| BIT LOCATION | FLAG    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                  |                                                      | FUN                                              | CTION                                                   |                                                                              |                                                        |                                        |  |
| PCON.0       | IDL .   | when IDI interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | E mode circuits, a                                               | is set, but<br>nd serial p                           | XTAL1-2, ort rema                                | timer/cou<br>in active. I                               | perations<br>nters 0, 1,<br>DLE mode<br>generated.                           | and 2, the                                             |                                        |  |
| PCON.1       | PD      | stopped                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | when PD                                                          |                                                      | et. PD m                                         | ode is car                                              | erations ar<br>ncelled wh                                                    |                                                        |                                        |  |
| PCON.2       | GF0     | General purpose bit. Testing this flag when IDLE mode is cancelled by an interrupt shows whether the interrupt is a normal interrupt or an IDLE mode release interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                  |                                                      |                                                  |                                                         |                                                                              |                                                        |                                        |  |
| PCON.3       | GF1     | General processing the whether the second se | is flag wh                                                       | nen PD mo                                            | de is car                                        | ncelled by                                              | an interru<br>PD mode r                                                      | pt shows<br>elease int                                 | errupt                                 |  |
| PCON.4       | - //    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | bit. The                                                         | output data                                          | a is "1" if t                                    | he bit is re                                            | ead.                                                                         |                                                        |                                        |  |
| PCON.5       | RPD     | interrupt<br>if interrup<br>"0". If the i<br>bit is "1" (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | signal. Po<br>t is not en<br>nterrupt f<br>even if intess of the | wer down<br>habled by<br>lag is set t<br>errupt is d | mode ca<br>E (interno<br>o "1" by a<br>isabled), | annot be out<br>upt enable<br>in interrup<br>the progra | lown mode<br>cancelled to<br>register)<br>trequests<br>am is execustruction. | by interrupt<br>when this<br>signal when<br>suted from | ot signa<br>bit is<br>en this<br>n the |  |
|              |         | ENABL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | E                                                                | RECOVER                                              | $\neg$                                           |                                                         |                                                                              |                                                        |                                        |  |
|              |         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                  | 0                                                    | PWDr                                             | not cancelled                                           | 1                                                                            |                                                        |                                        |  |
|              |         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                  | 0                                                    | Execut                                           | e interrupt r                                           | outine                                                                       |                                                        |                                        |  |
| •            |         | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                  | 1                                                    |                                                  | e next addre                                            |                                                                              |                                                        |                                        |  |
|              |         | 1 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                  | 1                                                    |                                                  | e interrupt re                                          |                                                                              |                                                        |                                        |  |
| PCON.6       | HPD     | The hard power down setting mode is enabled when this bit is set to "1" If the level of the power failure detect signal applied to the HPD1 pin (pir 3.5) is changed from "1" to "0" when this bit is "1", XTAL1-2 oscillation is stopped and the system is put into hard power down mode. HPD mode cancelled when the CPU is reset, or HPD1 pin go high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                  |                                                      |                                                  |                                                         |                                                                              |                                                        |                                        |  |
| PCON.7       | SMOD    | When the time/counter 1 carry signal is used as a clock in mode 1, 2 or 3 of the serial port, this bit has the following functions. The serial port operation clock is reduced by 1/2 when the bit is "0" for delayed processing. And when the bit is "1", the serial port operation clock is normal for faster processing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                  |                                                      |                                                  |                                                         |                                                                              |                                                        |                                        |  |

| 8 | 3 | C | 15 | 4 |
|---|---|---|----|---|
|   | • | ~ | -  | 7 |

## TIMER CONTROL REGISTER (TCON)

| NAME         | ADDRESS | MSB<br>7            | 6                                                                                                                                                        | 5           | 4                                           | 3             | 2                 | 1          | LSE  |  |  |  |
|--------------|---------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------------------------------------|---------------|-------------------|------------|------|--|--|--|
| TCON         | 88H     | TF1                 | TR1                                                                                                                                                      | TFO         | TRO                                         | IE1           | IT1               | IE0        | ПО   |  |  |  |
| BIT LOCATION | FLAG    |                     | FUNCTION                                                                                                                                                 |             |                                             |               |                   |            |      |  |  |  |
| TCON.0       | ITO     | External and in tr  | xternal interrupt 0 signal used in level detect mode when this bit is "0", nd in trigger detect mode when "1".                                           |             |                                             |               |                   |            |      |  |  |  |
| TCON.1       | IE0     | Bit is res          | terrupt request flag for external interrupt 0.  It is reset automatically when interrupt is serviced.  It can be set and reset by software when ITO="1". |             |                                             |               |                   |            |      |  |  |  |
| TCON.2       | IT1     | External and in tri | External interrupt 1 signal used in level detect mode when this bit is "0", and in trigger detect mode when "1".                                         |             |                                             |               |                   |            |      |  |  |  |
| TCON.3       | IE1     | Bit is res          | et automa                                                                                                                                                | atically wh | ternal inter<br>en interrup<br>software w   | ot is servi   |                   |            |      |  |  |  |
| TCON.4       | TRO.    |                     | unter 0 st                                                                                                                                               |             | ntrol bit for<br>ting when                  |               |                   | ops coun   | ting |  |  |  |
| TCON.5       | TFO .   | Bit is res          | et automa                                                                                                                                                | atically wh | er interrup<br>en interrup<br>ignal is gei  | ot is service |                   | counter 0  |      |  |  |  |
| TCON.6       | TR1     |                     | ounting start and stop control bit for timer/counter 1. mer/counter 1 starts counting when this bit is "1", and stops counting then "0".                 |             |                                             |               |                   |            |      |  |  |  |
| TCON.7       | TF1     | Bit is res          | et automa                                                                                                                                                | atically wh | er interrup<br>ien interrup<br>ignal is ger | ot is service | ced.<br>om timer/ | counter 1. |      |  |  |  |



|   | 02 | ~   | 54 |
|---|----|-----|----|
| _ | 00 | U 1 | 24 |

#### SERIAL PORT CONTROL REGISTER (SCON)

| NAME         | ADDRESS | MSB<br>7                                     | 6                                               | 5                                                 | 4                                                                                      | 3                                                     | 2                                                    | 1         | LSB<br>0 |
|--------------|---------|----------------------------------------------|-------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|-----------|----------|
| SCON         | 98H     | SMO                                          | SM1                                             | SM2                                               | REN                                                                                    | TB8                                                   | R88                                                  | TI        | RI       |
| BIT LOCATION | FLAG    |                                              |                                                 |                                                   | FUNC                                                                                   | TION                                                  | <u> </u>                                             |           |          |
| SCON.0       | RI      | This flag<br>This flag<br>mode 0,<br>however | must be<br>is set aft<br>or by the<br>RI is not | reset by:<br>er the eig<br>STOP bit<br>set if the | n" interrupt<br>software du<br>hth bit of d<br>when in ar<br>RB8 data is<br>s received | uring inter<br>ata has be<br>ny other m<br>s "0" with | rupt servic<br>een receiv<br>node. In mo<br>SM2="1". | ed when   | in       |
| SCON.1       | TI      | reset by<br>This flag                        | software is set aft                             | during inter the eig                              | sion" interru<br>terrupt serv<br>hth bit of da<br>has been s                           | ice routinata has be                                  | e.<br>een sent w                                     | vhen in m | node 0,  |
| SCON.2       | R88     | The STO                                      | P bit is ap                                     |                                                   | ed in möde<br>RB8 if SM2<br>ode 0.                                                     |                                                       |                                                      |           |          |
| SCON.3       | TB8     |                                              |                                                 |                                                   | ninth data                                                                             |                                                       |                                                      | 2 or 3.   |          |
| SCON.4       | REN     | No rece                                      | otion whe                                       | control ben REN="                                 | 0".                                                                                    |                                                       |                                                      |           |          |
| SCON.5       | SM2     | end of re                                    | eception*<br>e *end of                          | signal is                                         | lata is "0" w<br>not set in th<br>" signal set                                         | ne RI flag.                                           |                                                      |           |          |
| SCON.6       | SM1     | SMO                                          | SM1                                             | MODE                                              |                                                                                        |                                                       |                                                      |           |          |
|              | LY/     | 0                                            | 0 1                                             | 0 1                                               | 8-bit shift                                                                            | register V                                            | 0.                                                   |           |          |
|              |         | 0 1                                          | 1 1                                             | 1 1                                               | 8-bit UART                                                                             | variable                                              | baud rate.                                           |           |          |
| SCON.7       | SMO     | 1 7                                          | -0-1                                            | 2 7                                               | 9-bit UART                                                                             | 1/32 XTA                                              | L1. 1/64 X                                           | TAL1 bau  | d rate.  |
|              |         |                                              | 1 1                                             | 3 1                                               | 9-bit UART                                                                             | variable                                              | baud rate.                                           |           |          |

|  | 154 |  |
|--|-----|--|
|  |     |  |
|  |     |  |

## INTERRUPT ENABLE REGISTER (IE)

| NAME         | ADDRESS | MSB<br>7  | 6         | 5                                            | 4            | 3            | 2            | 1 1 | LSB |
|--------------|---------|-----------|-----------|----------------------------------------------|--------------|--------------|--------------|-----|-----|
| IE           | 0A8H    | EA        | -         | ET2                                          | ES           | ET1          | EX1          | ETO | EXC |
| BIT LOCATION | FLAG    |           |           |                                              | FUNC         | CTION        |              |     |     |
| IE.0         | EX0     | Interrupt | disabled  | oit for extern<br>when bit is<br>when bit is | s "0".       | upt O.       | 9 5          |     |     |
| IE.1         | ETO     | Interrupt | disabled  | oit for timer<br>when bit is<br>when bit is  | s "O".       | 0.           |              |     |     |
| IE.2         | EX1     | Interrupt | disabled  | when bit is                                  | s "O".       | ipt 1.       |              |     |     |
| IE.3         | ETI     | Interrupt | disabled  | it for timer i<br>when bit is<br>when bit is | 0".          | 1.           |              |     |     |
| IE.4         | ES      | Interrupt | disabled  | or serial por<br>when bit is<br>when bit is  | 0".          |              |              |     |     |
| IE.5         | ET2     | Interrupt | disabled  | it for timer i<br>when bit is<br>when bit is | "0".         | 2.           |              |     |     |
| IE.6         |         | Reserved  | bit. The  | output data                                  | is "1" if th | ne bit is re | ad.          |     |     |
| IE.7         | EA      |           | ots are c | ontrol bit.<br>lisabled wh<br>controlled b   |              |              | en bit is "1 | •   | -   |

## INTERRUPT PRIORITY REGISTER (IP)

|             | T       | 1 1100                   |                                   |                                                   |                      |              |            |               | ·        |
|-------------|---------|--------------------------|-----------------------------------|---------------------------------------------------|----------------------|--------------|------------|---------------|----------|
| NAME        | ADDRESS | MSB<br>7                 | 6                                 | 5                                                 | 4                    | 3            | 2          | 1             | LSE<br>0 |
| IP          | 088H    | PCT                      | -                                 | PT2                                               | PS                   | PT1          | PX1        | PTO           | PXC      |
| BITLOCATION | FLAG    |                          |                                   |                                                   | FUNC                 | CTION        |            | -             |          |
| IP.0        | PX0     | Interrupt<br>Priority is | priority to                       | it for exterior                                   | nal interru          | ipt 0.       |            | ************* |          |
| IP.1        | PTO     | Interrupt<br>Priority is | priority b                        | it for timer<br>d when bit                        | interrupt<br>is "1". | 0.           | 10         | 0 1           |          |
| IP.2        | PX1     |                          |                                   | it for externed when bit                          |                      | pt 1.        |            |               |          |
| IP.3        | PT1     |                          |                                   | it for timer<br>d when bit                        |                      | 1.           |            |               |          |
| IP.4        | PS      | Interrupt<br>Priority is | priority b<br>assigne             | it for serial<br>d when bit                       | port.<br>is "1".     |              | ,          | -             |          |
| IP.5 ·      | PT2     | Interrupt<br>Priority is | priority b<br>assigne             | it for timer<br>d when bit                        | interrupt :          | 2.           |            |               |          |
| IP.6        | -       | Reserved                 | bit. The                          | output dat                                        | a is "1" if t        | he bit is re | ead.       |               |          |
| IP.7        | PCT     | The priori<br>be proce   | ty registe<br>ssed wh<br>stopped, | rcuit control er contents en this bit and interro | are valid            | en the bit   | is 11, the | priority inte | errupt   |

83C154

#### PROGRAM STATUS WORD REGISTER (PSW)

| NAME         | ADDRESS | MSB<br>7             | 6                                  | 1 5         | 1 4                                                             | 3                        | 2                            | 1                       | LSB<br>0  |
|--------------|---------|----------------------|------------------------------------|-------------|-----------------------------------------------------------------|--------------------------|------------------------------|-------------------------|-----------|
| PSW          | ОДОН    | CY                   | AC                                 | FO          | RS1                                                             | RS0                      | OV                           | F1                      | Р         |
| BIT LOCATION | FLAG    |                      |                                    |             | FUNC                                                            | TION                     | L                            |                         | 1         |
| PSW.0        | Р       | "1" when             | lator (AC)<br>the "1" b            | it numbe    | indicator.<br>er in the acc                                     | umulator i               | s an odd i                   | number, a               | ind *0*   |
| PSW.1        | F1      | User flag            | which r                            | may be s    | et to "0" or "1                                                 | as desir                 | ed by the                    | user.                   |           |
| PSW.2        | OV      | as a res<br>resultan | ult of an<br>t product<br>than OFF | arithmetic  | if the carry<br>c operation.<br>uting a multi<br>reset to "0" i | The flag is plication in | s also set to<br>instruction | to "1" if the<br>(MULAB | e<br>) is |
| PSW.3        | RS0     | RAM rec              | gister bar                         | nk switch   |                                                                 |                          |                              |                         |           |
| ,            | i j     | RS1                  | RS0                                | BANK        | RAM ADDF                                                        | RESS                     |                              |                         |           |
|              |         | 0                    | 0                                  | 0           | 00H-07                                                          | 7H                       |                              |                         |           |
| PSW.4        | RS1     | 0                    | 1                                  | 1           | 08H-08                                                          | =H                       |                              |                         |           |
|              |         | 1                    | 0                                  | 2           | 10H-17                                                          | 7H                       |                              |                         |           |
|              |         | 1                    | 1                                  | 3           | 18H-18                                                          | FH .                     |                              | 4                       |           |
| PSW.5        | F0      | User flag            | which r                            | nay be s    | et to "0" or "1                                                 | as desir                 | ed by the                    | user                    |           |
| PSW.6        | AC      | result of            | is set to<br>execution             | "1" if a ca | arry C <sub>3</sub> is ger<br>nmetic opera<br>is reset to *(    | ation instr              |                              | f the ALU               | as a      |
| PSW.7        | CY      | of execu             | is set to                          | arithmetic  | erry C <sub>7</sub> is ger<br>operation in<br>ed, the flag      | struction.               |                              | f the ALU               | as resu   |

## TIMER 2 CONTROL REGISTER (T2CON)

| NAME         | ADDRESS | MSB<br>7                                       | 6                                    | 5                                    | 4                                       | 3                                                      | 2                          | 1                      | LSB<br>0             |
|--------------|---------|------------------------------------------------|--------------------------------------|--------------------------------------|-----------------------------------------|--------------------------------------------------------|----------------------------|------------------------|----------------------|
| T2CON        | 0C8H    | TF2                                            | EXF2                                 | RCLK                                 | TCLK                                    | EXEN2                                                  | TR2                        | C/T2                   | CP/RL2               |
| BIT LOCATION | FLAG    |                                                |                                      |                                      | FUNC                                    | CTION                                                  |                            | 1                      |                      |
| T2CON.0      | CP/RL2  | 16-bit au                                      |                                      | mode is s                            | et when 1                               | CLK="0" a<br>FCLK + RC<br>K="1".                       |                            |                        | <u>.</u> 2=*0*.      |
| T2CON.1      | C/T2    | The inte                                       | rnal clocks                          | al clock a                           | 2 + 12, XT                              | ion control<br>AL1-2 + 2<br>the T2 is pa               | ) are use                  | d when th<br>timer/cou | nis bit is<br>nter 2 |
| T2CON.2      | TR2     | Timer/co                                       | unter 2 co<br>unter 2 co<br>when "0" | ommence                              | art and sto<br>s counting               | op control<br>g when this                              | bit.<br>s bit is "1"       | and stop               | s                    |
| T2CON.3      | EXEN2   | T2EX tin<br>Input of<br>when "1"               | he T2EX s                            | er 2 extern<br>signal is d           | al control<br>isabled w                 | signal cor<br>hen this bi                              | ntrol bit.<br>t is "0", ar | nd enable              | d                    |
| T2CON.4      | TCLK    | Timer/co<br>"1", and the<br>clock.<br>Note, ho | unter 2 is<br>ne timer/c             | switched ounter 2 out the seria      | to baud recarry signal                  | control bit.<br>ate genera<br>al become:<br>n only use | itor mode<br>s the seri    | al port tra            | nsmit                |
| T2CON.5      | RCLK    | Timer/co<br>"1", and the<br>clock.<br>Note, ho | ne timer/co                          | switched<br>ounter 2 c               | to baud ra<br>arry signa<br>I ports car | ontrol bit.<br>ate genera<br>al becomes<br>n only use  | s the seria                | al port rec            | ceive                |
| T2CON.6      | EXF2    | This bit is<br>level is c<br>This flag         | nanged fro<br>serves as              | when the<br>om "1" to "<br>the timer | T2EX tim<br>0" while E<br>interrupt 2   | er/counter<br>EXEN2 = 1<br>2 request s<br>by software  | ignal. If a                |                        |                      |
| T2CON.7      | · TF2   | This bit is<br>reload m<br>This flag           | ode or in o<br>serves as             | by a carry<br>capture m<br>the timer | ode.<br>Interrupt 1                     | nen timer/o<br>2 request s<br>y software.              | signai. If a               |                        |                      |





AUGUST 1988

# **APPLICATION NOTE**

AN1043

# DIFFERENCES BETWEEN THE 83C154 AND THE 80C52

The 83C154 is an 8-bit microcontroller belonging to the MHS C51 family of microcontrollers. Its instruction set and the number of functions implemented are fully compatible with this family. The innovations concern the size of RAM available, 16 Kbytes instead of 8 and the new functions listed in table 1.

- TIMER 1 and TIMER 0: 32-bit TIMER/COUNTER WATCH DOG,

Asynchronous counting in POWER-DOWN mode.

- PORTS, 1, 2, 3: Choice of output resistance value. - UART

Receive error detection.
- POWER-DOWN MODE:

Software and hardware control.

- IDLE MODE:

New possibility for exiting from this mode.

- INTERRUPTS:

New mode.

- BITTRANSFER:

New instruction for implementing transfers between bits.

### IOCON

Figure 1 shows the correspondence between the 83C154's new functions and the different bits of the

IOCON register (OF8H) which can only be addressed by bit.



#### BITS RPD AND HPD

Two supplementary bits of egister PCON, RPD and HPD, are used to provide the additional management

functions for the POWER-DOWN and IDLE modes. Figure 2 shows the correspondence between the PCON register bits and the new power saving modes. PCON is not bit-addressable.



#### TIMER/COUNTERS 0 AND 1

The 83C154 has three 16-bit TIMER/COUNTERS. TIMER 0, TIMER 1 and TIMER 2. The architecture and instruction set of these three TIMERS are compatible with the MHS C51 family. In addition to the 4 existing

modes, 2 other modes have been added for TIMER 1 and TIMER 0:

- a WATCH-DOG mode,

- A 32-bit TIMER/COUNTER mode.

These new modes are explained in detail below.



#### 32-BIT MODE:

This mode is activated by setting bit T32 of register IOCON (ICON.6=OFEH) to "1". This action causes TIMER 0 and TIMER 1 to be configured as a 32-bit TIMER/COUNTER and this, whatever the value of the configuration register TMOD. TIMER 0 constitutes the LSBs and TIMER 1 the MSBs. Two sources provide control of this 32-bit TIMER/COUNTER, either the 83C154's clock (TIMER mode) or an external clock connected to input T0 (COUNTER mode). This selection is made by programming bit C/T0 of register TMOD (089H). If (C/T0)=0, the 83C154 is in TIMER mode and if (C/T)=1, it is in COUNTER mode.

Counting is started when bit (T32)=1 and is stopped by complementing T32. If the TIMER/COUNTER is to be stopped, when restarted and stopped again, care must be taken to ensure that bits TRO and TR1 are programmed with the value 0. The contrary would result in the restarting of one of the two TIMER/COUNTERs which would modify the content of the 32-bit TIMER/COUNTER Bit TF1 enables detection of a TIMER/COUNTER overflow. The following formulae are to be used for calculating the required frequency:

#### 32-bit TIMER MODE



### 32-bit COUNTER MODE

TO



TO,T1

TF1

In order to be able to increment its counter, the 83C154 must detect a complete signal at its input, that is to say a succession of two transitions. On each machine cycle the 83C154 samples its T0 input (fxtal/12). Therefore, to increment its counter, it must read its T0 input at least twice, in other words a minimum time of 24 clock periods. Thus, the maximum frequency of signal fxtal is less than or equal to fxtal/24.

#### WATCH-DOG MODE



This mode is activated by setting bit WDT of register ICON (ICON.7=OFFH) to \*1\*

Several configurations are possible, but always based on TIMERs 0 and 1:

- TIMER 0: program in mode 3,TH0 is seen as an 8-bit TIMER and is controlled by TR1.

TIMER 1: can be programmed in mode 0, 1 and 2.
 TIMER 32: special 83C154 mode which combines the bits of TIMER 0 and TIMER 1 to form a single 32-bit TIMER.

Whatever the chosen configuration, the WATCH-DOG can be controlled either by an internal source (C/T=0) or by an external source (C/T=1). The TIMER is started by setting bit TR0 or TR1 or TR32 of register TCON or ICON to \*1.\* A timer overflow is detected by flag TF1 (TF1=1) of register TCON (TCON.7=08FH). When an overflow occurs (TF1) = 1, the 83C154 is reset immediately. This action has the same effects as a hardware reset. As there are no precautions for protecting bit WDT, special care must be taken during program writing to avoid accidental manipulation of this bit. In particular, the user should use the IOCON register bit manipulation instructions:

- ŠETB X and CLR X

in preference to the byte manipulation instructions:

– MOV IOCON, #XXH, ORL IOCON, #XXH,

ANL IOCON, #OXXH,.....

#### EXTERNAL COUNTING IN POWER-DOWN MODE

In POWER-DOWN mode, the oscillator is stopped and the 83C154's activity is frozen. However, if an external clock is connected to one of the inputs T1 or T0, implementation of the functions of TIMER 0 and TIMER 1 can continue. In this case, counting is asynchronous and the maximum, admissible signal frequency on input T1 or T0 only depends on the counter's intrinsic constants. Overflow of one of the counters, TF0=1 or TF1=1 will either trigger the interrupt or will force a reset if the counter is programmed in the WATCH-DOG mode (COUNTER 1 only). In both cases, the overflow of one of the two counters results in exit from the POWER-DOWN mode.

#### POWER SAVING MODE IDLE MODE

This mode is 100% compatible with that of the 80C52 and has an additional function. This mode is softwarecontrolled. Entry and execution are implemented by setting the IDL bit to "1". Exit from this mode is controlled by bit RPD of register PCON and the interrupt register IE:

-RPD=0

If no interrupt is enabled, the only possibility of exiting from this mode is a reset of the 83C154.

If the interrupts are enabled, exit from the mode can be made either by interrupt or by reset.

-RPD=1

- Whether enabled or not, an interrupt request causes the 83C154 to exit from the POWER-DOWN mode.

If no interrupt is present, only a reset will cause the 83C154 to exit from this mode.

Table 2 summarizes the different types of operation of this mode.

| Input conditi | ons | Ou  | tput conditions   |     |
|---------------|-----|-----|-------------------|-----|
| IDLE          | IDL | RPD | INTERRUPTS        | RST |
| SOFTWARE      | 1   | 0   | If authorized     | YES |
| SOFTWARE      | 1   | 1   | Authorized or not | YES |

Table 2

#### POWER-DOWN MODE

This mode is controlled by:

- software by bits PD, RPD and the IE register,

- hardware by bit HPD.

On entry into this mode, the clock is stopped and the 83C154's activity is suspended. However, the UART ant TIMER (0/1) functions continue to work if:

- an external clock is connected to one of the inputs TO orT1.

- register TMOD is programmed correctly (C/T=1).

#### HARDWARE CONTROL

#### Hardware control (HPD=1)

This mode is entirely software-controlled by an external signal connected to input T1. The trailing edge. of this signal activates the POWER-DOWN mode (after the current instruction has been executed). The leading edge of this same signal (T1) or a reset enables the 83C154 to quit this mode. Interrupt requests, even if enabled, do not enable exit from this mode.

#### SOFTWARE CONTROL

 Entry to mode (PD=1)
 The POWER-DOWN mode is entered when bit PD of register PCON is at "1".

- Exit from mode

Exit from this mode is controlled by bit RPD.

If the interrupts are not enabled, the only means of exit from this mode is to apply a reset to input RST.

Whether the interrupts are enabled or not, an interrupt request or a reset causes the 83C154 to quit this mode.

If the interrupt requests are enabled by the IE register, execution of the program continues wint the servicing of the interrupt sub-routine.

If the interrupt requests are not enabled, the instruction following the POWER-DOWN mode instruction is executed.

Table 3 summarizes the different types of operation in this mode.

| Inpu         | t condition | IS |      | Output conditions |     |                   |     |  |
|--------------|-------------|----|------|-------------------|-----|-------------------|-----|--|
| POWER-DOWN   | HPD         | PD | . T1 | T1                | RPO | INTERRUPTS        | RST |  |
| 205711155    | 0           | 1  | X    | X                 | 0   | If authorized     | Yes |  |
| SOFTWARE     | 0           | 1  | X    | X                 | 1 1 | Authorized or not | Yes |  |
| HARDWARE     | 1           | 0  |      |                   | X   | X                 | Yes |  |
| HARDWARE and | 1           | 0  |      |                   | 0   | If authorized     | Yes |  |
| SOFTWARE     | 1           | 1  |      |                   | 1 1 | Authorized or not | Yes |  |

X = without action

Table 3



#### COMMENT

In the case of mixed-hardware software working, the POWER-DOWN mode can be entered by means of HPD=1 or PD=1.

When RPD=1, exit from the mode occurs when T1 returns to 1 and when an interrupt request is generated. Otherwise the only way of quitting the mode is to apply a reset to input RST.

It is possible to operate the POWER-DOWN and IDLE modes in parallel. Exit is only possible when exit T1 goes high and if with RPD1=1, an interrupt request has been generated. Otherwise the only possibility of exiting is to generate a reset on input RST.

#### SERIAL LINK

The 83C154 has all four of the 80C52's operating modes, with in addition:

- FRAME and OVERRUN error detection,

 Operation (mode 1,3) in POWER-DOWN and IDLE mode.

#### FRAME ERROR

This function enables detection of a transmission error in the format of a received character. Arrival of a character is detected by the trailing edge of the character start bit. All received bits are sampled on the 7th, 8th and 9th bits of the received cock (16 or 32 times the reception speed). A majority vote is taken on these 3 bits to determine if the received bit is a "1" or a "0". If a "0" is read in place of a stop bit (which is always at "1"), there is an error in the transmission format and bit SERR (SERR)=1 of register IOCON (IOCON=0F8H) is set at "1". The timing diagram below represents a character with its stop bit missing. A format error is signalled by bit SERR

Figure 3 gives the timing diagrams for a serial gate presenting this error.



As in the case of the RI flag, the SERR flag is reset to zero by the software.

#### OVERRUN ERROR

This function detects when a received character has not been read and has been replaced by another character. Reception of a character is signalled to the 83C154 by raising the RIflag to 11. This flag stays at 11.

until the user resets it to "0" (CLR RI). If the next character is sent before the previous character has been read, an error is detected and bit SERR of register IOCON (IOCON=0F8H) is set to "1".

Figure 4 shows the timing diagrams of the serial link for this error.



As in the case of the RI flag, the SERR flag is reset to zero by the software.



### POWER-DOWN AN IDLE MODE

The serial link is able to run in power down and idle mode. As the CPU clock is frozen, only the UART mode 1 and 3 are operationnal.

The transmission clock has to be generated with Timer 1 and use the external clock ( (C/T)=1, ((Gate=0)), Max frequency will be: Fext (Fxtal/24). Fext  $\leq$  OSC/24

#### I/O PORT



The I/O drives for P1, P2, P3 of the 83C154 are impedance programmable. The I/O buffers for ports 1, 2 and 3 implemented as shown in  $Fig\ 6$ .

The impedance can be programmed through the register IOCON (IOCON = 0F8H).

Table 4 is a detail of register IOCON showing PORT impedance selection.



There is a choice of three possible resistance values: 10k, 100k, and floating. ALF = 1, all the PORTS (1, 2 and 3) are floating in POWER-DOWN mode. P1HZ, P2HZ or P2HZ = 0 the output resistance depends on the choice of IZC. P1HZ, P2HZ or P3HZ=1 the PORT is floating. IZC=0, the output resistance is  $10k\Omega$ . IZC=1, the output resistance is  $10k\Omega$ . Table 5 below is a summary of the possibilities offered by register IOCON.

| ALF | IZC | PnHZ | ₽n    |
|-----|-----|------|-------|
| 0   | 0   | 0    | 10kg  |
| 0   | 0   | 1    | F     |
| 0   | 1   | 0    | 100kg |
| 0   | 1   | 1    | F     |
| 1   | X   | X    | *F    |

F=FLOATING; X=1 or 0;  $1 \le n \le 3$ \*in POWER-DOWN mode

The 83C154's IP register (088H) has a new function as the possibility of making the interrupt level identical for all types of 83C154 interrupts.

Programming of bit PCT ( (PCT)=1, PCT=IP.7) gives all interrupts the same level.
Table 6 is a detail of the IP register.



All the bits of this register can be addressed directly.

#### BIT TRANSFER INSTRUCTION

Instruction MOV BIT (code OA5H) enables transfer of a SOURCE BIT value from one register to the DESTINATION BIT of another register. Execution of the MOV BIT instruction is only possible for bit addressable registers.

#### SYNTAX:

MOVBIT bit ADDR (source), bit ADDR (destination)
A5H XX XX

For example: ACC2 ← P30.5 MOV P30.5,ACC2 A5 B5 E2



AUGUST 1988

# APPLICATION NOTE

AN1044

## DIFFERENCES BETWEEN OKI AND MHS 83C154s

MHS's 83C154 is a development of INTEL's 80C51/52 family of microcontrollers. All the basic mechanisms (interrupts, I/O, etc.) of MHS's 83C154 are 100% compatible with those of the INTEL 80C51/C52 family.

There are several incompatibilities between the basic mechanisms of the OKI 83C154 and the MHS 83C154. In practice, these differences are invisible to the user. They are listed below:

- Division by zero.
- Conditional jump.
- Long jump on a call from a sub-routine.
- Serial port.
- Port writing.
- TIMER interrupt request.

These differences are discussed in the following paragraphs.

### **DIVISION BY ZERO**

Division by zero is performed by putting the numerator in register B and the denominator in register A. The result in the division is stored in register A and

the remainder in register B. The difference between MHS and OKI is in the result and is shown below:

A div B → result = A remainder = B

MHS B=FF

OKI B = 00

#### CONDITIONAL JUMP

Conditional jumps JC, JNC, JZ and JNZ are single byte instructions that execute in 2 machine cycles. Before branching to the new address:

- MSH increments the PC twice.
- OKI increments the PC once.

### LONG JUMP

The long jumps, LCALL and LJMP are three-byte instructions that execute in 2 machine cycles, Before branching to the new address:

- MHS increments the PC 3 times,
- OKI increments the PC twice.

| - 0 | 2 | C | 10 | _ |
|-----|---|---|----|---|
|     |   |   |    |   |

### End of reception in modes 1, 2 and 3

When a received character is complete, an interrupt request (RI) is generated for the microcontroller. Once more, we can see a difference between the manufacturers:

MHS: the interrupt request in the center of the 9th bit received,

 $\ensuremath{\mathsf{OKI}}$  : the interrupt request is generated in the center of the stop bit.



#### INPUT/OUTPUT PORTS

The port write instructions execute in 2 cycles. The data arrives at the gate outputs on the second instruction cycle. The rapidity with which the data arrives at the gates varies with the manufacturer:

MHS: the data arrives in phase with the 1st clock cycle of the instruction cycle following the write cycle. OKI: the data arrive in phase with the 6th clock cycle of the 2nd write cycle.



8051/31 AH or 80C51/31

#### SERIAL PORT

Transmission clock start-up in modes 1, 2 and 3.



The divider by 16 which, ultimately, generates the clock, is controlled differently according to the manufacturer:

- MHS: the divider starts on completion of RESET,OKI: the divider starts after the following instructions:
- MOVTCON, #XXMOV SCON, #XXMOV SBUF, #XX

The following timing diagrams illustrate the





83C154s

#### INTERRUPTS

When a TIMER (0, 1 or 2) times out, the interrupt request is generated in the same instruction cycle in

the case of the MHS microcontroller and in the next cycle in the case of the OKI.





#### CONCLUSION

In practice, all these differences are transparent from the User's point of view. Only the differences in the division by zero and the interrupt requests from

the TIMERS and the UART are likely to prevent full compatibility between the two circuits.



## ภาคผนวก จ ลักษณะพิกัคและคำสั่งของ LCD



## Instructions

|                                   | Code                                                                                                                                                                                                                                                                                                 |     |                 |     |     |          |          |                 |     | Description                                                                                                                                                                             | Execution Time<br>(max)<br>' (when ico or                                                                                            |                      |  |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------|-----|-----|----------|----------|-----------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|
| astruction                        | RS                                                                                                                                                                                                                                                                                                   | R/W | DB <sub>7</sub> | DB4 | D84 | DB4      | DBs      | DB <sub>2</sub> | DBı | DB-                                                                                                                                                                                     | Date 4                                                                                                                               | foac is 250 kHz)     |  |
| Clear<br>Display                  | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | 0   | 0        | 0        | 0               | 0   | 1                                                                                                                                                                                       | Clears entire display and sets DD RAM address 0 in address counter.                                                                  | 1.64 ms              |  |
| Return<br>Home                    | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | 0   | 0        | 0        | 0               | 1   | •                                                                                                                                                                                       | Sets DD RAM address 0 in address counter. Also returns display being shifted to original position. DD RAM contents remain unchanged. | 1.64 ms              |  |
| Entry<br>Mode Set                 | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | ,o  | 0        | 0        | 1               | I/D | S                                                                                                                                                                                       | Sets cursor move direction and specifies shift of display. These operations are performed during data write and read.                | 40µs                 |  |
| Display<br>Ou/Off<br>Coetrol      | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | 0   | 0        | 1        | D               | С   | В                                                                                                                                                                                       | Sets ON/OFF of entire display (D), cursor ON/OFF (C), and blink of cursor position character (B).                                    | 40µs                 |  |
| Cursor or<br>Display<br>Shift     | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | 0   | 1        | S/C      | R/L             |     |                                                                                                                                                                                         | Moves cursor and shifts display without changing DD RAM contents.                                                                    | * 40 <sub>µ</sub> s  |  |
| Function<br>Set                   | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 0   | 1   | DL       | N        | F               |     | *                                                                                                                                                                                       | Sets interface data length (DL),<br>number of display lines (L) and<br>character font (F).                                           | 40µs                 |  |
| Set CG RAM<br>Address             | 0                                                                                                                                                                                                                                                                                                    | 0   | 0               | 1   |     | QE<br>AB | ^        | .CG             |     |                                                                                                                                                                                         | Sets CG RAM address. CG RAM data is sent and received after this setting.                                                            | 40µs                 |  |
| Set DD RAM<br>Address             | 0                                                                                                                                                                                                                                                                                                    | 0   | 1               |     |     |          | ADD      |                 |     |                                                                                                                                                                                         | Sets DD RAM address. DD RAM data is sent and received after this setting.                                                            | 40 <sub>ju</sub> s   |  |
| Read<br>Busy Flag<br>& Address    | 0                                                                                                                                                                                                                                                                                                    | 1   | BF              |     |     |          | AC       |                 |     |                                                                                                                                                                                         | Reads Busy flag (BF) indicating internal operation is being performed and reads address counter contents.                            | Opes                 |  |
| Write Data<br>to CG or<br>DD RAM  | 1                                                                                                                                                                                                                                                                                                    | 0   |                 | 18  | 13  | Wr       | ite Data | 91              | 39  | 1 2                                                                                                                                                                                     | Writes data into DD RAM or CG RAM.                                                                                                   | 40 <sub>ju</sub> s 1 |  |
| Read Data<br>from CG or<br>DD RAM | 1                                                                                                                                                                                                                                                                                                    |     | 18              | 19  | ก   | Re       | ad Data  | 119             | 80  | າລີ                                                                                                                                                                                     | Reads data from DD RAM or CG RAM.                                                                                                    | . 40µs               |  |
|                                   | I/D=1: Increment I/D=0: Decrement S=1: Accompanies display shift SC=1: Display shift SC=0: Carsor move R/L=1: Shift to the right R/L=0: Shift to the left DL=1: 8 bits, DL=0: 4 bits N=1: 2 lines, N=0: 1 line F=1: 5×10 dots, F=0: 5×7 dots BF=1: Internally operating BF=0: Can accept instruction |     |                 |     |     |          |          |                 |     | DD RAM: Display data RAM CG RAM: Character generator RAM Acc: CG RAM address Aoc: DD RAM Address Corresponds to cursor address AC: Address counter used for both DD and CG RAM address. | Execution time changes when frequency change Example: When fcp or fos is 270 kHz: $40_{\mu\rm S} \times \frac{250}{270} = 37$        |                      |  |

<sup>•</sup> No effect

# **DMC164**

• Display Format(16chacter ×4line) • Display Fonts(5×8dots) • Driving Method(1/16D)

### ABSOLUTE MAXIMUM RATINGS

#### **ELECTRICAL CHARACTERISTICS**

| Item ~~                               | Sym-         | Test<br>Condition | Standard Value |      |      | Unit | Item                  | Sym- | Test                   | Standard Value |      |      | Unit |
|---------------------------------------|--------------|-------------------|----------------|------|------|------|-----------------------|------|------------------------|----------------|------|------|------|
|                                       | bol          |                   | min.           | typ. | max  | -    |                       | bol  | Condition              | min.           | typ. | max. |      |
| Power Supply<br>Voltage for Logic     | Vcc~<br>Vss  | _                 | .0             | _    | 6.5  | V    | Input "High" Voltage  | ViH  |                        | 2.2            | -    | Vcc  | v    |
| Power Supply<br>Voltage for LCD Drive | Vcc ~<br>Vee |                   | 0-             | -    | 6.0  | ٧    | Input "Low" Voltage   | VIL  |                        | -0.3           | -    | 0.6  | v    |
| Input Voltage                         | Vı           |                   | Vss            |      | Vcc  | V    | Output "High" Voltage | Vон  | -10H=0.205mA           | 2.4            |      |      | V    |
| Operating<br>Temperature              | Та           | _                 | 0              |      | +50  | τ    | Output "Low" Voltage  | VoL  | I <sub>OH</sub> =1.2mA |                | 54.  | 0.4  | V    |
| Storage<br>Temperature                | Ţstg         |                   | -20            |      | + 70 | С    | Power Supply Current  | Icc  | Vcc=5.0V               |                | 2.4  | 4.0  | mΔ   |

\* Vcc = 5.0V ± 5%, Ta = 25°C

### Block diagram





### External dimensions/Display pattern



#### ภาคผนวก ฉ

# โปรแกรมควบคุมการทำงานของระบบสแกนข้อมูลภาพ

```
100 STRING 100,16
   110 PA=0E060H
   120 XBY(PA)=01H
  140 PX=80H: N=16: $(1)="BETA BACKSCATTER": GOSUB 3950
  150 PX=0C3H: N=11: $(1)="2-D IMAGING": GOSUB 3950
  160 PX=97H: N=2:$(1)="by": GOSUB 3950
  170 PX=0D3H: N=9:$(1)="K.Supasit": GOSUB 3950
  180 CALL 9000H
  185 PA=0E060H
  190 XBY(PA)=01H
  200 PX=80H: N=9: $(1)="Main menu": GOSUB 3950
  210 PX=0C1H: N=11:$(1)="F1=Clr mode": GOSUB 3950
  220 PX=91H: N=12: $(1)="F2=Scan mode": GOSUB 3950
  230 PX=0D1H: N=16: $(1)="F3=Transfer mode": GOSUB 3950
  240 GOSUB 4100
 250 IF DA=14 THEN GOTO 5000
 260 IF DA=13 THEN GOTO 300
 270 IF DA=11 THEN GOTO 290
 290 GOTO 240
 300 PA=0E060H: XBY(PA)=01H
 310 PX=80H: N=9:$(1)="Scan mode": GOSUB 3950
 320 PX=0C2H: N=12:$(1)="F1=1st frame": GOSUB 3950
 330 PX=92H: N=12: $(1)="F2=2nd frame": GOSUB 3950
 340 PX=0D2H: N=6:$(1)="F3=Ext": GOSUB 3950
 350 GOSUB 4100
 360 IF DA=14 THEN GOTO 495
 370 IF DA=13 THEN GOTO 5100
 380 IF DA=11 THEN GOTO 185
 400 GOTO 350
 495 PA=0E060H: XBY(PA)=01H
 500 PX=80H: N=14: $(1)="1st frame scan": GOSUB 3950
 510 PX=0C3H: N=8:$(1)="F1=Start": GOSUB 3950
 530 PX=093H: N=6: $(1)="F2=Ext": GOSUB 3950
 540 GOSUB 4100
550 IF DA=14 THEN CALL 9100H
560 IF DA=13 THEN GOTO 300
580 GOTO 540
3880 STOP
3890 REM
3900 REM
3910 REM
3920 REM
                         ini.LCD & display
3930 REM
3940 REM
3945 REM
3950 PA=0E060H: WR=0E062H
3960 XBY(PA)=38H
3970 XBY(PA)=14H:XBY(PA)=0CH
4000 XBY(PA)=PX
4010 FOR I=1 TO N
4020 XBY(WR)=ASC($(1),I)
4030 NEXT
4040 RETURN
```

```
4050 REM
4060 REM
4070 REM
                           keyboard detect Prog.
4080 REM
4090 REM
4100 XBY(0E0A3H)=92H
4110 DA=XBY(0E0A1H)
4120 DA=DA.AND.0FH
4130 RETURN
5000 PA=0E060H: XBY(PA)=01H
5010 PX=80H: N=10: $(1)="Clear data": GOSUB 3950
5020 PX=0C2H: N=12: $(1)="F1=1st frame": GOSUB 3950
5030 PX=92H: N=12:$(1)="F2=2nd frame": GOSUB 3950
5040 PX=0D2H: N=6:$(1)="F3=Ext": GOSUB 3950
5050 GOSUB 4100
5060 IF DA=14 THEN CALL 9050H
5070 IF DA=13 THEN CALL 90C0H
5080 IF DA=11 THEN GOTO 185
5090 GOTO 5050
5100 PA=0E060H: XBY(PA)=01H
5110 PX=80H: N=14: $(1)="2nd frame scan": GOSUB 3950
5120 PX=0C3H: N=8: $(1)="F1=Start": GOSUB 3950
5130 PX=93H: N=6: $(1)="F2=Ext": GOSUB 3950
5140 GOSUB 4100
5150 IF DA=14 THEN GOTO 5200
5160 IF DA=13 THEN GOTO 300
5170 GOTO 5140
5200 PA=0E060H: XBY(PA)=01H
5210 PX=83H: N=9: $(1)="2nd frame": GOSUB 3950
5220 PX=0C3H: N=10: $(1)="Scanning!": GOSUB 3950
5230 PX=93H: N=8: $(1)="F2=abort": GOSUB 3950
5240 GOSUB 4100
5250 IF DA=13 THEN GOTO 5100
5260 REM ***** SCAN PROG. *****
5270 GOTO 5240
6000 END
```

| ORG 9000H         | SJMP OUTP        |
|-------------------|------------------|
| DT EQU 33H        | NXT:             |
| DELAYX EQU 0FD00H | INC DPTR         |
| DELAYY EQU 0F000H | OUTP:            |
| PO EQU 0E0C0H     | MOV RO, DPL      |
| start             | MOV R1,DPH       |
| MOV DPTR,#0E0A3H  | MOV DPTR,#0E040H |
| MOV A,#82H        | MOV A,R0         |
| MOV R0,#DT        | MOVX @DPTR,A     |
| MOVX @DPTR,A      | MOV RO,A         |
| MOV DPTR,#0E0C3H  | MOV DPTR,#0E041H |
| MOV A,#80H        | MOV A,R1         |
| MOVX @DPTR,A      | MOVX @DPTR,A     |
| BACK:             | MOV DPTR,#0E042H |
| MOV DPTR,#0E0A1H  | MOV A,R2         |
| MOVX A,@DPTR      | MOVX @DPTR,A     |
| MOV R1,A          | MOV DPTR,#0E020H |
| ANL A,#10H        | MOV A,#DATA      |
| CJNE A,#10H,XSTEP | MOVX @DPTR,A     |
| MOV A,R1          | MOV DPH,R1       |
| ANL A,#20H        | MOV DPL,R0       |
| CJNE A,#20H,YSTEP | MOV A,#01H       |
| RET               | ANL A, DPH       |
| XSTEP:            | CJNE A,#01H,SUB1 |
| MOV DPTR,#PO      | SETB C           |
| MOV A,R0          | BACK1:           |
| ANL A,#0FH        | MOV A,DPL        |
| MOVX @DPTR,A      | RRC A            |
| MOV A,R0          | XRL A,#0E6H      |
| RR A              | CJNE A,#00H,NXT  |
| MOV RO,A          | MOV DPL,#00H     |
| MOV DPTR,#DELAYX  | PUSH DPL         |
| DL1:              | MOV DPL,DPH      |
| INC DPTR          | MOV DPH,R2       |
| MOV R2,DPH        | MOV A,DPL        |
| MOV A,DPL         | XRL A,#95H       |
| ORL A,R2          | MOV RO,A         |
| JNZ DL1           | MOV A,DPH        |
| SJMP BACK         | XRL A,#02H       |
| YSTEP:            | ORL A,R0         |
| MOV DPTR,#PO      | CJNE A,#00H,SUB2 |
| MOV A,R0          | RET              |
| ANL A,#0F0H       |                  |
| MOVX @DPTR,A      | SUB1:            |
| MOV A,R0          | CLR C            |
| RL A              | SJMP BACK1       |
| MOV R0,A          | SUB2:            |
| MOV DPTR,#DELAYY  | INC DPTR         |
| DL2:              | MOV R2,DPH       |
| INC DPTR          | MOV DPH, DPL     |
| MOV R2,DPH        | POP DPL          |
| MOV A,DPL         | SJMP OUTP        |
| ORL A,R2          | ;CLR SCREEN 2    |
| JNZ DL2           |                  |
| SJMP BACK         | ORG 90C0H        |
| ; CLR SCREEN 1    | DATA EQU 00H     |
| ORG 9000H         | ,                |
| DATA EQU 00H      | MOV DPTR,#0E043H |
| ;                 | MOV A,#80H       |
| MOV DPTR,#0000H   | MOVX @DPTR,A     |
| MOV R2,#00H       | MOV DPTR,#0E042H |
|                   |                  |

| MOV A,#04H               | RESETX EQU 0FF00H |
|--------------------------|-------------------|
| MOVX @DPTR,A             | PO EQU 0E0C0H     |
| MOV DPTR,#0000H          | ;ini              |
| MOV R2,#04H              | MOV DPTR,#0E0A3H  |
| SJMP OUTP                | MOV A,#92H        |
| NXT1:                    | MOVX @DPTR,A      |
| INC DPTR                 | MOV DPTR,#0E0C3H  |
| OUTP1:                   | MOV A,#80H        |
| MOV RO, DPL              | MOVX @DPTR,A      |
| MOV RO,DPL<br>MOV R1,DPH | MOVX @DPTR,A      |
|                          | MOV DPTR,#0E043H  |
| MOV DPTR,#0E040H         | MOV A,#80H        |
| MOV A,R0                 | MOVX @DPTR,A      |
| MOVX @DPTR,A             | MOV DPTR,#0E042H  |
| MOV RO,A                 | MOV A,#00H        |
| MOV DPTR,#0E041H         | MOVX @DPTR,A      |
| MOV A,R1                 | MOV DPTR,#0000H   |
| MOVX @DPTR,A             |                   |
| MOV DPTR,#0E042H         | MOV R2,#00H       |
| MOV A,R2                 | MOV R3,#DO        |
| MOVX @DPTR,A             | MOV R4,#DO        |
| MOV DPTR,#0E020H         | SJMP OUTP         |
| MOV A,#DATA              | NXT2:             |
| MOVX @DPTR,A             | INC DPTR          |
| MOV DPH,R1               | LCALL XSTEP       |
| MOV DPL,R0               | OUTP3:            |
| MOV A,#01H               | MOV RO,DPL        |
| ANL A,DPH                | MOV R1,DPH        |
| CJNE A,#01H,SUB3         | MOV DPTR,#0E043H  |
| SETB C                   | MOV A,#80H        |
| BACK2:                   | MOVX @DPTR,A      |
| MOV A,DPL                | MOV DPTR,#0E040H  |
| RRC A                    | MOV A,R0          |
| XRL A,#0E6H              | MOVX @DPTR,A      |
| CJNE A,#00H,NXT          | MOV RO,A          |
| MOV DPL,#00H             | MOV DPTR,#0E041H  |
| PUSH DPL                 | MOV A,R1          |
| MOV DPL,DPH              | MOVX @DPTR,A      |
| MOV DPH,R2               | MOV DPTR,#0E042H  |
| MOV A,DPL                | MOV A,R2          |
| XRL A,#95H               | MOVX @DPTR,A      |
| MOV RO,A                 | MOV DPTR,#0E0A0H  |
| MOV A,DPH                | MOVX A,@DPTR      |
| XRL A,#06H               | MOV DPTR,#0E020H  |
| ORL A,R0                 | MOVX @DPTR,A      |
| CJNE A,#00H,SUB4         | MOV DPH,R1        |
| RET                      | MOV DPL,R0        |
| KE1                      | MOV A,#01H        |
| CI ID2.                  | ANL A, DPH        |
| SUB3:<br>CLR C           | CJNE A,#01H,SUB5  |
|                          | SETB C            |
| SJMP BACK1               | BACK3:            |
| SUB2:<br>INC DPTR        | MOV A,DPL         |
|                          | RRC A             |
| MOV R2,DPH               | XRL A,#0C8H       |
| MOV DPH,DPL              | CJNE A,#00H,NXT   |
| POP DPL                  | LCALL XRESET      |
| SJMP OUTP                | MOV DPL,DPH       |
| ; 1st Prog               | MOV DPH,R2        |
| ORG 9100H                | MOV A,DPL         |
| DO EQU 33H               | XRL A,#59H        |
| DELAYX EQU 0C000H        | MOV RO,A          |

| MOV A,DPH          |       | POP DPL            |
|--------------------|-------|--------------------|
| XRL A,#02H         |       | RET                |
| ORL A,R0           |       | KL1                |
|                    | · ·   | acom.              |
| CJNE A,#00H,SUB6   | XKE   | ESET:              |
| RET                |       | PUSH DPL           |
| SUB5:              |       | PUSH DPH           |
| CLR C              |       | PUSH ACC           |
| LJMP BACK1         | GOX   |                    |
| SUB6:              | UUZ   |                    |
| INC DPTR           |       | MOV DPTR,#0E0A1H   |
|                    |       | MOVX A,@DPTR       |
| MOV R2,DPH         |       | ANL A,#10H         |
| MOV DPH,DPL        |       | CJNE A,#10H,ROTX   |
| MOV DPL,#00H       |       | MOV R5,#2AH        |
| LJMP OUTP3         |       | SJMP YSTEP         |
| ROTX:              | LOO   |                    |
| MOV DPTR,#PO       | LOO   |                    |
|                    |       | DEC R5             |
| MOV A,R3           | YST   |                    |
| ANL A,#0FH         |       | MOV DPTR,#PO       |
| MOV R6,A           |       | MOV A,R4           |
| MOV A,R4           |       | ANL A,#0F0H        |
| ANL A,#0F0H        |       | MOV R7,A           |
| ORL A,R6           |       |                    |
|                    |       | MOV A,R3           |
| MOVX @DPTR,A       |       | ANL A,#0FH         |
| MOV A,R3           |       | ORL A,R7           |
| RR A               |       | MOVX @DPTR,A       |
| MOV R3,A           |       | MOV A,R4           |
| MOV DPTR,#RESETX   |       | RR A               |
| DL3:               |       | MOV R4,A           |
| INC DPTR           |       |                    |
|                    |       | MOV DPTR,#DELAYY   |
| MOV R7,DPH         | DL5:  |                    |
| MOV A,DPL          |       | INC DPTR           |
| ORL A,R7           |       | MOV R7,DPH         |
| JNZ DL3            |       | MOV A, DPL         |
| LJMP GOXRS         |       | ORL A,R7           |
|                    |       | JNZ DL2            |
| LOOPX:             |       |                    |
|                    |       | CJNE R5,#00H,LOOPY |
| DEC R5             |       | MOV DPTR,#PO       |
| SJMP GOX           |       | MOVX @DPTR,A       |
| XSTEP:             |       | POP ACC            |
| PUSH DPL           |       | POP DPH            |
| PUSH DPH           |       | POP DPL            |
| PUSH ACC           |       | RET                |
| MOV R5,#03H        | . 2 4 |                    |
|                    | ; 2nd | Prog               |
| GOX:               |       | ORG 9100H          |
| MOV DPTR,#PO       |       | DO EQU 33H         |
| MOV A,R3           |       | DELAYX EQU 0C000H  |
| ANL A,#0FH         |       | DELAYY EQU 0F000H  |
| MOVX @DPTR,A       |       | RESETX EQU 0FF00H  |
| MOV A,R3           |       | PO EQU 0E0C0H      |
| RL A               |       | FO EQUIDEDCOH      |
|                    | ;ini  |                    |
| MOV R3,A           |       | MOV DPTR,#0E0A3H   |
| MOV DPTR,#DELAYX   |       | MOV A,#92H         |
| DL4:               |       | MOVX @DPTR,A       |
| INC DPTR           |       | MOV DPTR,#0E0C3H   |
| MOV R7,DPH         |       | MOV A,#80H         |
| MOV A,DPL          |       | MOVX @DPTR,A       |
| ORL A,R7           |       |                    |
|                    |       | MOVX @DPTR,A       |
| JNZ DL1            |       | MOV DPTR,#0E043H   |
| CJNE R5,#00H,LOOPX |       | MOV A,#80H         |
| POP ACC            |       | MOVX @DPTR,A       |
| POP DPH            |       | MOV DPTR #0E042H   |

| MOV A,#00H       | ROTX1:              |
|------------------|---------------------|
| MOVX @DPTR,A     | MOV DPTR,#PO        |
| MOV DPTR,#0000H  | MOV A,R3            |
| MOV R2,#04H      | ANL A,#0FH          |
| MOV R3,#DO       | MOV R6,A            |
| MOV R4,#DO       | MOV A,R4            |
| SJMP OUTP        |                     |
| NXT3:            | ANL A,#0F0H         |
|                  | ORL A,R6            |
| INC DPTR         | MOVX @DPTR,A        |
| LCALL XSTEP      | MOV A,R3            |
| OUTP:            | RR A                |
| MOV RO,DPL       | MOV R3,A            |
| MOV RI,DPH       | MOV DPTR,#RESETX1   |
| MOV DPTR,#0E043H | DL6:                |
| MOV A,#80H       | INC DPTR            |
| MOVX @DPTR,A     | MOV R7,DPH          |
| MOV DPTR,#0E040H | MOV A,DPL           |
| MOV A,R0         | ORL A,R7            |
| MOVX @DPTR,A     | JNZ DL3             |
| MOV R0,A         | LJMP GOXRS1         |
| MOV DPTR,#0E041H |                     |
| MOV A,R1         | LOOPX1:             |
| MOVX @DPTR,A     | DEC R5              |
| MOV DPTR,#0E042H | SJMP GOX1           |
| MOV A,R2         | XSTEP1:             |
| MOVX @DPTR,A     | PUSH DPL            |
| MOV DPTR,#0E0A0H | PUSH DPH            |
| MOVX A,@DPTR     | PUSH ACC            |
| MOV DPTR,#0E020H | MOV R5,#03H         |
| MOVX @DPTR,A     | GOX1:               |
| MOV DPH,R1       | MOV DPTR,#PO        |
| MOV DPL,R0       | MOV A,R3            |
| MOV A,#01H       |                     |
| ANL A,DPH        | ANL A,#0FH          |
| CJNE A,#01H,SUB7 | MOVX @DPTR,A        |
| SETB C           | MOV A,R3            |
|                  | RL A                |
| BACK4:           | MOV R3,A            |
| MOV A,DPL        | MOV DPTR,#DELAYX1   |
| RRC A            | DL7:                |
| XRL A,#0C8H      | INC DPTR            |
| CJNE A,#00H,NXT  | MOV R7,DPH          |
| LCALL XRESET     | MOV A,DPL           |
| MOV DPL,DPH      | ORL A,R7            |
| MOV DPH,R2       | JNZ DL1             |
| MOV A,DPL        | CJNE R5,#00H,LOOPX1 |
| XRL A,#59H       | POP ACC             |
| MOV R0,A         | POP DPH             |
| MOV A,DPH        | POP DPL             |
| XRL A,#02H       | RET                 |
| ORL A,R0         |                     |
| CJNE A,#00H,SUB8 | XRESET1:            |
| RET              | PUSH DPL            |
| SUB7:            | PUSH DPH            |
| CLR C            | PUSH ACC            |
| LJMP BACK1       | GOXRS1:             |
| SUB8:            | MOV DPTR,#0E0A1H    |
| INC DPTR         | MOVX A,@DPTR        |
| MOV R2,DPH       | ANL A,#10H          |
| MOV DPH,DPL      | CJNE A,#10H,ROTX1   |
| MOV DPL,#00H     | MOV R5,#2AH         |
| I IMP OUTP       | SIMP VSTEP1         |

#### LOOPY1: DEC R5 YSTEP1: MOV DPTR,#PO MOV A,R4 ANL A,#0F0H MOV R7,A MOV A,R3 ANL A,#0FH ORL A,R7 MOVX @DPTR,A MOV A,R4 RR A MOV R4,A MOV DPTR,#DELAYY1 DL8: INC DPTR MOV R7, DPH MOV A, DPL ORL A,R7 JNZ DL2 CJNE R5,#00H,LOOPY1 MOV DPTR,#PO MOVX @DPTR,A POP ACC POP DPH POP DPL RET

**END** 





# ประวัติผู้เขียน

นายลุ สิทธิ์ คะวีรัตน์ เกิดเมื่อวันที่ 19 กุมภาพันธ์ 2512 ที่อำเภอเมือง จังหวัดอุตรคิตถ์ สำเร็จการศึกษาปริญญาบัณฑิตจาก ภาควิชาเทคนิดอุตสาหกรรม สาขาอิเล็กทรอนิกส์ คณะ วิศวกรรมศาสตร์ สถาบันเทคโนโลยีพระจอมเกล้าเจ้าคุณทหารลาดกระบัง เมื่อปี พ.ศ. 2535 แล้ว เข้าศึกษาต่อในระดับปริญญามหาบัณฑิต สาขาวิชานิวเคลียร์เทคโนโลยี คณะวิศวกรรมศาสตร์ จุฬาลงกรณ์มหาวิทยาลัย ในปี พ.ศ.2536 และระหว่างการศึกษาได้เข้าทำงานที่บริษัท ฟายน์สเปค จำกัด ในตำแหน่งวิศวกร

ศูนย์วิทยทรัพยากร จุฬาลงกรณ์มหาวิทยาลัย