



# **EM6607**

# Ultra-low power microcontroller with 4 high drive outputs

#### **Features**

- □ Low Power typical 1.8µA active mode typical 0.5µA standby mode
  - typical 0.1µA sleep mode
  - @ 1.5V, 32kHz, 25 °C
- ☐ Low Voltage 1.2 to 3.3 V
- ☐ ROM 2k × 16 (Mask Programmed)
- □ RAM 96 × 4 (User Read/Write)
- 2 clocks per instruction cycleRISC architecture
- 5 software configurable 4-bit ports
- ☐ 1 High drive output port
- ☐ Up to 20 inputs (5 ports)
- ☐ Up to 16 outputs (4 ports)
- □ buzzer three tone
- ☐ Serial Write buffer SWB
- □ Supply Voltage level detection (SVLD).
- ☐ Analogue and timer watchdog
- 8 bit timer / event counter
- Internal interrupt sources (timer, event counter, prescaler)
- External interrupt sources (portA + portC)

# Description

The EM6607 is a single chip low power, mask programmed CMOS 4-bit microcontroller. It contains ROM, RAM, watchdog timer, oscillation detection circuit, combined timer / event counter, prescaler, voltage level detector and a number of clock functions. Its low voltage and low power operation make it the most suitable controller for battery, stand alone and mobile equipment. The EM6607 microcontroller is manufactured using EM's Advanced Low Power CMOS Process.

In 24 Pin package it is direct replacement for EM6603.

# **Typical Applications**

- sensor interfaces
- domestic appliances
- ☐ clocks
- security systems
- bicycle computers
- automotive controls
- TV & audio remote controls
- measurement equipment
- ☐ R/F and IR. control
- motor driving

Figure 1. Architecture



Figure 2. Pin Configuration

1



A COMPANY OF THE SWATCH GROUP





# EM6607 at a glance

#### □ Power Supply

- Low Voltage, low power architecture including internal voltage regulator
- 1.2V ... 3.3 V battery voltage
- 1.8µA in active mode
- $0.5\mu A$  in standby mode
- 0.1μA in sleep mode @ 1.5V, 32kHz, 25 °C
- 32 kHz Oscillator or external clock

#### □ RAM

- 96 x 4 bit, direct addressable

#### □ ROM

- 2048 x 16 bit metal mask programmable

#### □ CPU

- 4 bit RISC architecture
- 2 clock cycles per instruction
- 72 basic instructions

#### ■ Main Operating Modes and Resets

- Active mode (CPU is running)

- Standby mode (CPU in Halt)

- Sleep mode (No clock, Reset State)

- Initial reset on Power-On (POR)
- External reset pin
- Watchdog timer (time-out) reset
- Oscillation detection watchdog reset
- Reset with input combination on PortA

#### □ 4-Bit Input PortA

- Direct input read
- Debounced or direct input selectable (reg.)
- Interrupt request on input's rising or falling edge, selectable by register.
- Pull-down or Pull-up selectable by metal mask
- Software test variables for conditional jumps
- PA3 input for the event counter
- Reset with input combination on PortA (metal option)

#### □ 4-Bit Input/Output PortB

- Separate input or output selection by register
- Pull-up, Pull-down or none, selectable by metal mask if used as Input
- Buzzer output on PB0 (24-pin) / PE0 (28-pin)

# □ 4-Bit Input/Output PortC

- Input or Output port as a whole port
- Debounced or direct input selectable (reg.)
- Interrupt request on input's rising or falling edge, selectable by register.
- Pull-up, pull-down or none, selectable by metal mask if used as input
- CMOS or N-channel open drain mode

#### □ 4-Bit Input/Output PortD

- Input or Output port as a whole port
- Pull-up, Pull-down or none, selectable by metal mask if used as Input
- CMOS or N-channel open drain mode
- Serial Write Buffer clock and data output

#### □ 4-Bit Input/Output PortE

- Separate input or output selection by register
- Pull-up, Pull-down or none, selectable by metal mask if used as Input

#### □ Serial (output) Write Buffer

- max. 256 bits long clocked with 16/8/2/1kHz
- automatic send mode
- interactive send mode : interrupt request when buffer is empty

#### □ Buzzer Output

- if used output on PB0 (24 pin) or PE0 (28 pin)
- 3 tone buzzer 1kHz, 2kHz, 2.66kHz/4kHz (TBC)

#### □ Prescaler

- 32kHz output possible on the STB/RST pin
- 15 stage system clock divider down to 1 Hz
- 3 interrupt requests: 1Hz/8Hz/32Hz
- Prescaler reset (from 8kHz to 1Hz)

#### □ 8-bit Timer / Event Counter

- 8-bit auto-reload count-down timer
- 6 different clocks from prescaler
- or event counter from the PA3 input
- parallel load
- interrupt request when comes to 00 hex.

#### □ Supply Voltage Level Detector

- 3 software selectable levels (1.3V, 2.0V,
- 2.3V or user defined between 1.3V and 3.0V)
- Busy flag during measure
- Active only on request during measurement to reduce power consumption

#### □ Interrupt Controller

- 9 external interrupt sources: 4 from PortA, 4 from PortC.
- 3 internal interrupt sources, prescaler, timer and Serial Write Buffer
- Each interrupt request is individually selectable
- Interrupt request flag is cleared automatically on register read



# **EM6607**

| Tak             | ole of Contents                                                                                                         |                 |                   |       | CILLATOR                                                                                   | 43              |
|-----------------|-------------------------------------------------------------------------------------------------------------------------|-----------------|-------------------|-------|--------------------------------------------------------------------------------------------|-----------------|
| 1               | PIN DESCRIPTION FOR EM6607                                                                                              | 5               |                   |       | JT TIMING CHARACTERISTICS                                                                  | 43              |
| 2               | OPERATING MODES                                                                                                         | 7               | 19                |       | D LOCATION DIAGRAM                                                                         | 44              |
|                 | ACTIVE MODE                                                                                                             | 7               | 20                |       | CKAGE DIMENSIONS                                                                           | 45              |
| 2.2             | STANDBY MODE<br>SLEEP MODE                                                                                              | 7<br>7          | <b>21</b><br>21.1 |       | <b>DERING INFORMATION</b><br>CKAGE MARKING                                                 | <b>47</b><br>47 |
| 3               | POWER SUPPLY                                                                                                            | 8               | 21.2              | Cus   | STOMER MARKING                                                                             | 47              |
| 4               | RESET                                                                                                                   | 9               |                   |       |                                                                                            |                 |
| 4.1             | OSCILLATION DETECTION CIRCUIT                                                                                           | 9               | Tab               | ام ما | f Figures                                                                                  |                 |
| 4.2<br>4.3      | RESET PIN INPUT PORT (PA0PA3) RESET                                                                                     | 9<br>10         |                   |       | Architecture                                                                               | 1               |
| 4.4             | WATCHDOG TIMER RESET                                                                                                    | 10              | Figur             | e 2.  | Pin Configuration                                                                          | 1               |
| 4.5             | SOFTWARE POWER-ON-RESET                                                                                                 | 10              |                   |       | Typical Configuration: V <sub>DD</sub> 1.4V up to 3.3V                                     | 6<br>6          |
| 4.6             | CPU STATE AFTER RESET                                                                                                   | 11              | Figur             |       | Typical Configuration: V <sub>DD</sub> 1.2V up to 1.8V<br>Mode Transition Diagram          | 7               |
| 4.7             | POR with Power-Check Reset                                                                                              | 11              | Figur             | e 6.  | System reset generation                                                                    | 9               |
| 5               | OSCILLATOR                                                                                                              | 12              |                   |       | Port A<br>Port B                                                                           | 14<br>15        |
| 5.1             | Prescaler                                                                                                               | 12              |                   |       | Port C                                                                                     | 17              |
| 6               | WATCHDOG TIMER                                                                                                          | 12              |                   |       | Port D                                                                                     | 18              |
| 7               | INDUT AND OUTDUT DODTS                                                                                                  | 40              |                   |       | Port E<br>Timer / Event Counter                                                            | 19<br>21        |
| <b>7</b><br>71  | INPUT AND OUTPUT PORTS PORTA                                                                                            | <b>13</b><br>13 | Figur             | e 13. | Interrupt Request generation                                                               | 24              |
|                 | 1.1 PortA registers                                                                                                     | 14              | Figur             | e 14. | Serial write buffer                                                                        | 27              |
|                 | PortB                                                                                                                   | 15              |                   |       | Automatic Serial Write Buffer transmission<br>Interactive Serial Write Buffer transmission | 28<br>29        |
|                 | 2.1 PortB registers                                                                                                     | 15              |                   |       | Dimensions of SOP24 Package SOIC                                                           | 45              |
|                 | PORTC<br>3.1 PortC registers                                                                                            | 16<br>16        | Figur             | e 18. | Dimensions of TSSOP24 Package                                                              | 45              |
|                 | PortD                                                                                                                   | 18              | Figur             | e 19. | Dimensions of SOP28 Package SOIC Dimensions of TSSOP28 Package                             | 46<br>46        |
|                 | 4.1 PortD registers                                                                                                     | 18              | i igui            | C 20. | Difficilisions of 10001 201 ackage                                                         |                 |
|                 | PORTE                                                                                                                   | 19<br>19        |                   |       |                                                                                            |                 |
|                 | 5.1 PortE registers                                                                                                     |                 |                   |       |                                                                                            |                 |
| <b>8</b><br>8.1 | BUZZER BUZZER REGISTER                                                                                                  | <b>20</b><br>20 |                   |       |                                                                                            |                 |
| 9               | TIMER/EVENT COUNTER                                                                                                     | 21              |                   |       |                                                                                            |                 |
| 9.1             | TIMER/COUNTER REGISTERS                                                                                                 | 22              |                   |       |                                                                                            |                 |
| 10              | INTERRUPT CONTROLLER                                                                                                    | 23              |                   |       |                                                                                            |                 |
|                 | INTERRUPT CONTROL REGISTERS                                                                                             | 23              |                   |       |                                                                                            |                 |
| 11              | SUPPLY VOLTAGE LEVEL DETECTOR (SVLD)                                                                                    | 25              |                   |       |                                                                                            |                 |
| 12              | SERIAL WRITE BUFFER – SWB                                                                                               | 26              |                   |       |                                                                                            |                 |
|                 | SWB AUTOMATIC SEND MODE                                                                                                 | 28              |                   |       |                                                                                            |                 |
| 12.2            | SWB INTERACTIVE SEND MODE                                                                                               | 29              |                   |       |                                                                                            |                 |
| 13              | STROBE / RESET OUTPUT                                                                                                   | 30              |                   |       |                                                                                            |                 |
| 14              | TEST AT EM - ACTIVE SUPPLY CURRENT TES                                                                                  | ST30            |                   |       |                                                                                            |                 |
| 15              | METAL MASK OPTIONS                                                                                                      | 31              |                   |       |                                                                                            |                 |
|                 | .1.1 Power-Check Level Option                                                                                           | 32              |                   |       |                                                                                            |                 |
|                 | <ul><li>1.1.2 PortA reset Option, see paragraph 3.3</li><li>1.1.3 SVLD levels Option, see paragraph 10.0 SVLD</li></ul> | 32<br>32        |                   |       |                                                                                            |                 |
| 16              | PERIPHERAL MEMORY MAP                                                                                                   | 33              |                   |       |                                                                                            |                 |
| 17              | TEMPERATURE AND VOLTAGE BEHAVIOURS                                                                                      | 36              |                   |       |                                                                                            |                 |
|                 | IDD CURRENT (TYPICAL)                                                                                                   | 36              |                   |       |                                                                                            |                 |
|                 | PULL-DOWN RESISTANCE (TYPICAL)                                                                                          | 37              |                   |       |                                                                                            |                 |
| 17.3            | OUTPUT CURRENTS (TYPICAL)                                                                                               | 38              |                   |       |                                                                                            |                 |
| 18              | ELECTRICAL SPECIFICATIONS                                                                                               | 40              |                   |       |                                                                                            |                 |
|                 | ABSOLUTE MAXIMUM RATINGS STANDARD OPERATING CONDITIONS                                                                  | 40<br>40        |                   |       |                                                                                            |                 |
|                 | HANDLING PROCEDURES                                                                                                     | 40<br>40        |                   |       |                                                                                            |                 |
|                 | DC CHARACTERISTICS - POWER SUPPLY PINS                                                                                  | 40              |                   |       |                                                                                            |                 |
|                 | DC CHARACTERISTICS - INPUT/OUTPUT PINS                                                                                  | 42              |                   |       |                                                                                            |                 |
| 18 6            | DC CHARACTERISTICS - SUPPLY VOLTAGE DETECTOR                                                                            |                 |                   |       |                                                                                            |                 |

LEVELS

43





# **Table of Tables**

| Table 1.  | IntRq register                                         | 7   |
|-----------|--------------------------------------------------------|-----|
| Table 2.  | Watchdog register - WD                                 | 8   |
| Table 3.  | Internal state in Active, Stand-by and Sleep mode      | 8   |
| Table 4.  | PortA Inputs RESET options (metal Hardware option)     | 10  |
| Table 5.  | Watchdog-Timer Option (software option)                | 10  |
| Table 6.  | Software Power-On-Reset                                | 10  |
| Table 7.  | Initial Value after RESET                              | 11  |
| Table 8.  | Prescaler interrupts source                            | 12  |
| Table 9.  | Prescaler control register - PRESC                     | 12  |
| Table 10. | Watchdog register - WD                                 | 12  |
| Table 11. | Input / Output Ports Overview                          | 13  |
| Table 12. | Option register - Option                               | 13  |
| Table 13. | PortA input status register - PortA                    | 14  |
| Table 14. | PortA Interrupt request register - IRQpA               | 14  |
| Table 15. | PortA interrupt mask register - MportA                 | 14  |
| Table 16. | PortB input/output status register - PortB             | 15  |
| Table 17. | PortB Input/Output control register - CIOportB         | 15  |
| Table 18. | Ports A&C Interrupt                                    | 16  |
| Table 19. | PortC input/output register - PortC                    | 16  |
| Table 20. | PortC Interrupt request register - IRQpC               | 16  |
| Table 21. | PortC interrupt mask register - MportC                 | 16  |
| Table 22. | Option2 register - Option2                             | 17  |
| Table 23. | PortD Input/Output register - PortD                    | 18  |
| Table 24. | Ports control register - CPIOB                         | 18  |
| Table 25. | PortE Input/Output status register - PortE             | 19  |
| Table 26. | PortE Input/Output control register - CIOPortE         | 19  |
| Table 27. | Buzzer control register - BEEP                         | 20  |
| Table 28. | Buzzer output pad allocation                           | 20  |
| Table 29. | PB0 & PE0 function used with BUen and BuzzerPE0        |     |
|           | control bits                                           | 20  |
| Table 30. | Timer Clock Selection                                  | 22  |
| Table 31. | Timer control register - TimCtr                        | 22  |
| Table 32. | LOW Timer Load/Status register - LTimLS (4 low bits    |     |
| Table 33. | HIGH Timer Load/Status register - HTimLS (4 high bi 22 | ts) |
| Table 34. | PA3 counter input selection register - PA3cnt          | 22  |
| Table 35. | PA3 counter input selection                            | 22  |
| Table 36. | Main Interrupt request register - IntRq (Read Only)*   | 23  |
| Table 37. | Register - CIRQD                                       | 24  |
| Table 38. | SVLD Level selection                                   | 25  |
| Table 39. | SVLD control register - SVLD                           | 25  |
| Table 40. | SWB clock selection                                    | 26  |
| Table 41. | SWB clock selection register - ClkSWB                  | 26  |
| Table 42. | PortD status                                           | 26  |
| Table 43. | SWB buffer register - SWbuff                           | 27  |
| Table 44. | SWB Low size register - LowSWB                         | 27  |
| Table 45. | SWB High size register – HighSWB                       | 27  |
| Table 46. | input/output Ports                                     | 31  |
| Table 47. | PortB Hi Current Drive capability                      | 31  |



# 1 Pin Description for EM6607

| Pin Nb | Pin Nb | Pin Name                | Function                       | Remarks                                           |
|--------|--------|-------------------------|--------------------------------|---------------------------------------------------|
| 24 pin | 28 pin |                         |                                |                                                   |
| 1      | 1      | port A, 0               | input 0 port A                 | interrupt request; tvar 1                         |
| 2      | 2      | port A, 1               | input 1 port A                 | interrupt request; tvar 2                         |
| 3      | 3      | port A, 2               | input 2 port A                 | interrupt request; tvar 3                         |
| 4      | 4      | port A, 3               | input 3 port A                 | interrupt request; event counter input            |
| -      | 5      | port E, 0               | input / output 0 port E        | buzzer output in 28 pin package                   |
| 5      | 6      | port B, 0               | input / output 0 port B        | buzzer output in 24 pin package                   |
| 6      | 7      | port B, 1               | input / output 1 port B        |                                                   |
| 7      | 8      | port B, 2               | input / output 2 port B        |                                                   |
| 8      | 9      | port B, 3               | input / output 3 port B        |                                                   |
| -      | 10     | port E, 1               | input / output 1 port E        |                                                   |
| 9      | 11     | test                    | test input terminal            | for EM test purpose only (internal pull-down)     |
| 10     | 12     | Q <sub>out</sub> /osc 1 | crystal terminal 1             |                                                   |
| 11     | 13     | Q <sub>in</sub> /osc 2  | crystal terminal 2 (input)     | Can accept trimming capacitor tw. V <sub>SS</sub> |
| 12     | 14     | $V_{SS}$                | negative power supply terminal |                                                   |
| 13     | 15     | STB/RST                 | strobe / reset status          | μC reset state + port B, C, D write               |
| 14     | 16     | port C, 0               | input / output 0 port C        | interrupt request                                 |
| 15     | 17     | port C, 1               | input / output 1 port C        | interrupt request                                 |
| 16     | 18     | port C, 2               | input / output 2 port C        | interrupt request                                 |
| 17     | 19     | port C, 3               | input / output 3 port C        | interrupt request                                 |
| -      | 20     | port E, 2               | input / output 2 port E        |                                                   |
| 18     | 21     | port D, 0               | input / output 0 port D        | SWB Serial Clock Output                           |
| 19     | 22     | port D, 1               | input / output 1 port D        | SWB Serial Data Output                            |
| 20     | 23     | port D, 2               | input / output 2 port D        |                                                   |
| 21     | 24     | port D, 3               | input / output 3 port D        |                                                   |
| _      | 25     | port E, 3               | input / output 3 port E        |                                                   |
| 22     | 26     | RESET                   | reset terminal                 | Active high (internal pull-down)                  |
| 23     | 27     | $V_{REG}$               | internal voltage regulator     | Needs typ. 100nF capacitor tw. V <sub>SS</sub>    |
| 24     | 28     | $V_{DD}$                | positive power supply terminal |                                                   |

Table 1. Pin Description



Figure 3. Typical Configuration: V<sub>DD</sub> 1.4V up to 3.3V



Figure 4. Typical Configuration: V<sub>DD</sub> 1.2V up to 1.8V





#### 2 Operating modes

The EM6607 has two low power dissipation modes: STANDBY and SLEEP. Figure 5 is a transition diagram for these modes.

#### 2.1 Active Mode

The active mode is the actual CPU running mode. Instructions are read from the internal ROM and executed by the CPU. Leaving active mode via the halt instruction to go into standby mode, the **Sleep** bit write to go into Sleep mode or a reset from port A to go into reset mode.

#### 2.2 STANDBY Mode

Executing a HALT instruction puts the EM6607 into STANDBY mode. The voltage regulator, oscillator, Watchdog timer, interrupts and timer/event counter are operating. However, the CPU stops since the clock related to instruction execution stops. Registers, RAM, and I/O pins retain their states prior to STANDBY mode. A RESET or an Interrupt request cancel STANDBY mode.

#### 2.3 SLEEP MODE

Writing the SLEEP\* bit in the <a href="IntRq">IntRq</a>\* register puts the EM6607 in SLEEP mode. The oscillator stops and most functions of the EM6607 are inactive. To be able to write the SLEEP bit, the SLmask bit must be first set to 1 in register <a href="WD">WD</a>. In SLEEP mode only the voltage regulator and RESET input are active. The RAM data integrity is maintained. SLEEP mode may be cancelled only by a RESET at the terminal pin of the EM6607 or by the selected port A input reset combination. This combination is a metal option, see paragraph 15.1.2. The RESET port must be high for at least 10µsec.



Figure 5. Mode Transition Diagram

Due to the cold start characteristics of the oscillator, waking up from SLEEP mode may take some time to guarantee that the oscillator has started correctly. During this time the circuit is in RESET state and the strobe output STB/RST is high. Waking up from SLEEP mode clears the **SLEEP** flag but not the **SLmask** bit. By reading **SLmask** it can therefore determine if the EM6607 was powered up (**SLmask** = 0), or woken from SLEEP mode (**SLmask** = 1).

Table 1. IntRq register

| Bit | Name  | Reset | R/W | Description                     |
|-----|-------|-------|-----|---------------------------------|
| 3   | INTPR | 0     | R   | Prescaler interrupt request     |
| 2   | INTTE | 0     | R   | Timer/counter interrupt request |
| 1   | INTPC | 0     | R   | PortC Interrupt request         |
| 0   | INTPA | 0     | R   | PortA Interrupt request         |
| 2   | SLEEP | 0     | W*  | SLEEP mode flag                 |

<sup>\*</sup> Write bit 2 only if SLmask=1



Table 2. Watchdog register - WD

| Bit | Name   | Reset | R/W | Description          |
|-----|--------|-------|-----|----------------------|
| 3   | WDRST  | -     | R/W | Watchdog timer reset |
| 2   | Slmask | -     | R/W | SLEEP mask bit       |
| 1   | WD1    | 0     | R   | WD Timer data 1/4 Hz |
| 0   | WD0    | 0     | R   | WD Timer data 1/2 Hz |

Table 3 shows the status of different EM6607 blocks in these three main operating modes.

Table 3. Internal state in Active, Stand-by and Sleep mode

| Peripheral /// EM6607 mode      | ACTIVE mode                | STAND-BY mode              | SLEEP mode        |
|---------------------------------|----------------------------|----------------------------|-------------------|
| POR (static)                    | On                         | On                         | On                |
| Voltage regulator               | On                         | On                         | On (Low-Power)    |
| Quartz 32768 Hz oscillator      | On                         | On                         | Off               |
| Clocks (Prescaler & RC divider) | On                         | On                         | Off               |
| CPU                             | Running                    | In HALT – Stopped          | Stopped           |
| Peripheral register             | "On"                       | "On" retain value          | retain value      |
| RAM                             | "On"                       | retain value               | retain value      |
| Timer/Counter                   | "On"                       | "On" if activated before   | stopped           |
| Supply Voltage Level Det.=SVLD  | can be activated           | can not be activated       | Off               |
| PortA /C, Reset pad debounced   | Yes                        | Yes                        | No                |
| Interrupts / events             | Yes - possible             | Yes - possible             | No – not possible |
| Watch-Dog timer                 | On / Off (soft selectable) | On / Off (soft selectable) | No                |
| Analogue Watchdog (osc.detect)  | On/Off (soft select.)      | "On" if activated before   | Off               |

#### 3 Power Supply

The EM6607 is supplied by a single external power supply between  $V_{DD}$  and  $V_{SS}$ , the circuit reference being at  $V_{SS}$  (ground). A built-in voltage regulator generates  $V_{REG}$  providing regulated voltage for the oscillator and internal logic. Output drivers are supplied directly from the external supply  $V_{DD}$ . A typical connection configuration is shown in figure 4.

For  $V_{DD}$  less then 1.4V it is recommended that  $V_{DD}$  is connected directly to  $V_{REG}$  connected

For V<sub>DD</sub> >1.8V then the configuration shown in Figure 4 should be used.

<sup>\*</sup>registers are marked in bold and underlined like <u>IntRq</u>

<sup>\*</sup>Bits/Flags in registers are marked in bold only like SLEEP



#### 4 Reset

To initialize the EM6607, a system RESET must be executed. There are five methods of doing this:

- (1) Initial RESET from the oscillation detection circuit.
- (2) External RESET from the RESET PIN.
- (3) External RESET by simultaneous high input to terminals PA0..PA3. (Combinations defined by metal option)
- (4) Watchdog RESET (software option).
- (5) Software Power-On-Reset by writing **S0ftPOR** bit in **Option2** register to "1"

During any of these RESET's the STB/RST output pin is high.



Figure 6. System reset generation

#### 4.1 Oscillation detection circuit

At power on, the built-in voltage regulator starts to follow the supply voltage until  $V_{DD}$  becomes higher than  $V_{REG}$ . Since it is  $V_{REG}$  which supplies the oscillator and this needs time to stabilise, Power-On-Reset with the oscillation detection circuit therefore counts the first 32768 oscillator clocks after power-on and holds the system in RESET. The system will consequently remain in RESET for at least one second after power up.

After power up the Analogue Watchdog circuit monitors the oscillator. If it stops for any reason other then SLEEP mode, then a RESET is generated and the STB/RST pin is driven high.

#### 4.2 Reset Pin

During active or STANDBY mode the RESET terminal has a debouncer to reject noise and therefore must be active high for at least 2ms or 16ms (CLK = 32kHz) - software selectable by **DebCK** in **CIRQD** register. (See Table 37)

When cancelling sleep mode, the debouncer is not active (no clock), however, reset passes through an analogue filter with a time constant of typical. 5µs. In this case Reset pin must be high for at least 10 µs to generate a system reset.



#### 4.3 Input port (PA0..PA3) RESET

With a mask option it is possible to choose from eleven PortA reset combinations. The selected ports must be simultaneously high for at least 2ms/16ms (CLK = 32kHz) due to the presence of debouncers. Note also, that RESET with port A is not possible during SLEEP mode.

Below are the combinations of Port A (PA0..PA3) inputs, which can be used to generate a RESET. They can be selected by metal « **PortA RESET** » mask option, described in chapter 14.

Table 4. PortA Inputs RESET options (metal Hardware option)

|                                     | . ,       |
|-------------------------------------|-----------|
| Function                            | Opt. Code |
| NO inputs RESET                     | rstpa_no  |
| RESET = PA0 AND PA1                 | rstpa_3h  |
| RESET = PA0 AND PA2                 | rstpa_5h  |
| RESET = PA1 AND PA2                 | rstpa_6h  |
| RESET = PA0 AND PA1 AND PA2         | rstpa_7h  |
| RESET = PA0 AND PA3                 | rstpa_9h  |
| RESET = PA1 AND PA3                 | rstpa_ah  |
| RESET = PA0 AND PA1 AND PA3         | rstpa_bh  |
| RESET = PA2 AND PA3                 | rstpa_ch  |
| RESET = PA0 AND PA2 AND PA3         | rstpa_dh  |
| RESET = PA1 AND PA2 AND PA3         | rstpa_eh  |
| RESET = PA0 AND PA1 AND PA2 AND PA3 | rstpa_fh  |

#### 4.4 Watchdog Timer RESET

The Watchdog Timer RESET is a software option and if used it will generate a RESET if it is not cleared. See section 5. Watchdog timer for details.

 Table 5.
 Watchdog-Timer Option (software option)

| Watchdog Function               | NoWD bit in Option register |
|---------------------------------|-----------------------------|
| Without Watchdog Time-out reset | 1                           |
| With Watchdog Time-out reset    | 0                           |

#### 4.5 Software Power-On-Reset

This is software generation of POR, which can be used mainly to reset the circuit and start again the Power-Check function if enabled to be sure that  $V_{DD}$  supply is high enough when circuit will start to work again due to increased  $V_{DD}$ . When  $V_{DD}$  starts to decrease due to any reason and software by periodically testing the  $V_{DD}$  min by SVLD function detects this, user can generate POR at  $V_{DD}$  min and like that the circuit will go in Reset until Power-Check level is satisfied again to guarantee the proper circuit operation, not to fall in a grey zone below  $V_{DD}$  min until Static POR does it job at typ. 0.9V.

Table 6. Software Power-On-Reset

| Software POR function | SoftPOR in RegSoftPOR register |
|-----------------------|--------------------------------|
| Software POR start    | 1                              |
| No Software POR       | 0                              |



#### 4.6 CPU State after RESET

RESET initialises the CPU as shown in the table below.

Table 7. Initial Value after RESET

| name                 | bits | symbol | initial value                 |
|----------------------|------|--------|-------------------------------|
| Program counter 0    | 12   | PC0    | \$000 (as a result of Jump 0) |
| Program counter 1    | 12   | PC1    | undefined                     |
| Program counter 2    | 12   | PC2    | undefined                     |
| stack pointer        | 2    | SP     | SP(0) selected                |
| index register       | 7    | IX     | undefined                     |
| Carry flag           | 1    | CY     | undefined                     |
| Zero flag            | 1    | Z      | undefined                     |
| HALT                 | 1    | HALT   | 0                             |
| Instruction register | 16   | IR     | Jump 0                        |
| periphery registers  | 4    |        | see peripheral memory map     |

#### 4.7 POR with Power-Check Reset

POR and Power-Check are supervising the  $V_{REG}$  (digital) which follows more or less the  $V_{DD}$  supply voltage on start-up to guarantee proper operation after Power-On. The **resetcold** signal is released when the  $V_{DD}$  supply voltage is high enough for the IC to function correctly.

During power-up of the EM6607 static POR (Power-On-Reset) cell supervising the  $V_{REG}$  with level of typ. 0.9V is checked to give initial reset. Reset can be prolonged also with Power-Check function if enabled by metal option. In this case  $V_{DD}$  must come above  $V_{L1}$  of the SVLD described in Chapter 11 **Supply Voltage Level Detector (SVLD)** to release the circuit reset signal and starts to execute instructions.

When Power-Check is enabled a power-check logic is switched-on with POR signal high and starts to check periodically  $V_{DD}$  against the SVLD- $V_{L1}$  level which keeps **resetcold** active high until  $V_{DD} > V_{L1}$ . When used with external quartz first  $V_{DD}$  check starts in the middle of quartz Cold-Start sequence – after first 16384 system clocks with the same timing as in normal SVLD operation. If  $V_{DD} > V_{L1}$  Power-Check condition is met and system reset will wait until first 32768 clocks needed for Quartz Cold-Start is finished and release System reset.

In case  $V_{DD}$  <  $V_{L1}$ , comparison will be repeated with every next 8 Hz system clock until  $V_{DD}$  >  $V_{L1}$ . In case of a very slow rising  $V_{DD}$ , it might happen that Quartz Cold-Start is finished. System reset will keep the EM6607 under reset until first time  $V_{DD}$  becomes higher as  $V_{L1}$  to guarantee good operating conditions (oscillator stabilized during its Cold-Start delay and  $V_{DD}$  is high enough to avoid "grey" zone between static POR and  $V_{L1}$ ).

IMPORTANT: special care should be taken, when Power Supply starts to fall close to or below  $V_{_{DD}}$  min. Frequent checking of the SVLD  $V_{_{L1}}$  (1.3V) must be done. Between minimum  $V_{_{DD}}$  supply of 1.2V and static POR level of 0.9V there is a grey zone, which must be avoided for proper operation.



#### 5 Oscillator

A built-in crystal oscillator circuit generates the system-operating clock for the CPU and peripheral circuits from an externally connected crystal (typ. 32.768 kHz) and trimmer capacitor (from Qin tw.  $V_{SS}$ ). The regulated voltage,  $V_{REG}$ , supplies the oscillator circuit. In SLEEP mode the oscillator is stopped.

With Fout bit in PA3cnt register we can put the system 32.768 Hz frequency on STB/RST pin as output.

#### 5.1 Prescaler

The input to the prescaler is the system clock signal. The prescaler consists of a fifteen (15) element divider chain which delivers clock signals for the peripheral circuits such as the timer/counter, buzzer, I/O debouncers and edge detectors, as well as generating prescaler interrupts.

Table 8. Prescaler interrupts source

| Interrupt frequency | PSF1 | PSF0 |
|---------------------|------|------|
| mask(no interrupt)  | 0    | 0    |
| 1 Hz                | 0    | 1    |
| 8 Hz                | 1    | 0    |
| 32 Hz               | 1    | 1    |

The frequency of prescaler interrupts is software selectable, as shown in Table 8.

Table 9. Prescaler control register - PRESC

| Bit | Name | Reset | R/W | Description                  |
|-----|------|-------|-----|------------------------------|
| 3   | MTim | 0     | R/W | Timer/Counter Interrupt Mask |
| 2   | PRST | -     | R/W | Prescaler reset              |
| 1   | PSF1 | 0     | R/W | Prescaler Interrupt select 1 |
| 0   | PSF0 | 0     | R/W | Prescaler Interrupt select 0 |

#### 6 Watchdog timer

If for any reason the CPU crashes, then the watchdog timer can detect this situation and output a system reset signal. This function can be used to detect program overrun. For normal operation the watchdog timer must be reset periodically by software at least once every three seconds (CLK = 32kHz) or a system reset signal is generated to CPU and periphery. The watchdog is active during STANDBY. Setting the **NoWD** bit to 1 in the **Option** register deactivates the watchdog-reset function.

In worst case because of prescaler reset function WD time-out can come down to 2 seconds.

Writing 1 to the WDRST bit resets the watchdog timer. Writing 0 to WDRST has no effect.

The watchdog timer also operates in STANDBY mode. It is therefore necessary to reset it if this mode continues for more than three seconds. One method to do so is to use the prescaler 1Hz interrupt such, that the watchdog is reset every second.

Table 10. Watchdog register - WD

| Bit | Name   | Reset | R/W | Description          |
|-----|--------|-------|-----|----------------------|
| 3   | WDRST  | -     | R/W | Watchdog timer reset |
| 2   | Slmask | -     | R/W | SLEEP mask bit       |
| 1   | WD1    | 0     | R   | WD Timer data 1/4 Hz |
| 0   | WD0    | 0     | R   | WD Timer data 1/2 Hz |



#### 7 INPUT and OUTPUT ports

The EM6607 has five independent 4-bit ports, as shown in Table below

Table 11. Input / Output Ports Overview

| Port    | Mode                       | Mask Options          | Function(s)                             |
|---------|----------------------------|-----------------------|-----------------------------------------|
| PA(0:3) | Input                      | Pull-Up/Down          | Input Interrupt                         |
|         |                            | (*)Debouncer          | Software Test Variable                  |
|         |                            | (*) + or – IRQ edge   | PA3 input for event counter             |
|         |                            | RESET combination     | RESET input(s)                          |
| PB(0:3) | Individual input or output | Nch open drain output | Input or Output                         |
|         | (high Current)             | Pull-Up/Down on input | PB0 for buzzer output in 24-pin version |
|         |                            |                       | High Current outputs                    |
| PC(0:3) | Port input or output       | Pull-Up/Down          | Input or Output Port                    |
|         |                            | (*)+ or – IRQ edge    | Interrupt                               |
|         |                            | (*)Debouncer          |                                         |
|         |                            | Nch open drain output |                                         |
| PD(0:3) | Port input or Output       | Pull-Up/Down on Input | Input or Output Port                    |
|         |                            | Nch open drain output | PD0 -SWB serial clock output            |
|         |                            |                       | PD1 -SWB serial data output             |
| PE(0:3) | Individual input or output | Pull-Up/Down on Input | Input or Output Port                    |
|         |                            | Nch open drain output | PE0 for buzzer output in 28-pin version |

<sup>(\*)</sup> Some options can be set also by **Option** register.

Table 12. Option register - Option

| Bit | Name     | Reset | R/W | Description                       |
|-----|----------|-------|-----|-----------------------------------|
| 3   | IRQedgeR | 0     | R/W | Rising edge interrupt for portA&C |
| 2   | debPCN   | 0     | R/W | PortC without/with debouncer      |
| 1   | debPAN   | 0     | R/W | PortA without/with debouncer      |
| 0   | NoWD     | 0     | R/W | WatchDog timer Off                |

IRQedgeR: Valid for both PortA and PortC input interrupt edge. By default interrupt are active on a falling edge. When

set to 1 the rising edge is active.

debPAN: By default (after a reset) debouncers are enabled on whole PortA. Writing 1 removes the debouncers from

the PortA.

**debPCN:** By default debouncers are enabled on whole PortC. Writing 1 removes the debouncers from the PortC.

**NoWD:** By default Watchdog timer is On (NoWD=0). Writing 1 removes the watchdog timer.

#### 7.1 PortA

The EM6607 has one 4-bit general purpose input port. Each of the input port terminals PA3..PA0 has an internal pull-Up/Down resistor, which can be selected with mask options. Port information is directly read from the pin into a register.

On inputs PA0, PA1, PA2 and PA3 debouncers for noise rejection are added by default. For interrupt generation, either direct input and debounced input can be chosen. With the **debPAN** written to 0 in the Option register all the PortA inputs are debounced and with the **debPAN** bit at 1 none of the PortA inputs are debounced. With the debouncer selected the input must be stable for two rising edges of 1024Hz or 128Hz clocks (at 32kHz). This corresponds to a worst case of 1.95ms or 15.62msec. PortA terminals PA0, PA1 and PA2 are also used as input conditions for conditional software branches as shown on the next page:



Debounced **PA0** is connected to CPU **TestVar1**Debounced **PA1** is connected to CPU **TestVar2**Debounced **PA2** is connected to CPU **TestVar3** 



Figure 7. Port A

Additionally, PA3 can also be used as the input terminal for the event counter.

The input port PA(0:3) has also individually selectable interrupts. Each port has its own interrupt mask bit in the <u>MPortA</u> register. When an interrupt occurs, reading of the <u>IRQpA</u> and the <u>IntRq</u> registers allows identifying the source of the interrupt. The <u>IRQpA</u> register is automatically cleared by reading the register or by a RESET,. Reading <u>IRQpA</u> register also clears the <u>INTPA</u> flag in <u>IntRq</u> register. At initial RESET the <u>MPortA</u> is set to 0, thus disabling any input interrupts.

See paragraph 9 for further details about the interrupt controller.

# 7.1.1 PortA registers

Table 13. PortA input status register - PortA

| Bit | Name | Reset | R/W | Description      |
|-----|------|-------|-----|------------------|
| 3   | PA3  |       | R   | PA3 input status |
| 2   | PA2  | •     | R   | PA2 input status |
| 1   | PA1  | -     | R   | PA1 input status |
| 0   | PA0  | -     | R   | PA0 input status |

Table 14. PortA Interrupt request register - IRQpA

| Bit | Name   | Reset | R/W | Description                      |
|-----|--------|-------|-----|----------------------------------|
| 3   | IRQpa3 | 0     | R   | input PA3 interrupt request flag |
| 2   | IRQpa2 | 0     | R   | input PA2 interrupt request flag |
| 1   | IRQpa1 | 0     | R   | input PA1 interrupt request flag |
| 0   | IRQpa0 | 0     | R   | input PA0 interrupt request flag |

Table 15. PortA interrupt mask register - MportA

| Bit | Name | Reset | R/W | Description                  |
|-----|------|-------|-----|------------------------------|
| 3   | MPA3 | 0     | R/W | interrupt mask for input PA3 |
| 2   | MPA2 | 0     | R/W | interrupt mask for input PA2 |
| 1   | MPA1 | 0     | R/W | interrupt mask for input PA1 |
| 0   | MPA0 | 0     | R/W | interrupt mask for input PA0 |



#### 7.2 PortB

Port B is a 4-bit general-purpose I/O port. Outputs on this port are high current outputs. Each bit PB(0:3) can be separately configured by software to be either input or output by writing to the corresponding bit of the **CIOPortB** control register. The **PortB** register is used to read data when in input mode and to write data when in output mode. On each terminal controlled Pull-Up/Down resistor can be selected by metal option, which are active only when selected as input. Special case is when we want to use internal Strong Pull-Up resistor also when PortB terminal is declared as N-channel open drain output and internal Pull-Up resistor is used to pull up the output (not-controlled Pull-Up). This is a special option "**sod**" = strong Pull-Up for Open drain- active all the time (when terminal is input or output).

Writing 0 to the corresponding bit in the CIOPortB register sets input mode. This results in a high impedance state with the status of the pin being read from register <a href="PortB">PortB</a>. Writing 1 to the corresponding bit in the CIOPortB register sets output mode. Consequently the output terminal follows the status of the bits in the <a href="PortB">PortB</a> register. At initial RESET the <a href="CIOPortB">CIOPORTB</a> register is set to 0, thus setting the port to input. Additionally, PB0 can also be used as a three-tone buzzer output. For details see section 7, Buzzer.

#### 7.2.1 PortB registers

Table 16. PortB input/output status register - PortB

| Bit | Name | Reset | R/W | Description  |  |
|-----|------|-------|-----|--------------|--|
| 3   | PB3  | -     | R/W | PB3 I/O data |  |
| 2   | PB2  | -     | R/W | PB2 I/O data |  |
| 1   | PB1  | -     | R/W | PB1 I/O data |  |
| 0   | PB0  | -     | R/W | PB0 I/O data |  |

Table 17. PortB Input/Output control register - CIOportB

| Bit | Name   | Reset | R/W | Description             |
|-----|--------|-------|-----|-------------------------|
| 3   | CIOPB3 | 0     | R/W | PB3 Input/Output select |
| 2   | CIOPB2 | 0     | R/W | PB2 Input/Output select |
| 1   | CIOPB1 | 0     | R/W | PB1 Input/Output select |
| 0   | CIOPB0 | 0     | R/W | PB0 Input/Output select |



Figure 8. Port B

If metal mask option **3Y** (Input blocked when Output) is used and port is declared as Output (<u>CIOPortB</u> = 1111b) the real port information cannot be read directly. In this case no direct logic operations (like AND <u>PortB</u>) on Output ports are possible. This logic operation can be made with an image of the Port saved in the RAM which we store after on the output port. This is valid for PortB, PortC and PortD when declared as output and the metal Option **3Y** is used. In the case of metal option **3N** selected direct logic operations on output ports are possible.

If **OEBsleepRes** bit in <u>Option2</u> register is set to "1" (Output Hi-Z in SLEEP mode) the active Output will go tri-state when the circuit goes into SLEEP mode. In the case of **OEBsleepRes** at "0", output stays active also in the SLEEP mode.



#### 7.3 PortC

This port can be configured as either input or output (but it is not bitwise selectable). When in input mode it implements the identical interrupt functions as PortA. The <u>PortC</u> register is used to read data when input mode and to write data when in output mode. Input mode is set by writing 0 in the I/O control bit **CIOPC** in register <u>CPIOB</u>, the input becomes high impedance. On each terminal controlled Pull-Up/Down resistor can be selected by metal option, which are active only when port is input. When we want to use internal Strong pull-up resistor also when PortC terminal is declared as N-channel open drain output and internal pull-up resistor is used to pull up the output (not-controlled pull-up). This is a special option "sod" = strong pull-up for Open drain- active all the time (when terminal is input or output).

The output mode is selected by writing 1 to **CIOPC** bit, and the terminal follows the bits in the **PortC** register. When PortC is used as an input, interrupt functions as described for PortA can be enabled. Input to the interrupt logic can be direct or via a debounced input. With the **debPCN** bit at 0 in the Option register all the PortC inputs are debounced and with the **debPCN** bit at 1 none of the PortC inputs are debounced. **MPortC** is the interrupt mask register for this port and **IRQpC** is the portC interrupt request register. See also section 9.

By writing the **PA&C** bit in the <u>CPIOB</u> data register it is possible to combine PortA and PortC interrupt requests (logic AND) as shown in Table 17

At initial reset, the **CPIOC** control register is set to 0, and the port is in input mode. The **MPortC** register is also set to 0, therefore disabling interrupts.

Table 18. Ports A&C Interrupt

| IRQPA | IRQPC | PA&C | Request to CPU |
|-------|-------|------|----------------|
| 0     | 0     | X    | No             |
| 0     | 1     | 0    | Yes            |
| 1     | 0     | 0    | Yes            |
| 1     | 1     | 0    | Yes            |
| 0     | 1     | 1    | No             |
| 1     | 0     | 1    | No             |
| 1     | 1     | 1    | Yes            |

# 7.3.1 PortC registers

Table 19. PortC input/output register - PortC

| Bit | Name | Reset | R/W | Description  |  |
|-----|------|-------|-----|--------------|--|
| 3   | PC3  | -     | R/W | PC3 I/O data |  |
| 2   | PC2  | -     | R/W | PC2 I/O data |  |
| 1   | PC1  | -     | R/W | PC1 I/O data |  |
| 0   | PC0  | -     | R/W | PC0 I/O data |  |

Table 20. PortC Interrupt request register - IRQpC

| Bit | Name   | Reset | R/W | Description                      |
|-----|--------|-------|-----|----------------------------------|
| 3   | IRQpc3 | 0     | R   | input PC3 interrupt request flag |
| 2   | IRQpc2 | 0     | R   | input PC2 interrupt request flag |
| 1   | IRQpc1 | 0     | R   | input PC1 interrupt request flag |
| 0   | IRQpc0 | 0     | R   | input PC0 interrupt request flag |

Table 21. PortC interrupt mask register - MportC

| Bit | Name | Reset | R/W | Description                  |
|-----|------|-------|-----|------------------------------|
| 3   | MPC3 | 0     | R/W | interrupt mask for input PC3 |
| 2   | MPC2 | 0     | R/W | interrupt mask for input PC2 |
| 1   | MPC1 | 0     | R/W | interrupt mask for input PC1 |
| 0   | MPC0 | 0     | R/W | interrupt mask for input PC0 |





Figure 9. Port C

If **OECsleepRes** bit in <u>Option2</u> register is set to "1" (=6Y (Output Hi-Z in SLEEP mode)) the active Output will go tri-state when the circuit goes into SLEEP mode. In the case of 6N - OECsleepRes at "0", output stay active also in the SLEEP mode.

Table 22. Option2 register - Option2

| Bit | Name        | Reset | R/W | Description                             |
|-----|-------------|-------|-----|-----------------------------------------|
| 3   | OEDsleepRes | 0     | W   | PortD Output Enable reset by Sleep mode |
| 2   | OECsleepRes | 0     | W   | PortC Output Enable reset by Sleep mode |
| 1   | OEBsleepRes | 0     | W   | PortB Output Enable reset by Sleep mode |
| 0   | BuzzerPE0   | 0     | W   | Buzzer on PE0 if 1, on PB0 if 0         |



#### 7.4 PortD

The EM6607 has one all purpose I/O port similar to PortC but without interrupt capability. The <u>PortD</u> register is used to read input data when an input and to write output data for output. The input line can be pulled Up/Down (metal option) when the port is used as input. Input mode is set by writing 0 to the I/O control bit **CIOPD** in register <u>CPIOB</u>, and the terminal becomes high impedance. On each terminal controlled Pull-Up/Down resistor can be selected by metal option which are active only when selected as input. Special case is when we want to use internal Strong pull-up resistor also when PortC terminal is declared as N-channel open drain output and internal pull-up resistor is used to pull up the output (not-controlled pull-up). This is a special option "sod" = strong pull-up for Open drain- active all the time (when terminal is input or output).

Output mode is set by writing 1 to the control bit **CIOPD.** Consequently, the terminal follows the status of the bits in the **PortD** register. If Serial Write Buffer function is enabled PD0 and PD1 terminals of PortD output serial clock and serial data respectively. For details see **11.0 Serial Write Buffer**.

#### 7.4.1 PortD registers

Table 23. PortD Input/Output register - PortD

| Bit | Name | Reset | R/W | Description  |
|-----|------|-------|-----|--------------|
| 3   | PD3  | 0     | R/W | PD3 I/O data |
| 2   | PD2  | 0     | R/W | PD2 I/O data |
| 1   | PD1  | 0     | R/W | PD1 I/O data |
| 0   | PD0  | 0     | R/W | PD0 I/O data |

Table 24. Ports control register - CPIOB

| Bit | Name  | Reset | R/W | Description                             |
|-----|-------|-------|-----|-----------------------------------------|
| 3   | -     | -     | R/W | not used                                |
| 2   | CIOPD | 0     | R/W | I/O PortD select                        |
| 1   | CIOPC | 0     | R/W | I/O PortC select                        |
| 0   | PA&C  | 0     | R/W | Logical AND of IRQ's from PortA & PortC |



Figure 10. Port D

If **OEDsleepRes** bit in **Option2** register is set to "1" (Output Hi-Z in SLEEP mode) the active Output will go tri-state when the circuit goes into SLEEP mode. In the case of **OEDsleepRes** at "0", output stay active also in the SLEEP mode.



#### 7.5 PortE

PortE is a 4-bit I/O port where each pad PE(0:3) can be separately configured by software to be either input or output by writing to the corresponding bit of the <u>CIOPortE</u> control register. The <u>PortE</u> register is used to read data when in input mode and to write data when in output mode. On each terminal controlled Pull-Up/Down resistor can be selected by metal option which are active only when selected as input. Special case is when we want to use internal Strong pull-up resistor also when PortC terminal is declared as N-channel open drain output and internal pull-up resistor is used to pull up the output (not-controlled pull-up). This is a special option "sod" = strong pull-up for Open drain- active all the time (when terminal is input or output).

Input mode is set by writing 0 to the corresponding bit in the **CIOPortE** register. This results in a high impedance state with the status of the pin being read from register **PortE**. Output mode is set by writing 1 to the corresponding bit in the **CIOPortE** register. Consequently the output terminal follows the status of the bits in the **PortE** register. At initial RESET the **CIOPortE** register is set to 0, thus setting the port to an input.

#### 7.5.1 PortE registers

Table 25. PortE Input/Output status register - PortE

| Bit | Name | Reset | R/W | Description  |  |
|-----|------|-------|-----|--------------|--|
| 3   | PE3  | -     | R/W | PE3 I/O data |  |
| 2   | PE2  | -     | R/W | PE2 I/O data |  |
| 1   | PE1  | -     | R/W | PE1 I/O data |  |
| 0   | PE0  | -     | R/W | PE0 I/O data |  |

Table 26. PortE Input/Output control register - CIOPortE

| Bit | Name   | Reset | R/W | Description             |
|-----|--------|-------|-----|-------------------------|
| 3   | CIOPE3 | 0     | R/W | PE3 Input/Output select |
| 2   | CIOPE2 | 0     | R/W | PE2 Input/Output select |
| 1   | CIOPE1 | 0     | R/W | PE1 Input/Output select |
| 0   | CIOPE0 | 0     | R/W | PE0 Input/Output select |



Figure 11. Port E



#### 8 BUZZER

The EM6607 has one 50% duty cycle output with three different frequencies, which can be used to drive a buzzer. I/O terminal PB0 in 24-pin package or PE0 in 28-pin package (**BuzzerPE0** option) is used for this function when the buzzer is enabled by setting the **BUen** bit to 1 . Table 22 below shows how to select the frequency by writing to the **BCF1** and **BCF0** control flags in the **BEEP** register.

After writing to the buzzer control register **BEEP**, the chosen frequency (or silence) is selected immediately. With the **BUen** bit set to 1, the selected frequency is output at PB0 when **BuzzerPE0** is 0. When the **BUen** is set to 0 PB0 is used as a normal I/O terminal of PortB. The **BUen** bit has a higher priority over the I/O control bit **CIOPB0** in the **CIOPortB** register. In case when **BuzzerPE0** is 1 and **BUen** is set to 1 PE0 becomes output and PB0 is not influenced by buzzer function.

| Tone frequency | BCF1 | BCF0 |
|----------------|------|------|
| silence        | 0    | 0    |
| 1024 Hz        | 0    | 1    |
| 2048 Hz        | 1    | 0    |
| 2667 Hz        | 1    | 1    |

Table 2. Buzzer frequency selection

#### 8.1 Buzzer Register

Table 27. Buzzer control register - BEEP

| Bit | Name  | Reset | R/W | Description              |
|-----|-------|-------|-----|--------------------------|
| 3   | TimEn | 0     | R/W | Timer/counter enable     |
| 2   | BUen  | 0     | R/W | Buzzer enable            |
| 1   | BCF1  | 0     | R/W | Buzzer Frequency control |
| 0   | BCF0  | 0     | R/W | Buzzer Frequency control |

Table 28. Buzzer output pad allocation

| Buzzer on PB0 or PE0 | BuzzerPE0 in register Option2 |
|----------------------|-------------------------------|
| Buzzer output on PE0 | 1                             |
| Buzzer output on PB0 | 0                             |

Table 29. PB0 & PE0 function used with BUen and BuzzerPE0 control bits

| CIOPB0 | CIOPE0 | BUen | BuzzerPE0 | Function distributions on PB0 and PE0 pads  |
|--------|--------|------|-----------|---------------------------------------------|
| 0      | 0      | 0    | Х         | PB0 and PE0 are Inputs                      |
| 1      | 1      | 0    | X         | PB0 and PE0 are independent outputs         |
| X      | 0      | 1    | 0         | PB0 is Buzzer output, PE0 is input          |
| 0      | X      | 1    | 1         | PB0 is input, PE0 is Buzzer output          |
| 1      | Х      | 1    | 1         | PB0 is general output, PE0 is Buzzer output |



#### 9 Timer/Event Counter

The EM6607 has a built-in 8 bit countdown auto-reload Timer/Event counter that takes an input from either the prescaler or Port PA3. If the Timer/Event counter counts down to \$00 the interrupt request flag **IntTim** is set to 1. If the Timer/Event counter interrupt is enabled by setting the mask flag **MTimC** set to 1, then an interrupt request is generated to the CPU. See also section 9. If used as an event counter, pulses from the PA3 terminal are input to the event counter. See figure 10 and tables 28 and 29 on the next page for PA3 source selection (debounced or not, Rising/Falling edge). By default rising and debounced PA3 input is selected.

The timer control register <u>TimCtr</u> selects the auto-reload function and input clock source. At initial RESET this bit is cleared to 0 selecting no auto-reload. To enable auto-reload <u>TimAuto</u> must be set to 1. The Timer/Event counter can be enabled or disabled by writing to the <u>TIMen</u> control bit in the <u>BEEP</u> register. At initial RESET it is cleared to 0. When used as timer, it is initialised according to the data written into the timer load/status registers <u>LTimLS</u> (low 4 bits) and <u>HTimLS</u> (high four bits). The timer starts to count down as soon as the <u>LTimLS</u> value is written. When loading the Timer/Event counter registers the correct order must be respected: First, write either the control register <u>TimCtr</u> or the high data nibble <u>HTimLS</u>. The last register written should be the low data nibble <u>LTimLS</u>. During count down, the timer can always be reloaded with a new value, but the high four bits will only be accepted during the write of the low four bits.

In the case of the auto-reload function, the timer is initialised with the value of the load registers <u>LTimLS</u> and <u>HTimLS</u>. Counting with the auto-reload function is only enabled during the write to the low four bits, (writing **TimAuto** to 1 does not start the timer counting down with the last value in the timer load registers but it waits until a new <u>LTimLS</u> load). The timer counting to \$00 generates a timer interrupt event and reloads the registers before starting to count down again. To stop the timer at any time, a write of \$00 can be made to the timer load registers, this sets the **TimAuto** flag to 0. If the timer is stopped by writing the **TimEn** bit to 0, the timer status can be read. The current timer status can be always obtained by reading the timer registers <u>LTimLS</u> and <u>HTimLS</u>. For proper operation read ordering should be respected such that the first read should be of the <u>LTimLS</u> register followed by the <u>HTimLS</u> register. Example: To have continous 1sec timer IRQ with 128Hz one has to write 128dec (80hex) in Timer registers with auto-reload.

Using the Timer/Event Counter as the event counter allows several possibilities:

- 1.) Firstly, load the number of PA3 input edges expected into the load registers and then generate an interrupt request when counter reaches \$00.
- 2.) The second is to write timer/counter to \$FF, then select the event counter mode, and lastly enable the event counter by setting the **TimEn** bit to 1, which starts the count.

Because the counter counts down, a binary complement has to be done in order to get the number of events at the PA3 input.

3) Another option is to use the Timer/Event counter in conjunction with the prescaler interrupt, such that it is possible to count the number of the events during two consecutive 32Hz, 8Hz or 1Hz prescaler interrupts.



Figure 12. Timer / Event Counter



Table below shows the selection of inputs to the Timer/Event counter.

Table 30. Timer Clock Selection

| TEC2 | TEC1 | TEC0 | Timer/Counter clock source                |
|------|------|------|-------------------------------------------|
| 0    | 0    | 0    | not active                                |
| 0    | 0    | 1    | 2048 Hz from prescaler                    |
| 0    | 1    | 0    | 512 Hz from prescaler                     |
| 0    | 1    | 1    | 128 Hz from prescaler                     |
| 1    | 0    | 0    | 32 Hz from prescaler                      |
| 1    | 0    | 1    | 8 Hz from prescaler                       |
| 1    | 1    | 0    | 1 Hz from prescaler                       |
| 1    | 1    | 1    | PA3 input terminal (see tables 28 and 29) |

# 9.1 Timer/Counter registers

Table 31. Timer control register - TimCtr

| Bit | Name    | Reset | R/W | Description               |
|-----|---------|-------|-----|---------------------------|
| 3   | TimAuto | 0     | R/W | Timer/Counter AUTO reload |
| 2   | TEC2    | 0     | R/W | Timer/Counter mode 2      |
| 1   | TEC1    | 0     | R/W | Timer/Counter mode 1      |
| 0   | TEC0    | 0     | R/W | Timer/Counter mode 0      |

Table 32. LOW Timer Load/Status register - LTimLS (4 low bits)

| Bit | Name    | Reset | R/W | Description             |  |
|-----|---------|-------|-----|-------------------------|--|
| 3   | TL3/TS3 | 0     | R/W | Timer load/status bit 3 |  |
| 2   | TL2/TS2 | 0     | R/W | Timer load/status bit 2 |  |
| 1   | TL1/TS1 | 0     | R/W | Timer load/status bit 1 |  |
| 0   | TL0/TS0 | 0     | R/W | Timer load/status bit 0 |  |

Table 33. HIGH Timer Load/Status register - HTimLS (4 high bits)

| Bit | Name    | Reset | R/W | Description             |
|-----|---------|-------|-----|-------------------------|
| 3   | TL7/TS7 | 0     | R/W | Timer load/status bit 7 |
| 2   | TL6/TS6 | 0     | R/W | Timer load/status bit 6 |
| 1   | TL5/TS5 | 0     | R/W | Timer load/status bit 5 |
| 0   | TL4/TS4 | 0     | R/W | Timer load/status bit 4 |

Table 34. PA3 counter input selection register - PA3cnt

| bit | Name     | Reset | R/W | Description                        |
|-----|----------|-------|-----|------------------------------------|
| 3   | -        | 0     | -   | empty                              |
| 2   | WDanadis | 0     | R/W | Analogue WD disable                |
| 1   | Fout     | 0     | R/W | System freq. output on STB/RST pad |
| 0   | PA3cntin | 0     | R/W | PA3 input status                   |

Table 35. PA3 counter input selection

| PA3cntin | debPAN | IRQedgeR                       | Counter source                |
|----------|--------|--------------------------------|-------------------------------|
| 0        | X      | X PA3 debounced rising edge    |                               |
| 1        | 0      | 0                              | PA3 debounced falling edge    |
| 1        | 0      | 1 PA3 debounced rising edge    |                               |
| 1        | 1      | PA3 not debounced falling edge |                               |
| 1        | 1      | 1                              | PA3 not debounced rising edge |

#### X (Don't care)



#### 10 Interrupt Controller

The EM6607 has 12 different interrupt sources, each of which is maskable. These are:

External (9) - PortA PA3..PA0 inputs

- PortC PC3..PC0 inputs

- Combined AND of PortA \* PortC

Internal (3) - Prescaler (32Hz / 8Hz / 1Hz)

- Timer/Event counter

- SWB in interactive mode

For an interrupt to the CPU to be generated, the interrupt request flag must be set (INTxx), and the corresponding mask register bit must be set to 1 (Mxx), the general interrupt enable flag (INTEN) must also be set to 1. The interrupt request can be masked by the corresponding interrupt mask registers MPortx for each input interrupt and by PSF0 ,PSF1 and MTim for internal interrupts. At initial reset the interrupt mask bits are set to 0. INTEN bit is set automatically to 1 by Halt Instruction except when starting the Automatic SWB transfer (see Serial Write Buffer (SWB) chapter 11)

The CPU is interrupted when one of the interrupt request flags is set to 1 in register <u>IntRq</u> and the <u>INTEN</u> bit is enabled in the control register <u>CIRQD</u>. INTTE and INTPR flags are cleared automatically after a read of the <u>IntRq</u> register. The other two interrupt flags INTPA (IRQ from PortA) and INTPC (IRQ from PortC) in the <u>IntRq</u> register are cleared only after reading the corresponding Port interrupt request registers <u>IRQpA</u> and <u>IRQpC</u>. At the Power on reset and in SLEEP mode the INTEN bit is also set to 0 therefore not allowing any interrupt requests to the CPU until it is set to 1 by software.

Since the CPU has only one interrupt subroutine and because the <u>IntRq</u> register is cleared after reading, the CPU does not miss any of the interrupt requests which come during the interrupt service routine. If any occur during this time a new interrupt will be generated as soon as the CPU comes out of the current interrupt subroutine. Interrupt priority can be controlled through software by deciding which flag in the <u>IntRq</u> register should be serviced first.

For SWB interactive mode interrupt see section 11.0 Serial Write Buffer.

#### 10.1 Interrupt control registers

Table 36. Main Interrupt request register - IntRq (Read Only)\*

| Bit | Name  | Reset | R/W | Description                     |
|-----|-------|-------|-----|---------------------------------|
| 3   | INTPR | 0     | R   | Prescaler interrupt request     |
| 2   | INTTE | 0     | R   | Timer/counter interrupt request |
| 1   | INTPC | 0     | R   | PortC Interrupt request         |
| 0   | INTPA | 0     | R   | PortA Interrupt request         |
| 2   | SLEEP | 0     | W*  | SLEEP mode flag                 |

<sup>\*</sup> Write bit 2 only if SLmask=1

If the SLEEP flag is written with 1 then the EM6607 goes immediately into SLEEP mode (SLmask was at 1).



Table 37. Register - CIRQD

| Bit | Name  | Reset | R/W  | Description                             |
|-----|-------|-------|------|-----------------------------------------|
| 3   | -     | 0     | R/W  | Reserved, must written to 0             |
| 2   | -     | 0     | R/W* | Reserved, must written to 0             |
| 1   | DebCK | 0     | R/W  | Debouncer clock select (0=2ms : 1=16ms) |
| 0   | INTEN | 0     | R/W  | Enable interrupt to CPU (1=enabled)     |



Figure 13. Interrupt Request generation

IRQ mask bit which can be written to 0 or 1 (1 to enable an interrupt)

INTIE

interrupt request flag which is set on the input rising edge.

Timer IRQ flag **INTTE** and prescaler IRQ flag **INTPR** arrive independent of their mask bits not to loose any timing information. But the  $\mu$ processor will be interrupted only with mask set to 1.



# 11 Supply Voltage Level Detector (SVLD)

The EM6607 has a software configurable Supply Voltage Level detector. Three levels can be defined within the power supply range. During SLEEP mode this function is disabled.

Voltage level detector can be used also for Power-Check on Start-up of the EM6607 micro-controller when  $V_{DD}$  is applied (see Chapter 4.7 POR with Power-Check Reset).

The required voltage compare level is selected by writing the bits **VLC1** and **VLC2** in the <u>SVLD</u> control register that also activates the compare measurement. Since the measurement is not immediate the busy flag remains high during the measurement and is automatically cleared low when the measurement is finished. Reading the VLDR flag indicates the result. If the result is 0 then the voltage level is higher than the selected compare level. And if 1 it is lower than the compare level. The result **VLDR** of the last measurement remains until the new one is finished. The new result overwrites the previous one.

During the SVLD operation power consumption increases by approximately  $3\mu A$  for 3.9msec. The measurement internally starts with the rising 256Hz edge following the SVLD test command. The additional SVLD consumption stops after the falling edge of the 256Hz internal clock.

Table below lists the voltage level selection

Table 38. SVLD Level selection

| Voltage level   | VLC1 | VLC0 | Possible levels implementations                                                        |  |  |
|-----------------|------|------|----------------------------------------------------------------------------------------|--|--|
| SVLD disabled   | 0    | 0    |                                                                                        |  |  |
| V <sub>L1</sub> | 0    | 1    | V <sub>L1:</sub> possible levels are from 1.3V to 3V by step of 100mV.                 |  |  |
| V <sub>L2</sub> | 1    | 0    | V <sub>L2</sub> ; possible levels are 2.3V; 2.6V to 3.5V by step of 100mV; 3.7V and 4V |  |  |
| $V_{L3}$        | 1    | 1    | V <sub>L3</sub> ; possible levels are 2.6V to 3.5V by step of 100mV; 3.7V and 4V       |  |  |

V<sub>L1</sub> level is also the level used for Power check if activated (table 15.1.1).

Table 39. SVLD control register - SVLD

| Bit | Name | Reset | R/W | Description                    |
|-----|------|-------|-----|--------------------------------|
| 3   | VLDR | 0     | R   | SVLD result (0=higher 1=lower) |
| 2   | busy | 0     | R   | measurement in progress        |
| 1   | VLC1 | 0     | R/W | SVLD level control 1           |
| 0   | VLC0 | 0     | R/W | SVLD level control 0           |



#### 12 Serial Write Buffer - SWB

The EM6607 has a simple Serial Write Buffer (SWB) which outputs serial data and serial clock.

The SWB is enabled by setting the bit **V03** in the <u>CLKSWB</u> register as well as setting port D to output mode. The combination of the possible PortD mode is shown in Table 34. In SWB mode the serial clock is output on port D0 and the serial data is output on port D1.

The signal TestVar[3], which is used by the processor to make conditional jumps, indicates "Transmission finished" in automatic send mode or "SWBbuffer empty" in interactive send mode. In interactive mode, TestVar[3] (see port A section) is equivalent to the interrupt request flags stored in <a href="Interactive mode">IntRq</a> register: it permits to recognise the interrupt source. (See also the interrupt handling section 9.Interrupt Controller for further information). To serve the "SWBbuffer empty" interrupt request, one only has to make a conditional jump on TestVar[3].

Bits ClkSWB0 and ClkSWB1 in the <u>ClkSWB</u> register select the Serial Write Buffer output clock frequency. The possible values are 1kHz (default), 2kHz, 8kHz or 16kHz and are shown in Table below:

Table 40. SWB clock selection

| SWB clock output | CkSWB1 | CkSWB0 |
|------------------|--------|--------|
| 1024 Hz          | 0      | 0      |
| 2048 Hz          | 0      | 1      |
| 8192 Hz          | 1      | 0      |
| 16384 Hz         | 1      | 1      |

Table 41. SWB clock selection register - CIkSWB

| Bit | Name   | Reset | R/W | Description                   |
|-----|--------|-------|-----|-------------------------------|
| 3   | V03    | 0     | R/W | Serial Write buffer selection |
| 2   | -      | 0     | R   | RESERVED - read 0             |
| 1   | CkSWB1 | 0     | R/W | SWB clock selector 1          |
| 0   | CkSWB0 | 0     | R/W | SWB clock selector 0          |

Table 42. PortD status

| PortD status | CIOPD | V03 | PD0              | PD1             | PD2        | PD3        |
|--------------|-------|-----|------------------|-----------------|------------|------------|
| « NORMAL »   | 0     | 0   | input            | input           | input      | input      |
| « NORMAL »   | 0     | 1   | input            | input           | input      | input      |
| « NORMAL »   | 1     | 0   | output PD0       | output PD1      | output PD2 | output PD3 |
| « SWB »      | 1     | 1   | serial clock Out | SWB serial data | output PD2 | output PD3 |

When the SWB is enabled by setting the bit **V03** TestVar[3], which is used to make conditional jumps, is reassigned to the SWB and indicates either "SWBbuffer empty" interrupt or "Transmission finished". After Power-on-RESET **V03** is cleared at "0" and TestVar[3] is consequently assigned to PA2 input terminal.

The SWB data is output on the rising edge of the clock. Consequently, on the receiver side the serial data can be evaluated on falling edge of the serial clock edge.





Figure 14. Serial write buffer

Table 43. SWB buffer register - SWbuff

| Bit | Name  | Reset | R/W | Description   |
|-----|-------|-------|-----|---------------|
| 3   | Buff3 | 1     | R/W | SWB buffer D3 |
| 2   | Buff2 | 1     | R/W | SWB buffer D2 |
| 1   | Buff1 | 1     | R/W | SWB buffer D1 |
| 0   | Buff0 | 1     | R/W | SWB buffer D0 |

Table 44. SWB Low size register - <u>LowSWB</u>

| Bit | Name    | Reset | R/W | Description                |
|-----|---------|-------|-----|----------------------------|
| 3   | Size[3] | 0     | R/W | Auto mode buffer size bit3 |
| 2   | Size[2] | 0     | R/W | Auto mode buffer size bit2 |
| 1   | Size[1] | 0     | R/W | Auto mode buffer size bit1 |
| 0   | Size[0] | 0     | R/W | Auto mode buffer size bit0 |

Table 45. SWB High size register - HighSWB

| Bit | Name    | Reset | R/W | Description                |
|-----|---------|-------|-----|----------------------------|
| 3   | AutoSWB | 0     | R/W | SWB Automatic mode select  |
| 2   | StSWB   | 0     | R/W | SWB start interactive mode |
| 1   | Size[5] | 0     | R/W | Auto mode buffer size bit5 |
| 0   | Size[4] | 0     | R/W | Auto mode buffer size bit4 |

The SWB has two operational modes, automatic mode and interactive mode.



#### 12.1 SWB Automatic send mode

Automatic mode enables a buffer on a predefined length to be sent at high transmission speeds (up to 16khz). In this mode user prepares all the data to be sent (minimum 8 bits, maximum 256 bits) in RAM. The user then selects the clock speed, sets the number of data nibbles to be sent, selects automatic transmission mode (**AutoSWB** bit set to 1) and enters STANDBY mode by executing a HALT instruction. Once the HALT instruction is activated the SWB peripheral module sends the data in register **SWBuff** followed by the data in the RAM starting at address 00 up to the address specified by the bits **size[5:0**] located in the **LowSWB**, **HighSWB** registers.

During automatic transmission the general **INTEN** bit is disabled automatically to prevent other Interrupts to reset the standby mode. At the end of automatic transmission EM6607 leaves standby mode and sets TestVar[3] high. TestVar[3] = 1 is signaling SWB transmission is terminated. Once the transmission is finished, do not forget to enable the general **INTEN** bit if necessary.

The data to be sent must be prepared in the following order:

First nibble to be sent must be written in the <u>SWBuff</u> register. The other nibbles must be loaded in the RAM from address 0 (second nibble at adr.0, third at adr.1,...) up to the address with last nibble of data to be send = "size" address. Max. address space for SWB is 3E ("size" 3E hex) what gives with <u>SWBuff</u> up to 64 nibbles (256 bits) of possible data to be sent. The minimum possible data length we can send in Automatic SWB mode is 8 bits when the last RAM address to be sent is 00 ("size" = 00)

Once data are ready in the RAM and in the <u>SWBuff</u>, user has to load the "size" (adr. of the last nibble to be send - bits size[5:0]) into the <u>LowSWB</u> and <u>HighSWB</u> register together with **AutoSWB** bit = 1.

Now everything is ready for serial transmission. To start the transmission one has to put the EM6607 in standby mode with the HALT instruction. With this serial transmission starts. When transmission is finished the TESTvar[3] (can be used for conditional jumps) becomes active High, the **AutoSWB** bit is cleared, the processor is leaving the Standby mode and **INTEN** is switched on.



Figure 15. Automatic Serial Write Buffer transmission

The processor now starts to execute the first instruction placed after the HALT instruction (for instance write of <a href="SWBuff">SWBuff</a> register to clear TESTvar[3]), except if there was a IRQ during the serial transmission. In this case the CPU will go directly in the interrupt routine to serve other interrupt sources.

TestVar[3] stays high until <u>SWBuff</u> is rewritten. Before starting a second SWB action this bit must be cleared by performing a dummy write on <u>SWBuff</u> address.

Because the data in the RAM are still present one can start transmitting the same data once again only by recharging the <a href="MSWB">SWBuff</a>, <a href="LowSWB">LowSWB</a> and <a href="HighSWB">HighSWB</a> register together with <a href="AutoSWB">AutoSWB</a> bit and putting the <a href="EM6607">EM6607</a> in HALT mode will start new transmission.



#### 12.2 SWB Interactive send mode

In interactive SWB mode the reloading of the data transmission register <u>SWBbuff</u> is performed by the application program. This means that it is possible to have an unlimited length transmission data stream. However, since the application program is responsible for reloading the data a continuous data stream can only be achieved at 1kHz or 2kHz transmission speeds. For the higher transmission speeds a series of writes must be programmed and the serial output clock will not be continuous.

Serial transmission using the interactive mode is detailed in Figure 14. Programming of the SWB in interactive is achieved in the following manner:

Select the transmission clock speed using the bits ClkSW0 and ClkSW1 in the ClkSWB register.

Load the first nibble of data into the SWB data register SWBbuff

Start serial transmission by selecting the bit **StSWB** in the register **HighSWB** register.

Once the data has been transferred into the serial transmission register a non maskable interrupt (SWBEmpty) is generated and TESTvar[3] goes high. The CPU goes in the interrupt routine, with the JPV3 as first instruction in the routine one can immediately jump to the SWB update routine to load the next nibble to be transmitted into the **SWBuff** register. If this reload is performed before all the serial data is shifted out then the next nibble is automatically transmitted. This is only possible at the transmission speeds of 1KHz or 2KHz due to the number of instructions required to reload the register. At the higher transmission speeds of 8khz and 16khz the application must restart the serial transmission by writing the **StSWB** in the High **SWBHigh** register after writing the next nibble to the **SWBbuff** register.

Each time the <u>SWBuff</u> register is written the "SWBbuffer empty interrupt" and TestVar[3] are cleared to "0". For proper operation the <u>SWBuff</u> register must be written before the serial clock drops to low during sending the last bit (MSB) of the previous data.



Figure 16. Interactive Serial Write Buffer transmission

After loading the last nibble in the <u>SWBbuff</u> register a new interrupt is generated when this data is transferred to an intermediate Shift Register. Precaution must be made in this case because the SWB will give repetitive interrupts until the last data is sent out completely and the **STSWB** bit goes low automatically. One possibility to overcome this is to check in the Interrupt subroutine that the **STSWB** bit went low before exiting interrupt. Be careful because if **STSWB** bit is cleared by software transmission is stopped immediately.

At the end of transmission a dummy write of **SWBuff** must be done to clear TESTvar[3] and "SWBbuffer empty interrupt" or the next transmission will not work.



#### 13 STroBe / ReSeT Output

The STB/RST output pin is used to indicate the EM6607 RESET condition as well as write operations to ports B, C and D. For a PortB, PortC and PortD write operation the STROBE signal goes high for half of the system clock period. Write is effected on falling edge of the strobe signal and it can this be used to indicate when data changes at the output port pins. In addition, any EM6607 internal RESET condition is indicated by a continuous high level on STB/RST for the period of the RESET.

#### 14 Test at EM - Active Supply Current test

For this purpose, five instructions at the end of the ROM will be added.

Testloop: STI00H, 0AH

LDR 1BH

**NXORX** 

JPZ Testloop JMP 00H

To stay in the testloop, these values must be written in the corresponding addresses before jumping in the loop:

1BH: 0101b 32H: 1010b 6EH: 0010b 6FH: 0011b

Free space after last instruction: JMP 00H (0000)

Remark: empty space within the program are filled with NOP (FOFF).



#### 15 Metal Mask Options

The following options can be selected at the time of programming the metal mask ROM.

#### Table 46. input/output Ports

|    |            | Pull-Down<br>Yes / No<br>Strong / Weak | Pull-Up<br>Yes / No<br>Strong / Weak | Nch-open drain<br>Yes / No | Input blocked<br>when Output<br>Yes / No | Output Hi-Z in<br>SLEEP mode<br>Yes / No |
|----|------------|----------------------------------------|--------------------------------------|----------------------------|------------------------------------------|------------------------------------------|
|    |            | 0                                      | 1 (*1)                               | 2 (*1)                     | 3 (*2)                                   | 4                                        |
| A0 | PA0 input  |                                        |                                      |                            |                                          |                                          |
| A1 | PA1 input  |                                        |                                      |                            |                                          |                                          |
| A2 | PA2 input  |                                        |                                      |                            |                                          |                                          |
| A3 | PA3 input  |                                        |                                      |                            |                                          |                                          |
| B0 | PB0 In/Out |                                        |                                      |                            |                                          | OEBsleepRes                              |
| B1 | PB1 In/Out |                                        |                                      |                            |                                          | Bit in Option2                           |
| B2 | PB2 In/Out |                                        |                                      |                            |                                          | register.                                |
| B3 | PB3 In/Out |                                        |                                      |                            |                                          | Yes =1, No=0                             |
| C0 | PC0 In/Out |                                        |                                      |                            |                                          | OECsleepRes                              |
| C1 | PC1 In/Out |                                        |                                      |                            |                                          | Bit in Option2                           |
| C2 | PC2 In/Out |                                        |                                      |                            |                                          | register.                                |
| C3 | PC3 In/Out |                                        |                                      |                            |                                          | Yes =1, No=0                             |
| D0 | PD0 In/Out |                                        |                                      |                            |                                          | OEDsleepRes                              |
| D1 | PD1 In/Out |                                        |                                      |                            |                                          | Bit in Option2                           |
| D2 | PD2 In/Out |                                        |                                      |                            |                                          | register.                                |
| D3 | PD3 In/Out |                                        |                                      |                            |                                          | Yes =1, No=0                             |
| E0 | PE0 In/Out |                                        |                                      |                            |                                          |                                          |
| E1 | PE1 In/Out |                                        |                                      |                            |                                          |                                          |
| E2 | PE2 In/Out |                                        |                                      |                            |                                          |                                          |
| E3 | PE3 In/Out |                                        | proposed for the o                   |                            |                                          |                                          |

Put one letter (Y, N) in each BOX from proposed for the column.

For Pull-Up/Down if "Y" add also one letter (S,W) to define type of resistor. (see 18.5 electrical parameters also)

Table 47. PortB Hi Current Drive capability

|    |            | Driving to V <sub>ss</sub> (negative supply) Possible options are <b>4n</b> (weak), <b>10n</b> , <b>18n</b> (strong) | Driving to V <sub>DD</sub> (positive supply) Possible options are <b>6p</b> (weak), <b>14p</b> , <b>24p</b> (strong) |
|----|------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| B0 | PB0 output |                                                                                                                      |                                                                                                                      |
| B1 | PB1 output |                                                                                                                      |                                                                                                                      |
| B2 | PB2 output |                                                                                                                      |                                                                                                                      |
| В3 | PB3 output |                                                                                                                      |                                                                                                                      |

At higher  $V_{DD}$  scaling of this buffer is needed not to overcome the Maximum  $V_{DD}$  and  $V_{SS}$  current for the IC. Put in each box one of 3 possibilities mentioned in the title of column like 18n, 24p (strongest configuration). Numbers above state for number of active N and P transistors in output buffer. See electrical parameters to know what to expect at different option. Important Note: Maximum  $V_{DD}$  and  $V_{SS}$  current MUST be limited to 90 mA!! Only 2 PortB High current terminals can switch at the same time in strongest configuration to limit the spikes generated by switching.

<sup>\*1</sup> When used as N-channel Open drain output not-controlled Pull-Up (Y-SOD) can be used. Pull Up active during Output also if Y-S is set in Pull-Up & Y for Nch-open drain an external resistor is needed to make output High !!!! because Pull Up is active during input only! This is applicable only for Ports B,C,D and E which can be outputs also.

<sup>\*2</sup> Port-wise for PortC and PortD (one possibility for the whole port); PortB bit-wise



#### 15.1.1 Power-Check Level Option

| Option<br>Name |                      | Default<br>Value | User<br>Value |
|----------------|----------------------|------------------|---------------|
|                |                      | Α                | В             |
| PwCheck        | Power-Check Yes / No | NO               |               |

Power Check function can be enabled or disabled. For EM6603 compatibility the default selection is  ${\bf NO}$ , but can be set to  ${\bf YES}$  to be sure  ${\bf V}_{DD}$  on Power-Up came over SVLD level  ${\bf V}_{L1}$  before internal Reset is released and circuit starts to execute instructions.

# 15.1.2 PortA reset Option, see paragraph 4.3

| Option<br>Name |            | Default<br>Value | User<br>Value |
|----------------|------------|------------------|---------------|
|                |            | Α                | В             |
| RA             | PortAreset | rstpa_no         |               |

Refer to chapter 4.3 Input port (PA0..PA3) RESET to select the PortA reset option. Possible options are **rstpa\_no**, **rstpa\_xh** where x={3,5,6,7,9,a,b,c,d,e,f}

#### 15.1.3 SVLD levels Option, see paragraph 11 SVLD

| Option<br>Name |                     | typ. V <sub>L1</sub> level [V] | typ. V <sub>L2</sub> level [V] | typ. V <sub>L3</sub> level [V] |
|----------------|---------------------|--------------------------------|--------------------------------|--------------------------------|
| $V_{LX}$       | SVLD level in Volts |                                |                                |                                |

 $V_{L1}$  level is also the level used for Power check if activated (table 15.1.1).

 $V_{L1}$ : possible levels are from 1.3V to 3V by step of 100mV.

 $V_{L2}$ ; possible levels are 2.3V; 2.6V to 3.5V by step of 100mV; 3.7V and 4V

 $oldsymbol{V_{L3}}$  possible levels are 2.6V to 3.5V by step of 100mV ; 3.7V and 4V

| Software name is :         | bin, dated                                                   |
|----------------------------|--------------------------------------------------------------|
| The customer should spe    | ify the required options at the time of ordering.            |
| A copy of this sheet, as w | ell as the « Software ROM characteristic file » generated by |
| the assembler (*.STA) she  | uld be attached to the order.                                |



#### 16 PERIPHERAL MEMORY MAP

The following table shows the peripheral memory map of the EM6607. The address space is between 00 and F (Hex). Any addresses not shown can be considered to be reserved.

| Danistan         | 1-1        | 1-1        | power           |                              |                     |                                                    |
|------------------|------------|------------|-----------------|------------------------------|---------------------|----------------------------------------------------|
| Register<br>name | add<br>hex | add<br>dec | up              | write_bits                   | read_bits           | Remarks                                            |
|                  |            |            | value<br>b'3210 | Read/Wr                      | ita hita            |                                                    |
|                  | 00-        |            | 03210           | 0: E                         |                     |                                                    |
| RAM              | 00-        | 0-95       | XXXX            | 1: E                         |                     | dive et e delve e eine                             |
|                  | 5f         |            |                 | 2: 🗅                         |                     | direct addressing                                  |
|                  |            |            |                 | 3: [                         |                     |                                                    |
| LTimLS           | 60         | 96         | 0000            | 0: TL0<br>1: TL1             | 0: TS0<br>1: TS1    | low nibble of 8bit timer load and                  |
| LTIIILO          | 00         | 30         | 0000            | 2: TL2                       | 2: TS2              | status register                                    |
|                  |            |            |                 | 3: TL3                       | 3: TS3              | J S                                                |
|                  | 0.4        |            | 0000            | 0: TL4                       | 0: TS4              |                                                    |
| HTimLS           | 61         | 97         | 0000            | 1: TL5<br>2: TL6             | 1: TS5<br>2: TS6    | high nibble of 8bit timer load and status register |
|                  |            |            |                 | 3: TL7                       | 3: TS7              | and status register                                |
|                  |            |            |                 |                              | EC0                 |                                                    |
| TimCtr           | 62         | 98         | 0000            |                              | EC1                 | timer control register with                        |
|                  |            |            |                 |                              | EC2<br>imAuto       | frequency selector                                 |
|                  |            |            |                 |                              | oWD                 | Watch dog timer off                                |
| Option           | 63         | 99         | 0000            |                              | ebPAN               | Debouncer on port A disabled                       |
|                  |            |            |                 |                              | ebPCN               | Debouncer on port C disabled                       |
|                  |            |            |                 |                              | RQedgeR<br>uzzerPE0 | Rising edge interrupt Buzzer on PE0 enable         |
| Option2          | 64         | 100        | 0000            |                              | DEBsleepRes         | PortB OE reset by Sleep                            |
| Option2          |            | 100        | 0000            |                              | ECsleepRes          | PortC OE reset by Sleep                            |
|                  |            |            |                 |                              | EDsleepRes          | PortD OE reset by Sleep                            |
| DA0              | 0.5        | 404        | 0000            | 0: P<br>1: F                 | A3cntin             | PA3 counter input                                  |
| PA3cnt           | 65         | 101        | 0000            |                              | ουι<br>/Ddisana     | Frequency output on STRB                           |
|                  |            |            |                 | 3: 0                         |                     | Disable analogue WD                                |
|                  |            |            |                 | 0: P                         |                     |                                                    |
| PortE            | 66         | 102        | XXXX            | 1: P<br>2: P                 |                     | Port E Input/Output                                |
|                  |            |            |                 | 2. P<br>3: P                 |                     |                                                    |
|                  |            |            |                 | 0: CIOPE0                    |                     | Dort E Input/Output individual                     |
| CIOportE         | 67         | 103        | 0000            |                              | IOPE1               | Port E Input/Output individual control             |
|                  |            |            |                 |                              | IOPE2               | oona or                                            |
|                  |            |            |                 | 3: CIOPE3<br>0: CkSWB0       |                     |                                                    |
| CIkSWB           | 68         | 104        | 0000            |                              | kSWB1               | Clask salastar for SMD                             |
|                  |            |            |                 | 2: 0                         |                     | Clock selector for SWB                             |
|                  |            |            |                 | 3: V                         |                     |                                                    |
| SWBuff           | 69         | 105        | 1111            | 0: B<br>1: B                 |                     |                                                    |
| CTTDUII          |            | .55        | ''''            | 1: Buff1 SWB intermediate bu |                     | SWB intermediate buffer                            |
|                  |            |            |                 | 3: Buff3                     |                     |                                                    |
| LOWSIMD          | 6A         | 106        | 0000            | 0: size[0] low nib           |                     | low nibble to define the size of                   |
| LowSWB           | UA         | 106        | 0000            | 1: size[1]<br>2: size[2]     |                     | data to be send in Automatic                       |
|                  |            |            |                 | 3: size[2]                   |                     | mode                                               |
|                  |            |            |                 | 0: size[4]                   |                     |                                                    |
| HighSWB          | 6B         | 107        | 0000            | 1: size[5]<br>2: StSWB       |                     | the size of the data to be sent & SWB control      |
|                  |            |            |                 |                              | utoSWB              | SVVD COITHOI                                       |
| Posistor         | add        | add        | power           | 3.7                          |                     |                                                    |
| Register<br>name | hex        | dec        | up              | write_bits                   | read_bits           | Remarks                                            |
|                  |            |            | value           |                              |                     |                                                    |





|            |    |     | b'3210 | Read/Writ                                    | e_bits                                           |                                                                             |
|------------|----|-----|--------|----------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------|
| SVLD       | 6C | 108 | 0000   | 0: VLC0<br>1: VLC1<br>2: -<br>3: -           | 0: VLC0<br>1: VLC1<br>2: busy<br>3: VLDR         | voltage level<br>detector control                                           |
| CIRQD      | 6D | 109 | 0000   | 0: INTEN<br>1: DebCK<br>2: 0<br>3: 0         |                                                  | global interrupt enable<br>debouncer clock<br>IRQ Comp Bit<br>IRQ Comp Mask |
| Index LOW  | 6E | 110 | xxxx   | 0.0                                          |                                                  | internally used for INDEX register                                          |
| Index HIGH | 6F | 111 | XXXX   |                                              |                                                  | internally used for INDEX register                                          |
| IntRq      | 70 | 112 | 0000   | 0: -<br>1: -<br>2: SLEEP<br>3: -             | 0: INTPA<br>1: INTPC<br>2: INTTE<br>3: INTPR     | interrupt requests sleep mode                                               |
| WD         | 71 | 113 | 0000   | 0: -<br>1: -<br>2: SLmask<br>3: WDrst        | 0: WD0<br>1: WD1<br>2: SLmask<br>3: 0            | WatchDog timer control and SLEEP mask                                       |
| PortA      | 72 | 114 | XXXX   | c. Water                                     | 0: PA0<br>1: PA1<br>2: PA2<br>3: PA3             | Port A status                                                               |
| IRQpA      | 73 | 115 | 0000   |                                              | 0: IRQpa0<br>1: IRQpa1<br>2: IRQpa2<br>3: IRQpa3 | Port A interrupt request                                                    |
| MPortA     | 74 | 116 | 0000   | 0: MPA0<br>1: MPA1<br>2: MPA2<br>3: MPA3     |                                                  | Port A mask                                                                 |
| PortB      | 75 | 117 | xxxx   | 0: PB0<br>1: PB1<br>2: PB2<br>3: PB3         |                                                  | Port B Input/Output                                                         |
| CIOportB   | 76 | 118 | 0000   | 0: CIOPB<br>1: CIOPB<br>2: CIOPB<br>3: CIOPB | 1<br>2                                           | Port B Input/Output individual control                                      |
| PortC      | 77 | 119 | xxxx   | 0: PC0<br>1: PC1<br>2: PC2<br>3: PC3         |                                                  | Port C Input/Output                                                         |
| IRQpC      | 78 | 120 | 0000   |                                              | 0: IRQpc0<br>1: IRQpc1<br>2: IRQpc2<br>3: IRQpc3 | Port C interrupt request                                                    |
| MPortC     | 79 | 121 | 0000   | 0: MPC0<br>1: MPC1<br>2: MPC2<br>3: MPC3     | ·                                                | Port C mask                                                                 |
| PortD      | 7A | 122 | xxxx   | 0: PD0<br>1: PD1<br>2: PD2<br>3: PD3         |                                                  | Port D Input/Output                                                         |





| Register<br>name | add<br>hex | add<br>dec | power<br>up<br>value | write_bits                                | read_bits                             | Remarks                                               |
|------------------|------------|------------|----------------------|-------------------------------------------|---------------------------------------|-------------------------------------------------------|
|                  |            |            | b'3210               | Read/Wr                                   | ite_bits                              |                                                       |
| RegSoftPOR       | 7B         | 123        | 0000                 | 0: 0<br>1: 0<br>2:                        | 0: 0<br>1: 0<br>2:                    | 0 (                                                   |
|                  |            |            |                      | 3: SoftPOR                                | 3:                                    | Software POR                                          |
| CPIOB            | 7C         | 124        | x000                 | 0: PA&C<br>1: CIOPC<br>2: CIOPD<br>3: 0   |                                       | PortAirq AND PortCirq<br>PortC In/Out<br>PortD In/Out |
| PRESC            | 7D         | 125        | 0000                 | 0: PSF0<br>1: PSF1<br>2: PRST<br>3: MTim  | 0: PSF0<br>1: PSF1<br>2: 0<br>3: MTim | Prescaler control timer mask                          |
| BEEP             | 7E         | 126        | 0000                 | 0: BCF0<br>1: BCF1<br>2: BUen<br>3: TimEn |                                       | Buzzer control  Timer Enable                          |
| RegTestEM        | 7F         | 127        |                      |                                           |                                       | reserved                                              |



# 17 Temperature and Voltage Behaviours

# 17.1 IDD Current (Typical)















# 17.2 Pull-down resistance (Typical)



















# 17.3 Output Currents (Typical)

























#### 18 Electrical specifications

# 18.1 Absolute maximum ratings

| Parameter                                       | min.                  | max.                 | unit |
|-------------------------------------------------|-----------------------|----------------------|------|
| Supply voltage V <sub>DD</sub> -V <sub>SS</sub> | - 0.2                 | + 3.6                | V    |
| V <sub>DD</sub> current (DC)                    |                       | 90                   | mA   |
| V <sub>SS</sub> current (DC)                    |                       | 90                   | mA   |
| Input voltage                                   | V <sub>SS</sub> - 0.2 | V <sub>DD</sub> +0.2 | V    |
| Storage temperature                             | - 40                  | + 125                | °C   |

Stresses above these listed maximum ratings may cause permanent damage to the device. Exposure beyond specified electrical characteristics may affect device reliability or cause malfunction.

# 18.2 Standard Operating Conditions

| Parameter                                   | value          | Description                                      |
|---------------------------------------------|----------------|--------------------------------------------------|
| Temperature                                 | -20°C to +85°C |                                                  |
| V <sub>DD_range1</sub>                      | 1.4V to 3.3V   | With internal voltage regulator                  |
| $V_{DD\_range2}(V_{REG} = V_{DD})$ (note 1) | 1.2V to 1.8V   | Without internal voltage regulator               |
| $V_{SS}$                                    | 0V (reference) |                                                  |
| CV <sub>REG</sub>                           | min. 100nF     | regulated voltage capacitor tow. V <sub>SS</sub> |
| fq                                          | 32768Hz        | nominal frequency                                |
| R <sub>QS</sub>                             | 35kΩ           | typical quartz serial resistor                   |
| C <sub>L</sub>                              | 8.2pF          | typical quartz load capacitance                  |
| df/f                                        | ± 30ppm        | quartz frequency tolerance                       |

#### 18.3 Handling Procedures

This device has built-in protection against high static voltages or electric fields; however, anti-static precautions should be taken as for any other CMOS component.

Unless otherwise specified, proper operation can only occur when all terminal voltages are kept within the supply voltage range.

#### 18.4 DC characteristics - Power Supply Pins

Conditions: V<sub>DD</sub>=V<sub>REG</sub>=1.5V, T=25°C (note 5) (unless otherwise specified)

| Parameter                                                             | Conditions                              | Symb.                   | Min. | Typ.<br>(note1) | Max. | Unit |
|-----------------------------------------------------------------------|-----------------------------------------|-------------------------|------|-----------------|------|------|
| ACTIVE Supply Current                                                 | +25°C (note2)                           | I <sub>VDDa</sub>       |      | 1.8             | 3.0  | μΑ   |
| ACTIVE Supply Current (note2) (note2) (in active mode) -20°C to +85°C |                                         | I <sub>VDDa</sub>       |      |                 | 4.5  | μА   |
| STANDBY Supply Current                                                | +25°C                                   | I <sub>VDDh</sub>       |      | 0.5             | 1.0  | μΑ   |
| STANDBY Supply Current (in Halt mode)                                 | (note3)<br>-20°C to +85°C               | $I_{VDDh}$              |      |                 | 1.8  | μА   |
| SLEEP Supply Current                                                  | +25°C                                   | I <sub>VDDs</sub>       |      | 0.1             | 0.4  | μА   |
| SLEEP Supply Current (SLEEP =1)                                       | (note3)<br>-20°C to +85°C               | I <sub>VDDs</sub>       |      |                 | 1.2  | μА   |
| POR voltage                                                           |                                         | <b>V</b> <sub>POR</sub> |      | 0.7             | 1.0  | V    |
| RAM data retention                                                    |                                         | $V_{RD}$                | 1.1  |                 |      | V    |
| Regulated Voltage                                                     | V <sub>REG</sub> not at V <sub>DD</sub> | $V_{REG}$               | 1.10 |                 | 1.5  | V    |



Conditions:  $V_{DD}$ =3.0V, T=25°C (note 5) (unless otherwise specified),  $V_{REG}$  not shorted to  $V_{DD}$ 

| Parameter                              | Conditions                          | Symb.                   | Min. | Тур.     | Max. | Unit |
|----------------------------------------|-------------------------------------|-------------------------|------|----------|------|------|
|                                        |                                     |                         |      | (note 2) |      |      |
| ACTIVE Supply Current                  | +25°C (note 3)                      | I <sub>VDDa</sub>       |      | 1.8      | 3.0  | μΑ   |
| ACTIVE Supply Current (in active mode) | (note 3) (note 4)<br>-20°C to +85°C | I <sub>VDDa</sub>       |      |          | 4.5  | μА   |
| STANDBY Supply Current                 | +25°C                               | I <sub>VDDh</sub>       |      | 0.5      | 1.0  | μА   |
| STANDBY Supply Current                 | (note 4)                            |                         |      |          |      |      |
| (in Halt mode)                         | -20°C to +85°C                      | I <sub>VDDh</sub>       |      |          | 1.8  | μΑ   |
| SLEEP Supply Current                   | +25°C                               | I <sub>VDDs</sub>       |      | 0.1      | 0.4  | μА   |
| SLEEP Supply Current                   | (note 4)                            |                         |      |          |      |      |
| (SLEEP =1)                             | -20°C to +85°C                      | I <sub>VDDs</sub>       |      |          | 1.2  | μΑ   |
| POR voltage                            |                                     | <b>V</b> <sub>POR</sub> |      | 0.7      | 1.0  | V    |
| RAM data retention                     |                                     | $V_{RD}$                | 1.1  |          |      | V    |
| Regulated Voltage                      | -20°C to +85°C                      | $V_{REG}$               | 1.10 |          | 1.90 | V    |

- Note 1
- Because of the voltage regulator drop at low voltages  $V_{REG} = V_{DD}$  when  $V_{DD} < 1.8V$  For current measurement typical quartz described in Operating Conditions is used. All I/O pins without internal Pull Up/Down are pulled to  $V_{DD}$  externally.
- Note 3: Test loop with successive writing and reading of two different addresses with an inverted values (five instructions should be reserved for this measurement),
- Note 4: NOT tested if delivered in chip form.
- Note 5: Test conditions for ACTIVE and STANDBY Supply current mode are:  $Q_{IN}$  = external square wave, from rail to rail of  $V_{\text{REG}}$  (regulated voltage) with 100nF capacitor on  $V_{\text{REG}}$ .  $fQ_{IN} = 32kHz$ .



# 18.5 DC characteristics - Input/Output Pins

Conditions: V<sub>DD</sub>=1.5V / 3.0V, -20°C <T<85°C (unless otherwise specified)

| Parameter                                                                                                 | Conditions                                                                    | Symb.           | Min.                                                            | Тур.                           | Max.                                                            | Unit                 |
|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------------|-----------------------------------------------------------------|--------------------------------|-----------------------------------------------------------------|----------------------|
| Input Low voltage I/O ports A,B,C,D,E TEST, Reset Q <sub>IN</sub> (Note5)                                 | Pin at hi-impedance                                                           | V <sub>IL</sub> | V <sub>SS</sub><br>V <sub>SS</sub><br>V <sub>SS</sub>           |                                | 0.3V <sub>DD</sub><br>0.3V <sub>DD</sub><br>0.3V <sub>REG</sub> | V<br>V               |
| Input High voltage I/O ports A,B,C,D,E TEST, Reset Q <sub>IN</sub> (Note5)                                | Pin at hi-impedance                                                           | V <sub>IH</sub> | 0.7V <sub>DD</sub><br>0.7V <sub>DD</sub><br>0.9V <sub>REG</sub> |                                | $V_{DD}$ $V_{DD}$ $V_{REG}$                                     | V<br>V               |
| Output Low Current Port B 18 transistors                                                                  | VOL = 0.15V, V <sub>DD</sub> = 1.2V                                           | I <sub>OL</sub> | 3.0                                                             | 6.0                            |                                                                 | mA                   |
| Output Low Current Port B 18 transistors Port B 10 transistors Port B 4 transistors Port C,D,E, STRB/RST  | VOL = 0.3V, V <sub>DD</sub> = 1.5V                                            | I <sub>OL</sub> | 9.5<br>5.0<br>1.5<br>1.0                                        | 15.0<br>8.0<br>3.5<br>2.5      |                                                                 | mA<br>mA<br>mA       |
| Output Low Current Port B 18 transistors Port B 10 transistors Port B 4 transistors Port C,D,E, STRB/RST  | VOL = 0.4V, V <sub>DD</sub> = 3.0V                                            | I <sub>OL</sub> | 23.0<br>13.0<br>5.4<br>5.4                                      | 33.0<br>20.5<br>8.8<br>7.8     |                                                                 | mA<br>mA<br>mA<br>mA |
| Output High Current Port B 24 transistors                                                                 | VOH = 1.05V, V <sub>DD</sub> = 1.2V                                           | Іон             |                                                                 | -3.5                           | -2.5                                                            | mA                   |
| Output High Current Port B 24 transistors Port B 14 transistors Port B 6 transistors Port C,D,E, STRB/RST | VOH = 1.2V, V <sub>DD</sub> = 1.5V                                            | I <sub>OH</sub> |                                                                 | -9.4<br>-5.0<br>-2.5<br>-1.2   | -6.0<br>-3.0<br>-1.5<br>-0.6                                    | mA<br>mA<br>mA       |
| Output High Current Port B 24 transistors Port B 14 transistors Port B 6 transistors Port C,D,E, STRB/RST | VOH = 2.5V, V <sub>DD</sub> = 3.0V                                            | Іон             |                                                                 | -33.0<br>-20.0<br>-9.0<br>-4.5 | -23.0<br>-15.0<br>-3.0<br>-3.0                                  | mA<br>mA<br>mA       |
| Output load on Port B  Capacitor Resistor                                                                 | V <sub>DD</sub> = 3.0V,Port B 18/24 transistors option with 4 toggling ports. |                 | 150                                                             |                                | 50                                                              | nF                   |
| Input pull-down strong I/O ports A,B,C,D,E (option) Reset Test                                            | Pin at V <sub>DD</sub> = 1.5V, 25°C                                           | R <sub>IN</sub> | 50<br>50<br>10                                                  | 90<br>110<br>18                | 350<br>200<br>35                                                | kΩ<br>kΩ<br>kΩ       |
| Input pull-down strong I/O ports A,B,C,D,E (option) Reset Test                                            | Pin at V <sub>DD</sub> = 3.0V, 25°C                                           | R <sub>IN</sub> | 50<br>50<br>10                                                  | 90<br>110<br>18                | 160<br>200<br>35                                                | kΩ<br>kΩ<br>kΩ       |
| Input pull-down weak I/O ports A,B,C,D,E (option)                                                         | Pin at V <sub>DD</sub> = 1.5V, 25°C                                           | R <sub>IN</sub> | 80                                                              | 130                            | 350                                                             | kΩ                   |
| Input pull-down weak I/O ports A,B,C,D,E (option)                                                         | Pin at V <sub>DD</sub> = 3.0V, 25°C                                           | R <sub>IN</sub> | 50                                                              | 250                            | 600                                                             | kΩ                   |
| Input pull-up strong I/O ports A,B,C,D,E (option)                                                         | Pin at V <sub>DD</sub> = 1.5V, 25°C                                           | R <sub>IN</sub> | 50                                                              | 100                            | 250                                                             | kΩ                   |
| Input pull-up strong I/O ports A,B,C,D,E (option)                                                         | Pin at V <sub>DD</sub> = 3.0V, 25°C                                           | R <sub>IN</sub> | 50                                                              | 100                            | 200                                                             | kΩ                   |
| Input pull-up weak I/O ports A,B,C,D,E (option)                                                           | Pin at V <sub>DD</sub> = 1.5V, 25°C                                           | R <sub>IN</sub> | 300                                                             | 550                            | 1000                                                            | kΩ                   |
| Input pull-up weak I/O ports A,B,C,D,E (option)                                                           | Pin at V <sub>DD</sub> = 3.0V, 25°C                                           | R <sub>IN</sub> | 100                                                             | 180                            | 400                                                             | kΩ                   |

Note 5:  $Q_{\text{OUT}}$  is used only with crystal.



# 18.6 DC characteristics - Supply Voltage Detector Levels

Conditions: T= +25°C (unless otherwise specified)

| Parameter               | Conditions   | Symb.    | Min.                    | Тур.             | Max.                    | Unit |
|-------------------------|--------------|----------|-------------------------|------------------|-------------------------|------|
| Supply Voltage Detector |              |          |                         |                  |                         |      |
| SVLD lev3               |              | $V_{L3}$ | 0.88 x V <sub>L3</sub>  | V <sub>L3</sub>  | 1.12 x V <sub>L3</sub>  | V    |
| SVLD lev2               |              | $V_{L2}$ | $0.88 \times V_{12}$    | $V_{12}$         | 1.12 x V <sub>1.2</sub> | V    |
| SVLD lev1               |              | $V_{L1}$ | 0.88 x V <sub>L1</sub>  | V <sub>L1</sub>  | 1.12 x V <sub>L1</sub>  | V    |
| Supply Voltage Detector | 0°C to +65°C |          |                         |                  |                         |      |
| SVLD lev3               |              | $V_{13}$ | 0.88 x V <sub>1.3</sub> | V <sub>1.3</sub> | 1.12 x V <sub>1.3</sub> | V    |
| SVLD lev2               |              | $V_{L2}$ | 0.88 x V <sub>1.2</sub> | V <sub>L2</sub>  | 1.12 x V <sub>1.2</sub> | V    |
| SVLD lev1               |              | $V_{L1}$ | 0.88 x V <sub>L1</sub>  | V <sub>L1</sub>  | 1.12 x V <sub>L1</sub>  | V    |

SVLD typical level values must be selected with a precision of 100 mV.

# 18.7 Oscillator

Conditions: T=25°C (unless otherwise specified)

| Parameter                                           | Conditions                            | Symbol               | Min.                | Тур. | Max. | Unit    |
|-----------------------------------------------------|---------------------------------------|----------------------|---------------------|------|------|---------|
| Temperature stability                               | +15°C to +35 °C                       | df/f x dT            |                     |      | 0,3  | ppm /°C |
| Voltage stability                                   | V <sub>DD</sub> =1,4V to 1,6 V        | df/f x dU            |                     |      | 5    | ppm /V  |
| Input capacitor                                     | Ref. on V <sub>SS</sub>               | CIN                  | 5,6                 | 7    | 8,4  | pF      |
| Output capacitor                                    | Ref. on V <sub>SS</sub>               | CIN                  | 12,1                | 14   | 15,9 | pF      |
| Transconductance                                    | 50mVpp,V <sub>DD</sub> min            | Gm                   | 2.5                 |      | 15.0 | μA/V    |
| Oscillator start voltage                            | T <sub>START</sub> < 10 s             | U <sub>START</sub>   | V <sub>DD</sub> min |      |      | V       |
| Oscillator start time                               | $V_{DD} > V_{DD}$ Min                 | t <sub>DOSC</sub>    |                     | 0.5  | 3    | s       |
| System start time (oscillator + cold-start + reset) |                                       | t <sub>DSYS</sub>    |                     | 1.5  | 4    | s       |
| Oscillation detector frequency                      | V <sub>DD</sub> > V <sub>DD</sub> min | t <sub>DetFreq</sub> |                     | 6    | 12   | kHz     |

# 18.8 Input Timing characteristics

Conditions:  $1.5V < V_{DD} < 3.0V$ ,  $-20^{\circ}C < T < 85^{\circ}C$  (unless otherwise specified)

| Parameter                                | Conditions          | Symb.  | Min. | Unit |
|------------------------------------------|---------------------|--------|------|------|
| RESET pulse length to exit<br>SLEEP mode | RESET from<br>SLEEP | tRESsI | 2    | μS   |
| RESET pulse length (debounced)           | DebCK = 0           | tdeb0  | 2    | ms   |
| PortA , C pulse length (debounced)       | DebCK = 0           | tdeb0  | 2    | ms   |
| RESET pulse length (debounced)           | DebCK = 1           | tdeb1  | 16   | ms   |
| PortA , C pulse length (debounced)       | DebCK = 1           | tdeb1  | 16   | ms   |



# 19 Pad Location Diagram





# 20 Package Dimensions



Figure 17. Dimensions of SOP24 Package SOIC



Figure 18. Dimensions of TSSOP24 Package





Figure 19. Dimensions of SOP28 Package SOIC



Figure 20. Dimensions of TSSOP28 Package



#### 21 Ordering Information



Ordering Part Number (selected examples)

| Part Number     | Package/Die Form   | Delivery Form/ Thickness |
|-----------------|--------------------|--------------------------|
| EM6607SO28A-%%% | 28 pin SOIC        | Stick                    |
| EM6607SO28B-%%% | 28 pin SOIC        | Tape&Reel                |
| EM6607SO24A-%%% | 24 pin SOIC        | Stick                    |
| EM6607SO24B-%%% | 24 pin SOIC        | Tape&Reel                |
| EM6607TP28B-%%% | 28 pin TSSOP       | Tape&Reel                |
| EM6607TP24B-%%% | 24 pin TSSOP       | Tape&Reel                |
| EM6607WS11-%%%  | Sawn wafer         | 11 mils                  |
| EM6607WP11-%%%  | Die in waffle pack | 11 mils                  |

Please make sure to give the complete Part Number when ordering, including the 3-digit customer version. The customer version is made of 3 numbers %%% (e.g. 008, 012, 131, etc.)

#### 21.1 Package Marking

| 24/28-pin               | SOIC | marking: |
|-------------------------|------|----------|
| 2 <del>1</del> /20-0111 | 3010 | maining. |

24-pin TSSOP marking:

| Е | М | 6 | 6 | 0 | 7 | % | % |
|---|---|---|---|---|---|---|---|
| Р | Р | Р | Р | Р | Р | Р | Р |
|   |   | С | O | O | O | Υ | Ρ |

28-pin TSSOP marking:

Where: %%% or %% = customer version, specific number given by EM (e.g. 008, 012, 131, etc.)

PP...P = Production identification (date & lot number) of EM Microelectronic

Y = year of assembly

CC...C = Customer specific package marking on third line, selected by customer

#### 21.2 Customer Marking

There are 11 digits available for customer marking on SO24/28, 4 for TSSOP24, and 8 for TSSOP14.

EM Microelectronic-Marin SA (EM) makes no warranty for the use of its products, other than those expressly contained in the Company's standard warranty which is detailed in EM's General Terms of Sale located on the Company's web site. EM assumes no responsibility for any errors which may appear in this document, reserves the right to change devices or specifications detailed herein at any time without notice, and does not make any commitment to update the information contained herein. No licenses to patents or other intellectual property of EM are granted in connection with the sale of EM products, expressly or by implications. EM's products are not authorized for use as components in life support devices or systems.

© EM Microelectronic-Marin SA, 01/06, Rev. D