



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             | ST10                                                                  |
| Core Size                  | 16-Bit                                                                |
| Speed                      | 64MHz                                                                 |
| Connectivity               | ASC, CANbus, EBI/EMI, I <sup>2</sup> C, SSC, UART/USART               |
| Peripherals                | POR, PWM, WDT                                                         |
| Number of I/O              | 111                                                                   |
| Program Memory Size        | 256КВ (256К х 8)                                                      |
| Program Memory Type        | FLASH                                                                 |
| EEPROM Size                | -                                                                     |
| RAM Size                   | 20К х 8                                                               |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                           |
| Data Converters            | A/D 24x10b                                                            |
| Oscillator Type            | Internal                                                              |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                    |
| Mounting Type              | Surface Mount                                                         |
| Package / Case             | 144-BQFP                                                              |
| Supplier Device Package    | 144-PQFP (28x28)                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/stmicroelectronics/f272-bag-p-tr |

Email: info@E-XFL.COM

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

#### **Internal Flash memory** 5

#### **Overview** 5.1

The on-chip Flash is composed by one matrix module, 256 KBytes wide. This module is on ST10 Internal bus, so it is called IFLASH



Program/Erase Controller (FPEC). The High Voltages needed for Program/Erase operations are internally generated.

The programming operations of the flash are managed by an embedded Flash

The Data bus is 32-bit wide for fetch accesses to IFLASH, while it is 16 bit wide for read accesses to IFLASH. Read/write accesses to IFLASH Control Registers area are 16 bit wide.

#### 5.2 **Functional description**

#### 5.2.1 Structure

Table 3 shows the Address space reserved to the Flash module.

|  | Table 3. | Address spa | ace reserved to | the Flash module |
|--|----------|-------------|-----------------|------------------|
|--|----------|-------------|-----------------|------------------|

| Description                                | Addresses              | Size      |
|--------------------------------------------|------------------------|-----------|
| IFLASH sectors                             | 0x00 0000 to 0x04 FFFF | 256 Kbyte |
| Reserved IBUS area                         | 0x05 0000 to 0x07 FFFF | 192 Kbyte |
| Registers and Flash internal reserved area | 0x08 0000 to 0x08 FFFF | 64 Kbyte  |



## 5.2.2 Modules structure

The IFLASH module is composed by a bank (Bank 0) of 256 Kbyte of Program Memory divided in 8 sectors (B0F0...B0F7). Bank 0 contains also a reserved sector named Test-Flash. The Addresses from 0x08 0000 to 0x08 FFFF are reserved for the Control Register Interface and other internal service memory space used by the Flash Program/Erase controller.

The following tables show the memory mapping of the Flash when it is accessed in read mode (*Table 4: Flash modules sectorization (Read operations)*), and when accessed in write or erase mode (*Table 5: Flash modules sectorization (Write operations or with ROMS1='1' or BootStrap mode)*): note that with this second mapping, the first four banks are remapped into code segment 1 (same as obtained setting bit ROMS1 in SYSCON register).

| Bank | Description           | Addresses                 | Size  | ST10 Bus size  |
|------|-----------------------|---------------------------|-------|----------------|
|      | Bank 0 Flash 0 (B0F0) | 0x0000 0000 - 0x0000 1FFF | 8 KB  |                |
|      | Bank 0 Flash 1 (B0F1) | 0x0000 2000 - 0x0000 3FFF | 8 KB  |                |
|      | Bank 0 Flash 2 (B0F2) | 0x0000 4000 - 0x0000 5FFF | 8 KB  |                |
| B0   | Bank 0 Flash 3 (B0F3) | 0x0000 6000 - 0x0000 7FFF | 8 KB  | 22 hit (1 RUS) |
|      | Bank 0 Flash 4 (B0F4) | 0x0001 8000 - 0x0001 FFFF | 32 KB | 32-bit (1-803) |
|      | Bank 0 Flash 5 (B0F5) | 0x0002 0000 - 0x0002 FFFF | 64 KB |                |
|      | Bank 0 Flash 6 (B0F6) | 0x0003 0000 - 0x0003 FFFF | 64 KB |                |
|      | Bank 0 Flash 7 (B0F7) | 0x0004 0000 - 0x0004 FFFF | 64 KB |                |

Table 4. Flash modules sectorization (Read operations)

# Table 5. Flash modules sectorization (Write operations or with ROMS1='1' or BootStrap mode)

| Bank | Description              | Addresses                 | Size  | ST10 Bus size  |
|------|--------------------------|---------------------------|-------|----------------|
|      | Bank 0 Test-Flash (B0TF) | 0x0000 0000 - 0x0000 1FFF | 8 KB  |                |
|      | Bank 0 Flash 0 (B0F0)    | 0x0001 0000 - 0x0001 1FFF | 8 KB  |                |
| В0   | Bank 0 Flash 1 (B0F1)    | 0x0001 2000 - 0x0001 3FFF | 8 KB  |                |
|      | Bank 0 Flash 2 (B0F2)    | 0x0001 4000 - 0x0001 5FFF | 8 KB  |                |
|      | Bank 0 Flash 3 (B0F3)    | 0x0001 6000 - 0x0001 7FFF | 8 KB  | 32-bit (I-BUS) |
|      | Bank 0 Flash 4 (B0F4)    | 0x0001 8000 - 0x0001 FFFF | 32 KB |                |
|      | Bank 0 Flash 5 (B0F5)    | 0x0002 0000 - 0x0002 FFFF | 64 KB |                |
|      | Bank 0 Flash 6 (B0F6)    | 0x0003 0000 - 0x0003 FFFF | 64 KB |                |
|      | Bank 0 Flash 7 (B0F7)    | 0x0004 0000 - 0x0004 FFFF | 64 KB |                |

Table 5 above refers to the configuration when bit ROMS1 of SYSCON register is set.



## 5.3 Write operation

The Flash module have one single register interface mapped in the memory space of the IBUS (0x08 0000 to 0x08 0015). All the operations are enabled through four 16-bit control registers: Flash Control Register 1-0 High/Low (FCR1H/L-FCR0H/L). Eight other 16-bit registers are used to store Flash Address and Data for Program operations (FARH/L and FDR1H/L-FDR0H/L) and Write Operation Error flags (FERH/L). All registers are accessible with 8 and 16-bit instructions (since operates in 16-bit mode when in read/ write).

Before accessing the IFlash module (and consequently also the Flash register to be used for program/erasing operations), bit ROMEN in SYSCON register shall be set.

During a Flash write operation any attempt to read the flash itself, that is under modification, will output invalid data (software trap 009Bh). This means that the Flash is not fetchable when a programming operation is active: the write operation commands must be executed from another memory (internal RAM or external memory), as in ST10F269 device. In fact, due to IBUS characteristics, it is not possible to perform a write operation on IFLASH, when fetching code from IFLASH.

Direct addressing is not allowed for write accesses to IFLASH Control Registers.

During a Write operation, when bit LOCK of FCR0 is set, it is forbidden to write into the Flash Control Registers.

## Power supply drop

If during a write operation the internal low voltage supply drops below a certain internal voltage threshold, any write operation running is suddenly interrupted and the module is reset to Read mode. At following Power-on, the interrupted Flash write operation must be repeated.



# 7.2 Instruction set summary

The *Table 27* lists the instructions of the ST10F272. The detailed description of each instruction can be found in the "ST10 Family Programming Manual".

| Mnemonic         | Description                                                                                       | Bytes |
|------------------|---------------------------------------------------------------------------------------------------|-------|
| ADD(B)           | Add word (byte) operands                                                                          | 2/4   |
| ADDC(B)          | Add word (byte) operands with Carry                                                               | 2/4   |
| SUB(B)           | Subtract word (byte) operands                                                                     | 2/4   |
| SUBC(B)          | Subtract word (byte) operands with Carry                                                          | 2/4   |
| MUL(U)           | (Un)Signed multiply direct GPR by direct GPR (16-16-bit)                                          | 2     |
| DIV(U)           | (Un)Signed divide register MDL by direct GPR (16-/16-bit)                                         | 2     |
| DIVL(U)          | (Un)Signed long divide reg. MD by direct GPR (32-/16-bit)                                         | 2     |
| CPL(B)           | Complement direct word (byte) GPR                                                                 | 2     |
| NEG(B)           | Negate direct word (byte) GPR                                                                     | 2     |
| AND(B)           | Bit-wise AND, (word/byte operands)                                                                | 2/4   |
| OR(B)            | Bit-wise OR, (word/byte operands)                                                                 | 2/4   |
| XOR(B)           | Bit-wise XOR, (word/byte operands)                                                                | 2/4   |
| BCLR             | Clear direct bit                                                                                  | 2     |
| BSET             | Set direct bit                                                                                    | 2     |
| BMOV(N)          | Move (negated) direct bit to direct bit                                                           | 4     |
| BAND, BOR, BXOR  | AND/OR/XOR direct bit with direct bit                                                             | 4     |
| BCMP             | Compare direct bit to direct bit                                                                  | 4     |
| BFLDH/L          | Bit-wise modify masked high/low byte of bit-addressable direct word memory with immediate data    | 4     |
| CMP(B)           | Compare word (byte) operands                                                                      | 2/4   |
| CMPD1/2          | Compare word data to GPR and decrement GPR by 1/2                                                 | 2/4   |
| CMPI1/2          | Compare word data to GPR and increment GPR by 1/2                                                 | 2/4   |
| PRIOR            | Determine number of shift cycles to normalize direct word GPR and store result in direct word GPR | 2     |
| SHL / SHR        | Shift left/right direct word GPR                                                                  | 2     |
| ROL / ROR        | Rotate left/right direct word GPR                                                                 | 2     |
| ASHR             | Arithmetic (sign bit) shift right direct word GPR                                                 | 2     |
| MOV(B)           | Move word (byte) data                                                                             | 2/4   |
| MOVBS            | Move byte operand to word operand with sign extension                                             | 2/4   |
| MOVBZ            | Move byte operand to word operand with zero extension                                             | 2/4   |
| JMPA, JMPI, JMPR | Jump absolute/indirect/relative if condition is met                                               | 4     |
| JMPS             | Jump absolute to a code segment                                                                   | 4     |

Table 27. Standard instruction set summary



# 14 A/D converter

A 10-bit A/D converter with 16+8 multiplexed input channels and a sample and hold circuit is integrated on-chip. An automatic self-calibration adjusts the A/D converter module to process parameter variations at each reset event. The sample time (for loading the capacitors) and the conversion time is programmable and can be adjusted to the external circuitry.

The ST10F272E has 16+8 multiplexed input channels on Port 5 and Port 1. The selection between Port 5 and Port 1 is made via a bit in a XBus register. Refer to the User Manual for a detailed description.

A different accuracy is guaranteed (Total Unadjusted Error) on Port 5 and Port 1 analog channels (with higher restrictions when overload conditions occur); in particular, Port 5 channels are more accurate than the Port 1 ones. Refer to *Section 24: Electrical characteristics*.

The A/D converter input bandwidth is limited by the achievable accuracy: supposing a maximum error of 0.5LSB (2mV) impacting the global TUE (TUE depends also on other causes), in worst case of temperature and process, the maximum frequency for a sine wave analog signal is around 7.5 kHz. Of course, to reduce the effect of the input signal variation on the accuracy down to 0.05LSB, the maximum input frequency of the sine wave shall be reduced to 800 Hz.

If static signal is applied during sampling phase, series resistance shall not be greater than  $20k\Omega$  (this taking into account eventual input leakage). It is suggested to not connect any capacitance on analog input pins, in order to reduce the effect of charge partitioning (and consequent voltage drop error) between the external and the internal capacitance: in case an RC filter is necessary the external capacitance must be greater than 10nF to minimize the accuracy impact.

Overrun error detection / protection is controlled by the ADDAT register. Either an interrupt request is generated when the result of a previous conversion has not been read from the result register at the time the next conversion is complete, or the next conversion is suspended until the previous result has been read. For applications which require less than 16+8 analog input channels, the remaining channel inputs can be used as digital input port pins.

The A/D converter of the ST10F272 supports different conversion modes:

- Single channel single conversion: The analog level of the selected channel is sampled once and converted. The result of the conversion is stored in the ADDAT register.
- Single channel continuous conversion: The analog level of the selected channel is repeatedly sampled and converted. The result of the conversion is stored in the ADDAT register.
- Auto scan single conversion: The analog level of the selected channels are sampled once and converted. After each conversion the result is stored in the ADDAT register. The data can be transferred to the RAM by interrupt software management or using the powerful Peripheral Event Controller (PEC) data transfer.
- Auto scan continuous conversion: The analog level of the selected channels are repeatedly sampled and converted. The result of the conversion is stored in the ADDAT



## Single CAN bus

The single CAN Bus multiple interfaces configuration may be implemented using two CAN transceivers as shown in *Figure 12*.

Figure 12. Connection to single CAN bus via separate CAN transceivers



The ST10F272 also supports single CAN Bus multiple (dual) interfaces using the open drain option of the CANx\_TxD output as shown in *Figure 13*. Thanks to the OR-Wired Connection, only one transceiver is required. In this case the design of the application must take in account the wire length and the noise environment.









Figure 18. Asynchronous hardware RESET ( $\overline{EA} = 1$ )

1. Longer than Port0 settling time + PLL synchronization (if needed, that is P0 (15:13) changed).

2. Longer than 500ns to take into account of Input Filter on RSTIN pin.





Figure 21. Synchronous short / long hardware RESET ( $\overline{EA} = 0$ )

1. RSTIN assertion can be released there. Refer also to Section 21.1 for details on minimum pulse duration.

2. If during the reset condition (RSTIN low), RPD voltage drops below the threshold voltage (about 2.5 V for 5 V operation), the asynchronous reset is then immediately entered.

- 3. 3 to 8 TCL depending on clock source selection.
- 4. RSTIN pin is pulled low if bit BDRSTEN (bit 3 of SYSCON register) was previously set by software. Bit BDRSTEN is cleared after reset.
- 5. Minimum RSTIN low pulse duration shall also be longer than 500ns to guarantee the pulse is not masked by the internal filter (refer to *Section 21.1*).





or Watchdog Reset become a Short Hardware Reset. On the contrary, if RSTF remains low for less than 4 TCL, the device simply exits reset state.

The Bidirectional reset is not effective in case RPD is held low, when a Software or Watchdog reset event occurs. On the contrary, if a Software or Watchdog Bidirectional reset event is active and RPD becomes low, the RSTIN pin is immediately released, while the internal reset sequence is completed regardless of RPD status change (1024 TCL).

Note:

The bidirectional reset function is disabled by any reset sequence (bit BDRSTEN of SYSCON is cleared). To be activated again it must be enabled during the initialization routine.

## WDTCON flags

Similarly to what already highlighted in the previous section when discussing about Short reset and the degeneration into Long reset, similar situations may occur when Bidirectional reset is enabled. The presence of the internal filter on RSTIN pin introduces a delay: when RSTIN is released, the internal signal after the filter (see RSTF in the drawings) is delayed, so it remains still active (low) for a while. It means that depending on the internal clock speed, a short reset may be recognized as a long reset: the WDTCON flags are set accordingly.

Besides, when either Software or Watchdog bidirectional reset events occur, again when the RSTIN pin is released (at the end of the internal reset sequence), the RSTF internal signal (after the filter) remains low for a while, and depending on the clock frequency it is recognized high or low: 8TCL after the completion of the internal sequence, the level of RSTF signal is sampled, and if recognized still low a Hardware reset sequence starts, and WDTCON will flag this last event, masking the previous one (Software or Watchdog reset). Typically, a Short Hardware reset is recognized, unless the RSTIN pin (and consequently internal signal RSTF) is sufficiently held low by the external hardware to inject a Long Hardware reset. After this occurrence, the initialization routine is not able to recognize a Software or Watchdog bidirectional reset event, since a different source is flagged inside WDTCON register. This phenomenon does not occur when internal FLASH is selected during reset (EA = 1), since the initialization of the FLASH itself extend the internal reset duration well beyond the filter delay.

*Figure 26, Figure 27* and *Figure 28* summarize the timing for Software and Watchdog Timer Bidirectional reset events: in particular *Figure 28* shows the degeneration into Hardware reset.





Figure 34. PORT0 bits latched into the different registers after reset



| Name            | Physical address | 8-bit<br>address | Description                               | Reset<br>value      |
|-----------------|------------------|------------------|-------------------------------------------|---------------------|
| T1              | FE52h            | 29h              | CAPCOM timer 1 register                   | 0000h               |
| T1IC <b>b</b>   | FF9Eh            | CFh              | CAPCOM timer 1 interrupt control register | 00h                 |
| T1REL           | FE56h            | 2Bh              | CAPCOM timer 1 reload register            | 0000h               |
| T2              | FE40h            | 20h              | GPT1 timer 2 register                     | 0000h               |
| T2CON <b>b</b>  | FF40h            | A0h              | GPT1 timer 2 control register             | 0000h               |
| T2IC <b>b</b>   | FF60h            | B0h              | GPT1 timer 2 interrupt control register   | 00h                 |
| Т3              | FE42h            | 21h              | GPT1 timer 3 register                     | 0000h               |
| T3CON <b>b</b>  | FF42h            | A1h              | GPT1 timer 3 control register             | 0000h               |
| T3IC <b>b</b>   | FF62h            | B1h              | GPT1 timer 3 interrupt control register   | 00h                 |
| T4              | FE44h            | 22h              | GPT1 timer 4 register                     | 0000h               |
| T4CON <b>b</b>  | FF44h            | A2h              | GPT1 timer 4 control register             | 0000h               |
| T4IC <b>b</b>   | FF64h            | B2h              | GPT1 timer 4 interrupt control register   | 00h                 |
| Т5              | FE46h            | 23h              | GPT2 timer 5 register                     | 0000h               |
| T5CON <b>b</b>  | FF46h            | A3h              | GPT2 timer 5 control register             | 0000h               |
| T5IC <b>b</b>   | FF66h            | B3h              | GPT2 timer 5 interrupt control register   | 00h                 |
| Т6              | FE48h            | 24h              | GPT2 timer 6 register                     | 0000h               |
| T6CON <b>b</b>  | FF48h            | A4h              | GPT2 timer 6 control register             | 0000h               |
| T6IC <b>b</b>   | FF68h            | B4h              | GPT2 timer 6 interrupt control register   | 00h                 |
| T7              | F050h <b>E</b>   | 28h              | CAPCOM timer 7 register                   | 0000h               |
| T78CON <b>b</b> | FF20h            | 90h              | CAPCOM timer 7 and 8 control register     | 0000h               |
| T7IC <b>b</b>   | F17Ah <b>E</b>   | BDh              | CAPCOM timer 7 interrupt control register | 00h                 |
| T7REL           | F054h <b>E</b>   | 2Ah              | CAPCOM timer 7 reload register            | 0000h               |
| Т8              | F052h <b>E</b>   | 29h              | CAPCOM timer 8 register                   | 0000h               |
| T8IC <b>b</b>   | F17Ch <b>E</b>   | BEh              | CAPCOM timer 8 interrupt control register | 00h                 |
| T8REL           | F056h <b>E</b>   | 2Bh              | CAPCOM timer 8 reload register            | 0000h               |
| TFR b           | FFACh            | D6h              | Trap Flag register                        | 0000h               |
| WDT             | FEAEh            | 57h              | Watchdog timer register (read only)       | 0000h               |
| WDTCONb         | FFAEh            | D7h              | Watchdog timer control register           | 00xxh <sup>2)</sup> |
| XADRS3          | F01Ch <b>E</b>   | 0Eh              | XPER address select register 3            | 800Bh               |
| XP0IC <b>b</b>  | F186h <b>E</b>   | C3h              | See Section 9.1                           | 00h <sup>3)</sup>   |
| XP1IC <b>b</b>  | F18Eh <b>E</b>   | C7h              | See Section 9.1                           | 00h <sup>3)</sup>   |
| XP2IC <b>b</b>  | F196h <b>E</b>   | CBh              | See Section 9.1                           | 00h <sup>3)</sup>   |
| XP3IC <b>b</b>  | F19Eh <b>E</b>   | CFh              | See Section 9.1                           | 00h <sup>3)</sup>   |

| Table 53. | List of special function | registers | (continued) |
|-----------|--------------------------|-----------|-------------|
|           | •                        | •         | • •         |



| Name       | Physical address | Description                  | Reset<br>value |
|------------|------------------|------------------------------|----------------|
| CAN2IF1MC  | EE1Ch            | CAN2: IF1 message control    | 0000h          |
| CAN2IF2A1  | EE48h            | CAN2: IF2 arbitration 1      | 0000h          |
| CAN2IF2A2  | EE4Ah            | CAN2: IF2 arbitration 2      | 0000h          |
| CAN2IF2CM  | EE42h            | CAN2: IF2 command mask       | 0000h          |
| CAN2IF2CR  | EE40h            | CAN2: IF2 command request    | 0001h          |
| CAN2IF2DA1 | EE4Eh            | CAN2: IF2 data A 1           | 0000h          |
| CAN2IF2DA2 | EE50h            | CAN2: IF2 data A 2           | 0000h          |
| CAN2IF2DB1 | EE52h            | CAN2: IF2 data B 1           | 0000h          |
| CAN2IF2DB2 | EE54h            | CAN2: IF2 data B 2           | 0000h          |
| CAN2IF2M1  | EE44h            | CAN2: IF2 mask 1             | FFFFh          |
| CAN2IF2M2  | EE46h            | CAN2: IF2 mask 2             | FFFFh          |
| CAN2IF2MC  | EE4Ch            | CAN2: IF2 message control    | 0000h          |
| CAN2IP1    | EEA0h            | CAN2: interrupt pending 1    | 0000h          |
| CAN2IP2    | EEA2h            | CAN2: interrupt pending 2    | 0000h          |
| CAN2IR     | EE08h            | CAN2: interrupt register     | 0000h          |
| CAN2MV1    | EEB0h            | CAN2: message valid 1        | 0000h          |
| CAN2MV2    | EEB2h            | CAN2: message valid 2        | 0000h          |
| CAN2ND1    | EE90h            | CAN2: new data 1             | 0000h          |
| CAN2ND2    | EE92h            | CAN2: new data 2             | 0000h          |
| CAN2SR     | EE02h            | CAN2: status register        | 0000h          |
| CAN2TR     | EE0Ah            | CAN2: test register          | 00x0h          |
| CAN2TR1    | EE80h            | CAN2: transmission request 1 | 0000h          |
| CAN2TR2    | EE82h            | CAN2: Transmission request 2 | 0000h          |
| I2CCCR1    | EA06h            | I2C clock control register 1 | 0000h          |
| I2CCCR2    | EA0Eh            | I2C clock control register 2 | 0000h          |
| I2CCR      | EA00h            | I2C control register         | 0000h          |
| I2CDR      | EA0Ch            | I2C data register            | 0000h          |
| I2COAR1    | EA08h            | I2C own address register 1   | 0000h          |
| I2COAR2    | EA0Ah            | I2C own address register 2   | 0000h          |
| I2CSR1     | EA02h            | I2C status register 1        | 0000h          |
| I2CSR2     | EA04h            | I2C status register 2        | 0000h          |
| RTCAH      | ED14h            | RTC alarm register high byte | XXXXh          |
| RTCAL      | ED12h            | RTC alarm register low byte  | XXXXh          |
| RTCCON     | ED00H            | RTC control register         | 000Xh          |

Table 54. List of XBus registers (continued)



## Example of external network sizing

The following hypothesis are formulated in order to proceed in designing the external network on A/D Converter input pins:

- Analog Signal Source Bandwidth (f<sub>0</sub>):10kHz
- conversion Rate (f<sub>C</sub>):25kHz
- Sampling Time (T<sub>S</sub>):1μs
- Pin Input Capacitance (C<sub>P1</sub>):5pF
- Pin Input Routing Capacitance (C<sub>P2</sub>):1pF
- Sampling Capacitance (C<sub>S</sub>):4pF
- Maximum Input Current Injection (I<sub>INJ</sub>):3mA
- Maximum Analog Source Voltage (V<sub>AM)</sub>:12V
- Analog Source Impedance (R<sub>S</sub>):100Ω
- Channel Switch Resistance (R<sub>SW</sub>):500Ω
- Sampling Switch Resistance (R<sub>AD</sub>):200Ω
- 1. Supposing to design the filter with the pole exactly at the maximum frequency of the signal, the time constant of the filter is:

### **Equation 10**

$$R_{C}C_{F} = \frac{1}{2\pi f_{0}} = 15.9 \mu s$$

2. Using the relation between  $C_F$  and  $C_S$  and taking some margin (4000 instead of 2048), it is possible to define  $C_F$ :

## **Equation 11**

$$C_{F} = 4000 C_{S} = 16 nF$$

3. As a consequence of step 1 and 2, RC can be chosen:

#### **Equation 12**

$$R_{F} = \frac{1}{2\pi f_{0}C_{F}} = 995\Omega \cong 1k\Omega$$

4. Considering the current injection limitation and supposing that the source can go up to 12V, the total series resistance can be defined as:

#### **Equation 13**

$$R_{S} + R_{F} + R_{L} = \frac{V_{AM}}{I_{INJ}} = 4k\Omega$$

from which is now simple to define the value of R<sub>L</sub>:



## **Equation 14**

$$R_{L} = \frac{V_{AM}}{I_{INJ}} - R_{F} - R_{S} = 2.9 k\Omega$$

5. Now the three element of the external circuit R<sub>F</sub>, C<sub>F</sub> and R<sub>L</sub> are defined. Some conditions discussed in the previous paragraphs have been used to size the component, the other must now be verified. The relation which allow to minimize the accuracy error introduced by the switched capacitance equivalent resistance is in this case:

#### **Equation 15**

$$R_{EQ} = \frac{1}{f_C C_S} = 10M\Omega$$

So the error due to the voltage partitioning between the real resistive path and  $C_S$  is less then half a count (considering the worst case when  $V_A = 5V$ ):

#### **Equation 16**

$$V_{A} \cdot \frac{R_{S} + R_{F} + R_{L} + R_{SW} + R_{AD}}{R_{EQ}} = 2.35 \text{mV} < \frac{1}{2} \text{LSB}$$

The other conditions to be verified is the time constants of the transients are really and significantly shorter than the sampling period duration  $T_S$ :

#### **Equation 17**

$$\tau_{1} = (R_{SW} + R_{AD}) \cdot C_{S} = 2.8 \text{ ns} \quad << T_{S} = 1 \mu \text{s}$$
  
10  $\tau_{2} = 10 R_{L}(C_{S} + C_{P1} + C_{P2}) = 290 \text{ ns} \quad < T_{S} = 1 \mu \text{s}$ 

For complete set of parameters characterizing the ST10F272 A/D Converter equivalent circuit, refer to Section 24.7: A/D converter characteristics.



| P  | P0.15-13 |     | XTAL                         | Input                 | PLL          |           | Output               | CPU Frequency                            |
|----|----------|-----|------------------------------|-----------------------|--------------|-----------|----------------------|------------------------------------------|
| (P | 0H.7     | -5) | Frequency                    | Prescaler             | Multiply by  | Divide by | Prescaler            | f <sub>CPU</sub> = f <sub>XTAL</sub> x F |
| 1  | 1        | 1   | 4 to 8MHz                    | F <sub>XTAL</sub> /4  | 64           | 4         | -                    | F <sub>XTAL</sub> x 4                    |
| 1  | 1        | 0   | 5.3 to 10.6MHz <sup>1)</sup> | F <sub>XTAL</sub> /4  | 48           | 4         | -                    | F <sub>XTAL</sub> x 3                    |
| 1  | 0        | 1   | 4 to 8MHz                    | F <sub>XTAL</sub> / 4 | 64           | 2         | -                    | F <sub>XTAL</sub> x 8                    |
| 1  | 0        | 0   | 6.4 to 12MHz <sup>1)</sup>   | F <sub>XTAL</sub> /4  | 40           | 2         | -                    | F <sub>XTAL</sub> x 5                    |
| 0  | 1        | 1   | 1 to 64MHz                   | -                     | PLL by       | passed    | -                    | F <sub>XTAL</sub> x 1                    |
| 0  | 1        | 0   | 4 to 6.4MHz                  | F <sub>XTAL</sub> /2  | 40           | 2         | -                    | F <sub>XTAL</sub> x 10                   |
| 0  | 0        | 1   | 4 to 12MHz <sup>1)</sup>     | -                     | PLL bypassed |           | F <sub>PLL</sub> / 2 | F <sub>XTAL</sub> / 2                    |
| 0  | 0        | 0   | 4MHz                         | F <sub>XTAL</sub> / 2 | 64           | 2         | _                    | F <sub>XTAL</sub> x 16                   |

Table 70. Internal PLL divider mechanism

The PLL input frequency range is limited to 1 to 3.5MHz, while the VCO oscillation range is 64 to 128MHz. The CPU clock frequency range when PLL is used is 16 to 64MHz.

## Example 1

- $F_{XTAL} = 4MHz$
- P0(15:13) = '110' (Multiplication by 3)
- PLL Input Frequency = 1MHz
- VCO frequency = 48MHz
- PLL Output Frequency = 12MHz (VCO frequency divided by 4)
- F<sub>CPU</sub> = 12MHz (no effect of Output Prescaler)

## Example 2

- $F_{XTAL} = 8MHz$
- P0(15:13) = '100' (Multiplication by 5)
- PLL Input Frequency = 2MHz
- VCO frequency = 80MHz
- PLL Output Frequency = 40MHz (VCO frequency divided by 2)
- F<sub>CPU</sub> = 40MHz (no effect of Output Prescaler)

## 24.8.9 PLL Jitter

The following terminology is hereafter defined:

## Self referred single period jitter

Also called "Period Jitter", it can be defined as the difference of the  $T_{max}$  and  $T_{min}$ , where  $T_{max}$  is maximum time period of the PLL output clock and  $T_{min}$  is the minimum time period of the PLL output clock.

## • Self referred long term jitter

Also called "N period jitter", it can be defined as the difference of  $T_{max}$  and  $T_{min}$ , where  $T_{max}$  is the maximum time difference between N+1 clock rising edges and  $T_{min}$  is the minimum time difference between N+1 clock rising edges. Here N should be kept



contribution of the digital noise to the global jitter is widely taken into account in the curves provided in *Figure 45*.



## 24.8.10 PLL lock / unlock

During normal operation, if the PLL gets unlocked for any reason, an interrupt request to the CPU is generated, and the reference clock (oscillator) is automatically disconnected from the PLL input: in this way, the PLL goes into free-running mode, providing the system with a backup clock signal (free running frequency  $F_{free}$ ). This feature allows to recover from a crystal failure occurrence without risking to go in an undefined configuration: the system is provided with a clock allowing the execution of the PLL unlock interrupt routine in a safe mode.

The path between reference clock and PLL input can be restored only by a hardware reset, or by a bidirectional software or watchdog reset event that forces the RSTIN pin low.

Note: The external RC circuit on RSTIN pin shall be properly sized in order to extend the duration of the low pulse to grant the PLL gets locked before the level at RSTIN pin is recognized high: bidirectional reset internally drives RSTIN pin low for just 1024 TCL (definitively not sufficient to get the PLL locked starting from free-running mode).



| Symbol            | Peremeter                                                      | Conditions                                                                  | Value      |              | Unit |
|-------------------|----------------------------------------------------------------|-----------------------------------------------------------------------------|------------|--------------|------|
| Symbol            | Parameter                                                      | Conditions                                                                  | min.       | max.         | Unit |
| T <sub>PSUP</sub> | PLL Start-up time 1)                                           | Stable $V_{DD}$ and reference clock                                         | -          | 300          | μs   |
| T <sub>LOCK</sub> | PLL Lock-in time                                               | Stable V <sub>DD</sub> and reference clock, starting from free-running mode | -          | 250          | μs   |
| T <sub>JIT</sub>  | Single Period Jitter <sup>1)</sup><br>(cycle to cycle = 2 TCL) | 6 sigma time period variation<br>(peak to peak)                             | -500       | +500         | ps   |
| F <sub>free</sub> | PLL free running frequency                                     | Multiplication Factors: 3, 4<br>Multiplication Factors: 5, 8, 10, 16        | 250<br>500 | 2000<br>4000 | kHz  |

Table 71. PLL characteristics ( $V_{DD} = 5V \pm 10\%$ ,  $V_{SS} = 0V$ , TA = -40 to +125°C)

1. Not 100% tested, guaranteed by design characterization.

## 24.8.11 Main oscillator specifications

 $V_{DD}$  = 5V  $\pm$  10%,  $V_{SS}$  = 0V,  $T_A$  = –40 to +125°C

| Table 72. | Main oscillator | characteristics |
|-----------|-----------------|-----------------|
|           |                 |                 |

| Symbol            | Parameter                           | Conditions                         | Value |      |      | Unit |
|-------------------|-------------------------------------|------------------------------------|-------|------|------|------|
| Symbol            |                                     | Conditions                         | min.  | typ. | max. | Unit |
| 9 <sub>m</sub>    | Oscillator<br>Transconductance      |                                    | 1.4   | 2.6  | 4.2  | mA/V |
| V <sub>OSC</sub>  | Oscillation Amplitude <sup>1)</sup> | Peak to Peak                       | -     | 1.5  | -    | V    |
| V <sub>AV</sub>   | Oscillation Voltage level 1)        | Sine wave middle                   | -     | 0.8  | -    | V    |
| t <sub>STUP</sub> | Oscillator Start-up Time 1)         | Stable V <sub>DD</sub> - Crystal   | Ι     | 6    | 10   | ms   |
|                   |                                     | Stable V <sub>DD</sub> - Resonator | _     | 1    | 2    | ms   |

1. Not 100% tested, guaranteed by design characterization.

## Figure 46. Crystal oscillator and resonator connection diagram







# 24.8.16 Multiplexed bus

 $\label{eq:VDD} \begin{array}{l} \mathsf{V}_{\text{DD}} = \mathsf{5V} \pm 10\%, \, \mathsf{V}_{\text{SS}} = \mathsf{0V}, \, \mathsf{T}_{\text{A}} = -40 \text{ to } +125^{\circ}\text{C}, \, \mathsf{CL} = \mathsf{50pF}, \\ \text{ALE cycle time} = \mathsf{6} \; \mathsf{TCL} + 2t_{\text{A}} + t_{\text{C}} + t_{\text{F}} \; (\mathsf{75ns} \; \text{at} \; 40\text{MHz} \; \mathsf{CPU} \; \mathsf{clock} \; \mathsf{without} \; \mathsf{wait} \; \mathsf{states}) \end{array}$ 

| Symbol          |    | Parameter                                                                                           | F <sub>CPU</sub> = 40 MHz<br>TCL = 12.5 ns |                                             | Variable CPU Clock<br>1/2 TCL = 1 to 64MHz |                                                  | Jnit |
|-----------------|----|-----------------------------------------------------------------------------------------------------|--------------------------------------------|---------------------------------------------|--------------------------------------------|--------------------------------------------------|------|
|                 |    |                                                                                                     | min. max.                                  |                                             | min.                                       | max.                                             |      |
| t <sub>5</sub>  | CC | ALE high time                                                                                       | $4 + t_A$                                  | _                                           | TCL – 8.5 + t <sub>A</sub>                 | _                                                | ns   |
| t <sub>6</sub>  | CC | Address setup to ALE                                                                                | 1.5 + t <sub>A</sub>                       | _                                           | TCL – 11 + t <sub>A</sub>                  | _                                                | ns   |
| t <sub>7</sub>  | CC | Address hold after ALE                                                                              | $4 + t_A$                                  | -                                           | TCL – 8.5 + t <sub>A</sub>                 | -                                                | ns   |
| t <sub>8</sub>  | СС | ALE falling edge to $\overline{RD}$ , $\overline{WR}$ (with RW-delay)                               | $4 + t_A$                                  | -                                           | TCL – 8.5 + t <sub>A</sub>                 | _                                                | ns   |
| t <sub>9</sub>  | СС | ALE falling edge to RD, WR<br>(no RW-delay)                                                         | - 8.5 + t <sub>A</sub>                     | _                                           | - 8.5 + t <sub>A</sub>                     | _                                                | ns   |
| t <sub>10</sub> | СС | Address float after RD, WR<br>(with RW-delay)                                                       | _                                          | 6                                           | _                                          | 6                                                | ns   |
| t <sub>11</sub> | СС | Address float after RD, WR<br>(no RW-delay)                                                         | -                                          | 18.5                                        | _                                          | TCL + 6                                          | ns   |
| t <sub>12</sub> | СС | RD, WR low time<br>(with RW-delay)                                                                  | 15.5 + t <sub>C</sub>                      | -                                           | 2TCL – 9.5 + t <sub>C</sub>                | _                                                | ns   |
| t <sub>13</sub> | СС | RD, WR low time<br>(no RW-delay)                                                                    | 28 + t <sub>C</sub>                        | -                                           | 3TCL – 9.5 + t <sub>C</sub>                | _                                                | ns   |
| t <sub>14</sub> | SR | RD to valid data in<br>(with RW-delay)                                                              | -                                          | 6 + t <sub>C</sub>                          | _                                          | 2TCL – 19 + t <sub>C</sub>                       | ns   |
| t <sub>15</sub> | SR | RD to valid data in<br>(no RW-delay)                                                                | -                                          | 18.5 + t <sub>C</sub>                       | -                                          | 3TCL – 19 + t <sub>C</sub>                       | ns   |
| t <sub>16</sub> | SR | ALE low to valid data in                                                                            | -                                          | 17.5 +<br>+ t <sub>A</sub> + t <sub>C</sub> | -                                          | 3TCL – 20 +<br>+ t <sub>A</sub> + t <sub>C</sub> | ns   |
| t <sub>17</sub> | SR | Address/Unlatched $\overline{CS}$ to valid data in                                                  | -                                          | 20 + 2t <sub>A</sub> +<br>+ t <sub>C</sub>  | -                                          | $4TCL - 30 + 2t_A + t_C$                         | ns   |
| t <sub>18</sub> | SR | Data hold after RD<br>rising edge                                                                   | 0                                          | -                                           | 0                                          | _                                                | ns   |
| t <sub>19</sub> | SR | Data float after RD                                                                                 | -                                          | 16.5 + t <sub>F</sub>                       | -                                          | 2TCL – 8.5 + t <sub>F</sub>                      | ns   |
| t <sub>22</sub> | CC | Data valid to WR                                                                                    | 10 + t <sub>C</sub>                        | -                                           | 2TCL – 15 + t <sub>C</sub>                 | -                                                | ns   |
| t <sub>23</sub> | СС | Data hold after WR                                                                                  | 4 + t <sub>F</sub>                         | -                                           | 2TCL – 8.5 + t <sub>F</sub>                | -                                                | ns   |
| t <sub>25</sub> | СС | ALE rising edge after $\overline{RD}$ , $\overline{WR}$                                             | 15 + t <sub>F</sub>                        | _                                           | 2TCL – 10 + t <sub>F</sub>                 | _                                                | ns   |
| t <sub>27</sub> | сс | Address/Unlatched $\overline{\text{CS}}$ hold after $\overline{\text{RD}}$ , $\overline{\text{WR}}$ | 10 + t <sub>F</sub>                        | _                                           | 2TCL – 15 + t <sub>F</sub>                 | -                                                | ns   |
| t <sub>38</sub> | СС | ALE falling edge to Latched CS                                                                      | $-4-t_A$                                   | $10 - t_{A}$                                | $-4 - t_A$                                 | 10 – t <sub>A</sub>                              | ns   |

| Table 78. | Multiplexed | bus timings |
|-----------|-------------|-------------|
|-----------|-------------|-------------|



| Symbol          |    | Parameter                                                            | F <sub>CPU</sub> = 40 MHz<br>TCL = 12.5 ns |                                              | Variable CPU Clock<br>1/2 TCL = 1 to 64MHz |                                                   | Init |
|-----------------|----|----------------------------------------------------------------------|--------------------------------------------|----------------------------------------------|--------------------------------------------|---------------------------------------------------|------|
|                 |    |                                                                      | min.                                       | max.                                         | min.                                       | max.                                              | ر    |
| t <sub>38</sub> | СС | ALE falling edge to Latched                                          | $-4-t_A$                                   | $6 - t_A$                                    | $-4-t_A$ $6-t_A$                           |                                                   | ns   |
| t <sub>39</sub> | SR | Latched $\overline{CS}$ low to Valid Data In                         | -                                          | 16.5 +<br>+ t <sub>C</sub> + 2t <sub>A</sub> | _                                          | 3TCL – 21 +<br>+ t <sub>C</sub> + 2t <sub>A</sub> | ns   |
| t <sub>41</sub> | сс | Latched $\overline{CS}$ hold after $\overline{RD}$ , $\overline{WR}$ | 2 + t <sub>F</sub>                         | _                                            | TCL – 10.5 + t <sub>F</sub>                | _                                                 | ns   |
| t <sub>82</sub> | сс | Address setup to RdCS,<br>WrCS<br>(with RW-delay)                    | 14 + 2t <sub>A</sub>                       | -                                            | 2TCL – 11 + 2t <sub>A</sub>                | -                                                 | ns   |
| t <sub>83</sub> | сс | Address setup to RdCS,<br>WrCS<br>(no RW-delay)                      | 2 + 2t <sub>A</sub>                        | -                                            | TCL –10.5 + 2t <sub>A</sub>                | -                                                 | ns   |
| t <sub>46</sub> | SR | RdCS to Valid Data In<br>(with RW-delay)                             | -                                          | 4 + t <sub>C</sub>                           | -                                          | 2TCL – 21 + t <sub>C</sub>                        | ns   |
| t <sub>47</sub> | SR | RdCS to Valid Data In<br>(no RW-delay)                               | -                                          | 16.5 + t <sub>C</sub>                        | -                                          | 3TCL – 21 + t <sub>C</sub>                        | ns   |
| t <sub>48</sub> | сс | RdCS, WrCS Low Time<br>(with RW-delay)                               | 15.5 + t <sub>C</sub>                      | -                                            | 2TCL – 9.5 + t <sub>C</sub>                | -                                                 | ns   |
| t <sub>49</sub> | СС | RdCS, WrCS Low Time<br>(no RW-delay)                                 | 28 + t <sub>C</sub>                        | -                                            | 3TCL – 9.5 + t <sub>C</sub>                | -                                                 | ns   |
| t <sub>50</sub> | СС | Data valid to WrCS                                                   | 10 + t <sub>C</sub>                        | -                                            | 2TCL – 15 + t <sub>C</sub>                 | -                                                 | ns   |
| t <sub>51</sub> | SR | Data hold after RdCS                                                 | 0                                          | -                                            | 0                                          | -                                                 | ns   |
| t <sub>53</sub> | SR | Data float after RdCS<br>(with RW-delay)                             | -                                          | 16.5 + t <sub>F</sub>                        | -                                          | 2TCL – 8.5 + t <sub>F</sub>                       | ns   |
| t <sub>68</sub> | SR | Data float after RdCS<br>(no RW-delay)                               | -                                          | 4 + t <sub>F</sub>                           | -                                          | TCL – 8.5 + t <sub>F</sub>                        | ns   |
| t <sub>55</sub> | сс | Address hold after<br>RdCS, WrCS                                     | – 8.5 + t <sub>F</sub>                     | -                                            | – 8.5 + t <sub>F</sub>                     | -                                                 | ns   |
| t <sub>57</sub> | CC | Data hold after WrCS                                                 | 2 + t <sub>F</sub>                         | -                                            | TCL – 10.5 + t <sub>F</sub>                | _                                                 | ns   |

 Table 79.
 Demultiplexed bus timings (continued)

1. RW-delay and  $t_A$  refer to the next following bus cycle.

2. Read data are latched with the same clock edge that triggers the address change and the rising  $\overline{\text{RD}}$  edge. Therefore address changes before the end of  $\overline{\text{RD}}$  have no impact on read cycles.

3. Partially tested, guaranteed by design characterization.





Figure 55. External memory cycle: Demultipl. bus, with/without r/w delay, normal ALE, r/w CS

