# E·XFL



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Obsolete                                                               |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | ST7                                                                    |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 8MHz                                                                   |
| Connectivity               | I <sup>2</sup> C, SCI, SPI                                             |
| Peripherals                | LVD, POR, PWM, WDT                                                     |
| Number of I/O              | 48                                                                     |
| Program Memory Size        | 60KB (60K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 2K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 3.8V ~ 5.5V                                                            |
| Data Converters            | A/D 16x10b                                                             |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                      |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 64-LQFP                                                                |
| Supplier Device Package    | -                                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/stmicroelectronics/st72f321ar9tae |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

# List of tables

| Table 1.   | Device summary                                        | 1          |
|------------|-------------------------------------------------------|------------|
| Table 2.   | Product overview                                      | . 18       |
| Table 3.   | Device pin description                                | . 22       |
| Table 4.   | Hardware register map                                 | . 26       |
| Table 5.   | Sectors available in Flash devices                    | . 29       |
| Table 6.   | Flash control/status register address and reset value | . 32       |
| Table 7.   | Arithmetic management bits                            | . 34       |
| Table 8.   | Interrupt management bits                             | . 35       |
| Table 9.   | Interrupt software priority selection                 | . 35       |
| Table 10.  | ST7 clock sources                                     | . 39       |
| Table 11.  | Effect of low power modes on SI                       | . 46       |
| Table 12.  | AVD interrupt control/wake-up capability              | . 46       |
| Table 13.  | SICSR description                                     | . 47       |
| Table 14.  | Reset source flags                                    | . 47       |
| Table 15.  | Interrupt software priority levels                    | . 50       |
| Table 16.  | CPU CC register interrupt bits description            | . 53       |
| Table 17.  | Interrupt software priority levels                    | . 54       |
| Table 18.  | Interrupt priority bits                               | . 54       |
| Table 19.  | Interrupt dedicated instruction set.                  | . 55       |
| Table 20.  | Interrupt mapping                                     | . 56       |
| Table 21   | FICB register description                             | 59         |
| Table 22   | Interrunt sensitivity - ei2 (port B3_0)               | 60         |
| Table 23   | Interrupt sensitivity - ei3 (port B7 4)               | 60         |
| Table 24   | Interrunt sensitivity - ei0 (port A3_0)               | 60         |
| Table 25   | Interrunt sensitivity - ei1 (nort F2 0)               | 60         |
| Table 26   | Nested interrunts register map and reset values       | 61         |
| Table 27   | MCC/BTC low power mode selection                      | 65         |
| Table 28   | I/O output mode selection                             | 71         |
| Table 29   | I/O port mode options                                 | 72         |
| Table 30   | I/O port configurations                               | 73         |
| Table 31   | I/O port configuration                                | 74         |
| Table 32   | Effect of low power modes on I/O ports                | 75         |
| Table 33   | I/O port interrupt control/wake-up capability         | 75         |
| Table 34   | I/O port interrupt control, water up capability       | 75         |
| Table 35   | Effect of low nower modes on WDG                      | 80         |
| Table 36   | WDGCB register description                            | . 00<br>   |
| Table 37   | Watchdog timer register map and reset values          | 81         |
| Table 38   | Effect of low nower modes on MCC/BTC                  | . 01       |
| Table 30   | MCC/BTC interrupt control/wake-up capability          | . 00       |
| Table 39.  | MCCSR register description                            | . 00<br>   |
| Table 40.  |                                                       | . 04<br>85 |
| Table 41.  | MCCBCB register description                           | . 05       |
| Table 42.  | Boon frequency selection                              | . 05       |
| Table 43.  | Main clock controllor registor map and reset values   | . 05<br>86 |
| Table 44.  | ARTCSR register description                           | 00.        |
| Table 45.  | Droscalar salaction for ADT                           | . 90<br>02 |
| Table 40.  |                                                       | . 90<br>0/ |
| Table 47.  |                                                       | . 94       |
| 1 aute 40. | ANNAAN ICYISICI UCSUNPIIUN                            | . 94       |



| Pin  | No.  |                       |     | Le  | evel |       |     | I   | Port |     |      | Main                                                                                                                   | Alternate function                                                                                                                                                                      |  |
|------|------|-----------------------|-----|-----|------|-------|-----|-----|------|-----|------|------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 964  | 244  | Pin name              | ype | nt  | out  |       | Inp | out |      | Out | tput | function<br>(after                                                                                                     |                                                                                                                                                                                         |  |
| LQFI | LQFF |                       |     | lnp | Outp | float | ndm | int | ana  | аo  | РР   | reset)                                                                                                                 |                                                                                                                                                                                         |  |
|      |      | PE2<br>(Flash device) |     |     |      |       | x   |     |      |     |      | Port E2<br>Caution: In Flash devices this po<br>is always input with weak pull-up.                                     |                                                                                                                                                                                         |  |
| 63   | -    | PE2<br>(ROM device)   | I/O | CT  |      | x     |     |     |      | х   | х    | Port E2<br>Caution: I<br>weak pull-<br>In LQFP44<br>connected<br>like other u<br>recommen<br>output pus<br>current cor | n ROM devices, no<br>up present on this port.<br>I this pin is not<br>to an internal pull-up<br>unbonded pins. It is<br>ided to configure it as<br>sh-pull to avoid added<br>nsumption. |  |
| 64   | -    | PE3                   | I/O | CT  |      | X     | Х   |     |      | Х   | Х    | Port E3                                                                                                                |                                                                                                                                                                                         |  |

Table 3. Device pin description (continued)

1. It is mandatory to connect all available  $V_{DD}$  and  $V_{AREF}$  pins to the supply voltage and all  $V_{SS}$  and  $V_{SSA}$  pins to ground.

2. OSC1 and OSC2 pins connect a crystal/ceramic resonator or an external source to the on-chip oscillator; see Section 6: Supply, reset and clock management and Section 19.5: Clock and timing characteristics on page 195 for more details.

Legend / Abbreviations for Table 3:

| Туре:                   | I = input<br>O = output<br>S = supply                                                                                                               |  |  |  |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Input level:            | A = dedicated analog input                                                                                                                          |  |  |  |
| In/Output level:        | $\label{eq:C} \begin{split} C &= CMOS \; 0.3 V_{DD} / 0.7 V_{DD} \\ C_T &= CMOS \; 0.3 V_{DD} / 0.7 V_{DD} \; \text{with input trigge} \end{split}$ |  |  |  |
| Output level:           | HS = 20mA high sink (on N-buffer only)                                                                                                              |  |  |  |
| Port and control config | guration:                                                                                                                                           |  |  |  |
| Input:                  | float = floating<br>wpu = weak pull-up<br>int = interrupt <sup>(a)</sup><br>ana = analog                                                            |  |  |  |
| • Output:               | OD = open-drain <sup>(b)</sup><br>PP = push-pull                                                                                                    |  |  |  |

b. In the open-drain output column, "T" defines a true open-drain I/O (P-Buffer and protection diode to V<sub>DD</sub> are not implemented). See Section 9: I/O ports on page 70 and Section 19.8: I/O port pin characteristics on page 203 for more details.



a. In the interrupt input column, "eiX" defines the associated external interrupt vector. If the weak pull-up column (wpu) is merged with the interrupt column (int), then the I/O configuration is pull-up interrupt input, otherwise the configuration is floating interrupt input.

# 6.3 Phase locked loop

If the clock frequency input to the PLL is in the range 2 to 4 MHz, the PLL can be used to multiply the frequency by two to obtain an  $f_{OSC2}$  of 4 to 8 MHz. The PLL is enabled by option byte. If the PLL is disabled, then  $f_{OSC2} = f_{OSC}/2$ .

**Caution:** The PLL is not recommended for applications where timing accuracy is required (see *Section 19.5.5: PLL characteristics on page 198*).





# 6.4 Multi-oscillator (MO)

The main clock of the ST7 can be generated by three different source types coming from the multi-oscillator block:

- an external source
- 4 crystal or ceramic resonator oscillators
- an internal high frequency RC oscillator

Each oscillator is optimized for a given frequency range in terms of consumption and is selectable through the option byte. The associated hardware configurations are shown in *Table 10*. Refer to *Section 19: Electrical characteristics* for more details.

**Caution:** The OSC1 and/or OSC2 pins must not be left unconnected. For the purposes of Failure Mode and Effect Analysis, it should be noted that if the OSC1 and/or OSC2 pins are left unconnected, the ST7 main oscillator may start and, in this configuration, could generate an f<sub>OSC</sub> clock frequency in excess of the allowed maximum (> 16 MHz), putting the ST7 in an unsafe/undefined state. The product behavior must therefore be considered undefined when the OSC pins are left unconnected.

#### External clock source

In this external clock mode, a clock signal (square, sinus or triangle) with ~50% duty cycle has to drive the OSC1 pin while the OSC2 pin is tied to ground.

38/243



## 6.6 System integrity management (SI)

The System Integrity Management block contains the Low Voltage Detector (LVD) and Auxiliary Voltage Detector (AVD) functions. It is managed by the SICSR register.

#### 6.6.1 Low voltage detector (LVD)

The low voltage detector function (LVD) generates a static reset when the  $V_{DD}$  supply voltage is below a  $V_{IT}$  reference value. This means that it secures the power-up as well as the power-down keeping the ST7 in reset.

The V<sub>IT</sub> reference value for a voltage drop is lower than the V<sub>IT+</sub> reference value for poweron in order to avoid a parasitic reset when the MCU starts running and sinks current on the supply (hysteresis).

The LVD reset circuitry generates a reset when  $V_{DD}$  is below:

- V<sub>IT+</sub> when V<sub>DD</sub> is rising
- V<sub>IT</sub> when V<sub>DD</sub> is falling

The LVD function is illustrated in *Figure 14*.

The voltage threshold can be configured by option byte to be low, medium or high.

Provided the minimum  $V_{DD}$  value (guaranteed for the oscillator frequency) is above  $V_{IT-}$ , the MCU can only be in two modes:

- under full software control
- in static safe reset

In these conditions, secure operation is always ensured for the application without the need for external reset hardware.

During a low voltage detector reset, the **RESET** pin is held low, thus permitting the MCU to reset other devices.

Note: The LVD allows the device to be used without any external RESET circuitry.

If the medium or low thresholds are selected, the detection may occur outside the specified operating voltage range. Below 3.8V, device operation is not guaranteed.

The LVD is an optional function which can be selected by option byte.

It is recommended to make sure that the  $V_{DD}$  supply voltage rises monotonously when the device is exiting from Reset, to ensure the application functions properly.



| No. | Source<br>block | Description                               | Register<br>label   | Priority<br>order | Exit<br>from<br>Halt <sup>(1)</sup> | Address<br>vector |
|-----|-----------------|-------------------------------------------|---------------------|-------------------|-------------------------------------|-------------------|
|     | RESET           | Reset                                     | NI/A                |                   | yes                                 | FFFEh-FFFFh       |
|     | TRAP            | Software interrupt                        | IN/A                |                   | no                                  | FFFCh-FFFDh       |
| 0   | TLI             | External top level interrupt              | EICR                |                   | yes                                 | FFFAh-FFFBh       |
| 1   | MCC/RTC         | Main clock controller time base interrupt | MCCSR               | Higher            | yes                                 | FFF8h-FFF9h       |
| 2   | ei0             | External interrupt port A30               |                     | priority          | yes                                 | FFF6h-FFF7h       |
| 3   | ei1             | External interrupt port F20               | NI/A                |                   | yes                                 | FFF4h-FFF5h       |
| 4   | ei2             | External interrupt port B30               | IN/A                |                   | yes                                 | FFF2h-FFF3h       |
| 5   | ei3             | External interrupt port B74               |                     |                   | yes                                 | FFF0h-FFF1h       |
| 6   |                 | Not used                                  |                     |                   |                                     | FFEEh-FFEFh       |
| 7   | SPI             | SPI peripheral interrupts                 | SPICSR              |                   | yes <sup>(2)</sup>                  | FFECh-FFEDh       |
| 8   | TIMER A         | TIMER A peripheral interrupts             | TASR                |                   | no                                  | FFEAh-FFEBh       |
| 9   | TIMER B         | TIMER B peripheral interrupts             | TBSR                |                   | no                                  | FFE8h-FFE9h       |
| 10  | SCI             | SCI peripheral interrupts                 | SCISR               | Lower             | no                                  | FFE6h-FFE7h       |
| 11  | AVD             | Auxiliary voltage detector interrupt      | SICSR               | priority          | no                                  | FFE4h-FFE5h       |
| 12  | I2C             | I2C peripheral interrupts                 | (see<br>peripheral) |                   | no                                  | FFE2h-FFE3h       |
| 13  | PWM ART         | PWM ART interrupt                         | ARTCSR              |                   | yes <sup>(3)</sup>                  | FFE0h-FFE1h       |

#### Table 20. Interrupt mapping

1. In Flash devices only a RESET or MCC/RTC interrupt can be used to wake-up from Active Halt mode.

2. Exit from HALT possible when SPI is in slave mode.

3. Exit from HALT possible when PWM ART is in external clock mode.



Each external interrupt vector is linked to a dedicated group of I/O port pins (see pinout description and interrupt section). If several input pins are selected simultaneously as interrupt sources, these are first detected according to the sensitivity bits in the EICR register and then logically ORed.

The external interrupts are hardware interrupts, which means that the request latch (not accessible directly by the application) is automatically cleared when the corresponding interrupt vector is fetched. To clear an unwanted pending interrupt by software, the sensitivity bits in the EICR register must be modified.

#### 9.2.2 Output modes

The output configuration is selected by setting the corresponding DDR register bit. In this case, writing the DR register applies this digital value to the I/O pin through the latch. Then reading the DR register returns the previously stored value.

Two different output modes can be selected by software through the OR register: Output push-pull and open-drain. The DR register value and output pin status are shown in the following *Table 28*.

| Table 28. | I/O output | mode selection |
|-----------|------------|----------------|
|-----------|------------|----------------|

| DR | Push-pull       | Open-drain      |
|----|-----------------|-----------------|
| 0  | V <sub>SS</sub> | V <sub>SS</sub> |
| 1  | V <sub>DD</sub> | Floating        |

#### 9.2.3 Alternate functions

When an on-chip peripheral is configured to use a pin, the alternate function is automatically selected. This alternate function takes priority over the standard I/O programming.

When the signal is coming from an on-chip peripheral, the I/O pin is automatically configured in output mode (push-pull or open-drain according to the peripheral).

When the signal is going to an on-chip peripheral, the I/O pin must be configured in input mode. In this case, the pin state is also digitally readable by addressing the DR register.

Note: Input pull-up configuration can cause unexpected value at the input of the alternate peripheral input. When an on-chip peripheral use a pin as input and output, this pin has to be configured in input floating mode.





Figure 36. Output compare control

### 12.2.5 Independent PWM signal generation

This mode allows up to four Pulse Width Modulated signals to be generated on the PWMx output pins with minimum core processing overhead. This function is stopped during Halt mode.

Each PWMx output signal can be selected independently using the corresponding OEx bit in the PWM Control register (PWMCR). When this bit is set, the corresponding I/O pin is configured as output push-pull alternate function.

The PWM signals all have the same frequency which is controlled by the counter period and the ARTARR register value.

$$f_{PWM} = f_{COUNTER} / (256 - ARTARR)$$

When a counter overflow occurs, the PWMx pin level is changed depending on the corresponding OPx (output polarity) bit in the PWMCR register. When the counter reaches the value contained in one of the output compare register (OCRx) the corresponding PWMx pin level is restored.

It should be noted that the reload values will also affect the value and the resolution of the duty cycle of the PWM output signal. To obtain a signal on a PWMx pin, the contents of the OCRx register must be greater than the contents of the ARTARR register.

The maximum available resolution for the PWMx duty cycle is:

Resolution = 1 / (256 - ARTARR)

Note: To get the maximum resolution (1/256), the ARTARR register must be 0. With this maximum resolution, 0% and 100% can be obtained by changing the polarity.



# 14 Serial peripheral interface (SPI)

## 14.1 Introduction

The Serial Peripheral Interface (SPI) allows full-duplex, synchronous, serial communication with external devices. An SPI system may consist of a master and one or more slaves however the SPI interface cannot be a master in a multimaster system.

# 14.2 Main features

- Full duplex synchronous transfers (on 3 lines)
- Simplex synchronous transfers (on 2 lines)
- Master or slave operation
- 6 master mode frequencies (f<sub>CPU</sub>/4 max.)
- f<sub>CPU</sub>/2 max. slave mode frequency (see note)
- SS Management by software or hardware
- Programmable clock polarity and phase
- End of transfer interrupt flag
- Write collision, Master Mode Fault and Overrun flags

Note: In slave mode, continuous transmission is not possible at maximum frequency due to the software overhead for clearing status flags and to initiate the next transmission sequence.

# 14.3 General description

*Figure 55* shows the serial peripheral interface (SPI) block diagram. There are three registers:

- SPI Control Register (SPICR)
- SPI Control/Status Register (SPICSR)
- SPI Data Register (SPIDR)

The SPI is connected to external devices through four pins:

- MISO (Master In / Slave Out data)
- MOSI (Master Out / Slave In data)
- SCK (Serial Clock out by SPI masters and input by SPI slaves)
- SS (Slave select): This input signal acts as a 'chip select' to let the SPI master communicate with slaves individually and to avoid contention on the data lines. Slave SS inputs can be driven by standard I/O ports on the master MCU.



bit by software the SCI insert a logic 1 bit at the end of the last break frame to guarantee the recognition of the start bit of the next frame.

#### **Idle characters**

Setting the TE bit drives the SCI to send an idle frame before the first data frame.

Clearing and then setting the TE bit during a transmission sends an idle frame after the current word.

Note: Resetting and setting the TE bit causes the data in the TDR register to be lost. Therefore the best time to toggle the TE bit is when the TDRE bit is set, that is, before writing the next byte in the SCIDR.

#### 15.4.3 Receiver

The SCI can receive data words of either 8 or 9 bits. When the M bit is set, word length is 9 bits and the MSB is stored in the R8 bit in the SCICR1 register.

#### **Character reception**

During a SCI reception, data shifts in least significant bit first through the RDI pin. In this mode, the SCIDR register consists or a buffer (RDR) between the internal bus and the received shift register (see *Figure 62*).

#### Procedure

- 1. Select the M bit to define the word length.
- 2. Select the desired baud rate using the SCIBRR and the SCIERPR registers.
- 3. Set the RE bit, this enables the receiver which begins searching for a start bit.

When a character is received:

- The RDRF bit is set. It indicates that the content of the shift register is transferred to the RDR.
- An interrupt is generated if the RIE bit is set and the I bit is cleared in the CCR register.
- The error flags can be set if a frame error, noise or an overrun error has been detected during reception.

Clearing the RDRF bit is performed by the following software sequence done by:

- 1. An access to the SCISR register
- 2. A read to the SCIDR register.

The RDRF bit must be cleared before the end of the reception of the next character to avoid an overrun error.

#### Break character

When a break character is received, the SCI handles it as a framing error.

#### Idle character

When an idle frame is detected, there is the same procedure as a data received character plus an interrupt if the ILIE bit is set and the I bit is cleared in the CCR register.

#### Overrun error

An overrun error occurs when a character is received when RDRF has not been reset. Data cannot be transferred from the shift register to the RDR register as long as the RDRF bit is not cleared.



| Bit | Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | IDLE | <ul> <li>Idle line detect</li> <li>This bit is set by hardware when an Idle Line is detected. An interrupt is generated if the ILIE = 1 in the SCICR2 register. It is cleared by a software sequence (an access to the SCISR register followed by a read to the SCIDR register).</li> <li>0: No Idle Line is detected</li> <li>1: Idle Line is detected</li> <li>Note: The IDLE bit is not set again until the RDRF bit has been set itself (that is, a new idle line occurs).</li> </ul>                                                                                                                                                                 |
| 3   | OR   | Overrun error<br>This bit is set by hardware when the word currently being received in the shift<br>register is ready to be transferred into the RDR register while RDRF = 1. An interrupt<br>is generated if RIE = 1 in the SCICR2 register. It is cleared by a software sequence<br>(an access to the SCISR register followed by a read to the SCIDR register).<br>0: No Overrun error<br>1: Overrun error is detected<br>Note: When this bit is set RDR register content is not lost but the shift register is<br>overwritten.                                                                                                                         |
| 2   | NF   | <ul> <li>Noise flag</li> <li>This bit is set by hardware when noise is detected on a received frame. It is cleared by a software sequence (an access to the SCISR register followed by a read to the SCIDR register).</li> <li>0: No noise is detected</li> <li>1: Noise is detected</li> <li>Note: This bit does not generate interrupt as it appears at the same time as the RDRF bit which itself generates an interrupt.</li> </ul>                                                                                                                                                                                                                   |
| 1   | FE   | <ul> <li>Framing error</li> <li>This bit is set by hardware when a de-synchronization, excessive noise or a break character is detected. It is cleared by a software sequence (an access to the SCISR register followed by a read to the SCIDR register).</li> <li>0: No Framing error is detected</li> <li>1: Framing error or break character is detected</li> <li>Note: This bit does not generate interrupt as it appears at the same time as the RDRF bit which itself generates an interrupt. If the word currently being transferred causes both frame error and overrun error, it will be transferred and only the OR bit will be set.</li> </ul> |
| 0   | PE   | <ul> <li>Parity error</li> <li>This bit is set by hardware when a parity error occurs in receiver mode. It is cleared by a software sequence (a read to the status register followed by an access to the SCIDR data register). An interrupt is generated if PIE = 1 in the SCICR1 register.</li> <li>0: No parity error</li> <li>1: Parity error</li> </ul>                                                                                                                                                                                                                                                                                               |

 Table 73.
 SCISR register description (continued)



| Group                            | Instructions |      |      |      |      |       |     |     |
|----------------------------------|--------------|------|------|------|------|-------|-----|-----|
| Logical operations               | AND          | OR   | XOR  | CPL  | NEG  |       |     |     |
| Bit Operation                    | BSET         | BRES |      |      |      |       |     |     |
| Conditional Bit Test and Branch  | BTJT         | BTJF |      |      |      |       |     |     |
| Arithmetic operations            | ADC          | ADD  | SUB  | SBC  | MUL  |       |     |     |
| Shift and Rotates                | SLL          | SRL  | SRA  | RLC  | RRC  | SWAP  | SLA |     |
| Unconditional Jump or Call       | JRA          | JRT  | JRF  | JP   | CALL | CALLR | NOP | RET |
| Conditional Branch               | JRxx         |      |      |      |      |       |     |     |
| Interruption management          | TRAP         | WFI  | HALT | IRET |      |       |     |     |
| Condition Code Flag modification | SIM          | RIM  | SCF  | RCF  |      |       |     |     |

 Table 102.
 Instruction groups (continued)

### 18.2.1 Using a prebyte

The instructions are described with one to four opcodes.

In order to extend the number of available opcodes for an 8-bit CPU (256 opcodes), three different prebyte opcodes are defined. These prebytes modify the meaning of the instruction they precede.

The whole instruction becomes:

- PC 2 End of previous instruction
- PC 1 Prebyte
- PC Opcode
- PC + 1 Additional word (0 to 2) according to the number of bytes required to compute the effective address

These prebytes enable instruction in Y as well as indirect addressing modes to be implemented. They precede the opcode of the instruction in X or the instruction using direct addressing mode. The prebytes are:

- PDY 90 Replace an X based instruction using immediate, direct, indexed, or inherent addressing mode by a Y one.
- PIX 92 Replace an instruction using direct, direct bit, or direct relative addressing mode to an instruction using the corresponding indirect addressing mode.
   It also changes an instruction using X indexed addressing mode to an instruction using indirect X indexed addressing mode.
- PIY 91 Replace an instruction using X indirect indexed addressing mode by a Y one.





Figure 84. Typical  $V_{OL}$  at  $V_{DD}$  = 5V (standard) Figure 85. Typical  $V_{OL}$  at  $V_{DD}$  = 5V (high-sink)

Figure 86. Typical  $V_{OH}$  at  $V_{DD} = 5V$ 







Figure 87. Typical V<sub>OL</sub> versus V<sub>DD</sub> (standard)









Doc ID 13829 Rev 1







1. When ICC mode is not required by the application, the ICCSEL/V<sub>PP</sub> pin must be tied to V<sub>SS</sub>.

# **19.10** Timer peripheral characteristics

Subject to general operating conditions for  $V_{DD}$ ,  $f_{OSC}$ , and  $T_A$  unless otherwise specified.

Refer to *Section 19.8: I/O port pin characteristics* for more details on the input/output alternate function characteristics (such as output compare, input capture, external clock, or PWM output).

| Symbol                | Parameter                    | Conditions                                   | Min | Тур | Max    | Unit             |
|-----------------------|------------------------------|----------------------------------------------|-----|-----|--------|------------------|
| +                     | DW/M recolution time         |                                              | 1   |     |        | t <sub>CPU</sub> |
| <sup>t</sup> res(PWM) |                              | f <sub>CPU</sub> = 8 MHz                     | 125 |     |        | ns               |
| f <sub>EXT</sub>      | ART external clock frequency |                                              | 0   |     | f. /0  |                  |
| f <sub>PWM</sub>      | PWM repetition rate          |                                              | 0   |     | 'CPU/2 |                  |
| Res <sub>PWM</sub>    | PWM resolution               |                                              |     |     | 8      | bit              |
| V <sub>OS</sub>       | PWM/DAC output step voltage  | V <sub>DD</sub> = 5V,<br>Resolution = 8 bits |     | 20  |        | mV               |

 Table 130.
 8-bit PWM-ART auto-reload timer characteristics

#### Table 131. 16-bit timer characteristics

| Symbol                 | Parameter                      | Conditions               | Min | Тур | Max    | Unit             |
|------------------------|--------------------------------|--------------------------|-----|-----|--------|------------------|
| t <sub>w(ICAP)in</sub> | Input capture pulse time       |                          | 1   |     |        | t <sub>CPU</sub> |
| +                      | DW/M recolution time           |                          | 2   |     |        | t <sub>CPU</sub> |
| <sup>I</sup> res(PWM)  | F WW Tesolution time           | f <sub>CPU</sub> = 8 MHz | 250 |     |        | ns               |
| f <sub>EXT</sub>       | Timer external clock frequency |                          | 0   |     | f. //  |                  |
| f <sub>PWM</sub>       | PWM repetition rate            |                          | 0   |     | 'CPU/4 |                  |
| Res <sub>PWM</sub>     | PWM resolution                 |                          |     |     | 16     | bit              |





#### Figure 95. SPI master timing diagram<sup>(1)</sup>

1. Measurement points are done at CMOS levels:  $0.3 x V_{\text{DD}}$  and  $0.7 x V_{\text{DD}}.$ 

2. When no communication is on-going the data output line of the SPI (MOSI in master mode, MISO in slave mode) has its alternate function capability released. In this case, the pin status depends of the I/O port configuration.



# 20 Package characteristics



Figure 102. 64-pin (14x14) low profile quad flat package outline

#### Table 137. 64-pin (14x14) low profile quad flat package mechanical data

| Dimonsion |       | mm     |       | inches |        |        |  |  |
|-----------|-------|--------|-------|--------|--------|--------|--|--|
| Dimension | Min   | Тур    | Мах   | Min    | Тур    | Max    |  |  |
| А         |       |        | 1.600 |        |        | 0.0630 |  |  |
| A1        | 0.050 |        | 0.150 | 0.0020 |        | 0.0059 |  |  |
| A2        | 1.350 | 1.400  | 1.450 | 0.0531 | 0.0551 | 0.0571 |  |  |
| b         | 0.300 | 0.370  | 0.450 | 0.0118 | 0.0146 | 0.0177 |  |  |
| С         | 0.090 |        | 0.200 | 0.0035 |        | 0.0079 |  |  |
| D         |       | 16.000 |       |        | 0.6299 |        |  |  |
| D1        |       | 14.000 |       |        | 0.5512 |        |  |  |
| E         |       | 16.000 |       |        | 0.6299 |        |  |  |
| E1        |       | 14.000 |       |        | 0.5512 |        |  |  |
| е         |       | 0.800  |       |        | 0.0315 |        |  |  |
| θ         | 0°    | 3.5°   | 7°    | 0°     | 3.5°   | 7°     |  |  |
| L         | 0.450 | 0.600  | 0.750 | 0.0177 | 0.0236 | 0.0295 |  |  |
| L1        |       | 1.000  |       |        | 0.0394 |        |  |  |





| Bit    | Name          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| OPT7   | PKG1          | Package selection bit 1<br>This option bit, with the PKG0 bit, selects the package (see <i>Table 143: Package selection (OPT7)</i> ).                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| OPT6   | RSTC          | <ul> <li>RESET clock cycle selection</li> <li>This option bit selects the number of CPU cycles applied during the RESET phase and when exiting Halt mode. For resonator oscillators, it is advised to select 4096 due to the long crystal stabilization time.</li> <li>0: Reset phase with 4096 CPU cycles</li> <li>1: Reset phase with 256 CPU cycles</li> </ul>                                                                                                                                                                               |  |  |
| OPT5:4 | OSCTYPE[1:0]  | Oscillator type<br>These option bits select the ST7 main clock source type.<br>00: Clock source = Resonator oscillator<br>01: Reserved<br>10: Clock source = Internal RC oscillator<br>11: Clock source = External source                                                                                                                                                                                                                                                                                                                       |  |  |
| OPT3:1 | OSCRANGE[2:0] | Oscillator range<br>When the resonator oscillator type is selected, these option bits select<br>the resonator oscillator current source corresponding to the frequency<br>range of the resonator used. Otherwise, these bits are used to select<br>the normal operating frequency range.<br>000: Typ. frequency range = LP (1 ~ 2 MHz)<br>001: Typ. frequency range = MP (2 ~ 4 MHz)<br>010: Typ. frequency range = MS (4 ~ 8 MHz)<br>011: Typ. frequency range = HS (8 ~ 16 MHz)                                                               |  |  |
| OPT0   | PLLOFF        | <ul> <li>PLL activation</li> <li>This option bit activates the PLL which allows multiplication by two of the main input clock frequency. The PLL must not be used with the internal RC oscillator or with external clock source. The PLL is guaranteed only with an input frequency between 2 and 4 MHz.</li> <li>0: PLL x2 enabled</li> <li>1: PLL x2 disabled</li> <li>Caution: The PLL can be enabled only if the OSCRANGE (OPT3:1) bits are configured to "MP 2 ~ 4 MHz". Otherwise, the device functionality is not guaranteed.</li> </ul> |  |  |

Table 142. Option byte 1 bit description

 Table 143.
 Package selection (OPT7)

| Version | Selected package | PKG1 | PKG0 |
|---------|------------------|------|------|
| (A)R    | LQFP64           | 1    | 0    |
| J       | LQFP44           | 0    | 0    |

Note:

On the chip, each I/O port has up to eight pads. Pads that are not bonded to external pins are in input pull-up configuration after reset. The configuration of these pads must be kept at reset state to avoid added current consumption.





Figure 107. ST72321xxx-Auto ROM commercial product structure



# 21.3 Development tools

#### 21.3.1 Introduction

Development tools for the ST7 microcontrollers include a complete range of hardware systems and software tools from STMicroelectronics and third-party tool suppliers. The range of tools includes solutions to help you evaluate microcontroller peripherals, develop and debug your application, and program your microcontrollers.

#### 21.3.2 Evaluation tools and starter kits

ST offers complete, affordable starter kits and full-featured evaluation boards that allow you to evaluate microcontroller features and quickly start developing ST7 applications. Starter kits are complete, affordable hardware/software tool packages that include features and samples to help you quickly start developing your application. ST evaluation boards are open-design, embedded systems, which are developed and documented to serve as references for your application design. They include sample application software to help you demonstrate, learn about and implement your ST7's features.

#### 21.3.3 Development and debugging tools

Application development for ST7 is supported by fully optimizing C Compilers and the ST7 Assembler-Linker toolchain, which are all seamlessly integrated in the ST7 integrated development environments in order to facilitate the debugging and fine-tuning of your application. The Cosmic C Compiler is available in a free version that outputs up to 16 Kbytes of code.

The range of hardware tools includes cost effective ST7-DVP3 series emulators. These tools are supported by the ST7 Toolset from STMicroelectronics, which includes the STVD7 integrated development environment (IDE) with high-level language debugger, editor, project manager and integrated programming interface.

#### 21.3.4 Programming tools

During the development cycle, the ST7-DVP3 and ST7-EMU3 series emulators and the RLink provide in-circuit programming capability for programming the Flash microcontroller on your application board.

ST also provides a low-cost dedicated in-circuit programmer, the ST7-STICK, as well as ST7 socket boards which provide all the sockets required for programming any of the devices in a specific ST7 subfamily on a platform that can be used with any tool with in-circuit programming capability for ST7.

For production programming of ST7 devices, ST's third-party tool partners also provide a complete range of gang and automated programming solutions, which are ready to integrate into your production environment.

For additional ordering codes for spare parts, accessories and tools available for the ST7 (including from third party manufacturers), refer to the online product selector at www.st.com/mcu.



```
; check for falling edge
cp A,#$02
jrne OUT
TNZ Y
jrne OUT
LD A,#$01
LD sema,A
; set the semaphore to '1' if edge is detected
RIM
; reset the interrupt mask
LD A,sema
; check the semaphore status
CP A,#$01
jrne OUT
call call_routine
; call the interrupt routine
RIM
OUT:
RIM
JP while_loop
.call_routine
; entry to call_routine
PUSH A
PUSH X
PUSH CC
.ext1_rt
; entry to interrupt routine
LD A,#$00
LD sema,A
IRET
```

