

# **TM58PE10**

| 1. Feature                                                                                                                                                                                                                                        | . P.2                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| <ul><li>2. Pin Definition &amp; Pad Assignment</li><li>2.1 18 Pin &amp; 20 Pin</li><li>2.2 14 Pin &amp; COB type</li></ul>                                                                                                                        |                      |
| <ol> <li>Pin Description</li> <li>3.1 18 Pin</li> <li>3.2 14 Pin</li> </ol>                                                                                                                                                                       |                      |
| 4. Control Register                                                                                                                                                                                                                               | P.8                  |
| 5. System Block Diagram                                                                                                                                                                                                                           | P.9                  |
| <ul> <li>6. Memory Map</li> <li>6.1 Program memory</li> <li>6.2 Data memory</li> <li>6.2.1 General mode</li> <li>6.2.2 Advance mode</li> </ul>                                                                                                    | P.12                 |
| <ul> <li>7. Function Description</li> <li>7.1 TMR0 and Watchdog timer</li> <li>7.2 Reset</li> <li>7.3 STATUS [6:5](Page select bits) in advance mode</li> <li>7.4 Timer1 and Timer2</li> <li>7.5 Example program for Timer1 and Timer2</li> </ul> | P.29<br>P.31<br>P.33 |
| 8. Instruction Set                                                                                                                                                                                                                                | P.41                 |
| <ul> <li>9. Electrical Characteristics</li> <li>9.1 Absolute Maximum Ratings</li> <li>9.2 DC Characteristics</li> <li>9.3 AC Characteristics</li></ul>                                                                                            | P.45<br>P.46         |



#### 1. Feature

ROM: 1K x 14 bits RAM: 49 x 8 bits / 25 x 8bits STACK: 4 Levels

I/O ports: 12 / 16 I/O PAD

- (a) 8 Pull High I/O PAD from Port B (PULL-Hi resister=54K(Vdd=5V))
- (b) 4 normal I/O PAD from Port A
- (c) 4 special I/O PAD from EXT\_CLK, RESETB1 (Input only), OSC2 and OSC1 (Only In Advance mode, assign to PA4 ~ PA7)

Timer/counter: 8 bits x 3 (TMR0, TMR1, TMR2) TMR1 and TMR2 can connect be a 16 bits x 1 timer

Prescaler: 3Bits

- Five IRQ sources: 3 Internal IRQ, when TMR0, TMR1, TMR2 count overflow 2 External IRQ: PA0/RESETB0/INT0, PA5/RESETB1/INT1
- Watchdog Timer: On chip WDT is based on an internal RC oscillator (for WDT used only). Has 4 mode period can be selected: 1mS, 4mS, 8mS, and 16mS. User can extend the WDT overflow period by using prescaler.

Reset mode: (a) Power-On reset

- (b) Low voltage reset
- (c) 2 External Pin reset (PA0/RESETB0/INT0, PA5/RESETB1/INT1)
- (d) Watchdog timer count overflow reset

Reset Timer: 16mS (5V)

Four external Oscillate modes: RC, LP Crystal, NT Crystal and HS Crystal. One internal RC oscillator: 4M Hz (for user used) Two operation modes: General mode and Advanced mode



Operation Voltage: 2.2V 5.5V Instruction set: 79

Wake-up mode: Port B (PB7~PB0) Pin Change wakeup Wake up time can be set by WDTSEL register (23H)

Reset vector: 3FFH IRQ vector: 3FEH

Package Type: TM58PE10SS20C TM58PE10D18C TM58PE10S18C TM58PE10D14C TM58PE10S14C



# **TM58PE10**

#### 2. Pin Definition & Pad Assignment 2.1 18 Pin & 20 Pin

| PA2                         | 1 | 18 | PA1                     |
|-----------------------------|---|----|-------------------------|
| PA3                         | 2 | 17 | PA0<br>/ INT0 / RESETB0 |
| EXT_CLK / PA4               | 3 | 16 | OSC1 / PA7              |
| PA5<br>RESETB1 / VPP / INT1 | 4 | 15 | OSC2 / PA6              |
| VSS                         | 5 | 14 | VDD                     |
| PB0                         | 6 | 13 | PB7                     |
| PB1                         | 7 | 12 | PB6                     |
| PB2                         | 8 | 11 | PB5                     |
| PB3                         | 9 | 10 | PB4                     |
|                             |   |    |                         |

18 Pin Package Types : DIP (TM58PE10D18C) SOP (TM58PE10S18C)



20Pin Package Type: SSOP (TM58PE10SS20C)



2.2 14 Pin



 OSC1 / PA7
 8-3
 8-6
 EXT\_CLK / PA4

 PA0
 8-4
 8-5
 PA3

СОВ Туре



## **3. PIN Description**

## 3.1 18 Pin

| Pin name                   | Pin No. | Туре          | Description                                                                                                                                                                                                   |
|----------------------------|---------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PA2<br>PA3                 | 1<br>2  | I/O           | 1. I/O pin                                                                                                                                                                                                    |
| EXT_CLK / PA4              | 3       | I/O           | <ol> <li>External clock input to TMR0, TMR1, TMR2<br/>counter</li> <li>I/O pin</li> </ol>                                                                                                                     |
| PA5<br>RESETB1/ VPP / INT1 | 4       | Input<br>Only | <ol> <li>System Reset Pin, triggered by falling edge<br/>(Set in configuration word)</li> <li>External interrupt Pin, triggered by falling edge</li> <li>High voltage input Pin</li> <li>Input pin</li> </ol> |
| VSS                        | 5       | Р             | Ground input                                                                                                                                                                                                  |
| PB0 ~ PB7                  | 6 ~ 13  | I/O           | <ol> <li>In Advance mode, wakeup from sleep mode<br/>when pin change</li> <li>I/O pin (pull-high option)</li> </ol>                                                                                           |
| VDD                        | 14      | Р             | Power input                                                                                                                                                                                                   |
| PA6 / OSC2                 | 15      | I/O, O        | <ol> <li>Oscillator output pin</li> <li>I/O pin (set in configuration word)</li> </ol>                                                                                                                        |
| PA7 / OSC1                 | 16      | I/O, I        | <ol> <li>Oscillator input pin</li> <li>I/O pin (set in configuration word)</li> </ol>                                                                                                                         |
| PA0 / RESETB0/ INT0        | 17      | I/O           | <ol> <li>System Reset pin, triggered by falling edge<br/>(Set in configuration word)</li> <li>External interrupt pin, triggered by falling edge</li> <li>I/O pin</li> </ol>                                   |
| PA1                        | 18      | I/O           | 1. I/O pin                                                                                                                                                                                                    |



#### 3.2 14 Pin

| Pin name                  | Pin No. | Туре          | Description                                                                                                                                                                                                   |
|---------------------------|---------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PB5 ~ PB7                 | 1~ 3    | I/O           | <ol> <li>In Advance mode, wakeup from sleep mode<br/>when pin change</li> <li>I/O pin (pull-high option)</li> </ol>                                                                                           |
| VDD                       | 4       | Р             | Power input                                                                                                                                                                                                   |
| PA6 / OSC2                | 5       | I/O, O        | <ol> <li>Oscillator output pin</li> <li>I/O pin (set in configuration word)</li> </ol>                                                                                                                        |
| PA7 / OSC1                | 6       | I/O, I        | <ol> <li>Oscillator input pin</li> <li>I/O pin (set in configuration word)</li> </ol>                                                                                                                         |
| PA0 /RESETB0/ INT0        | 7       | I/O           | <ol> <li>System Reset pin, triggered by falling edge<br/>(Set in configuration word)</li> <li>External interrupt pin, triggered by falling edge</li> <li>I/O pin</li> </ol>                                   |
| PA3                       | 8       | I/O           | 1. I/O pin                                                                                                                                                                                                    |
| EXT_CLK / PA4             | 9       | I/O           | <ol> <li>External clock input to TMR0 ,TMR1, TMR2<br/>counter</li> <li>I/O pin</li> </ol>                                                                                                                     |
| PA5<br>RESETB1/ VPP/ INT1 | 10      | Input<br>Only | <ol> <li>System Reset Pin, triggered by falling edge<br/>(Set in configuration word)</li> <li>External interrupt pin, triggered by falling edge</li> <li>High voltage input pin</li> <li>Input pin</li> </ol> |
| VSS                       | 11      | Р             | Ground input                                                                                                                                                                                                  |
| PB0 ~ PB2                 | 12~ 14  | I/O           | <ol> <li>In Advance mode, wakeup from sleep mode<br/>when pin change</li> <li>I/O pin (pull-high option)</li> </ol>                                                                                           |



# **4.Control Register**

| Name         | Addr | Bit 7  | Bit 6 | Bit 5          | Bit 4           | Bit 3           | Bit 2   | Bit 1   | Bit 0 |
|--------------|------|--------|-------|----------------|-----------------|-----------------|---------|---------|-------|
| SELECT       |      |        |       | SUR0           | EDGE0           | PSA             | PS2     | PS1     | PS0   |
| IAR          | \$00 |        | A6    | A5             | A4              | A3              | A2      | A1      | A0    |
| TMR0         | \$01 | D7     | D6    | D5             | D4              | D3              | D2      | D1      | D0    |
| PC           | \$02 | D7     | D6    | D5             | D4              | D3              | D2      | D1      | D0    |
| STATUS       | \$03 |        | A8    | SA0 (A9)       | $\overline{TO}$ | $\overline{PD}$ | Z       | DC      | С     |
| BSR          | \$04 |        | D6    | D <sub>5</sub> | D4              | D3              | D2      | D1      | D0    |
| I/O PortA    | \$05 | PA7    | PA6   | PA5            | PA4             | PA3             | PA2     | PA1     | PA0   |
| I/O PortB    | \$06 | PB7    | PB6   | PB5            | PB4             | PB3             | PB2     | PB1     | PB0   |
| PULL-Hi      | \$20 | PUH7   | PUH6  | PUH5           | PUH4            | PUH3            | PUH2    | PUH1    | PUH0  |
| IRQM         | \$21 | INTM   |       | TMR2M          | TMR1M           |                 | EXINTM1 | EXINTM0 | TMR0M |
| IRQF         | \$22 |        |       | TMR2F          | TMR1F           |                 | EXINTF1 | EXINTF0 | TMR0F |
| WDTSEL       | \$23 |        |       |                |                 |                 |         | S1      | S0    |
| TMR1 Control | \$24 | TMR1EN | Load  | SUR1           | SUR0            | EDGE            | PS2     | PS1     | PS0   |
| TMR2 Control | \$25 | TMR2EN | Load  | SUR1           | SUR0            | EDGE            | PS2     | PS1     | PS0   |
| TMR1 Preload | \$26 | D7     | D6    | D5             | D4              | D3              | D2      | D1      | D0    |
| TMR2 preload | \$27 | D7     | D6    | D5             | D4              | D3              | D2      | D1      | D0    |
| WAKE_UP      | \$40 | WDTS   | WUE   | RTCEN          |                 |                 |         | EIS1    | EIS0  |



Select range function only in Advanced mode.



#### 5. System Block Diagram





#### 6. Memory Map

TM58PE10 memory is organized into program memory and data memory.

#### 6.1 Program memory

TM58PE10 provides 2 program memory map modes, general mode and advanced mode. User can select different mode by setting configuration word.

In general mode, there are only 512 words of the same page that can be directly addressed. Extra program memory can be addressed by setting bit 5 of status register. The sequence of instructions is controlled via the program counter (PC), which automatically increases 1. However, the sequence can be changed by skip, call, goto, lcall and lgoto instructions or by moving data to the PC.

In advanced mode, TM58PE10 allow directly address any address in 1K memories without limited by page size. In addition, Icall and Igoto instructions are employed to provide flexible addressing mode.

TM58PE10 has a 10-bits program counter capable of accessing 1K spaces. If accessing address has over 1K, then the address will map to physical 1K memories, i.e. 1K+M will be mapped to M. A NOP at the reset vector location will cause a restart at address 000h. A simple map to induce illustrate ROM organization is shown in figures 5-1.







TM58PE10 only provide IRQ function in advanced mode. In this mode, the address 3FEH is reserved for IRQ vector. User can operate advanced mode by setting configuration word. The configuration word is located 800H, shown in figure 6-2.

|     | Configuration Word |                                         |                                                           |                                             |                          |  |  |  |  |  |  |
|-----|--------------------|-----------------------------------------|-----------------------------------------------------------|---------------------------------------------|--------------------------|--|--|--|--|--|--|
| Bit | Symbol             |                                         | Description                                               |                                             |                          |  |  |  |  |  |  |
|     |                    | Bit [1]                                 | Bit [0]                                                   | OSC Type                                    | Resonance Frequency      |  |  |  |  |  |  |
|     | FOSC1              | 0                                       | 0                                                         | LP (low speed)                              | 32~200K Hz               |  |  |  |  |  |  |
| 1~0 |                    | 0                                       | 1                                                         | NT <sub>(Normal speed)</sub>                | 200K~10M Hz              |  |  |  |  |  |  |
|     | FOSC0              | 1                                       | 0                                                         | HS (high speed)                             | 10~20M Hz                |  |  |  |  |  |  |
|     |                    | 1                                       | 1                                                         | 32K ~ 20M Hz (VDD=5V)                       |                          |  |  |  |  |  |  |
|     | WDTE               |                                         |                                                           | og enable/disable cont                      | rol                      |  |  |  |  |  |  |
| 2   | WDTE               |                                         | VDT ena<br>VDT dis                                        |                                             |                          |  |  |  |  |  |  |
|     |                    |                                         |                                                           | ection bit                                  |                          |  |  |  |  |  |  |
| 3   | CPT                |                                         | DFF                                                       |                                             |                          |  |  |  |  |  |  |
|     |                    | 0: 0                                    | N                                                         |                                             |                          |  |  |  |  |  |  |
|     |                    |                                         | TYPE: Select operating mode                               |                                             |                          |  |  |  |  |  |  |
| 4   | TYPE               |                                         | Advance                                                   |                                             |                          |  |  |  |  |  |  |
|     |                    |                                         | 0: General mode                                           |                                             |                          |  |  |  |  |  |  |
|     |                    | LV1 LV0 Detect voltage                  |                                                           |                                             |                          |  |  |  |  |  |  |
|     |                    | 0                                       | 0                                                         |                                             | 4V                       |  |  |  |  |  |  |
| 6~5 | LV1~LV0            | 0                                       | 1                                                         |                                             | plemented                |  |  |  |  |  |  |
|     |                    | 1                                       | 0                                                         |                                             | 2.2V                     |  |  |  |  |  |  |
|     |                    | 1                                       | 1                                                         | Do                                          | n't use                  |  |  |  |  |  |  |
|     |                    |                                         |                                                           | •                                           | eneral mode only set =0) |  |  |  |  |  |  |
| 7   | RESETB0            |                                         |                                                           | ESETB0/INT0 be Norm<br>ESETB0/INT0 be syste |                          |  |  |  |  |  |  |
|     |                    |                                         |                                                           |                                             | eneral mode only set =1) |  |  |  |  |  |  |
| 8   | RESETB1            |                                         |                                                           | SETB1/INT1 be Input F                       |                          |  |  |  |  |  |  |
| Ū   |                    | 1: PA5/RESETB1/INT1 be system reset Pin |                                                           |                                             |                          |  |  |  |  |  |  |
|     |                    | IOC: OS                                 | IOC: OSC1, OSC2 I/O Control (In General mode only set =0) |                                             |                          |  |  |  |  |  |  |
| 9   | IOC                |                                         |                                                           |                                             |                          |  |  |  |  |  |  |
|     |                    |                                         |                                                           | SC2 be I/O Pin                              |                          |  |  |  |  |  |  |
| 10  | INRC               |                                         |                                                           | C (In General mode o<br>Internal RC clock   | niy set =0)              |  |  |  |  |  |  |
| 10  | INRO               | -                                       |                                                           | nal RC clock                                |                          |  |  |  |  |  |  |
|     |                    |                                         |                                                           |                                             |                          |  |  |  |  |  |  |



| 11 | AUP | <ul> <li>AUP : Auto Update Page (In General mode only set =0)</li> <li>0: Disable auto update page in Advance mode</li> <li>1: Enable auto update page in Advance mode</li> </ul> |
|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Figure 6-2 The Configuration Word

#### 6.2 Data memory

Data memory is composed of special function registers and general-purpose ram. The size of data memory is not stationary; it depends on bit 4 of configuration word (general or advanced mode).

#### 6.2.1 General Mode

In general mode, TM58PE10 has 25 general-purpose registers. The special function registers include the program counter (PC), the timer (TMR0) register, the status register, the bank select register (BSR), and the I/O port registers (PORTA, PORTB). Furthermore, TM58PE10 has 3 auxiliary registers that include indirect addressing register (IAR), the select register (Select) and the I/O direction register (IODIR). The register map of general mode is shown in figure 6-3.

|         | Bank0                                      |
|---------|--------------------------------------------|
| 00H     | IAR                                        |
| 01H     | TMR0                                       |
| 02H     | PC                                         |
| 03H     | STATUS                                     |
| 04H     | BSR                                        |
| 05H     | PORTA                                      |
| 06H     | PORTB                                      |
| 0+16=25 | General Purpose<br>Register<br>07 H – 0F H |
| 9+16=25 | General Purpose<br>Register<br>10 H -1F H  |

Figure 6-3 The Register Map of General Mode



- A. The IAR (indirect addressing register) is not a physical register and is used to assist BSR with indirect addressing. Any instruction attempts to access IAR actually mapping to another address that is pointed by BSR. Since IAR is not a material circuit, user reads IAR itself (BSR=00H) will always return 00h at data bus. Writing to IAR itself will like NOP.
- B. Select register is used to control WDT and TMR0. It has not assigned a specific address in data memory and can only set control bits by "select" instruction, i.e. it is write-only register. The content of accumulator will be sent to the select register by executing the "select" instruction. If select register has never set by program, its default value is 3FH. We drew Figure 6-4 to explain how to set select register.

|     | Control register SELECT |      |                                                                                                                                                                                |       |           |          |  |  |  |  |
|-----|-------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|----------|--|--|--|--|
| Bit | Symbol                  |      | Description                                                                                                                                                                    |       |           |          |  |  |  |  |
|     |                         | PS2  | PS1                                                                                                                                                                            | PS0   | TMR0 rate | WDT rate |  |  |  |  |
|     |                         | 0    | 0                                                                                                                                                                              | 0     | 1:2       | 1:1      |  |  |  |  |
|     |                         | 0    | 0                                                                                                                                                                              | 1     | 1:4       | 1:2      |  |  |  |  |
|     |                         | 0    | 1                                                                                                                                                                              | 0     | 1:8       | 1:4      |  |  |  |  |
| 2~0 | PS2~PS0                 | 0    | 1                                                                                                                                                                              | 1     | 1:16      | 1:8      |  |  |  |  |
|     |                         | 1    | 0                                                                                                                                                                              | 0     | 1:32      | 1:16     |  |  |  |  |
|     |                         | 1    | 0                                                                                                                                                                              | 1     | 1:64      | 1:32     |  |  |  |  |
|     |                         | 1    | 1                                                                                                                                                                              | 1:64  |           |          |  |  |  |  |
|     |                         | 1    | 1 1 1 1:256 1:128                                                                                                                                                              |       |           |          |  |  |  |  |
| 3   | PSA                     | 1: P | PSA: Prescaler assignment bit<br>1: Prescaler assigned to WDT<br>0: Prescaler assigned to TMR0                                                                                 |       |           |          |  |  |  |  |
| 4   | EDGE0                   | 1:in | EDGE0: TMR0 source signal edge control bit<br>1:increment when $H\rightarrow L$ transition on external clock<br>0:increment when $L\rightarrow H$ transition on external clock |       |           |          |  |  |  |  |
| 5   | SUR0                    | 1: E | SUR0: TMR0 clock source bit<br>1: External clock input<br>0: (Internal clock)/4 or internal instruction cycle                                                                  |       |           |          |  |  |  |  |
| 6~7 |                         | Unir | npleme                                                                                                                                                                         | ented |           |          |  |  |  |  |

Figure 6-4 Select Register



- C. The I/O Direction control register is similar to the Select register that is write-only register. To set an I/O port pin as input, the corresponding direction control bit must be high. Similarly, the zero represents output. Any direction control bit can be programmed individually as input or output by using IODIR instruction. If the register is not programmed, then all I/O ports always keep input mode.
- PC (program counter, 02H) is a 10-bit wide binary counter and increases itself for every instruction cycle, except the following instructions.
  - 1. call, goto, lgoto and lcall: the label will move to PC
  - 2. retla, reti and ret: the top value of stack will pop to PC
- Incrementing PC when it changes to the next higher page. It should be noted that the page select bits in the status register would not be changed synchronously. The following Goto, Call, MOVAM PC or ADDAM PC instruction will return to the previous page, unless the page select bits have been updated in program. In order to reduce the complexity of programming. TM58PE10 provides 2 instructions to facilitate subroutine call and branch handling which are LCALL and LGOTO. LCALL and LGOTO can address to anywhere in the ROM. However the page select bits will keep default value. If the program counter register is written then system will load page select register default value to high address. System will go the wrong address. See example on Figure 6-5-3.
- The attached operands of CALL and GOTO are 8-bit and 9-bit respectively, and so need extra bits (page select bits) to address whole memory. However, LCALL and LGOTO have 10-bit wide operands that are easy to address the total ROM space.
   Page select bits in control register STATUS (03H) bit [6:5] function in advance mode will be described in section 7.3.
- TMR0 is 8-bit wide binary counter/timer. This register increases by an external signal edge applied to EXT\_CLK pin, or by internal instruction cycle. It has the following features.
  - A. Readable and writeable
  - B. Synchronize with 2 internal clocks
  - C. Can use programmable prescaler by setting select register



The other details will be described in follow-up chapter.

- Status register contains page select bits, time out bit, power down bit and the status bits of ALU. Please note that  $\overline{TO}$  and  $\overline{PD}$  are controlled by hardware and unchangeable by program.
- ullet

|     | Control register STATUS (03H) |                                                                                                                                                                             |                                                                                                                                                  |                                                                                |  |  |  |  |  |  |  |
|-----|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Bit | Symbol                        |                                                                                                                                                                             | Des                                                                                                                                              | cription                                                                       |  |  |  |  |  |  |  |
|     |                               |                                                                                                                                                                             | d Borrow bit                                                                                                                                     |                                                                                |  |  |  |  |  |  |  |
|     |                               | ADD                                                                                                                                                                         | ) instruction                                                                                                                                    | SUB instruction                                                                |  |  |  |  |  |  |  |
| 0   | С                             | 1: a carry occ<br>0: no carry                                                                                                                                               | curred from the MSB                                                                                                                              | 1: no borrow <sup>(Note1)</sup><br>0: a borrow occurred from the MSB           |  |  |  |  |  |  |  |
|     |                               |                                                                                                                                                                             | Nibble Carry and                                                                                                                                 | d Nibble Borrow bit                                                            |  |  |  |  |  |  |  |
| 1   | DC                            |                                                                                                                                                                             | ) instruction                                                                                                                                    | SUB instruction                                                                |  |  |  |  |  |  |  |
|     | DC                            | of the resul<br>0: no carry                                                                                                                                                 | n the low nibble bits<br>t occurred                                                                                                              | 1: no borrow<br>0: a borrow from the low nibble bits<br>of the result occurred |  |  |  |  |  |  |  |
| 2   | Z                             | 1: the resu                                                                                                                                                                 | Zero bit:<br>1: the result of a logic operation is zero<br>0: the result of a logic operation is not zero                                        |                                                                                |  |  |  |  |  |  |  |
| 3   | PD                            | 0: the result of a logic operation is not zero<br>Power down flag bit: <sup>(Note2)</sup><br>1: after power-on or by the CLRWDT instruction<br>0: execute SLEEP instruction |                                                                                                                                                  |                                                                                |  |  |  |  |  |  |  |
| 4   | $\overline{TO}$               | Time out flag<br>1: after pov                                                                                                                                               | bit: (Note2)                                                                                                                                     | RWDT or SLEEP instruction                                                      |  |  |  |  |  |  |  |
|     |                               |                                                                                                                                                                             |                                                                                                                                                  | Page Location                                                                  |  |  |  |  |  |  |  |
| 5   | SA0<br>(A9)                   | 0<br>1                                                                                                                                                                      |                                                                                                                                                  | age0 (000H~1FFH)<br>age1 (200H~3FFH)                                           |  |  |  |  |  |  |  |
| 6   | A8                            | General mo                                                                                                                                                                  | ode always = "0 ", Ad                                                                                                                            | vance mode can be set.                                                         |  |  |  |  |  |  |  |
| 7   |                               | Unimpleme                                                                                                                                                                   | nted                                                                                                                                             |                                                                                |  |  |  |  |  |  |  |
|     | Bit [5]                       | Bit [6]                                                                                                                                                                     | 14                                                                                                                                               | ranco modo uso only                                                            |  |  |  |  |  |  |  |
| S   | 6A0 (A9)                      | A8                                                                                                                                                                          | <u>A00</u>                                                                                                                                       | rance mode use only                                                            |  |  |  |  |  |  |  |
|     | 0<br>0<br>1<br>1              | 0<br>1<br>0<br>1                                                                                                                                                            | Page0 (OTP mapping = 000H ~ 0FFH)<br>Page1 (OTP mapping = 100H ~ 1FFH)<br>Page2 (OTP mapping = 200H ~ 2FFH)<br>Page3 (OTP mapping = 300H ~ 3FFH) |                                                                                |  |  |  |  |  |  |  |
|     |                               |                                                                                                                                                                             | Figure 6-5 Status R                                                                                                                              | egister                                                                        |  |  |  |  |  |  |  |
|     |                               |                                                                                                                                                                             |                                                                                                                                                  |                                                                                |  |  |  |  |  |  |  |



Note1: A SUB instruction is executed by adding the 2's complement of the subtrahend, so C = 1 represents positive result. The Figure 6-5-1 show the relation between C-bit and borrow.

| C       B7       B6       B5       B4       B3       B2       B1       B0       C       B7       B6       B5       B4       B3       B2       B1       B0         +       1       0       1       1       0       0       0       0       1       0       1       0       0       0       0         +       1       0       1       1       0       0       0       +       0       1       0       1       0       0       0         =       1       0       1       1       0       0       0       0       +       0       1       0       1       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0 <th colspan="9">B0H - 50H</th> <th></th> <th></th> <th>5</th> <th>0H</th> <th>- B</th> <th>0H</th> <th></th> <th></th> <th></th> <th></th> | B0H - 50H |   |    |    |    |    |    |    |    |    |   | 5 | 0H | - B | 0H |    |    |    |    |    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---|----|----|----|----|----|----|----|----|---|---|----|-----|----|----|----|----|----|----|
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           | С | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |   | С | Β7 | B6  | B5 | B4 | B3 | B2 | B1 | B0 |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |   | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  |   |   | 0  | 1   | 0  | 1  | 0  | 0  | 0  | 0  |
| = 1 0 1 1 0 0 0 0 0 = 0 1 0 1 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | +         |   | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | + |   | 0  | 1   | 0  | 1  | 0  | 0  | 0  | 0  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | =         | 1 | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | = | 0 | 1  | 0   | 1  | 0  | 0  | 0  | 0  | 0  |

Figure 6-5-1

Note2: The  $\overline{TO}$  and  $\overline{PD}$  bits are active low that can be used to determine different causes of reset. The Figure 6-5-2 illustrates the value of  $\overline{TO}$  and  $\overline{PD}$  after the relative reset events.

| $\overline{TO}$ | $\overline{PD}$ | Reset Event                                           |
|-----------------|-----------------|-------------------------------------------------------|
| 0               | 0               | WDT time out from sleep mode                          |
| 0               | 1               | WDT time out from normal mode                         |
| 1               | 0               | Input a 'low" at RESETB0, RESETB1 from sleep mode     |
| 1               | 1               | Power on reset                                        |
| Unchanged       | Unchanged       | Input a "low" at RESETB0, RESETB1 from<br>normal mode |

Figure 6-5-2





Example: Used Lcall , Lgoto in general mode may take care of page select register.

Figure 6-5-3 Use "Lgoto" instruction in general mode.

BSR (bank select register) is associated with IAR to indirectly access the data memory. The BSR<4:0> bits are used to select data memory addresses 00h to 1Fh (Bank0). The addressing map is shown in Figure 6-6.







• Port A~B are programmable I/O ports. Please note that read I/O instruction always read the I/O pin even though the pin is output mode. On reset, all I/O pins were set as input mode until IODIR has been changed.

#### 6.2.2 Advanced mode

In advanced mode, we provide IRQ, convenient wake up functions and flexible addressing mode. In addition to extend data memory, we increase 9 extra registers to support IRQ, wake\_up, Timer1 and Timer2. This section will introduce these increased control registers and characteristics. The data memory map of advanced mode and the addressing map are shown in figure 6-7 and figure 6-8 respectively.

| / 10/01/00 |                                          |              |                                          |               |             |  |
|------------|------------------------------------------|--------------|------------------------------------------|---------------|-------------|--|
|            | 00~1F                                    |              | 20~3F                                    |               | 40~5F       |  |
| 00H        | IAR                                      | 20H          | PULL-Hi                                  | 40H           | WAKE_UP     |  |
| 01H        | TMR0                                     | 21H          | IRQM                                     |               |             |  |
| 02H        | PC                                       | 22H          | IRQF                                     |               |             |  |
| 03H        | STATUS                                   | 23H          | WDTSEL                                   |               |             |  |
| 04H        | BSR                                      | 24H          | TMR1 Control                             |               |             |  |
| 05H        | PORTA                                    | 25H          | TMR2 Control                             |               |             |  |
| 06H        | PORTB                                    | 26H          | TMR1 Preload                             |               |             |  |
|            |                                          | 27H          | TMR2 Preload                             | Unimplemented |             |  |
| 9+16       | General Purpose<br>Register<br>07H - 0FH |              | General Purpose<br>Register<br>28H - 2FH |               | implemented |  |
| = 25       | General Purpose<br>Register<br>10H - 1FH | 8+16<br>= 24 | General Purpose<br>Register<br>30H - 3FH |               |             |  |

Advanced mode (Type=1)

Figure 6-7 The Data Memory Map of Advanced Mode





Figure 6-8 The Direct and Indirect Addressing Map

In advanced mode, we locate the increased 24 general-purpose registers on  $28 \sim 3F$  which shown in Fig 6-7. The IRQ and the Wakeup control registers (PULL\_Hi, IRQM, IRQF and WAKE\_UP) are assigned to 20H, 21H, 22H and 40H respectively. In advanced mode, TM58PE10 allows 7-bit wide operand to access ram, operand<6:0> can address 00H ~ 40H directly. It doesn't need bank select bits, and reduces the complexity of programming.

 Pull-High register (PULL-Hi---20H) if (PUH [N]=1) and only if (Port B Bit [N] as input pin); [N]=7~0, then PortB Bit[N] will PULL-Hi. See Figure 6-9 PULL-Hi Register

|     | Control register PULL-Hi (20H) |                                                                                                              |  |  |  |  |  |
|-----|--------------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit | Symbol Description             |                                                                                                              |  |  |  |  |  |
| 7~0 | PUH [7]~PUH [0]                | Pull High Port B bit7 ~ bit0:<br>0: disable pull-hi function.<br>1: Enable Pull High bit (Bit [7] ~ Bit [0]) |  |  |  |  |  |

Figure 6-9 PULL-Hi Register



The wakeup control register (WAKE\_UP; 40H) is used to set watchdog enable and distinguish between external wake-up signal, EXT\_CLK I/O control and IRQ. WUE bit control external wake-up function. In TM58PE10 wakeup operation in PortB be input pin and pin change wakeup; see page 22. On reset, all bits are defined as "0"; except for bit [5] "RTCEN" defined as "0" that can be programming by software. The scheme of WAKE\_UP register is shown in Fig 6-10.

|     | Control register WAKE_UP (40H) |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|-----|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit | Bit Symbol Description         |                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 7   | WDTS                           | <ul> <li>Watch Dog Timer Software Control bit:<br/>TM58PE10 has 2 WDT control bits (WDTE and WDTS), WDTE<br/>is set in configuration word by hardware and WDTS is set in<br/>control register by software. If WDTS is valid only if WDTE has<br/>been set, i.e. WDTE has higher priority than WDTS.</li> <li>1: enable</li> <li>0: disable</li> </ul> |  |  |  |  |  |
| 6   | WUE                            | Wake Up Enable bit:<br>1: enable external wake-up function<br>0: disable external wake-up function                                                                                                                                                                                                                                                    |  |  |  |  |  |
| 5   | RTCEN                          | EXT_CLK be I/O Pin Enable bit:<br>1: set EXT_CLK/PA4 as a normal clock pin<br>0: set EXT_CLK/PA4 as a bi-directional I/O pin <i>(default value)</i>                                                                                                                                                                                                   |  |  |  |  |  |
| 4~2 |                                | Unimplemented read as "0"                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 1   | EIS1                           | External Interrupt Select1:<br>1: set RESETB1/PA5/INT1 as an external IRQ pin <sup>(Note3)</sup><br>0: set RESETB1/PA5/INT1 as a Input pin                                                                                                                                                                                                            |  |  |  |  |  |
| 0   | EIS0                           | External Interrupt Select0:<br>1: set PA0/RESETB0/INT0 as an external IRQ pin <sup>(Note3)</sup><br>0: set PA0/RESETB0/INT0 as a bi-directional I/O pin                                                                                                                                                                                               |  |  |  |  |  |

Figure 6-10 WAKE\_UP Register

Note3: The IRQ must execute at normal mode. If an IRQ is occurred at sleep mode, then the IRQ routine will be performed until this chip has woken by external wake up signal. Other wake methods include (1) power on reset, (2) external reset and (3)



WDT overflow (if enabled), the foregoing cases mean the IRQ ought to be abolished.

 The Interrupt Mask register and Interrupt Flag register are used to control IRQ handling. A TM58PE10 support TMR0, TMR1, TMR2 and two external interrupt (INT0, INT1), but nest-interrupt is not allowed. The schemes of the interrupt mask register and the interrupt flag register are shown in Fig 6-10 and 6-11, respectively.

|     | Control register IRQM (21H) |                                                                                                                                                                                                                                                 |  |  |  |  |
|-----|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit | Symbol                      | Description                                                                                                                                                                                                                                     |  |  |  |  |
| 7   | INTM                        | Global enable bit:<br>The bit has higher priority than any interrupt enable signal.<br>1: enable<br>0: disable<br>By the way, when system occur interrupt the INTM will<br>be cleared by hardware and RETI instruction will set<br>INTM as '1'. |  |  |  |  |
| 6   |                             | Unimplemented                                                                                                                                                                                                                                   |  |  |  |  |
| 5   | TMR2M                       | TMR2 Interrupt enable:<br>1:Enable Interrupt<br>0:Disable Interrupt                                                                                                                                                                             |  |  |  |  |
| 4   | TMR1M                       | TMR1 Interrupt enable:<br>1:Enable Interrupt<br>0:Disable Interrupt                                                                                                                                                                             |  |  |  |  |
| 3   |                             | Unimplemented                                                                                                                                                                                                                                   |  |  |  |  |
| 2   | EXINTM1                     | External Interrupt enable PA5/RESETB1/INT1:<br>1:Enable Interrupt<br>0:Disable Interrupt                                                                                                                                                        |  |  |  |  |
| 1   | EXINTM0                     | External Interrupt enable PA0/RESETB0/INT0:<br>1:Enable Interrupt<br>0:Disable Interrupt                                                                                                                                                        |  |  |  |  |
| 0   | TMR0M                       | TMR0 Interrupt enable:<br>1:Enable Interrupt<br>0:Disable Interrupt                                                                                                                                                                             |  |  |  |  |

Figure 6-10 Interrupt Mask register



|     | Control register IRQF (22H) |                                                                                                                                     |  |  |  |  |
|-----|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Bit | Symbol                      | Description                                                                                                                         |  |  |  |  |
| 7~6 |                             | Unimplemented                                                                                                                       |  |  |  |  |
| 5   | TMR2F                       | TMR2 interrupt flag:<br>1: The TMR2 counter overflow<br>generates an interrupt request.                                             |  |  |  |  |
| 4   | TMR1F                       | TMR1 interrupt flag:<br>1: The TMR1 counter overflow<br>generates an interrupt request.                                             |  |  |  |  |
| 3   |                             | Unimplemented                                                                                                                       |  |  |  |  |
| 2   | EXINTF1                     | External interrupt flag:<br>1: the External interrupt be requested<br>by the external interface PA5/RESETB1/INT1 <sup>(Note4)</sup> |  |  |  |  |
| 1   | EXINTF0                     | External interrupt flag:<br>1: the External interrupt be requested<br>by the external interface PA0/RESETB0/INT0 <sup>(Note4)</sup> |  |  |  |  |
| 0   | TMR0F                       | TMR0 interrupt flag:<br>1: The TMR0 counter overflow generates<br>an interrupt request.                                             |  |  |  |  |

Figure 6-11 Interrupt Flag register

Note 4: Both interrupt flags are set by hardware; software can only clear flags. It is useless that attempt writing '1' to flag.

 If user don't setting perscaler rate to WDT, the default base period is 16mS. In TM58PE10 advance mode, user can select different base period by setting WDTSEL register (23H). Program will run following the sleep instruction after wakeup by portB in sleep mode. There will be a response time from wakeup to program running (see the illustrated waveform below). The response time is affected by WDT base period and user can set different response time by setting WDT base period.



Default response time value is 16mS. See in Figure 6-12 and example in following text.

|         | Control register WDTSEL (23H) |                                                          |  |  |  |  |
|---------|-------------------------------|----------------------------------------------------------|--|--|--|--|
| Bit     | Symbol                        | Description                                              |  |  |  |  |
| 7~2     |                               | Unimplemented                                            |  |  |  |  |
| Bit [1] | Bit [0]                       | Wakeup response time<br>(Base on Watch Dog Timer period) |  |  |  |  |
| S1      | S0                            |                                                          |  |  |  |  |
| 0       | 0                             | 1mS                                                      |  |  |  |  |
| 0       | 1                             | 4mS                                                      |  |  |  |  |
| 1       | 0                             | 8mS                                                      |  |  |  |  |
| 1       | 1                             | 16mS (default value)                                     |  |  |  |  |

Figure 6-12 WDTSEL register

Example: How to reduce wakeup response time





• In this section we describe Timer1 and Timer2 Control register. Some detailed function description in section 7.3. Timer1 and Timer2 register setting need consider about Configuration Word. That can make Timer1 and Timer2 operation more correctly.

| Control register TMR1 Control (24H) |         |                                 |                                                                                                                                                                                                                                                                                                            |        |                                                |  |  |  |  |
|-------------------------------------|---------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------------------------------|--|--|--|--|
| Bit                                 | Symbol  |                                 | Description                                                                                                                                                                                                                                                                                                |        |                                                |  |  |  |  |
| 7                                   | TMR1EN  | 1: Tir                          | Timer1 count Enable bit<br>1: Timer1 count enable<br>0: Timer1 count disable                                                                                                                                                                                                                               |        |                                                |  |  |  |  |
| 6                                   | LOAD    | 1: Co<br>Ti<br>0: Pr            | <ul> <li>Timer1 data load mode</li> <li>1: Counter, when data write to Timer1 data register (26H)</li> <li>Timer1 count value is written immediately. (Default value)</li> <li>0: Preload, when data write to Timer1 data register (26H),</li> <li>Waiting Timer1count overflow then load data.</li> </ul> |        |                                                |  |  |  |  |
| 5                                   | SUR1    | SUR1                            | SUR1 SUR0 Timer1 source (Refer to example 7.4.1 at page 33)                                                                                                                                                                                                                                                |        |                                                |  |  |  |  |
|                                     |         | 0                               | 0 0 From System CLK (only Internal RC or External                                                                                                                                                                                                                                                          |        |                                                |  |  |  |  |
| 4                                   | SUR0    | 0<br>1<br>1                     | 1<br>0<br>1                                                                                                                                                                                                                                                                                                | From T | EXT_CLK<br>Timer2 (connect to be 16 bit timer) |  |  |  |  |
| 3                                   | EDGE1   | 1:inc                           | EDGE1: TMR1 source from EXT_CLK signal edge control bit<br>1:increment when EXT_CLK H→L transition<br>0:increment when EXT_CLK L→H transition                                                                                                                                                              |        |                                                |  |  |  |  |
|                                     |         | PS2                             | PS1                                                                                                                                                                                                                                                                                                        | PS0    | Timer1 Prescaler rate                          |  |  |  |  |
| 2~0                                 | PS2~PS0 | 0<br>0<br>0<br>1<br>1<br>1<br>1 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                      |        |                                                |  |  |  |  |

Figure 6-13 Timer1 Control register



| Control register TMR2 Control (25H) |         |                                 |                                                                                                                                                                                                                                                               |     |                       |  |  |  |  |
|-------------------------------------|---------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------|--|--|--|--|
| Bit                                 | Symbol  |                                 | Description                                                                                                                                                                                                                                                   |     |                       |  |  |  |  |
| 7                                   | TMR2EN  | 1: Tin                          | Timer2 count Enable bit<br>1: Timer2 count enable<br>0: Timer2 count disable                                                                                                                                                                                  |     |                       |  |  |  |  |
| 6                                   | LOAD    | 1:Co<br>Tii<br>0: Pr            | Timer2 data load mode<br>1:Counter, when data write to Timer2 data register (27H)<br>Timer2 count value is written immediately. (Default value)<br>0: Preload, when data write to Timer2 data register (27H),<br>Waiting Timer2count overflow then load data. |     |                       |  |  |  |  |
| 5                                   | SUR1    | SUR1                            | (Refer to example 7.4.1 at page 33)                                                                                                                                                                                                                           |     |                       |  |  |  |  |
|                                     |         | 0                               | 0 0 From System CLK (Only Crystal mode) (Note                                                                                                                                                                                                                 |     |                       |  |  |  |  |
| 4                                   | SUR0    | 0<br>1<br>1                     | 1 0 From Timer1 (connect to be 16 bit timer)                                                                                                                                                                                                                  |     |                       |  |  |  |  |
| 3                                   | EDGE2   | 1:inc                           | EDGE2: TMR2 source from EXT_CLK signal edge control bit 1:increment when EXT_CLK H $\rightarrow$ L transition 0:increment when EXT_CLK L $\rightarrow$ H transition                                                                                           |     |                       |  |  |  |  |
|                                     |         | PS2                             | PS1                                                                                                                                                                                                                                                           | PS0 | Timer2 Prescaler rate |  |  |  |  |
| 2~0                                 | PS2~PS0 | 0<br>0<br>0<br>1<br>1<br>1<br>1 | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                         |     |                       |  |  |  |  |

Figure 6-14 Timer2 Control register

Note 5: Configuration Word bits [1:0] can only select one operate mode, which is either crystal mode (HS, XT and LP) or external RC mode. So <u>Timer1 and Timer2 can't</u> <u>adopt Crystal and External RC at the same time</u>.



|     | Control register TMR1, TMR2 data register (26H, 27H) |                                                               |  |  |  |  |  |
|-----|------------------------------------------------------|---------------------------------------------------------------|--|--|--|--|--|
| Bit | Bit Symbol Description                               |                                                               |  |  |  |  |  |
| 7~0 | D7~D0                                                | Timer1 and Timer2 data register.<br>Default data D7~ D0 = FFH |  |  |  |  |  |

Figure 6-15 Timer1 and Timer2 data register

The debounce time is the interval that must pass before a second pressing of a key is accepted. User can set this interval with the delay routine (See Example A).

Example A :Key bounce

| interrup        |                                |
|-----------------|--------------------------------|
| ;               |                                |
| btmss irqf,1    | ;; if external IRQ(INT0)?      |
| lgoto int_end   |                                |
| int_nt1:        | ;; filter out key begin bounce |
| btmsc ra,0      |                                |
| lgoto int_nt1   |                                |
| int_loop1:      | ;; filter out key end bounce   |
| call delay      | ;; worse case 30ms             |
| btmss ra,0      |                                |
| lgoto int_loop1 |                                |
|                 |                                |
| call delay      | ;; such as 30ms                |
| btmss ra,0      |                                |
| lgoto int_loop1 |                                |
| ;               |                                |
| bcm irqf,1      |                                |
| int_end:        |                                |
| reti            |                                |
|                 |                                |



### 7. Functional Description

#### 7.1 TMR0 and Watchdog timer

Fig. 7-1 shows the block diagram of the TMR0/WDT prescaler. As shown in the figure, the prescaler register can be a pre-scaler for TMR0 or be a post-scaler for WDT.



Figure 7-1 Block Diagram of the TMR0/WDT Prescaler



The TMR0 is an 8-bit timer/counter. The clock source of TMR0 can come from the instruction clock or the external clock.

- A. To select the instruction clock, the SUR0 bit of the select register should be clear. When no prescaler is used, TMR0 will increase by 1 at every instruction cycle.
- B. To select the external clock, the SUR0 bit of the select register should be set. In this mode, TMR0 relies on the EDGE0 bit to determine that TMR0 is increased by 1 at every falling or rising edge. When an external clock is used for TMR0, a problem must be noted that the external clock synchronizes with internal clock. TM58PE10 synchronizes external clock by sampling internal clock at T2 and T4. If external pulse is smaller than 2 internal cycles, the pulse maybe ignored. Therefore, the external clock must keep stable state (high or low) for at least 2 internal cycles.

The WDT counter is an 8-bit binary counter. The clock source of WDT is provided by an independent on-chip RC oscillator that does not need any external clock. Therefore, the WDT will keep counting even if the chip has slept already. A WDT time-out will restart system and set the time-out flag bit (bit4 of status register) as "0". The WDT time-out period vary with temperature, power voltage and process. This period can be improved via the prescaler. The maximum division ratio can up to 1:128 by setting PS2~PS0 bits of select register as "111".

The prescaler can be assigned to either the TMR0 or the WDT via the PSA bit of select register. Note that either WDT or TMR0 cannot employ the prescaler simultaneously. When the prescaler is assigned to WDT, "CLRWDT" and "SLEEP" instruction will clear the prescaler and the WDT. When the prescaler is assigned to TMR0, the prescaler will be cleared by any instruction that writes to TMR0.



#### 7.2 Reset

TM58PE10 may be reset by one of the following conditions:

- (1) Power-on.
- (2) Low voltage reset (circuit protection), refer to electrical characteristic.
- (3) RESETB1/VPP/PA5/INT1 or PA0/RESETB0/INT0 (if be set as reset pin) input a negative pulse.
- (4) WDT timer out reset (if enabled).



Figure 7-2 Scheme of the Reset Controller

As shown in the figure 7-2, four reset conditions are listed. The power-down event will cause TM58PE10 to reset which the voltage ranges is according to the bit6~bit5 in the configuration word. This condition is used to protect chip in deficient power environment. The voltage ranges of power-down are defined in electrical characteristics. Furthermore, the ranges may be influenced by process and temperature variations. In general, we call the first two reset-cases as cold reset. The cold reset time may be too short for slow crystals and RC oscillators that require much longer than setup time <sup>(note6)</sup> to oscillate. In order to insure the system is correct, the events should be synchronized with system clock.

Note6: the setup time is approximately 16ms that will affect due to power voltage, process and temperature variations.



The last two cases are called warm reset. The different reset events will affect registers and ram. The  $\overline{TO}$  and  $\overline{PD}$  bits can be used to determine the type of reset. These relation are listed in figure 7-3

| Address | Name                  | Cold Reset    | Warm Reset             |
|---------|-----------------------|---------------|------------------------|
| N/A     | Accumulator           | XXXX XXXX     | рррр рррр              |
| N/A     | IODIR                 | 1111 1111     | 1111 1111              |
| N/A     | Select                | 11 1111       | 11 1111                |
| 00H     | IAR                   |               |                        |
| 01H     | TMR0                  | XXXX XXXX     | pppp pppp              |
| 02H     | PC                    | 111 1111 1111 | 111 1111 1111          |
| 03H     | STATUS                | 0001 1xxx     | 000? ?ppp <sup>1</sup> |
| 04H     | BSR (In General mode) | 111x xxxx     | 111р рррр              |
| 04H     | BSR (In Advance mode) | 1xxx xxxx     | 1ррр рррр              |
| 05H     | PORTA                 | 0000 xxxx     | 0000 pppp              |
| 06H     | PORTB                 | XXXX XXXX     | pppp pppp              |
| 07H~1FH | General Purpose RAM   | Xxxx xxxx     | Рррр рррр              |
| 20H     | PULL-Hi               | 0000 0000     | 0000 0000              |
| 21H     | IRQM                  | 0000 0000     | 0000 0000 <sup>2</sup> |
| 22H     | IRQF                  | 0000 0000     | 0000 0000              |
| 23H     | WDTSEL                | 0000 0011     | 0000 0011              |
| 24H     | TMR1 Control          | 0100 0000     | 0100 0000              |
| 25H     | TMR2 Control          | 0100 0000     | 0100 0000              |
| 26H     | TMR1 Preload          | 1111 1111     | 1111 1111              |
| 27H     | TMR2 Preload          | 1111 1111     | 1111 1111              |
| 28H~3FH | General Purpose RAM   | Xxxx xxxx     | Рррр рррр              |
| 40H     | WAKE_UP               | 00000         | 00000                  |

Figure 7-3 RESET CONDITIONS

X: unknown; P: previous data ; ?: value depends on condition ; -:unimplemented and read as"0".



#### 7.3 STATUS [6:5] (Page select bits) in advance mode

In Advance mode, system can auto update STATUS [6:5] (page select bits) by hardware or write STATUS [6:5] by software. User can use instruction " Lcall "," Lgoto ", "Ret ", "Retla " and " Reti ", it can go anywhere in OTP by hardware. Above-mentioned five instructions need two instruction cycles to operate. See operation diagram in Figure 7-4.







However user need attention occur interrupt. For example, if STATUS [6:5] default value = 00 then user write STATUS [6:5] =10 by software before occur interrupt. After occurs interrupt, system addressing to interrupt vector 3FEH. It will auto update the page select register STATUS [6:5] =11 (page3) by hardware. After finishes interrupt, stack pop PC+1 address to system, STATUS [6:5] = 00.Before occur interrupt, page select register STATUS bit [5:6] is written =10 will loss. User need take care about interrupt when you write STATUS [6:5] (page select bits) by yourself in advance mode. If user want disable auto update page function in advance mode, please set Configuration Word Bit [11] =0. In this example the page select register STATUS bit [5:6] =10 won't loss. See operation diagram in Figure 7-5.



Figure 7-5 STATUS [6:5] operation with occur interrupt diagram. When Configuration Word Bit [11] set =1.



In Figure 7-6-1 shows the block diagram of the TMR1/TMR2 data register (counter / preload). Reading from TMR1/ TMR2 data register will push TMR1/ TMR2 value to accumulator. Writing to TMR1/ TMR2 data register will push accumulator value to TMR1/ TMR2, depends on data load mode. If Load mode of TMR1/ TMR2 control register has be set =1, the TMR0/ TMR2 data register will be modified immediately.



Figure 7-6-1 TMR1/TMR2 data register (counter / preload)



Figure 7-6 -2 shows the block diagram of the Timer1 and Timer2 prescaler. As show in the figure; Timer1 and Timer2 can be 8 bits X 1 countdown timer and register default value is FFH. Two timer can connect together be one 16 bits X 1 countdown timer default value is FFFFH. If user wants to use Timer1 and Timer2 in interrupt function, please don't set counter value = "00H" or "01H" avoid occur error function in timer interrupt.



Figure 7-6-2 Block Diagram of the TMR1 and TMR2



For example, when user wants to get a 16-bit counter, source from internal RC. Timer1 is first order and Timer2 is second order. We can set Timer2 source from Timer1, connection a 16-bit counter. User can set prescaler rate in Timer1 control register, and then Timer1 clock connect to Timer2 won't do prescaler again, please set prescaler rate 1:1. The clock from Timer1 will connect to Timer2 counter directly.

TMR1 and TMR2 clock source from internal RC, External RC and Crystal. Two timer control register and Configuration Word can assemble more different function. It shows in example 7.4.1.

Example 7.4.1: How to set Configuration Word Bit [10:9] and Bit [1:0] for user? (See Figure 7-7)

- Step 1: Determine system clock from Internal RC, External RC or Crystal.
- Step 2: Determine OSC1/OSC2 want to be clock pin or normal I/O pin.
- Step 3: Determine what source will be used in Timer1 and Timer2.
- Step 4: Set the Configuration Word Bit [10:9] and Bit [1:0] that you want.

| System OSC1 |                |        |         | Configuration Word |             |             |             | Operation<br>Clock |         |       |
|-------------|----------------|--------|---------|--------------------|-------------|-------------|-------------|--------------------|---------|-------|
| Clock       | OSC2<br>Status | Source | Source  | SBIT<br>[10]       | SBIT<br>[9] | SBIT<br>[1] | SBIT<br>[0] |                    |         |       |
|             |                |        |         | INRC               | IOC         | FOSC1       |             | IN_RC              | Crystal | EX_RC |
| IN_RC       | I/O            | IN_RC  |         | 1                  | 1           |             |             | V                  |         |       |
| IN_RC       | Clock          | IN_RC  | Crystal | 1                  | 0           | Crystal (H  | S, XT, LP)  | V                  | V       |       |
| Crystal     | Clock          |        | Crystal | 0                  | 0           | Crystal (H  | IS, XT, LP) |                    | V       |       |
| EX_RC       | Clock          | EX_RC  |         | 0                  | 0           | Exterr      | nal RC      |                    |         | V     |

Figure 7-7 TMR1and TMR2 assemblies with Configuration Word

(V: used, - - -: don't used)

In Figure7-7, TMR1 and TMR2 source show "-----" also can select EXT\_CLK or another TMR1, TMR2 (be 16bits X 1 timer). SBIT [10:9]=10; system clock use internal RC and TMR2 source clock use crystal, the dual clock can operate at the same time. TMR1and TMR2 control register description in Figure 6-13 and Figure 6-14.



## 7.5 Example program for the Configuration Word , Timer1 and Timer2

| Example1: Timer1 operation diagram                               |                                                |
|------------------------------------------------------------------|------------------------------------------------|
| Timer1 source from EXT_CLK.                                      |                                                |
| Timer1_con EQU 24H                                               |                                                |
| Timer1_pre EQU 26H                                               |                                                |
|                                                                  |                                                |
| MOVLA 59H                                                        |                                                |
| MOVAM Timer1_con ; Timer1 source from EXT_CLK (H -> L transtion) |                                                |
|                                                                  | ; Prescaler rate 1:2                           |
| MOVLA 06H                                                        |                                                |
| MOVAM Timer1_pre ; In Timer1_con load data mode=1                |                                                |
|                                                                  | ; Timer1 count value = 06H                     |
|                                                                  | ; Total count N times occur overflow = 6 times |
| BSM_Timer1_con,b7 ;                                              |                                                |
|                                                                  | <u>.</u>                                       |
|                                                                  |                                                |
|                                                                  |                                                |
|                                                                  | :                                              |
|                                                                  |                                                |
| EXT_CLK                                                          |                                                |
|                                                                  |                                                |
| INS                                                              | BSM                                            |
| ING                                                              | Timer1con,B7                                   |
|                                                                  |                                                |
| Timer1                                                           | 06 H 06H 05H 001H 06H 05H                      |
|                                                                  |                                                |
|                                                                  |                                                |
| Timer1                                                           |                                                |
| count overflow                                                   |                                                |
|                                                                  | Overflow signal, all count six times           |



#### Example2: Dual Clock Application

Set Configuration Word Bit 10 and Bit 9= 10 We select system clock from Internal RC. Timer1 source from Internal RC. Timer2 source from Crystal. Timer1\_con EQU 24H Timer2 con EQU 25H Timer1\_pre EQU 26H Timer2 \_pre EQU 27H MOVLA 40H MOVAM Timer1\_con; Timer1 source from Internal RC set prescaler rate 1:1 MOVLA 01H MOVAM Timer2\_con ; Timer2 source from Crystal and prescaler rate 1:2 MOVLA 77H MOVAM Timer1\_pre ; In Timer1\_con set load data mode=1 :Timer1 count value=77H MOVLA 50H MOVAM Timer2\_pre ; In Timer2\_con load data mode=0 ; Timer2 count value = FFH (default value) ; Waiting "FFH" count overflow then load "50H" to Timer2 BSM Timer2 con,b7; Timer2 countdown enable BSM Timer1\_con,b7; Timer1 countdown enable



#### Example 3

Set Configuration Word Bit 10 and Bit 9= 11 We select system clock from internal RC and OSC1/OSC2 will be I/O Pin. Timer1 source from Timer1 connect to be a 16 bit x 1 timer. Timer1\_con EQU 24H Timer2\_con EQU 25H Timer1\_pre EQU 26H Timer2\_pre EQU 27H MOVLA 42H MOVAM Timer1\_con ; Timer1 source from internal RC and prescaler rate 1:4 MOVLA 60H MOVAM Timer2\_con ; Timer2 source from timer1 and only can set prescaler rate 1:1 ; connect to be 16 bit x1 timer

MOVLA 77H MOVAM Timer1\_pre ; In Timer1\_con set load data mode=1

MOVLA 50H ; In Timer2\_con set load data mode=1 MOVAM Timer2\_pre ; 16 bit x 1 timer value = 5077 H

BSM Timer1\_con,b7; Timer1 countdown enable (first order countdown first) BSM Timer2\_con,b7; Timer2 countdown enable (second order countdown later)



#### Example 4

Set Configuration Word Bit 10 and Bit 9= 00 We select system clock from Crystal. Timer2 source from Crystal. Timer1 source from Timer2 be a 16-bit timer.

Timer1\_con EQU 24H Timer2\_con EQU 25H Timer1\_pre EQU 26H Timer2\_pre EQU 27H

MOVLA 60H MOVAM Timer1\_con ; Timer1 source from Timer2 and only can set prescaler rate 1:1

MOVLA 41H MOVAM Timer2\_con ; Timer2 source from Crystal and prescaler rate 1:2

MOVLA 50H MOVAM Timer2\_pre ;

MOVLA 77H MOVAM Timer1\_pre ; Timer1 count value = 7750 H

BSM Timer2\_con,b7; Timer2 countdown enable (first order countdown first) BSM Timer1\_con,b7; Timer1 countdown enable (second order countdown later)



#### Example 5

Set Configuration Word Bit 10 and Bit 9= 00 We select system clock from Crystal. Timer1 source from EXT CLK. Timer2 source from Crystal. Timer1 con EQU 24H Timer2 con EQU 25H Timer1\_pre EQU 26H Timer2 \_pre EQU 27H MOVLA 58H MOVAM Timer1 con ; Timer1 source from EXT CLK (H -> L transtion) ; Prescaler rate 1:1 MOVLA 40H MOVAM Timer2 con ; Timer2 source from Crystal ; Prescaler rate 1:1 MOVLA 77H MOVAM Timer1\_pre ; In Timer1\_con load data mode=1 ; Timer1 count value = 77H MOVLA 50H MOVAM Timer2\_pre ; In Timer2\_con load data mode=1 : Timer2 count value = 50H BSM Timer2 con,b7; BSM Timer1 con,b7;



#### 8. Instruction Set

| Mnemonic<br>Operands | Instruction<br>Code (Advance)                | Cycles        | Status<br>Affected | OP-code           |
|----------------------|----------------------------------------------|---------------|--------------------|-------------------|
| ADDAM M, m           | $(M)$ +(acc) $\rightarrow$ (M)               | 1             | C, DC, Z           | 10 0101 1MMM MMMM |
| ADDAM M, a           | $(M)$ +(acc) $\rightarrow$ (acc)             | 1             | C, DC, Z           | 10 0101 0MMM MMMM |
| ANDAM M, m           | (M) . (acc) $\rightarrow$ (M)                | 1             | Z                  | 10 0100 1MMM MMMM |
| ANDAM M, a           | (M) . (acc) $\rightarrow$ (acc)              | 1             | Z                  | 10 0100 0MMM MMMM |
| ANDLA I              | Literal . (acc) $\rightarrow$ (acc)          | 1             | Z                  | 11 1001           |
| BCM M, b0            | Clear bit0 of (M)                            | 1             | None               | 00 1100 0MMM MMMM |
| BCM M, b1            | Clear bit1 of (M)                            | 1             | None               | 00 1100 1MMM MMMM |
| BCM M, b2            | Clear bit2 of (M)                            | 1             | None               | 00 1101 0MMM MMMM |
| BCM M, b3            | Clear bit3 of (M)                            | 1             | None               | 00 1101 1MMM MMMM |
| BCM M, b4            | Clear bit4 of (M)                            | 1             | None               | 00 1110 0MMM MMMM |
| BCM M, b5            | Clear bit5 of (M)                            | 1             | None               | 00 1110 1MMM MMMM |
| BCM M, b6            | Clear bit6 of (M)                            | 1             | None               | 00 1111 0MMM MMMM |
| BCM M, b7            | Clear bit7 of (M)                            | 1             | None               | 00 1111 1MMM MMMM |
| BSM M, b0            | Set bit0 of (M)                              | 1             | None               | 00 1000 0MMM MMMM |
| BSM M, b1            | Set bit1 of (M)                              | 1             | None               | 00 1000 1MMM MMMM |
| BSM M, b2            | Set bit2 of (M)                              | 1             | None               | 00 1001 0MMM MMMM |
| BSM M, b3            | Set bit3 of (M)                              | 1             | None               | 00 1001 1MMM MMMM |
| BSM M, b4            | Set bit4 of (M)                              | 1             | None               | 00 1010 0MMM MMMM |
| BSM M, b5            | Set bit5 of (M)                              | 1             | None               | 00 1010 1MMM MMMM |
| BSM M, b6            | Set bit6 of (M)                              | 1             | None               | 00 1011 0MMM MMMM |
| BSM M, b7            | Set bit7 of (M)                              | 1             | None               | 00 1011 1MMM MMMM |
| BTMSC M, b0          | If bit0 of (M) = 0, skip<br>next instruction | 1 +<br>(skip) | None               | 00 0100 0MMM MMMM |
| BTMSC M, b1          | If bit1 of (M) = 0, skip<br>next instruction | 1 +<br>(skip) | None               | 00 0100 1MMM MMMM |
| BTMSC M, b2          | If bit2 of (M) = 0, skip<br>next instruction | 1 +<br>(skip) | None               | 00 0101 0MMM MMMM |
| BTMSC M, b3          | If bit3 of (M) = 0, skip<br>next instruction | 1 +<br>(skip) | None               | 00 0101 1MMM MMMM |
| BTMSC M, b4          | If bit4 of (M) = 0, skip<br>next instruction | 1 +<br>(skip) | None               | 00 0110 0MMM MMMM |



#### 十速科技股份有限公司 tenx technology inc.

# **TM58PE10**

|             | 1                                                  |               |                                   | . <u> </u>        |
|-------------|----------------------------------------------------|---------------|-----------------------------------|-------------------|
| BTMSC M, b5 | If bit5 of (M) = 0, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0110 1MMM MMMM |
| BTMSC M, b6 | If bit6 of (M) = 0, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0111 0MMM MMMM |
| BTMSC M, b7 | If bit7 of (M) = 0, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0111 1MMM MMMM |
| BTMSS M, b0 | If bit0 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0000 0MMM MMMM |
| BTMSS M, b1 | If bit1 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0000 1MMM MMMM |
| BTMSS M, b2 | If bit2 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0001 0MMM MMMM |
| BTMSS M, b3 | If bit3 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0001 1MMM MMMM |
| BTMSS M, b4 | If bit4 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0010 0MMM MMMM |
| BTMSS M, b5 | If bit5 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0010 1MMM MMMM |
| BTMSS M, b6 | If bit6 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0011 0MMM MMMM |
| BTMSS M, b7 | If bit7 of (M) = 1, skip<br>next instruction       | 1 +<br>(skip) | None                              | 00 0011 1MMM MMMM |
| CALL I      | Call subroutine                                    | 2             | None                              | 11 0110           |
| CLRA        | Clear accumulator                                  | 1             | Z                                 | 10 0001 0000 0000 |
| CLRM M      | Clear memory M                                     | 1             | Z                                 | 10 0001 1MMM MMMM |
| CLRWDT      | Clear watch-dog<br>register                        | 1             | $\overline{TO}$ , $\overline{PD}$ | 10 0000 0000 0001 |
| COMM M, m   | $\sim$ (M) $\rightarrow$ (M)                       | 1             | Z                                 | 10 0010 1MMM MMMM |
| COMM M, a   | $\sim$ (M) → (acc)                                 | 1             | Z                                 | 10 0010 0MMM MMMM |
| DECM M, m   | Decrement M to M                                   | 1             | Z                                 | 10 0110 1MMM MMMM |
| DECM M, a   | (M) - 1 $\rightarrow$ (acc)                        | 1             | Z                                 | 10 0110 0MMM MMMM |
| DECMSZ M, m | $(M) - 1 \rightarrow (M), \text{ skip if} (M) = 0$ | 1 +<br>(skip) | None                              | 10 0111 1MMM MMMM |
| DECMSZ M, a | (M) - 1 $\rightarrow$ (acc), skip if<br>(M) = 0    | 1 +<br>(skip) | None                              | 10 0111 0MMM MMMM |
| GOTO I      | Goto branch                                        | 2             | None                              | 11 101            |
| INCM M, m   | $(M) + 1 \to (M)$                                  | 1             | Z                                 | 10 1000 1MMM MMMM |
| INCM M, a   | $(M) + 1 \rightarrow (acc)$                        | 1             | Z                                 | 10 1000 0MMM MMMM |
| INCMSZ M, m | (M) + 1 $\rightarrow$ (M), skip if                 | 1+            | None                              | 10 1001 1MMM MMMM |



#### 十速科技股份有限公司 tenx technology inc.

# **TM58PE10**

|             | (M) = 0                                                         | (skip)        |                                   |                   |
|-------------|-----------------------------------------------------------------|---------------|-----------------------------------|-------------------|
| INCMSZ M, a | $(M) + 1 \rightarrow (acc)$ , skip if<br>(M) = 0                | 1 +<br>(skip) | None                              | 10 1001 0MMM MMMM |
| IODIR M     | Set i/o direction                                               | 1             | None                              | 10 0000 0000 0MMM |
| IORAM M, m  | (M) ior (acc) $\rightarrow$ (M)                                 | 1             | Z                                 | 10 1111 1MMM MMMM |
| IORAM M, a  | (M) ior (acc) $\rightarrow$ (acc)                               | 1             | Z                                 | 10 1111 0MMM MMMM |
| IORLA I     | Literal ior (acc) $\rightarrow$ (acc)                           | 1             | Z                                 | 11 0011           |
| LCALL I     | Call subroutine.<br>However, LCALL can<br>addressing 1K address | 2             | None                              | 010               |
| LGOTO I     | Go branch to any<br>address                                     | 2             | None                              | 011111 1111 1111  |
| MOVAM m     | Move data form acc to<br>memory                                 | 1             | None                              | 10 0000 1MMM MMMM |
| MOVLA I     | Move literal to<br>accumulator                                  | 1             | None                              | 11 0001           |
| MOVM M, m   | $(M) \to (M)$                                                   | 1             | Z                                 | 10 0011 1MMM MMMM |
| MOVM M, a   | $(M) \rightarrow (acc)$                                         | 1             | Z                                 | 10 0011 0MMM MMMM |
| NOP         | No operation                                                    | 1             | None                              | 10 0000 0000 0000 |
| RET         | Return                                                          | 2             | None                              | 11 1111 0111 1111 |
| RETI        | Return and enable<br>INTM                                       | 2             | None                              | 11 1111 1111 1111 |
| RETLA I     | Return and move literal to accumulator                          | 2             | None                              | 11 1100           |
| RLM M, m    | Rotate left from m to<br>itself                                 | 1             | С                                 | 10 1100 1MMM MMMM |
| RLM M, a    | Rotate left from m to<br>acc                                    | 1             | С                                 | 10 1100 0MMM MMMM |
| RRM M, m    | Rotate right from m to<br>itself                                | 1             | С                                 | 10 1110 1MMM MMMM |
| RRM M, a    | Rotate right from m to acc                                      | 1             | С                                 | 10 1110 0MMM MMMM |
| SELECT      | Set select register                                             | 1             | None                              | 10 0000 0000 0010 |
| SLEEP       | Enter sleep (saving)<br>mode                                    | 1             | $\overline{TO}$ , $\overline{PD}$ | 10 0000 0000 0011 |
| SUBAM M, m  | $(M)\text{-}(acc) \to (M)$                                      | 1             | C, DC, Z                          | 10 1010 1MMM MMMM |
| SUBAM M, a  | (M) –(acc) $\rightarrow$ (acc)                                  | 1             | C, DC, Z                          | 10 1010 0MMM MMMM |



| SWAPM M, m | Swap data from m to<br>itself         | 1 | None | 10 1101 1MMM MMMM |
|------------|---------------------------------------|---|------|-------------------|
| SWAPM M, a | Swap data from m to acc               | 1 | None | 10 1101 0MMM MMMM |
| XORAM M, m | (M) xor (acc) $\rightarrow$ (M)       | 1 | Z    | 10 1011 1MMM MMMM |
| XORAM M, a | (M) xor (acc) $\rightarrow$ (acc)     | 1 | Z    | 10 1011 0MMM MMMM |
| XORLA I    | Literal xor (acc) $\rightarrow$ (acc) | 1 | Z    | 11 1000           |



### 9. Electrical Characteristics

#### 9.1 Absolute Maximum Ratings

| Supply Voltage Vss-0.3V to Vss+5.5V | Storge Temperature –50  | to 125 |
|-------------------------------------|-------------------------|--------|
| Input Voltage Vss-0.3V to VDD+0.3V  | Operating Temperature 0 | to 70  |

#### 9.2 DC Characteristics

| Symbol            | Parameter                        |                                                            | Test Conditions                                              | Min                | Min. Typ. |                             | Unit |   |  |    |
|-------------------|----------------------------------|------------------------------------------------------------|--------------------------------------------------------------|--------------------|-----------|-----------------------------|------|---|--|----|
| Symbol            | Farameter                        | VDD                                                        | Conditions                                                   | IVIII I.           | тур.      | Max.                        | Unit |   |  |    |
| VDD               | Operating Voltage                |                                                            |                                                              | 2.2                |           | 5.5                         | V    |   |  |    |
| V <sub>DVT</sub>  | 5V                               | Low Voltage Detector<br>(Idd = 3uA)<br>Config bit6.bit5=00 |                                                              | 4                  |           | V                           |      |   |  |    |
|                   | Detect Voltage                   | 3V                                                         | Low Voltage Detector<br>(Idd = 1.5uA)<br>Config bit6.bit5=10 |                    | 2.3       |                             | V    |   |  |    |
| V <sub>IH</sub>   | Input High Voltage               | 5V                                                         | I/O Port                                                     | 2                  |           | VDD                         | V    |   |  |    |
| V <sub>IL</sub>   | Input Low Voltage                | 5V                                                         | I/O Port                                                     |                    |           | 0.8                         | V    |   |  |    |
| I <sub>DD1</sub>  | I <sub>DD1</sub> Standby Current |                                                            | L Standby Current                                            | La Standby Current | 5V        | LVD disable, WDT<br>disable |      | 1 |  | uA |
| וטטי              |                                  | 50                                                         | LVD disable, WDT<br>enable                                   |                    | 10        |                             | uA   |   |  |    |
| $I_{IL}$          | Input Leakage<br>Current         | 5V                                                         | Vin=VDD, VSS                                                 |                    | 1         |                             | uA   |   |  |    |
|                   |                                  |                                                            |                                                              | Voh=4.5V           |           | 9                           |      |   |  |    |
|                   | I/O Port Driving                 |                                                            | Voh=4V                                                       |                    | 17        |                             |      |   |  |    |
| I <sub>OH</sub>   | Current                          |                                                            | Voh=3.5V                                                     |                    | 23        |                             | mA   |   |  |    |
|                   |                                  | 3V                                                         | Voh=2.5V                                                     |                    | 6.5       |                             |      |   |  |    |
|                   |                                  |                                                            | Voh=2V                                                       |                    | 10        |                             |      |   |  |    |
|                   |                                  |                                                            | Vol=0.5V                                                     |                    | 20        |                             |      |   |  |    |
|                   |                                  |                                                            | Vol=01V                                                      |                    | 35        |                             |      |   |  |    |
| I <sub>OL</sub>   | I/O Port Sink                    |                                                            | Vol=1.5V                                                     |                    | 50        |                             | mA   |   |  |    |
|                   | Current                          |                                                            | Vol=0.5V                                                     |                    | 10        |                             |      |   |  |    |
|                   |                                  | 3V                                                         | Vol=01V                                                      | Vol=01V 20         |           |                             |      |   |  |    |
|                   |                                  |                                                            | Vol=1.5V                                                     |                    | 25        |                             |      |   |  |    |
|                   | Pull_Hi Pin                      | 5V                                                         | Set PortB input pin and<br>Pull_Hi                           |                    | 60        |                             |      |   |  |    |
| R <sub>PUHI</sub> | Resister                         | 3V                                                         | Set PortB input pin and<br>Pull_Hi                           |                    | 150       |                             | KΩ   |   |  |    |



#### 9.3 AC Characteristics

|                   |            |     | st Conditions   |     |      |     |        |
|-------------------|------------|-----|-----------------|-----|------|-----|--------|
| Symbol            | Parameter  | VDD | Conditions      | Min | Тур. | Max | Unit   |
|                   | System     | 5V  | LP              | 32  |      | 200 |        |
| f <sub>sys1</sub> | Clock      | 3V  | Crystal mode    | 32  |      | 200 | Khz    |
| f                 | System     | 5V  | NT              | 0.2 |      | 10  | Mhz    |
| f <sub>sys2</sub> | Clock      | 3V  | Crystal mode    | 0.2 |      | 10  | IVITIZ |
| f                 | System     | 5V  | HS              | 10  |      | 20  | Mhz    |
| f <sub>sys3</sub> | Clock      | 3V  | Crystal mode    |     |      |     | IVITIZ |
| f                 | System     | 5V  | RC mode         |     |      | 10  | Mhz    |
| f <sub>sys4</sub> | Clock      | 3V  | RC mode         |     |      | 10  | IVITIZ |
|                   | Watchdog   | 5V  | (Default value) |     | 16   |     | mS     |
| T <sub>wdt</sub>  | Timer      | 3V  | (Default value) |     | 20   |     | 1115   |
| <b>–</b>          | Reset Hold | 5V  | (Defeult velue) |     | 16   |     |        |
| T <sub>rht</sub>  | Time       | 3V  | (Default value) |     | 20   |     | mS     |

### 9.4 Packaging Diagrams and Description

#### 9.4.1 Part number Guide





#### 9.4.2 Package mode

#### (1) 18Pin DIP (300 mil)



#### (2) 18Pin SOP (300 mil)



| Symbol    | MIN   | MAX   |  |
|-----------|-------|-------|--|
| A         | 0.093 | 0.104 |  |
| A1        | 0.004 | 0.012 |  |
| D         | 0.447 | 0.463 |  |
| Е         | 0.291 | 0.299 |  |
| н         | 0.394 | 0.419 |  |
| L         | 0.016 | 0.050 |  |
| <b>0°</b> | 0     | 8     |  |
| UNIT:INCH |       |       |  |

IJEDEC OUTLINEMS-013 AB 2DIMENSIONS"D" DOES NOT INCLUDE MOLD FLASH PROTRUSIONS OR GATE BURRMOLD FLASHPROTRUSIONS AND GATE BURRS SHALL NOT EXCEED5mm(.006in)

AND GATE BORKS SHALL NOT EACEELEMM(A00In) PER SIDE 3DIMENSIONS"E" DOES NOT INCLUDE INTERLEAD FLASH OR PROTRUSIONSINTERLEAD FLASH AND PROTRUSIONS SHALL NOT EXCEEL25mm(.010in) PER SIDE



#### (3) 14Pin DIP (300 mil)



| SYMBOLS | MIN   | NOR      | MAX   |
|---------|-------|----------|-------|
| Α       | _     | —        | 0.210 |
| A1      | 0.015 | —        | —     |
| A2      | 0.125 | 0.130    | 0.135 |
| D       | 0.735 | 0.750    | 0.775 |
| E       |       | .300 BSC |       |
| E1      | 0.245 | 0.250    | 0.255 |
| L       | 0.115 | 0.130    | 0.150 |
| eB      | 0.335 | 0.355    | 0.375 |
| θ°      | 0     | 7        | 15    |

UNIT : INCH

NOTES 1 JEDEC OUTLINEMS-001 AA

3.eB IS MEASURED AT THE LEAD TIPS WITH THE LEADS UNCONSTRAINED 4.POINTED OR ROUNDED LEAD TIPS ARE PREFERRED TO EASE INSERTION 5.DISTANCE BETWEEN LEADS INCLUDING DAM BAR PROTRUSIONS TO BE.005 INCH MINNUM 6.DATUM PLANE H COINCIDENT WITH THE BOTTON OF LEADWHERE LEAD EXITS BODY.

#### (4) 14Pin SOP (150 mil)





DETAIL A



\$748015



NOTE :

- ì
- CONTROLLING DIMENSION ; MOH CONTROLLING DIMENSION ; MOH CONTROLLING DIMENSION ; COPPER 194 DIMENSION TO TOCIS NOT POLILIDE MOUD TASH, TE DIM BLINES AND GATE BLINES SMULT RANK TO TOCIS NOT MOLILIDE MURRIES SMULT NOT DIGED DIADETOLIDE DIADETOLIDE GRANT DIADETOLIDE MURRIES SMULT NOT DIGED DIADETOLIDE DIADETOLIDE GRANT DIADETOLIDE DIADETOLIDE DIADETOLIDE SMULT NOT DIGED NOT MUCLINE DIADETOLIDE SMULT DIADETOLIDE DIADETOLIDE DIADETOLIDE SMULT DIADETOLIDE DIADETOLIDE DIADETOLIDE CONSTRUCT DE LIDUTE DIADETOLIDE DIADETOLIDE CONSTRUCT DE LIDUTED DIA DE LIDUTE ROLLIDE ON THE CONSTRUCT DE LIDUTED DIA DE LIDUTE ROLLIDE ON THE COLUMINES SANCE BENERAL PROFILIZION AND MI ADADETOLIDE DIA DE GALOSTINITI LALISSI CITIENTE SPECIFIED
- а.
- SPECIFIC DIMENSION FOLLOW ACCEPTIME.E SPEC. 7. REFERENCE DOCUMENT : JEDEC SPEC MS-012

0.058 14 1.50 A 0.063 0.005 ٨1 0.10 0.35 0,004 1,45 0.067 A2 0.33 0.51 6.070 0.013 ь 0.41 0.015 0.19 0.25 0.70 0.0275 0.008 0.0008 8,53 8.84 8.74 0.336 0.340 0.344 5,99 \$29 0,228 0.235 0.244 3,61 3,91 3.99 0.187 0,150 0.154 1.21 0.060 0.38 0.71 1.27 0.050 0.015 0.408 6.003 F 0.075 ō è £

MAK

DIKENSIONS IN INCHES

HO4

400

MN

SOP-14PIN-150MIL

DINDERNS IN MULMETERS

NON

**NN** 



#### (5) 20 Pin SSOP (209 mil)

