# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



# Features

- Single Package Fully-integrated 4-bit Microcontroller with RF Transmitter
- Low Power Consumption in Sleep Mode (< 1 µA Typically)</li>
- Flash Controller for Application Program Available
- Maximum Output Power with Low Supply Current
- 2.0V to 4.0V Operation Voltage for Single Li-cell Power Supply
- –40°C to +125°C Operation Temperature
- SSO24 Package
- About Seven External Components

# 1. Description

The ATAM862-8 is a single package dual-chip circuit. It combines a UHF ASK/FSK transmitter with a 4-bit microcontroller. It supports highly integrated solutions in car access and tire pressure monitoring applications, as well as manifold applications in the industrial and consumer segment. It is available for the transmitting frequency range of 868 MHz to 928 MHz with data rates up to 32 kbaud Manchester coded.

For further frequency ranges 310 MHz to 330 MHz and 429 MHz to 439 MHz separate datasheets are available.

The device contains a flash microcontroller.

Figure 1-1. Application Diagram





Microcontroller with UHF ASK/FSK Transmitter

# ATAM862-8

4590G-4BMCU-06/07





# 2. Pin Configuration

Figure 2-1. Pinning SSO24



| Table 2-1. Pi | n Description: RF Part |
|---------------|------------------------|
|---------------|------------------------|

| Pin | Symbol | Function               | Configuration                                        |
|-----|--------|------------------------|------------------------------------------------------|
| 1   | XTAL   | Connection for crystal | XTAL<br>182 µA                                       |
| 2   | VS     | Supply voltage         | ESD protection circuitry (see Figure 7-5 on page 11) |
| 3   | GND    | Ground                 | ESD protection circuitry (see Figure 7-5 on page 11) |
| 4   | ENABLE | Enable input           | ENABLE 200k                                          |

2

# ATAM862-8

| Table 2-1. | Pin Description: | RF Part | (Continued) | ) |
|------------|------------------|---------|-------------|---|
|            |                  |         |             |   |

| Pin      | Symbol       | Function                                                                                                                | Configuration                           |
|----------|--------------|-------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
| 21       | CLK          | Clock output signal for microcontroller,<br>the clock output frequency is set by the<br>crystal to f <sub>XTAL</sub> /4 | VS<br>100<br>100<br>CLK                 |
| 22       | PA_ENABLE    | Switches on power amplifier, used for<br>ASK modulation                                                                 | PA_ENABLE 50k Uref = 1.1V<br>20 $\mu$ A |
| 23<br>24 | ANT2<br>ANT1 | Emitter of antenna output stage<br>Open collector antenna output                                                        | ANT1<br>ANT2                            |

| Table 2-2. | Pin Description: Microcontroller Part |
|------------|---------------------------------------|
|------------|---------------------------------------|

| Name            | Туре | Function                            | Alternate Function                                                                                      | Pin No. | Reset State |
|-----------------|------|-------------------------------------|---------------------------------------------------------------------------------------------------------|---------|-------------|
| V <sub>DD</sub> | -    | Supply voltage                      | -                                                                                                       | 13      | NA          |
| V <sub>SS</sub> | -    | Circuit ground                      | -                                                                                                       | 12      | NA          |
| BP20            | I/O  | Bi-directional I/O line of Port 2.0 | NTE-test mode enable, see also section "Master Reset"                                                   | 7       | Input       |
| BP40            | I/O  | Bi-directional I/O line of Port 4.0 | SC-serial clock or INT3 external interrupt input                                                        | 14      | Input       |
| BP41            | I/O  | Bi-directional I/O line of Port 4.1 | VMI voltage monitor input or T2I external clock input<br>Timer 2                                        | 9       | Input       |
| BP42            | I/O  | Bi-directional I/O line of Port 4.2 | T2O Timer 2 output                                                                                      | 10      | Input       |
| BP43            | I/O  | Bi-directional I/O line of Port 4.3 | SD serial data I/O or INT3-external interrupt input                                                     | 11      | Input       |
| BP50            | I/O  | Bi-directional I/O line of Port 5.0 | INT6 external interrupt input                                                                           | 17      | Input       |
| BP52            | I/O  | Bi-directional I/O line of Port 5.2 | INT1 external interrupt input                                                                           | 16      | Input       |
| BP53            | I/O  | Bi-directional I/O line of Port 5.3 | INT1 external interrupt input                                                                           | 15      | Input       |
| BP60            | I/O  | Bi-directional I/O line of Port 6.0 | T3O Timer 3 output                                                                                      | 20      | Input       |
| BP63            | I/O  | Bi-directional I/O line of Port 6.3 | T3I Timer 3 input                                                                                       | 6       | Input       |
| OSC1            | I    | Oscillator input                    | 4-MHz crystal input or 32-kHz crystal input or external clock input or external trimming resistor input | 18      | Input       |
| OSC2            | 0    | Oscillator output                   | 4-MHz crystal output or 32-kHz crystal output or external clock input                                   | 19      | Input       |
| NRESET          | I/O  | Bi-directional reset pin            | -                                                                                                       | 5       | I/O         |





# 3. UHF ASK/FSK Transmitter Block

# 4. Features

- Integrated PLL Loop Filter
- ESD Protection also at ANT1/ANT2 (4 kV HBM/200 V MM, Except Pin 2: 4 kV HBM/100 V MM)
- High Output Power (5.5 dBm) with Low Supply Current (8.5 mA)
- Modulation Scheme ASK/FSK
  - FSK Modulation is Achieved by Connecting an Additional Capacitor between the XTAL Load Capacitor and the Open-drain Output of the Modulating Microcontroller
- Easy to Design-in Due to Excellent Isolation of the PLL from the PA and Power Supply
- Single Li-cell for Power Supply
- Supply Voltage 2.0 V to 4.0 V in the Temperature Range of -40° C to 85° C/125° C
- Single-ended Antenna Output with High Efficient Power Amplifier
- CLK Output for Clocking the Microcontroller
- One-chip Solution with Minimum External Circuitry
- 125° C Operation for Tire Pressure Systems

# 5. Description

The PLL transmitter block has been developed for the demands of RF low-cost transmission systems, at data rates up to 32 kbaud. The transmitting frequency range is 868 MHz to 928 MHz. It can be used in both FSK and ASK systems.

4

Figure 5-1. Block Diagram







# 6. General Description

The fully-integrated PLL transmitter that allows particularly simple, low-cost RF miniature transmitters to be assembled. The VCO is locked to  $64 \times f_{XTAL}$ , thus, a 13.5672 MHz crystal is needed for a 868.3 MHz transmitter and a 14.2969 MHz crystal for a 915 MHz transmitter. All other PLL and VCO peripheral elements are integrated.

The XTO is a series resonance oscillator so that only one capacitor together with a crystal connected in series to GND are needed as external elements.

The crystal oscillator together with the PLL needs typically < 1 ms until the PLL is locked and the CLK output is stable. A wait time of  $\geq$  4 ms must be used until the CLK is used for the microcontroller and the PA is switched on.

The power amplifier is an open-collector output delivering a current pulse which is nearly independent from the load impedance. The delivered output power is controlled via the connected load impedance.

This output configuration enables a simple matching to any kind of antenna or to 50  $\Omega$  A high power efficiency of  $\eta = P_{out}/(I_{S,PA} \times V_S)$  of 24% for the power amplifier at 868.3 MHz results when an optimized load impedance of  $Z_{Load} = (166 + j226) \Omega$  is used at 3 V supply voltage.

# 7. Functional Description

If ENABLE = L and PA\_ENABLE = L, the circuit is in standby mode consuming only a very small amount of current, so that a lithium cell used as power supply can work for several years.

With ENABLE = H, the XTO, PLL and the CLK driver are switched on. If PA\_ENABLE remains L, only the PLL and the XTO are running and the CLK signal is delivered to the microcontroller. The VCO locks to 64 times the XTO frequency.

With ENABLE = H and PA\_ENABLE = H, the PLL, XTO, CLK driver and the power amplifier are on. With PA\_ENABLE, the power amplifier can be switched on and off, which is used to perform the ASK modulation.

## 7.1 ASK Transmission

The PLL transmitter block is activated by ENABLE = H. PA\_ENABLE must remain L for t  $\ge$  4 ms, then the CLK signal can be taken to clock the microcontroller and the output power can be modulated by means of pin PA\_ENABLE. After transmission, PA\_ENABLE is switched to L and the microcontroller switches back to internal clocking. The ATAM862-8 is switched back to standby mode with ENABLE = L.

#### 7.2 FSK Transmission

The PLL transmitter block is activated by ENABLE = H. PA\_ENABLE must remain L for  $t \ge 4$  ms, then the CLK signal can be taken to clock the microcontroller and the power amplifier is switched on with PA\_ENABLE = H. The chip is then ready for FSK modulation. The microcontroller starts to switch on and off the capacitor between the XTAL load capacitor and GND with an open-drain output port, thus changing the reference frequency of the PLL. If the switch is closed, the output frequency is lower than if the switch is open. After transmission PA\_ENABLE is switched to L and the microcontroller switches back to internal clocking. The PLL transmitter block is switched back to standby mode with ENABLE = L.

The accuracy of the frequency deviation with XTAL pulling method is about  $\pm 25\%$  when the following tolerances are considered.

#### Figure 7-1. Tolerances of Frequency Modulation



Using C<sub>4</sub> = 9.2 pF ±2%, C<sub>5</sub> = 6.8 pF ±5%, a switch port with C<sub>Switch</sub> = 3 pF ±10%, stray capacitances on each side of the crystal of C<sub>Stray1</sub> = C<sub>Stray2</sub> = 1 pF ±10%, a parallel capacitance of the crystal of C<sub>0</sub> = 3.2 pF ±10% and a crystal with C<sub>M</sub> = 13 fF ±10%, an FSK deviation of ±21 kHz typical with worst case tolerances of ±16.3 kHz to ±28.8 kHz results.

#### 7.3 CLK Output

An output CLK signal is provided for a connected microcontroller. The delivered signal is CMOS compatible if the load capacitance is lower than 10 pF.

#### 7.3.1 Clock Pulse Take Over

The clock of the crystal oscillator can be used for clocking the microcontroller. The Microcontroller block has the special feature of starting with an integrated RC-oscillator to switch on the PLL transmitter block with ENABLE = H, and after 4 ms to assume the clock signal of the transmission IC, so the message can be sent with crystal accuracy.

#### 7.3.2 Output Matching and Power Setting

The output power is set by the load impedance of the antenna. The maximum output power is achieved with a load impedance of  $Z_{Load,opt} = (166 + j226) \Omega$  at 868.3 MHz. There must be a low resistive path to V<sub>S</sub> to deliver the DC current.

The delivered current pulse of the power amplifier is 7.7 mA and the maximum output power is delivered to a resistive load of 475  $\Omega$  if the 0.53 pF output capacitance of the power amplifier is compensated by the load impedance.

An optimum load impedance of:

 $Z_{Load}$  = 475  $\Omega \parallel j/(2 \times \pi \times f \times 0.53 \text{ pF})$  = (166 + j226)  $\Omega$  thus results for the maximum output power of 5.5 dBm.

The load impedance is defined as the impedance seen from the PLL transmitter block's ANT1, ANT2 into the matching network. Do not confuse this large signal load impedance with a small signal input impedance delivered as input characteristic of RF amplifiers and measured from the application into the IC instead of from the IC into the application for a power amplifier.

Less output power is achieved by lowering the real parallel part of 475  $\Omega$  where the parallel imaginary part should be kept constant.

Output power measurement can be done with the circuit shown in Figure 7-2 on page 8. Note that the component values must be changed to compensate the individual board parasitics until the PLL transmitter block has the right load impedance  $Z_{Load,opt} = (166 + j226) \Omega$  at 868.3 MHz. Also the damping of the cable used to measure the output power must be calibrated.





#### Figure 7-2. Output Power Measurement



#### 7.4 Application Circuit

For the supply-voltage blocking capacitor  $C_3$ , a value of 68 nF/X7R is recommended (see Figure 7-3 on page 9 and Figure 7-4 on page 10).  $C_1$  and  $C_2$  are used to match the loop antenna to the power amplifier where  $C_1$  typically is 3.9 pF/NP0 and  $C_2$  is 1 pF/NP0; for  $C_2$  two capacitors in series should be used to achieve a better tolerance value and to have the possibility to realize the  $Z_{Load,opt}$  by using standard valued capacitors.

 $C_1$  forms together with the pins of PLL transmitter block and the PCB board wires a series resonance loop that suppresses the 1<sup>st</sup> harmonic, thus, the position of  $C_1$  on the PCB is important. Normally the best supression is achieved when  $C_1$  is placed as close as possible to the pins ANT1 and ANT2.

The loop antenna should not exceed a width of 1.5 mm, otherwise the Q-factor of the loop antenna is too high.

 $L_1 \approx 50$  nH to 100 nH) can be printed on PCB.  $C_4$  should be selected so the XTO runs on the load resonance frequency of the crystal. Normally, a value of 12 pF results for a 15 pF load-capacitance crystal.

8

Figure 7-3. ASK Application Circuit











**NEL** 

Figure 7-4. FSK Application Circuit





# 8. Absolute Maximum Ratings: RF Part

Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions beyond those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

| Parameters           | Symbol                    | Min. | Max.                                  | Unit |
|----------------------|---------------------------|------|---------------------------------------|------|
| Supply voltage       | V <sub>S</sub>            |      | 5                                     | V    |
| Power dissipation    | P <sub>tot</sub>          |      | 100                                   | mW   |
| Junction temperature | Tj                        |      | 150                                   | °C   |
| Storage temperature  | T <sub>stg</sub>          | -55  | +125                                  | °C   |
| Ambient temperature  | T <sub>amb</sub>          | -55  | +125                                  | °C   |
| Input voltage        | V <sub>maxPA_ENABLE</sub> | -0.3 | (V <sub>S</sub> + 0.3) <sup>(1)</sup> | V    |

Note: 1. If  $V_S$  + 0.3 is higher than 3.7 V, the maximum voltage will be reduced to 3.7 V.

# 9. Thermal Resistance

| Parameters       | Symbol            | Value | Unit |
|------------------|-------------------|-------|------|
| Junction ambient | R <sub>thJA</sub> | 135   | K/W  |

# **10. Electrical Characteristics**

 $V_S$  = 2.0 V to 4.0 V,  $T_{amb}$  = -40°C to +125°C unless otherwise specified.

Typical values are given at  $V_s = 3.0$  V and  $T_{amb} = 25^{\circ}$ C. All parameters are referred to GND (Pin 3).

| Parameters Test Conditions |                                                                                                                                                                                      | Symbol                  | Min. | Тур. | Max.     | Unit           |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------|------|----------|----------------|
| Supply current             | Power down,<br>V <sub>ENABLE</sub> < 0.25 V, -40°C to 85°C<br>V <sub>PA_ENABLE</sub> < 0.25 V, -85°C to +125°C<br>V <sub>PA_ENABLE</sub> < 0.25 V, 25°C<br>(100% correlation tested) | I <sub>S_Off</sub>      |      | <10  | 350<br>7 | nA<br>μA<br>nA |
|                            | Power up, PA off, $V_S = 3 V$<br>$V_{ENABLE} > 1.7 V$ , $V_{PA_ENABLE} < 0.25 V$                                                                                                     | ۱ <sub>S</sub>          |      | 3.6  | 4.6      | mA             |
| Supply current             | Power up, $V_S = 3.0 \text{ V}$<br>$V_{ENABLE} > 1.7 \text{ V}$ , $V_{PA\_ENABLE} > 1.7 \text{ V}$                                                                                   | I <sub>S_Transmit</sub> |      | 8.5  | 11       | mA             |
| Output power               | $V_{S} = 3.0$ V, $T_{amb} = 25^{\circ}$ C<br>f = 868.3 MHz, Z <sub>Load</sub> = (166 + j226) Ω                                                                                       | P <sub>Ref</sub>        | 3.5  | 5.5  | 8        | dBm            |



|  | 6 |
|--|---|

# **10. Electrical Characteristics (Continued)**

 $V_{s} = 2.0 \text{ V}$  to 4.0 V,  $T_{amb} = -40^{\circ}\text{C}$  to  $+125^{\circ}\text{C}$  unless otherwise specified. Typical values are given at  $V_{s} = 3.0 \text{ V}$  and  $T_{amb} = 25^{\circ}\text{C}$ . All parameters are referred to GND (Pin 3).

| Parameters                                                                                                                                                                                                                                                                                                | Test Conditions                                                                                                                                    | Symbol                                                | Min.               | Тур.                | Max.                                       | Unit             |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------|---------------------|--------------------------------------------|------------------|
| Output power variation for the full temperature range                                                                                                                                                                                                                                                     | $ \begin{aligned} T_{amb} &= -40^\circ C \text{ to } +85^\circ C \\ V_{S} &= 3.0  V \\ V_{S} &= 2.0  V \end{aligned} $                             | $\Delta P_{Ref} \ \Delta P_{Ref}$                     |                    |                     | -1.5<br>-4.0                               | dB<br>dB         |
| Output power variation for the full temperature range                                                                                                                                                                                                                                                     | $ \begin{aligned} T_{amb} &= -40^\circ C \text{ to } +125^\circ C \\ V_S &= 3.0 V \\ V_S &= 2.0 V \\ P_Out &= P_Ref + \Delta P_Ref \end{aligned} $ | $\Delta P_{Ref} \ \Delta P_{Ref}$                     |                    |                     | -2.0<br>-4.5                               | dB<br>dB         |
| Achievable output-power range                                                                                                                                                                                                                                                                             | Selectable by load impedance                                                                                                                       | P <sub>Out_typ</sub>                                  | -3                 |                     | +5.5                                       | dBm              |
| Spurious emission                                                                                                                                                                                                                                                                                         | $f_{CLK} = f_0/128$<br>Load capacitance at pin CLK = 10 pF                                                                                         |                                                       |                    | -52<br>-52          |                                            | dBc<br>dBc       |
| $\begin{array}{l} f_{\text{XTO}} = f_0/32 \\ f_{\text{XTAL}} = \text{resonant frequency of the XTAL}, \\ C_M \leq 10 \text{ fF}, \text{ load capacitance selected} \\ accordingly \\ T_{amb} = -40^\circ\text{C to } +85^\circ\text{C} \\ T_{amb} = -40^\circ\text{C to } +125^\circ\text{C} \end{array}$ |                                                                                                                                                    | f <sub>xto</sub>                                      | -30<br>-40         | f <sub>XTAL</sub>   | +30<br>+40                                 | ppm<br>ppm       |
| PLL loop bandwidth                                                                                                                                                                                                                                                                                        |                                                                                                                                                    |                                                       |                    | 250                 |                                            | kHz              |
| Phase noise of phase comparator                                                                                                                                                                                                                                                                           | Referred to $f_{PC} = f_{XT0,}$<br>25 kHz distance to carrier                                                                                      |                                                       |                    | -116                | -110                                       | dBc/Hz           |
| In loop phase noise PLL                                                                                                                                                                                                                                                                                   | 25 kHz distance to carrier                                                                                                                         |                                                       |                    | -80                 | -74                                        | dBc/Hz           |
| Phase noise VCO                                                                                                                                                                                                                                                                                           | at 1 MHz<br>at 36 MHz                                                                                                                              |                                                       |                    | -89<br>-120         | -86<br>-117                                | dBc/Hz<br>dBc/Hz |
| Frequency range of VCO                                                                                                                                                                                                                                                                                    |                                                                                                                                                    | f <sub>vco</sub>                                      | 868                |                     | 928                                        | MHz              |
| Clock output frequency (CMOS microcontroller compatible)                                                                                                                                                                                                                                                  |                                                                                                                                                    |                                                       |                    | f <sub>0</sub> /256 |                                            | MHz              |
| Voltage swing at Pin CLK                                                                                                                                                                                                                                                                                  | C <sub>Load</sub> ≤10 pF                                                                                                                           | V <sub>0h</sub><br>V <sub>0l</sub>                    | $V_{S} \times 0.8$ |                     | $V_{S} \times 0.2$                         | V<br>V           |
| Series resonance R of the crystal                                                                                                                                                                                                                                                                         |                                                                                                                                                    | Rs                                                    |                    |                     | 110                                        | Ω                |
| Capaictive load at Pin XT0                                                                                                                                                                                                                                                                                |                                                                                                                                                    |                                                       |                    |                     | 7                                          | pF               |
| FSK modulation frequency rate                                                                                                                                                                                                                                                                             | Duty cycle of the modulation signal = 50%                                                                                                          |                                                       | 0                  |                     | 32                                         | kHz              |
| ASK modulation frequency rate                                                                                                                                                                                                                                                                             | Duty cycle of the modulation signal = 50%                                                                                                          |                                                       | 0                  |                     | 32                                         | kHz              |
| ENABLE input                                                                                                                                                                                                                                                                                              | Low level input voltage<br>High level input voltage<br>Input current high                                                                          | V <sub>II</sub><br>V <sub>Ih</sub><br>I <sub>In</sub> | 1.7                |                     | 0.25<br>20                                 | V<br>V<br>μA     |
| PA_ENABLE input                                                                                                                                                                                                                                                                                           | Low level input voltage                                                                                                                            |                                                       | 1.7                |                     | 0.25<br>V <sub>S</sub> <sup>(1)</sup><br>5 | V<br>V<br>µA     |

Note: 1. If  $V_S$  is higher than 3.6 V, the maximum voltage will be reduced to 3.6 V.

# **11. Microcontroller Block**

# 12. Features

- 4-Kbyte ROM, 256 x 4-bit RAM
- EEPROM Programmable Options
- Read Protection for the EEPROM Program Memory
- 11 Bi-directional I/Os
- Up to Seven External/Internal Interrupt Sources
- Eight Hardware and Software Interrupt Priorities
- Multifunction Timer/Counter
  - IR Remote Control Carrier Generator
  - Biphase-, Manchester- and Pulse-width Modulator and Demodulator
  - Phase Control Function
- Programmable System Clock with Prescaler and Five Different Clock Sources
- Very Low Sleep Current (< 1 μA)
- $2 \times 512$ -bit EEPROM Data Memory
- 256  $\times$  4-bit RAM Data Memory
- Synchronous Serial Interface (2-wire, 3-wire)
- Watchdog, POR and Brown-out Function
- Voltage Monitoring Inclusive Lo\_BAT Detect

# 13. Description

The microcontroller is designed with EEPROM cells so it can be programmed several times. To offer full compatibility with each ROM version, the I/O configuration is stored into a separate internal EEPROM block during programming. The configuration is downloaded to the I/Os with every power-on reset.

# 14. Introduction

The microcontroller block is a member of Atmel's family of 4-bit single-chip microcontrollers. Instead of ROM it contains EEPROM, RAM, parallel I/O ports, two 8-bit programmable multi-function timer/counters, voltage supervisor, interval timer with watchdog function and a sophisticated on-chip clock generation with integrated RC-, 32-kHz and 4-MHz crystal oscillators.





## 14.1 Differences between ATAM862-8 and ATAR862 Microconrtollers

#### 14.1.1 Program Memory

The program memory of the devices is realized as an EEPROM. The memory size for user programs is 4096 bytes. It is programmed as  $258 \times 16$  bytes blocks of data. the implement LOCK-bit function is user-selectable and protects the device from unauthorized read-out of the program memory.

#### 14.1.2 Configuration Memory

An additional area of 32 bytes of the EEPROM is used to store information about the hardware configuration. All the options that are selectable for the ROM versions are available to the user. This includes not only the different port options but also the possibilities to select different capacitors for OSC1 and OSC2, the option to enable or disable the hardlock for the watchdog, the option to select OSC2 instead of OSC1 as external clock input and the option to enable the external clock monitor as a reset source.

#### 14.1.3 Data Memory

The microcontroller block contains an internal data EEPROM that is organized as two pages of  $32 \times 16$ -bit. To be compatible with the ROM parts, the page used has to be defined within the application software by writing the 2-wire interface command "09h" to the EEPROM. This command has no effect for the microcontroller block, if it is left inside the HEX-file for the ROM version. Also for compatibility reasons, the access to the EEPROM is handled via the MCL (serial interface) as in the corresponding ROM parts.

#### 14.1.4 Reset Function

During each reset (power-on or brown-out), the I/O configuration is deleted and reloaded with the data from the configuration memory. This leads to a slightly different behavior compared to the ROM versions. Both devices switch their I/Os to input during reset but the ROM part has the mask selected pull-up or pull-down resistors active while the MTP has them removed until the download is finished.

# **15. MARC4 Architecture General Description**

The microcontroller consists of an advanced stack-based, 4-bit CPU core and on-chip peripherals. The CPU is based on the Harvard architecture with physically separated program memory (ROM) and data memory (RAM). Three independent buses, the instruction bus, the memory bus and the I/O bus, are used for parallel communication between ROM, RAM and peripherals. This enhances program execution speed by allowing both instruction prefetching, and a simultaneous communication to the on-chip peripheral circuitry. The extremely powerful integrated interrupt controller with associated eight prioritized interrupt levels supports fast and efficient processing of hardware events. The microcontroller is designed for the high-level programming language qFORTH. The core includes both an expression and a return stack. This architecture enables high-level language programming without any loss of efficiency or code density.





# 16. Components of Microcontroller Core

The core contains ROM, RAM, ALU, program counter, RAM address registers, instruction decoder and interrupt controller. The following sections describe each functional block in more detail.





#### 16.1 Program Memory

The program memory (EEPROM) is programmable with the customer application program during the fabrication of the microcontroller. The EEPROM is addressed by a 12-bit wide program counter, thus predefining a maximum program bank size of 4-Kbytes. The lowest user program memory address segment is taken up by a 512 bytes Zero page which contains predefined start addresses for interrupt service routines and special subroutines accessible with single byte instructions (SCALL).

The corresponding memory map is shown in Figure 16-1. Look-up tables of constants can also be held in ROM and are accessed via the microcontrollers' built-in table instruction.



Figure 16-1. ROM Map of the Microcontroller Block

#### 16.2 RAM

The microcontroller block contains a 256 x 4-bit wide static random access memory (RAM), which is used for the expression stack. The return stack and data memory are used for variables and arrays. The RAM is addressed by any of the four 8-bit wide RAM address registers SP, RP, X and Y.

#### 16.2.1 Expression Stack

The 4-bit wide expression stack is addressed with the expression stack pointer (SP). All arithmetic, I/O and memory reference operations take their operands, and return their results to the expression stack. The microcontroller performs the operations with the top of stack items (TOS and TOS-1). The TOS register contains the top element of the expression stack and works in the same way as an accumulator. This stack is also used for passing parameters between subroutines and as a scratch pad area for temporary storage of data.

#### 16.2.2 Return Stack

The 12-bit wide return stack is addressed by the return stack pointer (RP). It is used for storing return addresses of subroutines, interrupt routines and for keeping loop index counts. The return stack can also be used as a temporary storage area.

The microcontroller instruction set supports the exchange of data between the top elements of the expression stack and the return stack. The two stacks within the RAM have a user definable location and maximum depth.

#### Figure 16-2. RAM Map



#### 16.3 Registers

The microcontroller has seven programmable registers and one condition code register (see Figure 16-3).

#### 16.3.1 Program Counter (PC)

The program counter is a 12-bit register which contains the address of the next instruction to be fetched from the EEPROM. Instructions currently being executed are decoded in the instruction decoder to determine the internal micro-operations. For linear code (no calls or branches), the program counter is incremented with every instruction cycle. If a branch-, call-, return-instruction or an interrupt is executed, the program counter is loaded with a new address. The program counter is also used with the table instruction to fetch 8-bit wide EEPROM constants.



#### Figure 16-3. Programming Mode I





#### 16.3.2 RAM Address Registers

The RAM is addressed with the four 8-bit wide RAM address registers: SP, RP, X and Y. These registers allow access to any of the 256 RAM nibbles.

#### 16.3.3 Expression Stack Pointer (SP)

The stack pointer contains the address of the next-to-top 4-bit item (TOS-1) of the expression stack. The pointer is automatically pre-incremented if a nibble is moved onto the stack or post-decremented if a nibble is removed from the stack. Every post-decrement operation moves the item (TOS-1) to the TOS register before the SP is decremented. After a reset, the stack pointer has to be initialized with >SP S0 to allocate the start address of the expression stack area.

#### 16.3.4 Return Stack Pointer (RP)

The return stack pointer points to the top element of the 12-bit wide return stack. The pointer automatically pre-increments if an element is moved onto the stack, or it post-decrements if an element is removed from the stack. The return stack pointer increments and decrements in steps of 4. This means that every time a 12-bit element is stacked, a 4-bit RAM location is left unwritten. This location is used by the qFORTH compiler to allocate 4-bit variables. After a reset the return stack pointer has to be initialized via >RP FCh.

#### 16.3.5 RAM Address Registers (X and Y)

The X and Y registers are used to address any 4-bit item in the RAM. A fetch operation moves the addressed nibble onto the TOS. A store operation moves the TOS to the addressed RAM location. By using either the pre-increment or post-decrement addressing mode arrays in the RAM can be compared, filled or moved.

#### 16.3.6 Top of Stack (TOS)

The top of stack register is the accumulator of the microcontroller block. All arithmetic/logic, memory reference and I/O operations use this register. The TOS register receives data from the ALU, EEPROM, RAM or I/O bus.

#### 16.3.7 Condition Code Register (CCR)

The 4-bit wide condition code register contains the branch, the carry and the interrupt enable flag. These bits indicate the current state of the CPU. The CCR flags are set or reset by ALU operations. The instructions SET\_BCF, TOG\_BF, CCR! and DI allow direct manipulation of the condition code register.

#### 16.3.8 Carry/Borrow (C)

The carry/borrow flag indicates that the borrowing or carrying out of arithmetic logic unit (ALU) occurred during the last arithmetic operation. During shift and rotate operations, this bit is used as a fifth bit. Boolean operations have no effect on the C-flag.

#### 16.3.9 Branch (B)

The branch flag controls the conditional program branching. Should the branch flag has been set by a previous instruction, a conditional branch will cause a jump. This flag is affected by arithmetic, logic, shift, and rotate operations.

#### 16.3.10 Interrupt Enable (I)

The interrupt enable flag globally enables or disables the triggering of all interrupt routines with the exception of the non-maskable reset. After a reset or while executing the DI instruction, the interrupt enable flag is reset, thus disabling all interrupts. The core will not accept any further interrupt requests until the interrupt enable flag has been set again by either executing an EI or SLEEP instruction.

#### 16.4 ALU

The 4-bit ALU performs all the arithmetic, logical, shift and rotate operations with the top two elements of the expression stack (TOS and TOS-1) and returns the result to the TOS. The ALU operations affects the carry/borrow and branch flag in the condition code register (CCR).





#### 16.5 I/O Bus

The I/O ports and the registers of the peripheral modules are I/O mapped. All communication between the core and the on-chip peripherals take place via the I/O bus and the associated I/O control. With the microcontroller IN and OUT instructions, the I/O bus allows a direct read or write access to one of the 16 primary I/O addresses. More about the I/O access to the on-chip peripherals is described in the section "Peripheral Modules" on page 32. The I/O bus is internal and is not accessible by the customer on the final microcontroller device, but it is used as the interface for the microcontroller emulation (see section "Emulation" on page 104).

#### 16.6 Instruction Set

The microcontroller instruction set is optimized for the high level programming language qFORTH. Many microcontroller instructions are qFORTH words. This enables the compiler to generate a fast and compact program code. The CPU has an instruction pipeline allowing the controller to prefetch an instruction from EEPROM at the same time as the present instruction is being executed. The microcontroller is a zero-address machine, the instructions contain only the operation to be performed and no source or destination address fields. The operations are implicitly performed on the data placed on the stack. There are one- and two-byte instructions which are executed within 1 to 4 machine cycles. A microcontroller machine cycle is made up of two system clock cycles (SYSCL). Most of the instructions are only one byte long and are executed in a single machine cycle. For more information refer to the "MARC4 Programmer's Guide".





#### 16.7 Interrupt Structure

The microcontroller can handle interrupts with eight different priority levels. They can be generated from the internal and external interrupt sources or by a software interrupt from the CPU itself. Each interrupt level has a hard-wired priority and an associated vector for the service routine in the EEPROM (see Table 16-1 on page 21). The programmer can postpone the processing of interrupts by resetting the interrupt enable flag (I) in the CCR. An interrupt occurrence will still be registered, but the interrupt routine only started after the I-flag is set. All interrupts can be masked, and the priority individually software configured by programming the appropriate control register of the interrupting module (see section "Peripheral Modules" on page 32).

#### 16.7.1 Interrupt Processing

For processing the eight interrupt levels, the microcontroller includes an interrupt controller with two 8-bit wide interrupt pending and interrupt active registers. The interrupt controller samples all interrupt requests during every non-I/O instruction cycle and latches these in the interrupt pending register. If no higher priority interrupt is present in the interrupt active register, it signals the CPU to interrupt the current program execution. If the interrupt enable bit is set, the processor enters an interrupt acknowledge cycle. During this cycle a short call (SCALL) instruction to the service routine is executed and the current PC is saved on the return stack. An interrupt service routine is completed with the RTI instruction. This instruction, resets the corresponding bits in the interrupt pending/active register and fetches the return address from the return stack to the program counter. When the interrupt service routines is inhibited but not the logging of the interrupt requests in the interrupt pending register. The execution of the interrupt is delayed until the interrupt enable flag is set again. Note that interrupts are only lost if an interrupt request occurs while the corresponding bit in the pending register is still set (i.e., the interrupt service routine is not yet finished).

It should be noted that automatic stacking of the RBR is not carried out by the hardware and so if ROM banking is used, the RBR must be stacked on the expression stack by the application program and restored before the RTI. After a master reset (power-on, brown-out or watchdog reset), the interrupt enable flag and the interrupt pending and interrupt active register are all reset.

#### 16.7.2 Interrupt Latency

The interrupt latency is the time from the occurrence of the interrupt to the interrupt service routine being activated. This is extremely short (taking between 3 to 5 machine cycles depending on the state of the core).





Table 16-1. Interrupt Priority

| Interrupt | Priority | ROM Address | Interrupt Opcode | Function                                                     |
|-----------|----------|-------------|------------------|--------------------------------------------------------------|
| INT0      | Lowest   | 040h        | C8h (SCALL 040h) | Software interrupt (SWI0)                                    |
| INT1      | I        | 080h        | D0h (SCALL 080h) | External hardware interrupt, any edge at BP52 or BP53        |
| INT2      | I        | 0C0h        | D8h (SCALL 0C0h) | Timer 1 interrupt                                            |
| INT3      | I        | 100h        | E8h (SCALL 100h) | SSI interrupt or external hardware interrupt at BP40 or BP43 |
| INT4      | I        | 140h        | E8h (SCALL 140h) | Timer 2 interrupt                                            |
| INT5      | I        | 180h        | F0h (SCALL 180h) | Timer 3 interrupt                                            |
| INT6      | I        | 1C0h        | F8h (SCALL 1C0h) | External hardware interrupt, at any edge at BP50 or BP51     |
| INT7      | Highest  | 1E0h        | FCh (SCALL 1E0h) | Voltage monitor (VM) interrupt                               |





#### Table 16-2. Hardware Interrupts

|           | Interrupt Mask        |                                                                                                                |                                          |  |
|-----------|-----------------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------|--|
| Interrupt | Register              | Bit                                                                                                            | Interrupt Source                         |  |
| INT1      | P5CR                  | P52M1, P52M2<br>P53M1, P53M2                                                                                   | Any edge at BP52<br>any edge at BP53     |  |
| INT2      | T1M                   | T1IM Timer 1                                                                                                   |                                          |  |
| INT3      | SISC                  | SIM SSI buffer full/empty or BP40/BP43 interrupt                                                               |                                          |  |
| INT4      | T2CM                  | T2IM                                                                                                           | Timer 2 compare match/overflow           |  |
| INT5      | T3CM1<br>T3CM2<br>T3C | T3IM1Timer 3 compare register 1 matchT3IM2Timer 3 compare register 2 matchT3EIMTimer 3 edge event occurs (T3I) |                                          |  |
| INT6      | P5CR                  | P50M1, P50M2 Any edge at BP50,<br>P51M1, P51M2 any edge at BP51                                                |                                          |  |
| INT7      | VCM                   | VIM                                                                                                            | VIM External/internal voltage monitoring |  |

#### 16.8 Software Interrupts

The programmer can generate interrupts by using the software interrupt instruction (SWI), which is supported in qFORTH by predefined macros named SWI0...SWI7. The software triggered interrupt operates exactly like any hardware triggered interrupt. The SWI instruction takes the top two elements from the expression stack and writes the corresponding bits via the I/O bus to the interrupt pending register. Therefore, by using the SWI instruction, interrupts can be re-prior-itized or lower priority processes scheduled for later execution.

#### 16.9 Hardware Interrupts

In the microcontroller block, there are eleven hardware interrupt sources with seven different levels. Each source can be masked individually by mask bits in the corresponding control registers. An overview of the possible hardware configurations is shown in Table 16-2.

# 17. Master Reset

The master reset forces the CPU into a well-defined condition. It is unmaskable and is activated independent of the current program state. It can be triggered by either initial supply power-up, a short collapse of the power supply, brown-out detection circuitry, watchdog time-out, or an external input clock supervisor stage (see Figure 17-1). A master reset activation will reset the interrupt enable flag, the interrupt pending register and the interrupt active register. During the power-on reset phase, the I/O bus control signals are set to reset mode, thereby, initializing all on-chip peripherals. All bi-directional ports are set to input mode.

Attention: During any reset phase, the BP20/NTE input is driven towards V<sub>DD</sub> by an additional internal strong pull-up transistor. This pin must not be pulled down to V<sub>SS</sub> during reset by any external circuitry representing a resistor of less than 150 k $\Omega$ 

Releasing the reset results in a short call instruction (opcode C1h) to the ROM address 008h. This activates the initialization routine \$RESET which in turn has to initialize all necessary RAM variables, stack pointers and peripheral configuration registers (see Table 21-1 on page 34).





#### 17.1 Power-on Reset and Brown-out Detection

The microcontroller block has a fully integrated power-on reset and brown-out detection circuitry. For reset generation no external components are needed.

These circuits ensure that the core is held in the reset state until the minimum operating supply voltage has been reached. A reset condition will also be generated should the supply voltage drop momentarily below the minimum operating level except when a power-down mode is activated (the core is in SLEEP mode and the peripheral clock is stopped). In this power-down mode the brown-out detection is disabled.

Two values for the brown-out voltage threshold are programmable via the BOT bit in the SC register.





A power-on reset pulse is generated by a  $V_{DD}$  rise across the default BOT voltage level (1.7 V). A brown-out reset pulse is generated when  $V_{DD}$  falls below the brown-out voltage threshold. Two values for the brown-out voltage threshold are programmable via the BOT bit in the SC register. When the controller runs in the upper supply voltage range with a high system clock frequency, the high threshold must be used. When it runs with a lower system clock frequency, the low threshold and a wider supply voltage range may be chosen. For further details, see the electrical specification and the SC register description for BOT programming.





BOT = 1, low brown-out voltage threshold 1.7 V (is reset value). BOT = 0, high brown-out voltage threshold 2.0 V.

#### 17.1.1 Watchdog Reset

The watchdog's function can be enabled at the WDC register and triggers a reset with every watchdog counter overflow. To suppress the watchdog reset, the watchdog counter must be regularly reset by reading the watchdog register address (CWD). The CPU reacts in exactly the same manner as a reset stimulus from any of the above sources.

#### 17.1.2 External Clock Supervisor

The external input clock supervisor function can be enabled if the external input clock is selected within the CM and SC registers of the clock module. The CPU reacts in exactly the same manner as a reset stimulus from any of the above sources.

## 18. Voltage Monitor

The voltage monitor consists of a comparator with internal voltage reference. It is used to supervise the supply voltage or an external voltage at the VMI pin. The comparator for the supply voltage has three internal programmable thresholds one lower threshold (2.2 V), one middle threshold (2.6 V) and one higher threshold (3.0 V). For external voltages at the VMI pin, the comparator threshold is set to  $V_{BG} = 1.3$  V. The VMS bit indicates if the supervised voltage is below (VMS = 0) or above (VMS = 1) this threshold. An interrupt can be generated when the VMS bit is set or reset to detect a rising or falling slope. A voltage monitor interrupt (INT7) is enabled when the interrupt mask bit (VIM) is reset in the VMC register.

# Figure 18-1. Voltage Monitor



## 18.0.1 Voltage Monitor Control/Status Register

Primary register address: "F"hex

|            | Bit 3 | Bit 2 | Bit 1    | Bit 0 |                    |
|------------|-------|-------|----------|-------|--------------------|
| VMC: Write | VM2   | VM1   | VM0      | VIM   | Reset value: 1111b |
|            |       | 1     |          |       | ~                  |
| VMST: Read | -     | -     | Reserved | VMS   | Reset value: xx11b |

VM2: Voltage monitor Mode bit 2

VM1: Voltage monitor Mode bit 1

VM0: Voltage monitor Mode bit 0

## Table 18-1. Voltage Monitor Modes

| VM2 | VM1 | VM0 | Function                                                                                  |  |  |
|-----|-----|-----|-------------------------------------------------------------------------------------------|--|--|
| 1   | 1   | 1   | Disable voltage monitor                                                                   |  |  |
| 1   | 1   | 0   | External (VIM input), internal reference threshold (1.3 V), interrupt with negative slope |  |  |
| 1   | 0   | 1   | Not allowed                                                                               |  |  |
| 1   | 0   | 0   | External (VMI input), internal reference threshold (1.3 V), interrupt with positive slope |  |  |
| 0   | 1   | 1   | Internal (supply voltage), high threshold (3.0 V), interrupt with negative slop           |  |  |
| 0   | 1   | 0   | Internal (supply voltage), middle threshold (2.6 V), interrupt with negative slope        |  |  |
| 0   | 0   | 1   | Internal (supply voltage), low threshold (2.2 V), interrupt with negative slope           |  |  |
| 0   | 0   | 0   | Not allowed                                                                               |  |  |

VIM

## Voltage Interrupt Mask bit

VIM = 0, voltage monitor interrupt is enabled

VIM = 1, voltage monitor interrupt is disabled

VMS

Voltage Monitor Status bit

VMS = 0, the voltage at the comparator input is below  $\ensuremath{\mathsf{V}_{\mathsf{Ref}}}$ 

VMS = 1, the voltage at the comparator input is above  $V_{\text{Ref}}$ 

