



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               | LINbusSCI                                                           |
| Peripherals                | LVD, Motor Control PWM, POR, PWM, WDT                               |
| Number of I/O              | 17                                                                  |
| Program Memory Size        | 8KB (8K x 8)                                                        |
| Program Memory Type        | FLASH                                                               |
| EEPROM Size                | -                                                                   |
| RAM Size                   | 384 x 8                                                             |
| Voltage - Supply (Vcc/Vdd) | 3.8V ~ 5.5V                                                         |
| Data Converters            | A/D 8x10b                                                           |
| Oscillator Type            | Internal                                                            |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                   |
| Mounting Type              | Surface Mount                                                       |
| Package / Case             | 32-LQFP                                                             |
| Supplier Device Package    | -                                                                   |
| Purchase URL               | https://www.e-xfl.com/product-detail/stmicroelectronics/st7fmc1k2t6 |

Email: info@E-XFL.COM

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

# SYSTEM INTEGRITY MANAGEMENT (Cont'd)

# SYSTEM INTEGRITY (SI) CONTROL/STATUS REGISTER (SICSR, page 1)

Reset Value: 00000000 (00h)

| 7        |   |           |          |           |   |            | 0 |
|----------|---|-----------|----------|-----------|---|------------|---|
| PA<br>GE | 0 | VCO<br>EN | LO<br>CK | PLL<br>EN | 0 | CK-<br>SEL | 0 |

Bit 7 = **PAGE** SICSR Register Page Selection This bit selects the SICSR register page. It is set and cleared by software

0: Access to SICSR register mapped in page 0.

1: Access to SICSR register mapped in page 1.

Bit 6 = Reserved, must be kept cleared.

#### Bit 5 = VCOEN VCO Enable

This bit is set and cleared by software.

- 0: VCO (Voltage Controlled Oscillator) connected to the output of the PLL charge pump (default mode), to obtain a 16-MHz output frequency (with an 8-MHz input frequency).
- 1: VCO tied to ground in order to obtain a 10-MHz frequency (f<sub>vco</sub>)

#### Notes:

1. During ICC session, this bit is set to 1 in order to have an internal frequency which does not depend on the input clock. Then, it can be reset in order to run faster with an external oscillator.

#### Bit 4 = LOCK PLL Locked

This bit is read only. It is set by hardware. It is set automatically when the PLL reaches its operating frequency.

- 0: PLL not locked
- 1: PLL locked

Bit 3 = **PLLEN** *PLL Enable* 

This bit enables the PLL and the clock detector. It is set and cleared by software.

0: PLL and Clock Detector (CKD) disabled

1: PLL and Clock Detector (CKD) enabled

#### Notes:

During ICC session, this bit is set to 1.
 PLL cannot be disabled if PLL clock source is selected (CKSEL= 1).

Bit 2 = Reserved, must be kept cleared.

#### Bit 1 = CKSEL Clock Source Selection

This bit selects the clock source: oscillator clock or clock from the PLL. It is set and cleared by software. It can also be set by option byte (PLL opt) 0: Oscillator clock selected

1: PLL clock selected

#### Notes:

 During ICC session, this bit is set to 1. Then, CKSEL can be reset in order to run with f<sub>OSC</sub>.
 Clock from the PLL cannot be selected if the PLL is disabled (PLLEN =0)
 If the clock source is selected by PLL option bit,

3. If the clock source is selected by PLL option bit, CKSEL bit selection has no effect.

Bit 0 = Reserved, must be kept cleared.



# I/O PORTS (Cont'd)

57

# Table 13. I/O Port Register Map and Reset Values

| Address<br>(Hex.)    | Register<br>Label        | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----------------------|--------------------------|-----|---|---|---|---|---|---|-----|
| Rese<br>of all I/O p | t Value<br>ort registers | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0   |
| 0000h                | PADR                     |     |   |   |   |   |   |   |     |
| 0001h                | PADDR                    | MSB |   |   |   |   |   |   | LSB |
| 0002h                | PAOR                     |     |   |   |   |   |   |   |     |
| 0003h                | PBDR                     |     |   |   |   |   |   |   |     |
| 0004h                | PBDDR                    | MSB |   |   |   |   |   |   | LSB |
| 0005h                | PBOR                     |     |   |   |   |   |   |   |     |
| 0006h                | PCDR                     |     |   |   |   |   |   |   |     |
| 0007h                | PCDDR                    | MSB |   |   |   |   |   |   | LSB |
| 0008h                | PCOR                     |     |   |   |   |   |   |   |     |
| 0009h                | PDDR                     |     |   |   |   |   |   |   |     |
| 000Ah                | PDDDR                    | MSB |   |   |   |   |   |   | LSB |
| 000Bh                | PDOR                     |     |   |   |   |   |   |   |     |
| 000Ch                | PEDR                     |     |   |   |   |   |   |   |     |
| 000Dh                | PEDDR                    | MSB |   |   |   |   |   |   | LSB |
| 000Eh                | PEOR                     |     |   |   |   |   |   |   |     |
| 000Fh                | PFDR                     |     |   |   |   |   |   |   |     |
| 0010h                | PFDDR                    | MSB |   |   |   |   |   |   | LSB |
| 0011h                | PFOR                     |     |   |   |   |   |   |   |     |
| 0012h                | PGDR                     |     |   |   |   |   |   |   |     |
| 0013h                | PGDDR                    | MSB |   |   |   |   |   |   | LSB |
| 0014h                | PGOR                     |     |   |   |   |   |   |   |     |
| 0015h                | PHDR                     |     |   |   |   |   |   |   |     |
| 0016h                | PHDDR                    | MSB |   |   |   |   |   |   | LSB |
| 0017h                | PHOR                     |     |   |   |   |   |   |   |     |

# WINDOW WATCHDOG (Cont'd)

#### 10.1.5 How to Program the Watchdog Timeout

Figure 35 shows the linear relationship between the 6-bit value to be loaded in the Watchdog Counter (CNT) and the resulting timeout duration in milliseconds. This can be used for a quick calculation without taking the timing variations into account. If



more precision is needed, use the formulae in Figure 36.

**Caution:** When writing to the WDGCR register, always write 1 in the T6 bit to avoid generating an immediate reset.





# **ON-CHIP PERIPHERALS** (Cont'd)

# PWM CONTROL REGISTER (PWMCR)

Read/Write

5/

Reset Value: 0000 0000 (00h)

| 7   |     |     |     |     |     |     | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| OE3 | OE2 | OE1 | OE0 | OP3 | OP2 | OP1 | OP0 |

#### Bit 7:4 = OE[3:0] PWM Output Enable

These bits are set and cleared by software. They enable or disable the PWM output channels independently acting on the corresponding I/O pin. 0: PWM output disabled.

1: PWM output enabled.

# Bit 3:0 = OP[3:0] PWM Output Polarity

These bits are set and cleared by software. They independently select the polarity of the four PWM output signals.

| PWMx ou         | OPv            |   |  |
|-----------------|----------------|---|--|
| Counter <= OCRx | Counter > OCRx |   |  |
| 1               | 0              | 0 |  |
| 0               | 1              | 1 |  |

**Note**: When an OPx bit is modified, the PWMx output signal polarity is immediately reversed.

# **DUTY CYCLE REGISTERS (PWMDCRx)**

Read/Write

Reset Value: 0000 0000 (00h)



# Bit 7:0 = DC[7:0] Duty Cycle Data

These bits are set and cleared by software.

A PWMDCRx register is associated with the OCRx register of each PWM channel to determine the second edge location of the PWM signal (the first edge location is common to all channels and given by the ARTARR register). These PWMDCR registers allow the duty cycle to be set independently for each PWM channel.

# SERIAL PERIPHERAL INTERFACE (cont'd)

# 10.4.5.4 Single Master and Multimaster Configurations

There are two types of SPI systems:

- Single Master System
- Multimaster System

# Single Master System

A typical single master system may be configured using a device as the master and four devices as slaves (see Figure 61).

The master device selects the individual slave devices by <u>using</u> four pins of a parallel port to control the four SS pins of the slave devices.

The  $\overline{SS}$  pins are pulled high during reset since the master device ports will be forced to be inputs at that time, thus disabling the slave devices.

**Note:** To prevent a bus conflict on the MISO line, the master allows only one active slave device during a transmission.

For more security, the slave device may respond to the master with the received data byte. Then the master will receive the previous byte back from the slave device if all MISO and MOSI pins are connected and the slave has not written to its SPIDR register.

Other transmission security methods can use ports for handshake lines or data bytes with command fields.

#### Multimaster System

A multimaster system may also be configured by the user. Transfer of master control could be implemented using a handshake method through the I/O ports or by an exchange of code messages through the serial peripheral interface system.

The multimaster system is principally handled by the MSTR bit in the SPICR register and the MODF bit in the SPICSR register.



# Figure 61. Single Master / Multiple Slave Configuration

# LINSCI<sup>TM</sup> SERIAL COMMUNICATION INTERFACE (SCI Mode) (cont'd)

#### 10.5.5.6 Receiver Muting and Wake-up Feature

In multiprocessor configurations it is often desirable that only the intended message recipient should actively receive the full message contents, thus reducing redundant SCI service overhead for all non-addressed receivers.

The non-addressed devices may be placed in sleep mode by means of the muting function.

Setting the RWU bit by software puts the SCI in sleep mode:

All the reception status bits can not be set.

All the receive interrupts are inhibited.

A muted receiver may be woken up in one of the following ways:

- by Idle Line detection if the WAKE bit is reset,

- by Address Mark detection if the WAKE bit is set.

#### Idle Line Detection

Receiver wakes up by Idle Line detection when the Receive line has recognized an Idle Line. Then the RWU bit is reset by hardware but the IDLE bit is not set.

This feature is useful in a multiprocessor system when the first characters of the message determine the address and when each message ends by an idle line: As soon as the line becomes idle, every receivers is waken up and analyse the first characters of the message which indicates the addressed receiver. The receivers which are not addressed set RWU bit to enter in mute mode. Consequently, they will not treat the next characters constituting the next part of the message. At the end of the message, an idle line is sent by the transmitter: this wakes up every receivers which are ready to analyse the addressing characters of the new message.

In such a system, the inter-characters space must be smaller than the idle time.

#### **Address Mark Detection**

Receiver wakes up by Address Mark detection when it received a "1" as the most significant bit of a word, thus indicating that the message is an address. The reception of this particular word wakes up the receiver, resets the RWU bit and sets the RDRF bit, which allows the receiver to receive this word normally and to use it as an address word.

This feature is useful in a multiprocessor system when the most significant bit of each character (except for the break character) is reserved for Address Detection. As soon as the receivers received an address character (most significant bit = '1'), the receivers are waken up. The receivers which are not addressed set RWU bit to enter in mute mode. Consequently, they will not treat the next characters constituting the next part of the message.

#### 10.5.5.7 Parity Control

Hardware byte Parity control (generation of parity bit in transmission and parity checking in reception) can be enabled by setting the PCE bit in the SCICR1 register. Depending on the character format defined by the M bit, the possible SCI character formats are as listed in Table 20.

**Note**: In case of wake-up by an address mark, the MSB bit of the data is taken into account and not the parity bit

#### **Table 20. Character Formats**

| M bit | PCE bit | Character format           |
|-------|---------|----------------------------|
| 0 0   |         | SB   8 bit data   STB      |
| 0     | 1       | SB   7-bit data   PB   STB |
| 1 0   |         | SB   9-bit data   STB      |
| 1     | 1       | SB   8-bit data   PB   STB |

**Legend:** SB = Start Bit, STB = Stop Bit, PB = Parity Bit

**Even parity:** The parity bit is calculated to obtain an even number of "1s" inside the character made of the 7 or 8 LSB bits (depending on whether M is equal to 0 or 1) and the parity bit.

Example: data = 00110101; 4 bits set => parity bit will be 0 if even parity is selected (PS bit = 0).

**Odd parity:** The parity bit is calculated to obtain an odd number of "1s" inside the character made of the 7 or 8 LSB bits (depending on whether M is equal to 0 or 1) and the parity bit.

Example: data = 00110101; 4 bits set => parity bit will be 1 if odd parity is selected (PS bit = 1).

**Transmission mode:** If the PCE bit is set then the MSB bit of the data written in the data register is not transmitted but is changed by the parity bit.

**Reception mode:** If the PCE bit is set then the interface checks if the received data byte has an even number of "1s" if even parity is selected (PS = 0) or an odd number of "1s" if odd parity is selected (PS = 1). If the parity check fails, the PE flag is set in the SCISR register and an interrupt is generated if PCIE is set in the SCICR1 register.

57

# LINSCI<sup>TM</sup> SERIAL COMMUNICATION INTERFACE (SCI Mode) (cont'd)

# 10.5.6 Low Power Modes

| Mode | Description                                                                                                     |
|------|-----------------------------------------------------------------------------------------------------------------|
| Wait | No effect on SCI.<br>SCI interrupts cause the device to exit from<br>Wait mode.                                 |
| Halt | SCI registers are frozen.<br>In Halt mode, the SCI stops transmitting/re-<br>ceiving until Halt mode is exited. |

# 10.5.7 Interrupts

| Interrupt Event                              | Event<br>Flag | Enable<br>Control<br>Bit | Exit<br>from<br>Wait | Exit<br>from<br>Halt |
|----------------------------------------------|---------------|--------------------------|----------------------|----------------------|
| Transmit Data Register<br>Empty              | TDRE          | TIE                      |                      |                      |
| Transmission Com-<br>plete                   | тс            | TCIE                     |                      |                      |
| Received Data Ready to be Read               | RDRF          | DIE                      | Yes                  | No                   |
| Overrun Error or LIN<br>Synch Error Detected | OR/<br>LHE    | 111                      |                      |                      |
| Idle Line Detected                           | IDLE          | ILIE                     |                      |                      |
| Parity Error                                 | PE            | PIE                      |                      |                      |
| LIN Header Detection                         | LHDF          | LHIE                     |                      |                      |

The SCI interrupt events are connected to the same interrupt vector (see Interrupts chapter).

These events generate an interrupt if the corresponding Enable Control Bit is set and the interrupt mask in the CC register is reset (RIM instruction).

#### LINSCI™ SERIAL COMMUNICATION INTERFACE (LIN Mode) (cont'd) LIN PRESCALER FRACTION REGISTER will effectively upd

(LPFR)

**Read/Write** 

5/

Reset Value: 0000 0000 (00h)

| 7 |   |   |   |           |           |           | 0         |
|---|---|---|---|-----------|-----------|-----------|-----------|
| 0 | 0 | 0 | 0 | LPFR<br>3 | LPFR<br>2 | LPFR<br>1 | LPFR<br>0 |

Bits 7:4 = Reserved.

# Bits 3:0 = LPFR[3:0] Fraction of LDIV

These 4 bits define the fraction of the LIN Divider (LDIV):

| LPFR[3:0] | Fraction (LDIV) |
|-----------|-----------------|
| 0h        | 0               |
| 1h        | 1/16            |
|           |                 |
| Eh        | 14/16           |
| Fh        | 15/16           |

1. When initializing LDIV, the LPFR register must be written first. Then, the write to the LPR register

will effectively update LDIV and so the clock generation.

2. In LIN Slave mode, if the LPR[7:0] register is equal to 00h, the transceiver and receiver input clocks are switched off.

# Examples of LDIV coding:

Example 1: LPR = 27d and LPFR = 12d This leads to: Mantissa (LDIV) = 27d Fraction (LDIV) = 12/16 = 0.75dTherefore LDIV = 27.75d

Example 2: LDIV = 25.62dThis leads to: LPFR = rounded(16\*0.62d) = rounded(9.92d) = 10d = Ah LPR = mantissa (25.620d) = 25d = 1Bh

Example 3: LDIV = 25.99d This leads to: LPFR = rounded(16\*0.99d) = rounded(15.84d) = 16d

#### **10.6.5 Functional Description**

The MTC can be split into five main parts as shown in the simplified block diagram in Figure 77. Each of these parts may be configured for different purposes:

- INPUT DETECTION BLOCK with a comparator, an input multiplexer and an incremental encoder interface, which may work as:
  - A BEMF zero-crossing detector
  - A Speed Sensor Interface
- The DELAY MANAGER with an 8/16-bit timer and an 8x8 bit multiplier, which may work as a:
  - 8-bit delay manager
  - Speed Measurement unit
- The PWM MANAGER, including a measurement window generator, a mode selector and a current comparator.
- The CHANNEL MANAGER with the PWM multiplexer, polarity programming, deadtime insertion and high frequency chopping capability and emergency HiZ configuration input.
- The THREE-PHASE PWM GENERATOR with 12-bit free-running counter and repetition counter.

#### **10.6.6 Input Detection Block**

This block can operate in Position sensor mode, in sensorless mode or in Speed Sensor mode. The mode is selected via the SR bit in the MCRA register and the TES[1:0] bits in MPAR register (refer

to Table 35 for set-up information). The block diagram is shown in Figure 78 for the Position Sensor/Sensorless modes (TES[1:0] = 00) and in Figure 88 for the Speed Sensor mode (TES[1:0] = 01, 10, 11).

#### 10.6.6.1 Input Pins

The MCIA, MCIB and MCIC input pins can be used as analog or as digital pins.

- In sensorless mode, the analog inputs are used to measure the BEMF zero crossing and to detect the end of demagnetization if required.
- In sensor mode, the analog inputs are used to get the Hall sensor information.
- In speed sensor mode (e.g. tachogenerator), the inputs are used as digital pins. When using an AC tachogenerator, a small external circuit may be needed to convert the incoming signal into a square wave signal which can be treated by the MTC.

Due to the presence of diodes, these pins can permanently support an input current of 5mA. In sensorless mode, this feature enables the inputs to be connected to each motor phase through a single resistor.

A multiplexer, programmed by the IS[1:0] bits in the MPHST register selects the input pins and connects them to the control logic in either sensorless or tachogenerator mode. In encoder mode, it is mandatory to connect sensor digital outputs to the MCIA and MCIB pins.

Table 30 shows the event control selected by the ZVD and CPB bits. In most cases, the D and Z events have opposite edge polarity, so the ZVD bit is usually 0.

| Table 30. | ZVD | and | СРВ | Edae | Selection | Bits |
|-----------|-----|-----|-----|------|-----------|------|
|           | _   |     |     |      |           |      |

| ZVD bit | CPB bit             | Event generation vs input data sampled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | 0                   | $ \begin{array}{c c}                                    $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0       | 1                   | $\begin{array}{c c} & & ZWF & ZEF \\ \leftarrow \rightarrow & \leftarrow \rightarrow & \leftarrow \rightarrow \\ & & & \leftarrow \rightarrow \\ & & & & \leftarrow \rightarrow \\ & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & & & & \leftarrow \rightarrow \\ & & & & & & & & & & & & & \\ & & & &$ |
| 1       | 0                   | $\begin{array}{c c} & ZWF & ZEF \\ \leftarrow \rightarrow & \leftarrow \rightarrow \\ & C & \Box_{H} \\ \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1       | 1                   | $\begin{array}{c c} & & ZWF & & ZEF \\ \hline \leftarrow \rightarrow & \leftarrow \rightarrow & \leftarrow \rightarrow \\ C & & \hline D_{H} & & \hline Z \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| N       | ote: The ZVD bit is | located in the MPOL register, the CPB bit is in the MCRB register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# Legend:

DWF= D window filter DEF= D event filter ZWF = Z window filter ZEF = Z event filter Refer also to Table 34 on page 162.



#### 10.6.6.9 Sampling block

For a full digital solution, the phase comparator output sampling frequency is the frequency of the PWM signal applied to the switches and the sampling for the Z event detection in sensorless mode is done at the end of the off time of this PWM signal to avoid to have to re-create a virtual ground because when the PWM signal is off, the star point is at ground due to the free-wheeling diode. That's why, the sampling for Z event detection is done by default during the OFF-state of the PWM signal and therefore at the PWM frequency.

In current mode, this PWM signal is generated by a combination of the output of the measurement window generator (SA[3:0] bits), the output of the current comparator and a minimum OFF time set by the OT[3:0] bits for system stabilisation.

In voltage mode, this PWM signal is generated by the 12-bit PWM generator signal in the compare U register with still a minimum OFF time required if the sampling is done at the end of the OFF time of the PWM signal for system stabilisation. The PWM signal is put OFF as soon as the current feedback reaches the current input limitation. This can add an OFF time to the one programmed with the 12bit Timer.

For D event detection in sensorless mode, no specific PWM configuration is needed and the sampling frequency (f<sub>SCF.</sub> see Table 82) is completely independent from the PWM signal.

In sensor mode, the D event detection is not needed as the MCIA, MCIB and MCIC pins are the digital signals coming from the hall sensors so no specific PWM configuration is needed and the sampling for the Z detection event is done at f<sub>SCF</sub>, completely independent from the PWM signal.

In sensorless mode, if a virtual ground is created by the addition of an external circuit, sampling for the Z event detection can be completely independent from the PWM signal applied to the switches. Setting the SPLG bit in the MCRC register allows a sampling frequency of f<sub>SCF</sub> for Z event detection independent from the PWM signal after getting the D (end of demagnetisation) event. This means that the sampling order is given whatever the PWM signal (during the ON time or the OFF time). As soon as the SPLG bit is set in the MCRC register, the minimum OFF time needed for the PWM signal in current mode is set to 0µs and a true 100% duty

57/

cycle can be set in the 12-bit PWM generator compare register in voltage mode.

Specific applications can require sampling for the Z event detection only during the ON time of the PWM signal. This can happen when the PWM signal is applied only on the low side switches for Z event detection. In this case, during the OFF time of the PWM signal, the phase voltage is tied to the application voltage V and no back-EMF signal can be seen. During the ON time of the PWM signal, the phase voltage can be compared to the neutral point voltage and the Z event can be detected. Therefore, it is possible to add a programmable delay before sampling (which is normally done when the PWM signal is switched ON) to perform the sampling during the ON time of the PWM signal. This delay is set with the DS [3:0] bits in the MCONF register.

| DS3     | DS2     | DS1       | DS0       | Delay added to<br>sample at Ton          |
|---------|---------|-----------|-----------|------------------------------------------|
| 0       | 0       | 0         | 0         | No delay added.<br>Sample during<br>Toff |
| 0       | 0       | 0         | 1         | 2.5 µs                                   |
| 0       | 0       | 1         | 0         | 5 µs                                     |
| 0       | 0       | 1         | 1         | 7.5 µs                                   |
| 0       | 1       | 0         | 0         | 10 µs                                    |
| 0       | 1       | 0         | 1         | 12.5 µs                                  |
| 0       | 1       | 1         | 0         | 15 µs                                    |
| 0       | 1       | 1         | 1         | 17.5 µs                                  |
| 1       | 0       | 0         | 0         | 20 µs                                    |
| 1       | 0       | 0         | 1         | 22.5 µs                                  |
| 1       | 0       | 1         | 0         | 25 µs                                    |
| 1       | 0       | 1         | 1         | 27.5 µs                                  |
| 1       | 1       | 0         | 0         | 30 µS                                    |
| 1       | 1       | 0         | 1         | 32.5 μs                                  |
| 1       | 1       | 1         | 0         | 35 µS                                    |
| 1       | 1       | 1         | 1         | 37.5 μs                                  |
| Noto: T | impe ar | a indicat | tod for 1 | MHz f                                    |

#### Table 33. Delay length before sampling

Note: Times are indicated for 4 MHZ TPERIPH

As soon as a delay is set in the DS[3:0] bits, the minimum OFF time for the PWM signal is no longer required and it is automatically set to 0µs in current mode in the internal sampling clock and a true 100% duty cycle can be set in the 12-bit PWM generator compare U register if needed.

159/309

#### 10.6.7.5 Speed Measurement Mode

Motor speed can be measured using two methods depending on sensor type: period measurement or pulse counting. Typical sensor handling is described here.

Incremental encoders allows accurate speed measurement by providing a large number of pulses per revolution (ppr) with ppr rates up to several thousands; the higher the ppr rate, the higher the resolution. The proposed method consists of counting the number of clock cycles issued by the Incremental Encoder Interface (Encoder Clock) during a fixed time window (refer to Figure 100).

The tachogenerator has a much lower ppr rate than the encoder (typically factor 10). In this context, it is more meaningful to measure the period between Tacho Captures (i.e. relevant transitions of the incoming signals). Accuracy is imposed by the reference clock, i.e. the CPU clock (refer to Figure 99).





Figure 100. Encoder Clock frequency measure using MTIM timer



If the 13-bit Compare register value is greater than the extended Compare 0 Register (the 13<sup>th</sup> bit is set to '0'), the corresponding PWM output signal is held at '1'. If the 13-bit Compare register value is 0, the corresponding PWM output signal is held at '0'.

Figure 119 shows some center-aligned PWM waveforms in an example where the Compare 0 register value = 8.



#### Figure 119. Center-aligned PWM Waveforms (Compare 0 Register = 8)



<u>(</u>ح)

Edge-aligned Mode (CMS bit = 0)

In this operating mode, the PWM Counter counts up to the value loaded in the 12-bit Compare Register. Then the PWM Counter is cleared and it restarts counting up.

The PWM signals are set to '0' when the PWM Counter reaches, in up-counting, the corresponding 13-bit Compare register value and they are set to '1' when the PWM Counter is cleared. If the 13-bit Compare register value is greater than the extended Compare 0 register (the 13<sup>th</sup> bit is set to '0'), the corresponding PWM output signal is held at '1'.

If the 13-bit Compare register value = 0, the corresponding PWM output signal is held at '0'.

Figure 120 shows some edge-aligned PWM waveforms in an example where the Compare 0 register value = 8.

#### Figure 120. Edge-aligned PWM Waveforms (Compare 0 Register = 8)



#### MOTOR CONTROLLER (Cont'd) CONTROL REGISTER B (MCRB) Read/Write

Reset Value: 0000 0000 (00h)

| 7 | 6    | 5    | 4    | 3   | 2    | 1   | 0   |
|---|------|------|------|-----|------|-----|-----|
| 0 | CPB* | HDM* | SDM* | OCV | OS2* | OS1 | OS0 |

Bit 7= Reserved, must be kept at reset value.

Bit 6= **CPB**\*: Compare Bit for Zero-crossing detection.

0: Zero crossing detection on falling edge

1: Zero crossing detection on rising edge

Bit 5= **HDM**\*: Hardware Demagnetization event Mask bit

0: Hardware Demagnetization disabled

1: Hardware Demagnetization enabled

Bit 4= **SDM**\*: Simulated Demagnetization event Mask bit

0: Simulated Demagnetization disabled

1: Simulated Demagnetization enabled

Bit 3 = **OCV**: Over Current Handling in Voltage mode 0: Over Current protection is OFF

1:Over current protection is ON

This bit acts as follows

# Table 60. Over current handling

| CLIM bit | CLI bit | OCV bit | Output effect                                                           | Interrupt |
|----------|---------|---------|-------------------------------------------------------------------------|-----------|
| 0        | 0       | x       | Normal running<br>mode                                                  | No        |
| 0        | 1       | х       | PWM is put off as<br>Current loop effect                                | No        |
| 1        | 0       | x       | Normal running<br>mode                                                  | No        |
| 1        | 1       | 0       | PWM is put off as<br>Current loop effect                                | Yes       |
| 1        | 1       | 1       | All MCOx outputs<br>are put in reset<br>state (MOE reset) <sup>1)</sup> | Yes       |

**Note 1**: This feature is also available when using the three PWM outputs (PCN bit=1 in the MDTG register), providing that the VOC1bit = 0 (MCRA register). See section 10.6.8.2 on page 186

Bits 2:0 = **OS2\***, **OS[1:0]**: Operating output mode Selection bits

Refer to the Step behaviour diagrams (Figure 109, Figure 110) and Table 61, "Step Behaviour/ sensorless mode," on page 212.

These bits are used to define the various PWM output configurations.

Note: OS2 is the only preload bit.

#### Table 61. Step Behaviour/ sensorless mode

| OS2<br>bit | PWM after<br>C and<br>before D | OS1<br>bit  | PWM after<br>D and<br>before Z | OS0 | PWM after<br>Z and<br>before next<br>C |
|------------|--------------------------------|-------------|--------------------------------|-----|----------------------------------------|
|            | On High<br>Channels            | 0           | On High<br>Channels            | 0   | On high<br>channels                    |
| 0          |                                | 0           |                                | 1   | On low<br>channels                     |
|            |                                | 1           | On Low<br>Channels             | 0   | On high<br>channels                    |
|            |                                |             |                                | 1   | On low<br>channels                     |
|            | On Low<br>Channels             | 0<br>On Low | On High<br>Channels            | 0   | On high<br>channels                    |
| 1          |                                |             |                                | 1   | On low<br>channels                     |
|            |                                | 4           | On Low<br>Channels             | 0   | On high<br>channels                    |
|            |                                |             |                                | 1   | On low channels                        |

**Note:** For more details, see Step behaviour diagrams (Figure 109 and Figure 110).

\* Preload bits, new value taken into account at the next C event. A C event is generated at each write to MPHST in Direct Access mode.

# **OP-AMP MODULE** (Cont'd)

# 10.7.5 Op-Amp Programming

The flowchart for Op-Amp operation is shown in Figure 126

#### Figure 126. Normal Op-Amp Operation



# **12.5 CLOCK AND TIMING CHARACTERISTICS**

Subject to general operating conditions for V<sub>DD</sub>, f<sub>OSC</sub>, and T<sub>A</sub>.

### 12.5.1 General Timings

| Symbol               | Parameter                             | Conditions             | Min  | <b>Typ</b> <sup>1)</sup> | Max  | Unit             |
|----------------------|---------------------------------------|------------------------|------|--------------------------|------|------------------|
| t <sub>c(INST)</sub> | Instruction cycle time                |                        | 2    | 3                        | 12   | t <sub>CPU</sub> |
|                      |                                       | f <sub>CPU</sub> =8MHz | 250  | 375                      | 1500 | ns               |
| +                    | Interrupt reaction time 2)            |                        | 10   |                          | 22   | t <sub>CPU</sub> |
| t <sub>v(IT)</sub>   | $t_{v(IT)} = \Delta t_{c(INST)} + 10$ | f <sub>CPU</sub> =8MHz | 1.25 |                          | 2.75 | μs               |

#### Notes:

1. Data based on typical application software.

2. Time measured between interrupt event and interrupt vector fetch.  $\Delta t_{c(INST)}$  is the number of  $t_{CPU}$  cycles needed to finish the current instruction execution.

#### 12.5.2 External Clock Source

| Symbol                                         | Parameter                            | Conditions                                        | Min                             | Тур | Max                             | Unit |
|------------------------------------------------|--------------------------------------|---------------------------------------------------|---------------------------------|-----|---------------------------------|------|
| V <sub>OSC1H</sub>                             | OSC1 input pin high level voltage    |                                                   | $0.7 \mathrm{xV}_{\mathrm{DD}}$ |     | V <sub>DD</sub>                 | V    |
| V <sub>OSC1L</sub>                             | OSC1 input pin low level voltage     |                                                   | V <sub>SS</sub>                 |     | $0.3 \mathrm{xV}_{\mathrm{DD}}$ | v    |
| t <sub>w(OSC1H)</sub><br>t <sub>w(OSC1L)</sub> | OSC1 high or low time <sup>1)</sup>  | see Figure 135                                    | 25                              |     |                                 | ne   |
| t <sub>r(OSC1)</sub><br>t <sub>f(OSC1)</sub>   | OSC1 rise or fall time <sup>1)</sup> |                                                   |                                 |     | 5                               | 113  |
| ١L                                             | OSCx Input leakage current           | V <sub>SS</sub> ⋬∕ <sub>IN</sub> ⋬∕ <sub>DD</sub> |                                 |     | ± 1                             | μÂ   |

#### Figure 135. Typical Application with an External Clock Source



#### Notes:

1. Data based on design simulation and/or technology characteristics, not tested in production.

# **12.14 10-BIT ADC CHARACTERISTICS**

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

| Symbol            | Parameter                                                                       | Conditions                                                                                 | Min              | Тур      | Max                             | Unit               |
|-------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------|----------|---------------------------------|--------------------|
| V <sub>AREF</sub> | Analog Reference Voltage                                                        |                                                                                            | 3                |          | V <sub>DD</sub>                 | V                  |
| f <sub>ADC</sub>  | ADC clock frequency                                                             |                                                                                            |                  |          | 4                               | MHz                |
| V <sub>AIN</sub>  | Conversion voltage range 1)                                                     |                                                                                            | V <sub>SSA</sub> |          | V <sub>AREF</sub>               | V                  |
|                   | Positive input leakage current for analog input                                 |                                                                                            |                  |          | ±1                              | μA                 |
| likg              | Negative input leakage current on analog pins                                   | V <sub>IN</sub> <v<sub>SS,   I<sub>IN</sub>  &lt; 400µA on<br/>adjacent analog pin</v<sub> |                  | 5        | 6                               | μA                 |
| R <sub>AIN</sub>  | External input impedance                                                        |                                                                                            |                  |          | see                             | kΩ                 |
| C <sub>AIN</sub>  | External capacitor on analog input                                              |                                                                                            |                  |          | Figure                          | pF                 |
| f <sub>AIN</sub>  | Variation freq. of analog input signal                                          |                                                                                            |                  |          | Figure<br>158 <sup>2)3)4)</sup> | Hz                 |
| C <sub>ADC</sub>  | Internal sample and hold capacitor                                              |                                                                                            |                  | 6        |                                 | pF                 |
|                   | Conversion time (Sample+Hold)                                                   | f <sub>CPU</sub> =8MHz, f <sub>ADC</sub> =4MHz,                                            |                  | 3.5      |                                 | μs                 |
|                   | <ul> <li>Sample capacitor loading time</li> <li>Hold conversion time</li> </ul> | ADSTS bit in MCCBCR<br>register = 0                                                        |                  | 4<br>10  |                                 | 1/f <sub>ADC</sub> |
| <sup>I</sup> ADC  | Conversion time (Sample+Hold)                                                   | f <sub>CPU</sub> =8MHz, f <sub>ADC</sub> =4MHz,                                            |                  | 6.5      |                                 | μs                 |
|                   | <ul> <li>Sample capacitor loading time</li> <li>Hold conversion time</li> </ul> | ADSTS bit in MCCBCR<br>register = 1                                                        |                  | 16<br>10 |                                 | 1/f <sub>ADC</sub> |
| R <sub>AREF</sub> | Analog Reference Input Resistor                                                 |                                                                                            |                  | 11       |                                 | kΩ                 |

# Figure 157. R<sub>AIN</sub> max. vs f<sub>ADC</sub> with C<sub>AIN</sub>=0pF<sup>3)</sup>



57

# Figure 158. Recommended C<sub>AIN</sub> & R<sub>AIN values</sub>.<sup>4)</sup>



# ST7MC DEVICE CONFIGURATION AND ORDERING INFORMATION (Cont'd)

# **OPTION BYTE 1**

OPT7:5= **PKG[2:0]** *package selection* These option bits are used to select the device package.

| Selected Package | PKG2 | PKG1 | PKG0 |
|------------------|------|------|------|
| LQFP32 / SDIP32  | 0    | 0    | 0    |
| LQFP44           | 0    | 0    | 1    |
| SDIP 56          | 0    | 1    | 0    |
| LQFP64           | 0    | 1    | 1    |
| LQFP80           | 1    | х    | х    |

OPT1:0 = **MCO** *Motor Control Output Options* MCO port under reset.

| Motor Control Output | bit 1 | bit 0 |
|----------------------|-------|-------|
| HiZ                  | 0     | 0     |
| Low                  | 0     | 1     |
| High                 | 1     | 0     |
| HiZ                  | 1     | 1     |

OPT4:2= Reserved

<u>ل</u>رک

### **IMPORTANT NOTES** (Cont'd)

#### Impact on application

Software may execute the interrupt routine twice after header reception.

Moreover, in reception mode, as the receiver is no longer in mute mode, an interrupt will be generated on each data byte reception.

# Workaround

The problem can be detected in the LINSCI interrupt routine. In case of timeout error (LHE is set and LHLR is loaded with 00h), the software can check the RWU bit in the SCICR2 register. If RWU is cleared, it can be set by software. Refer to Figure 169. Workaround is shown in bold characters.

#### Figure 169. LINSCI Interrupt routine

```
@interrupt void LINSCI_IT ( void ) /* LINSCI interrupt routine */
{
     /* clear flags */
     SCISR_buffer = SCISR;
     SCIDR_buffer = SCIDR;
     if ( SCISR buffer & LHE )/* header error ? */
     {
           if (!LHLR) /* header time-out? */
           {
                 if ( !(SCICR2 & RWU) )/* active mode ? */
                 £
                         asm("sim");/* disable interrupts */
                        SCISR;
                        SCIDR;/* Clear RDRF flag */
                        SCICR2 |= RWU; /* set mute mode */
                        SCISR;
                        SCIDR;/* Clear RDRF flag */
                        SCICR2 |= RWU; /* set mute mode */
                        _asm("rim");/* enable interrupts */
                 }
           }
     }
}
                                                    Example using Cosmic compiler syntax
```

# 15.5 MISSING DETECTION OF BLDC "Z EVENT"

For a BLDC drive, the Dead Time generator is enabled through the MDTG register (PCN=0 and DTE=1). If the duty cycle of the PWM signal generated to drive the motor is lower than the programmed deadtime, the Z event sampling will be missing.

#### Workaround

The complementary PWM must be disabled by resetting the DTE bit in the MDTG register (see page 221).

As the current in the motor is very low in this case, the MOSFET body diode can be used.

#### **15.6 INJECTED CURRENT ON PD7**

On rev.B silicon, the parameter linj(pin), injected current on I/O pins (see section 12.8.1 on page 264), is limited at 0 (instead of -2mA) for the pin PD7. This limitation is no longer present on rev.C and A silicon and all I/O pins have the max values +5/-2 mA.

#### **15.7 RESET VALUE OF UNAVAILABLE PINS**

On A silicon versions, some ports (Ports A, C and E) have less than 8 pins. The bits associated to the unavailable pins must always be kept at reset state.

57