MCF8316C-Q1 SLLSFV2 - AUGUST 2023 # MCF8316C-Q1 Sensorless Field Oriented Control (FOC) Integrated FET BLDC Driver ### 1 Features - AEC-Q100 qualified for automotive applications - Temperature Grade-1 : –40°C ≤ T<sub>A</sub> ≤ 125°C - Three-phase BLDC motor driver with integrated sensorless motor control algorithm - Code-free Field Oriented Control (FOC) - Offline motor parameters measurement with Motor Parameter Extraction Tool (MPET) - 5-point configurable speed profile support - Windmilling support through forward resynchronization and reverse drive - Analog, PWM, freq. or I<sup>2</sup>C based speed input - Configurable motor start-up and stop options - Anti-voltage surge (AVS) protection - Improved acoustic performance with soft-start, soft-stop and dead time compensation - Variable monitoring through DACOUT pins - 4.5- to 35-V operating voltage (40-V abs max) - High output current capability: 8-A peak - Low MOSFET on-state resistance - $R_{DS(ON)}$ (HS + LS) at $T_A = 25$ °C : 95-m $\Omega$ (typ.) - Low power sleep mode: Refer Table 7-7 - 5-μA (maximum) at V<sub>VM</sub> = 24-V, T<sub>A</sub> = 25°C - Speed loop accuracy: 3% with internal clock and 1% with external clock reference - Customer-configurable non-volatile memory (EEPROM) to store device configuration - Supports up to 60-kHz PWM frequency for low inductance motor support - Does not require external current sense resistors; uses built-in current sensing - Built-in 3.3-V, 20-mA LDO regulator - Built-in 3.3-V/5-V, 170-mA buck regulator - Dedicated DRVOFF pin to disable (Hi-Z) outputs - Spread spectrum and slew rate for EMI mitigation - Suite of integrated protection features - Supply under voltage lockout (UVLO) - Supply over voltage protection (OVP) - Motor lock detection (5 different types) - Over current protection (OCP) - Thermal warning and shutdown (OTW/TSD) - Fault condition indication pin (nFAULT) - Optional fault diagnostics over I<sup>2</sup>C interface ## 2 Applications - **Automotive Fan and Blowers** - Brushless-DC (BLDC) Motor Modules - Residential and Living Fans - Air Purifiers and Humidifier Fans - Washer and Dishwashers Pumps - **CPAP Machines** # 3 Description The MCF8316C-Q1 provides a single-chip, code-free sensorless FOC device for customers driving speedcontrolled 12- to 24-V brushless-DC motors (BLDC) or Permanent Magnet Synchronous motor (PMSM) up to 8-A peak current. The MCF8316C-Q1 integrates three ½-bridges with 40-V absolute maximum capability and a very low $R_{DS(ON)}$ of 95 $m\Omega$ (high-side + low-side FETs). MCF8316C-Q1 integrates power management circuits including an voltage-adjustable buck regulator (3.3 V / 5 V, 170-mA) and LDO (3.3 V / 20 mA) that can be used to power external circuits. The FOC algorithm configuration can be stored in non-volatile EEPROM, which allows the device to operate stand-alone once the device has been configured. The device receives a speed command through a PWM input, analog voltage, variable frequency square wave or I<sup>2</sup>C command. There are a large number of protection features integrated into the MCF8316C-Q1, intended to protect the device, motor, and system against fault events. ### Device Information<sup>(1)</sup> | PART NUMBER | PACKAGE | BODY SIZE (NOM) | | | |---------------|-----------|-------------------|--|--| | MCF8316C1V-Q1 | VQFN (40) | 7.00 mm x 5.00 mm | | | For all available packages, see the orderable addendum at the end of the data sheet. #### Documentation for reference: - Refer MCF8316C-Q1 tuning guide - Refer to the MCF8316C-Q1 EVM GUI Simplified Schematic # **Table of Contents** | 1 Features | .1 | 7.6 EEPROM access and I <sup>2</sup> C interface | 78 | |------------------------------------------------|------------|--------------------------------------------------|-------------------| | 2 Applications | .1 | 7.7 EEPROM (Non-Volatile) Register Map | 84 | | 3 Description | .1 | 7.8 RAM (Volatile) Register Map | 136 | | 4 Revision History | | 8 Application and Implementation | 190 | | 5 Pin Configuration and Functions | .3 | 8.1 Application Information | | | 6 Specifications | 5 | 8.2 Typical Applications | | | 6.1 Absolute Maximum Ratings | 5 | 9 Power Supply Recommendations | 197 | | 6.2 ESD Ratings Auto | .5 | 9.1 Bulk Capacitance | 197 | | 6.3 Recommended Operating Conditions | .5 | 10 Layout | 198 | | 6.4 Thermal Information | .6 | 10.1 Layout Guidelines | 198 | | 6.5 Electrical Characteristics | .6 | 10.2 Layout Example | 199 | | 6.6 Characteristics of the SDA and SCL bus for | | 10.3 Thermal Considerations | <mark>20</mark> 0 | | Standard and Fast mode1 | 13 | 11 Device and Documentation Support | <mark>20</mark> 1 | | 6.7 Typical Characteristics1 | 15 | 11.1 Support Resources | <mark>20</mark> 1 | | 7 Detailed Description1 | 6 | 11.2 Trademarks | 201 | | 7.1 Overview1 | 6 | 11.3 Electrostatic Discharge Caution | 201 | | 7.2 Functional Block Diagram1 | 17 | 11.4 Glossary | 201 | | 7.3 Feature Description1 | | 12 Mechanical, Packaging, and Orderable | | | 7.4 Device Functional Modes7 | | Information | 201 | | 7.5 External Interface7 | <b>'</b> 6 | | | | | | | | # **4 Revision History** | DATE | REVISION | NOTES | |-------------|----------|-----------------| | August 2023 | * | Initial Release | # **5 Pin Configuration and Functions** Figure 5-1. MCF8316C-Q1, 40-Pin VQFN With Exposed Thermal Pad, Top View Table 5-1. Pin Functions | Table 5-1.1 III I dilctions | | | | | | | |-----------------------------|-------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | PIN | 40-pin<br>package | TYPE <sup>(1)</sup> | DESCRIPTION | | | | | NAME | MCF8316C-<br>Q1 | IIFE(/ | DESCRIPTION | | | | | AGND | 26 | GND | Device analog ground. Refer Layout Guidelines for connection recommendation. | | | | | ALARM | 39 | 0 | Alarm signal: push-pull output. Pulled logic high during fault condition, if enabled. If ALARM pin is not used, leave it floating. | | | | | AVDD | 27 | PWR O | 3.3-V internal regulator output. Connect a X5R or X7R, 1-µF, 6.3-V ceramic capacitor between the AVDD and AGND pins. This regulator can source up to 20 mA for external circuits. | | | | | BRAKE | 35 | I | High → Brake the motor Low → Normal motor operation If BRAKE pin is not used, connect to AGND directly. If BRAKE pin is used to brake the motor, use an (optional) external 10-kΩ pull-down resistor (to AGND) for better noise rejection. | | | | | СР | 8 | PWR | Charge pump output. Connect a X5R or X7R, 1-µF, 16-V ceramic capacitor between the CP and VM pins. | | | | | CPH | 7 | PWR | Charge pump switching node. Connect a X5R or X7R, 47-nF, ceramic capacitor between | | | | | CPL | 6 | PWR | the CPH and CPL pins. TI recommends a capacitor voltage rating at least twice the normal operating voltage of the device. | | | | | DACOUT1 | 36 | 0 | DAC output DACOUT1 | | | | | DACOUT2 | 37 | 0 | DAC output DACOUT2 | | | | # **Table 5-1. Pin Functions (continued)** | PIN | 40-pin<br>package | <b>TYPE</b> (1) | Table 5-1. Pin Functions (continued) | | | | |-----------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | NAME | NAME MCF8316C-<br>Q1 | | DESCRIPTION | | | | | DACOUT2/S<br>OX | 38 | 0 | Multi-purpose pin: DAC output when configured as DACOUT2 CSA output when configured as SOX | | | | | DGND | 2 | GND | Device digital ground. Refer Layout Guidelines for connection recommendation. | | | | | DIR | 34 | I | Direction of motor spinning; When low, phase driving sequence is OUT A $\rightarrow$ OUT C $\rightarrow$ OUT B When high, phase driving sequence is OUT A $\rightarrow$ OUT B $\rightarrow$ OUT C If DIR pin is not used, connect to AGND or AVDD directly (depending on phase driving sequence needed). If DIR pin is used for changing motor spin direction, use an (optional) external 10-k $\Omega$ pull-down resistor (to AGND) for better noise rejection. | | | | | DRVOFF | 21 | pull-down resistor (to AGND) for better noise rejection. 1.5.V internal regulator output. Connect a X5R or X7R, 2.2-uE 6.3-V ceramic capacitor. | | | | | | DVDD | 1 | PWR | 1.5-V internal regulator output. Connect a X5R or X7R, 2.2-µF, 6.3-V ceramic capacitor between the DVDD and DGND pins. | | | | | EXT_CLK | 33 | I | External clock reference input in external clock reference mode. | | | | | EXT_WD | 32 | I | External watchdog input. | | | | | FB_BK | 3 | PWR I/O | Feedback for buck regulator output control. Connect to buck regulator output after the inductor/resistor. | | | | | FG | 29 | 0 | Motor speed indicator: open-drain output that requires an external pull-up resistor to 1.8-V to 5.0-V. An optional internal pull-up resistor to AVDD is enabled by setting PULLUP_ENABLE to 1b; no external pull-up resistor should be used when internal pull-up resistor is enabled. | | | | | GND_BK | 4 | GND | Buck regulator ground. Refer Layout Guidelines for connection recommendation. | | | | | NC | 22, 23, 24, 25 | - | No connection. Leave these pins floating. These pins can also be tied to AGND plane and thermal pad for better heat dissipation. | | | | | nFAULT | 40 | 0 | Fault indicator. Pulled logic-low with fault condition; open-drain output that requires an external pull-up resistor to 1.8-V to 5.0-V. An optional internal pull-up resistor to AVDD is enabled by setting PULLUP_ENABLE to 1b; no external pull-up resistor should be used when internal pull-up resistor is enabled. | | | | | OUTA | 13, 14 | PWR O | Half-bridge output A | | | | | OUTB | 16, 17 | PWR O | Half-bridge output B | | | | | OUTC | 19, 20 | PWR O | Half-bridge output C | | | | | PGND | 12, 15, 18 | GND | Device power ground. Refer Layout Guidelines for connection recommendation. | | | | | SCL | 31 | I | I <sup>2</sup> C clock input | | | | | SDA | 30 | I/O | I <sup>2</sup> C data line | | | | | SPEED/<br>WAKE | 28 | I | Device speed input; supports analog, PWM or frequency based speed input. The speed pin input mode can be configured through SPEED_MODE. | | | | | SW_BK | 5 | PWR | Buck switch node. Connect this pin to an inductor or resistor. | | | | | VM | 9, 10, 11 | PWR I | Device and motor power supply. Connect to motor supply voltage; bypass to PGND with one 0.1-µF capacitor plus one bulk capacitor. TI recommends a capacitor voltage rating at least twice the normal operating voltage of the device. | | | | | Thermal pad | | GND | Must be connected to AGND. | | | | <sup>(1)</sup> I = input, O = output, GND = ground, PWR = power, NC = no connect # **6 Specifications** # **6.1 Absolute Maximum Ratings** over operating ambient temperature range (unless otherwise noted)(1) | | MIN | MAX | UNIT | |--------------------------------------------------------------------------------|------|----------------------|------| | Power supply pin voltage (VM) | -0.3 | 40 | V | | Power supply voltage ramp (VM) | | 4 | V/µs | | Voltage difference between ground pins (GND_BK, DGND, PGND, AGND) | -0.3 | 0.3 | V | | Charge pump voltage (CPH, CP) | -0.3 | V <sub>VM</sub> + 6 | V | | Charge pump negative switching pin voltage (CPL) | -0.3 | V <sub>VM</sub> +0.3 | V | | Switching regulator pin voltage (FB_BK) | -0.3 | 6 | V | | Switching node pin voltage (SW_BK) | -0.3 | V <sub>VM</sub> +0.3 | V | | Analog regulator pin voltage (AVDD) | -0.3 | 4 | V | | Digital regulator pin voltage (DVDD) | -0.3 | 1.7 | V | | Logic pin input voltage (BRAKE, DRVOFF, DIR, EXT_CLK, EXT_WD, SCL, SDA, SPEED) | -0.3 | 6 | V | | Open drain pin output voltage (nFAULT, FG) | -0.3 | 6 | V | | Output pin voltage (OUTA, OUTB, OUTC) | -1 | V <sub>VM</sub> + 1 | V | | Ambient temperature, T <sub>A</sub> | -40 | 125 | °C | | Junction temperature, T <sub>J</sub> | -40 | 150 | °C | | Storage tempertaure, T <sub>stg</sub> | -65 | 150 | °C | <sup>(1)</sup> Operation outside the Absolute Maximum Ratings may cause permanent device damage. Absolute Maximum Ratings do not imply functional operation of the device at these or any other conditions beyond those listed under Recommended Operating Conditions. If used outside the Recommended Operating Conditions but within the Absolute Maximum Ratings, the device may not be fully functional, and this may affect device reliability, functionality, performance, and shorten the device lifetime # 6.2 ESD Ratings Auto | | | | | VALUE | UNIT | |--------------------|-----------|-------------------------------------------------------------------------------------------|-------------|-----------------------|------| | | | Human body model (HBM), per AEC Q100-002 <sup>(1)</sup><br>HBM ESD Classification Level 2 | | | | | V <sub>(ESD)</sub> | discharge | Charged device model (CDM), per AEC Q100-011 | Corner pins | ±750 | V | | | | CDM ESD Classification Level C4B | Other pins | ±2000<br>±750<br>±750 | | <sup>(1)</sup> AEC Q100-002 indicates that HBM stressing shall be in accordance with the ANSI/ESDA/JEDEC JS-001 specification. ## **6.3 Recommended Operating Conditions** over operating ambient temperature range (unless otherwise noted) | | | | MIN | NOM | MAX | UNIT | |-----------------------|--------------------------------------|------------------------------------------------------|------|-----|-----|------| | $V_{VM}$ | Power supply voltage | $V_{VM}$ | 4.5 | 24 | 35 | V | | I <sub>OUT</sub> (1) | Peak output winding current | OUTA, OUTB, OUTC | | | 8 | Α | | V <sub>IN_LOGIC</sub> | Logic input voltage | BRAKE, DRVOFF, DIR, EXT_CLK, EXT_WD, SPEED, SDA, SCL | -0.1 | | 5.5 | V | | V <sub>OD</sub> | Open drain pullup voltage | nFAULT, FG | -0.1 | | 5.5 | V | | I <sub>OD</sub> | Open drain output current capability | nFAULT, FG | | | 5 | mA | | T <sub>A</sub> | Operating ambient temperature | | -40 | | 125 | °C | | TJ | Operating junction temperature | | -40 | | 150 | °C | <sup>(1)</sup> Power dissipation and thermal limits must be observed # **6.4 Thermal Information** | | | MCF8316C-Q1 | | |-----------------------|----------------------------------------------|-------------|------| | | THERMAL METRIC <sup>(1)</sup> | RGF (VQFN) | UNIT | | | | 40 Pins | | | $R_{\theta JA}$ | Junction-to-ambient thermal resistance | 25.7 | °C/W | | R <sub>0JC(top)</sub> | Junction-to-case (top) thermal resistance | 15.2 | °C/W | | $R_{\theta JB}$ | Junction-to-board thermal resistance | 7.3 | °C/W | | $\Psi_{JT}$ | Junction-to-top characterization parameter | 0.2 | °C/W | | $\Psi_{JB}$ | Junction-to-board characterization parameter | 7.2 | °C/W | | $R_{\theta JC(bot)}$ | Junction-to-case (bottom) thermal resistance | 2.0 | °C/W | <sup>(1)</sup> For more information about traditional and new thermal metrics, see the Semiconductor and IC Package Thermal Metrics application report. # 6.5 Electrical Characteristics at $T_J = -40^{\circ}\text{C}$ to +150°C, $V_{VM}$ = 4.5 to 35 V (unless otherwise noted). Typical limits apply for $T_A = 25^{\circ}\text{C}$ , $V_{VM} = 24 \text{ V}$ | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |---------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|-------------------------------------------------------------------------------|------| | POWER : | SUPPLIES | | | | - | | | | VM along models assument | V <sub>VM</sub> > 6 V, V <sub>SPEED</sub> = 0, T <sub>A</sub> = 25 °C | | 3 | 5 | μA | | IVMQ | VM sleep mode current | V <sub>SPEED</sub> = 0, T <sub>A</sub> = 125 °C | | 3.5 | | μA | | | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EN\_SB}$ , DRVOFF = High, $T_A$ = 25 °C, $L_{BK}$ = 47 $\mu$ H, $C_{BK}$ = 22 $\mu$ F | | 8 | 15 | mA | | VMQ VMS VMS AVDD AVDD AVDD | VM standby mode current | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EN\_SB}$ , DRVOFF = High, $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F | | 25 | 28 | mA | | | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EN\_SB}$ , DRVOFF = High, $L_{BK}$ = 47 $\mu$ H, $C_{BK}$ = 22 $\mu$ F | | 8 | 5<br>7<br>15<br>28<br>15<br>28<br>18<br>32<br>17<br>33<br>3.465<br>20<br>1.65 | mA | | | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EN\_SB}$ , DRVOFF = High, $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F | | 25 | | mA | | | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EX\_SL}$ ,<br>PWM_FREQ_OUT = 0011b (25 kHz),<br>$T_J$ = 25 °C, $L_{BK}$ = 47 μH, $C_{BK}$ = 22 μF,<br>No Motor Connected | | 11 | 18 | mA | | ı | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EX\_SL}$ ,<br>PWM_FREQ_OUT = 0011b (25 kHz),<br>$T_{J}$ = 25 °C, $R_{BK}$ = 22 Ω, $C_{BK}$ = 22 μF,<br>No Motor Connected | | 27 | 32 | mA | | IVM | VM operating mode current | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EX\_SL}$ ,<br>PWM_FREQ_OUT = 0011b (25 kHz),<br>$L_{BK}$ = 47 $\mu$ H, $C_{BK}$ = 22 $\mu$ F, No Motor<br>Connected | | 11 | 5 7 8 15 5 28 8 15 5 28 1 18 7 32 1 17 8 33 3 3.465 20 5 1.65 | mA | | | | $V_{VM}$ > 6 V, $V_{SPEED}$ > $V_{EX\_SL}$ ,<br>PWM_FREQ_OUT = 0011b (25 kHz),<br>$R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F, No Motor<br>Connected | | 28 | | mA | | V <sub>AVDD</sub> | Analog regulator voltage | 0 mA ≤ I <sub>AVDD</sub> ≤ 20 mA | 3.125 | 3.3 | 3.465 | V | | I <sub>AVDD</sub> | External analog regulator load | | | | 20 | mA | | $V_{DVDD}$ | Digital regulator voltage | | 1.4 | 1.55 | 1.65 | V | | V <sub>VCP</sub> | Charge pump regulator voltage | VCP with respect to VM | 4.0 | 4.7 | 5.5 | V | at $T_1 = -40^{\circ}$ C to +150°C, $V_{VM} = 4.5$ to 35 V (unless otherwise noted). Typical limits apply for $T_{\Delta} = 25^{\circ}$ C, $V_{VM} = 24$ V | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |---------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------| | BUCK RE | GULATOR | | | | | | | | | $V_{VM} > 6 \text{ V, 0 mA} \le I_{BK} \le 170 \text{ mA},$<br>BUCK_SEL = 00b | 3.1 | 3.3 | 3.5 | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 170 \text{ mA}, \\ BUCK\_SEL = 01b$ | 4.6 | 5.0 | 5.4 | V | | $V_{BK}$ | Buck regulator average voltage ( $L_{BK}$ = 47 $\mu$ H, $C_{BK}$ = 22 $\mu$ F) | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 170 \text{ mA},$<br>BUCK_SEL = 10b | 3.7 | 4.0 | 4.3 | V | | | | $V_{VM} > 6.7 \text{ V}$ , 0 mA $\leq I_{BK} \leq 170 \text{ mA}$ , BUCK_SEL = 11b | 5.2 | 5.7 | 5.8 | V | | | | $V_{VM}$ < 6.0 V (BUCK_SEL = 00b, 01b, 10b, 11b), 0 mA ≤ $I_{BK}$ ≤ 170 mA | Ι <sub>Β</sub> | V <sub>VM</sub> -<br>s <sub>K</sub> *(R <sub>LBK</sub><br>+2) <sup>1</sup> | | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 20 \text{ mA},$<br>BUCK_SEL = 00b | 3.1 | 3.3 | 3.5 | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 20 \text{ mA},$<br>BUCK_SEL = 01b | 4.6 | 5.0 | 5.4 | V | | $V_{BK}$ | Buck regulator average voltage ( $L_{BK}$ = 22 $\mu$ H, $C_{BK}$ = 22 $\mu$ F) | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 20 \text{ mA},$<br>BUCK_SEL = 10b | 3.7 | 4.0 | 4.3 | V | | | | $V_{VM} > 6.7 \text{ V}, 0 \text{ mA} \le I_{BK} \le 20 \text{ mA},$<br>BUCK_SEL = 11b | 5.2 | 5.7 | 5.8 | V | | | | $V_{VM}$ < 6.0 V (BUCK_SEL = 00b, 01b, 10b, 11b), 0 mA ≤ $I_{BK}$ ≤ 20 mA | I <sub>B</sub> | V <sub>VM</sub> -<br>s <sub>K</sub> *(R <sub>LBK</sub><br>+2) <sup>1</sup> | 5.4 4.3 5.8 3.5 5.4 4.3 5.8 3.5 5.4 4.3 5.8 100 100 170 170 170 170 170 170 20 20 | V | | $V_{BK}$ | Buck regulator average voltage ( $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu F$ ) | $V_{VM} > 6 \text{ V, 0 mA} \le I_{BK} \le 10 \text{ mA,}$<br>BUCK_SEL = 00b | 3.1 | 3.3 | 3.5 | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 10 \text{ mA},$<br>BUCK_SEL = 01b | 4.6 | 5.0 | 5.4 | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 10 \text{ mA},$<br>BUCK_SEL = 10b | 3.7 | 4.0 | 4.3 | V | | | | $V_{VM} > 6.7 \text{ V}, 0 \text{ mA} \le I_{BK} \le 10 \text{ mA},$<br>BUCK_SEL = 11b | 5.2 | 5.7 | 5.8 | V | | | | $V_{VM}$ < 6.0 V (BUCK_SEL = 00b, 01b, 10b, 11b), 0 mA ≤ $I_{BK}$ ≤ 10 mA | I <sub>B</sub> | V <sub>VM</sub> -<br>s <sub>K</sub> *(R <sub>LBK</sub><br>+2) <sup>(1)</sup> | | V | | | | $V_{VM} > 6 \text{ V}, 0 \text{ mA} \le I_{BK} \le 170 \text{ mA}, Buck}$ regulator with inductor, $L_{BK} = 47 \mu\text{H}, C_{BK} = 22 \mu\text{F}$ | -100 | | 100 | mV | | V <sub>BK_RIP</sub> | Buck regulator ripple voltage | $V_{VM}$ > 6 V, 0 mA ≤ $I_{BK}$ ≤ 20 mA, Buck regulator with inductor, $L_{BK}$ = 22 $\mu$ H, $C_{BK}$ = 22 $\mu$ F | -100 | | 100 | mV | | | | $V_{VM}$ > 6 V, 0 mA ≤ $I_{BK}$ ≤ 10 mA, Buck regulator with resistor, $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F | -100 | | 5.4 4.3 5.8 3.5 5.4 4.3 5.8 100 100 100 170 170 170 170 170 20 20 1AVDD | mV | | | | L <sub>BK</sub> = 47 μH, C <sub>BK</sub> = 22 μF,<br>BUCK_PS_DIS = 1b | | | 170 | mA | | | | L <sub>BK</sub> = 47 μH, C <sub>BK</sub> = 22 μF,<br>BUCK_PS_DIS = 0b | | | | mA | | l <sub>niz</sub> | External buck regulator load | L <sub>BK</sub> = 22 μH, C <sub>BK</sub> = 22 μF,<br>BUCK_PS_DIS = 1b | | | 20 | mA | | I <sub>BK</sub> | External buck regulator load | L <sub>BK</sub> = 22 μH, C <sub>BK</sub> = 22 μF,<br>BUCK_PS_DIS = 0b | | | | mA | | | | $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F,<br>BUCK_PS_DIS = 1b | | | 10 | mA | | | | $R_{BK}$ = 22 $\Omega$ , $C_{BK}$ = 22 $\mu$ F,<br>BUCK_PS_DIS = 0b | | | 10 –<br>I <sub>AVDD</sub> | mA | | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |------------------------|--------------------------------------------------|------------------------------------------------------------------------|-----|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------| | £ | Duels regulator quitabing frequency | Regulation Mode | 20 | | 535 | kHz | | t <sub>SW_BK</sub> | Buck regulator switching frequency | Linear Mode | 20 | | 535 | kHz | | | | V <sub>BK</sub> rising, BUCK_SEL = 00b | 2.7 | 2.8 | 2.95 | V | | | | V <sub>BK</sub> falling, BUCK_SEL = 00b | 2.5 | 2.6 | 535<br>535 | V | | | | V <sub>BK</sub> rising, BUCK_SEL = 01b | 4.3 | 4.4 | | V | | \ | Buck regulator undervoltage lockout | V <sub>BK</sub> falling, BUCK_SEL = 01b | 4.1 | 4.2 | | V | | $V_{BK\_UV}$ | | V <sub>BK</sub> rising, BUCK_SEL = 10b | 2.7 | 2.8 | 2.95 | V | | | | V <sub>BK</sub> falling, BUCK_SEL = 10b | 2.5 | 2.6 | 2.7 | V | | | | V <sub>BK</sub> rising, BUCK_SEL = 11b | 4.3 | 4.4 | 535 535 2.8 2.95 2.6 2.7 4.4 4.55 4.2 4.38 2.8 2.95 2.6 2.7 4.4 4.55 4.2 4.38 2.00 400 200 400 200 400 200 400 200 400 3 4 1 1.3 95 125 105 130 140 185 145 190 125 185 200 280 125 185 200 280 125 185 200 280 125 185 | V | | | | V <sub>BK</sub> falling, BUCK_SEL = 11b | 4.1 | 4.2 | | V | | | | Rising to falling threshold, BUCK_SEL = 00b | 90 | 200 | 535 .8 | mV | | V | Buck regulator undervoltage lockout | Rising to falling threshold, BUCK_SEL = 01b | 90 | 20 20 200 200 200 200 200 200 200 200 2 | 400 | mV | | V <sub>BK_UV_HYS</sub> | hysteresis | Rising to falling threshold, BUCK_SEL = 10b | 90 | 200 | 535 535 2.95 2.7 4.55 4.38 2.95 2.7 4.55 4.38 400 400 400 400 400 410 260 4 1.3 125 130 185 190 185 280 1000 | mV | | | | Rising to falling threshold, BUCK_SEL =11b | 90 | 90 200 400<br>90 200 400<br>360 600 910<br>80 150 260 | mV | | | 1 | Buck regulator current limit threshold | BUCK_CL = 0b | 360 | 600 | 535 535 2.95 2.7 4.55 4.38 2.95 2.7 4.55 4.38 400 400 400 400 400 410 260 4 1.3 125 130 185 190 185 280 1000 | mA | | I <sub>BK_CL</sub> | - | BUCK_CL = 1b | 80 | 150 | 260 | mA | | I <sub>BK_OCP</sub> | Buck regulator overcurrent protection trip point | | 2 | 3 | 4 | Α | | t <sub>BK_RETRY</sub> | Overcurrent protection retry time | | 0.7 | 1 | 1.3 | ms | | DRIVER OU | TPUTS | | | | | | | | | V <sub>VM</sub> > 6 V, I <sub>OUT</sub> = 1 A, T <sub>A</sub> = 25°C | | 95 | 125 | mΩ | | D | Total MOSFET on resistance (High-side | V <sub>VM</sub> < 6 V, I <sub>OUT</sub> = 1 A, T <sub>A</sub> = 25°C | | 105 | 130 | mΩ | | R <sub>DS(ON)</sub> | (C(ON) | V <sub>VM</sub> > 6 V, I <sub>OUT</sub> = 1 A, T <sub>J</sub> = 150 °C | | 140 | 185 | mΩ | | | | V <sub>VM</sub> < 6 V, I <sub>OUT</sub> = 1 A, T <sub>J</sub> = 150 °C | | 145 | 190 | mΩ | | SR | Phase pin slew rate switching low to high | V <sub>VM</sub> = 24 V, SLEW_RATE = 10b | 80 | 125 | 185 | V/µs | | OΙ | (Rising from 20 % to 80 %) | V <sub>VM</sub> = 24 V, SLEW_RATE = 11b | 130 | 200 | 280 | V/µs | | SR | Phase pin slew rate switching high to low | V <sub>VM</sub> = 24 V, SLEW_RATE = 10b | 80 | 125 | 185 | V/µs | | OIN. | (Falling from 80 % to 20 % | V <sub>VM</sub> = 24 V, SLEW_RATE = 11b | 110 | 200 | 280 | V/µs | | t | Output dead time (high to low / low to | V <sub>VM</sub> = 24 V, SLEW_RATE = 10b | | 650 | 1000 | ns | | t <sub>DEAD</sub> | high) | V <sub>VM</sub> = 24 V, SLEW_RATE = 11b | | 500 | 750 | ns | Product Folder Links: MCF8316C-Q1 Submit Document Feedback 8 | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------|------|-------|------| | SPEED INP | UT - PWM MODE | | | | | | | $f_{PWM}$ | PWM input frequency | | 0.01 | | 100 | kHz | | | | 0.01 kHz ≤ f <sub>PWM</sub> < 0.35 kHz | 11 | 12 | 13 | bits | | | | 0.35 kHz ≤ f <sub>PWM</sub> < 2 kHz | 12 | 13 | 14 | bits | | | | 2 kHz ≤ f <sub>PWM</sub> < 3.5 kHz | 11 | 11.5 | 12 | bits | | | | 3.5 kHz ≤ f <sub>PWM</sub> < 7 kHz | 13 | 13.5 | 14 | bits | | Res <sub>PWM</sub> | PWM input resolution | 7 kHz ≤ f <sub>PWM</sub> < 14 kHz | 12 | 12.5 | 13 | bits | | | | 14 kHz ≤ f <sub>PWM</sub> < 29.3 kHz | 11 | 11.5 | 12 | bits | | | | $29.3 \text{ kHz} \le f_{\text{PWM}} < 60 \text{ kHz}$ | 10 | 10.5 | 11 | bits | | | | 60 kHz ≤ f <sub>PWM</sub> ≤ 100 kHz | 8 | 9 | 10 | bits | | SDEED INDI | UT - ANALOG MODE | OO KI IZ S IPWM S 100 KI IZ | 0 | 9 | 10 | טונס | | | 1 | | 2.05 | 2 | 2.05 | | | V <sub>ANA_FS</sub> | Analog full-speed voltage | | 2.95 | 3 | 3.05 | V | | V <sub>ANA_RES</sub> | Analog voltage resolution | | | 732 | | μV | | | UT - FREQUENCY MODE | | | | | | | PWM_FREQ | PWM input frequency range | Duty cycle = 50% | 3 | | 32767 | Hz | | SLEEP MOD | T | | | | | | | V <sub>EN_SL</sub> | Analog voltage to enter sleep state | SPEED_MODE = 00b (analog mode) | | | 40 | mV | | / <sub>EX_SL</sub> | Analog voltage to exit sleep state | SPEED_MODE = 00b (analog mode) | 2.2 | | | V | | DET_ANA | Time needed to detect wake-up signal on SPEED pin | SPEED_MODE = 00b (analog mode) V <sub>SPEED</sub> > V <sub>EX_SL</sub> | 0.5 | 1 | 1.5 | μs | | twake | Wake-up time from sleep state | V <sub>SPEED</sub> > V <sub>EX_SL</sub> to DVDD voltage<br>available, SPEED_MODE = 01b (PWM<br>mode) | | 3 | 5 | ms | | EX_SL_DR_A | Time taken to drive motor after wake-up from sleep state | SPEED_MODE = 00b (analog mode), DVDD voltage available to first output PWM pulse, ISD detection disabled | | | 20 | ms | | DET_PWM | Time needed to detect wake-up signal on SPEED pin | SPEED_MODE = 01b (PWM mode) V <sub>SPEED</sub> > V <sub>IH</sub> | 0.5 | 1 | 1.5 | μs | | WAKE_PWM | Wake-up time from sleep state | V <sub>SPEED</sub> > V <sub>IH</sub> to DVDD voltage available,<br>SPEED_MODE = 01b (PWM mode) | | 3 | 5 | ms | | EX_SL_DR_P<br>WM | Time taken to drive motor after wake-up from sleep state | SPEED_MODE = 01b (PWM mode), DVDD voltage available to first output PWM pulse, ISD detection disabled | | | 20 | ms | | | | SPEED_MODE = 00b (analog mode),<br>V <sub>SPEED</sub> <<br>V <sub>EN_SL</sub> , SLEEP_ENTRY_TIME = 00b | 0.035 | 0.05 | 0.065 | ms | | <sup>t</sup> DET_SL_ANA | Time needed to detect clean command | SPEED_MODE = 00b (analog mode),<br>V <sub>SPEED</sub> <<br>V <sub>EN_SL</sub> , SLEEP_ENTRY_TIME = 01b | 0.14 | 0.2 | 0.26 | ms | | | Time needed to detect sleep command | SPEED_MODE = 00b (analog mode),<br>V <sub>SPEED</sub> <<br>V <sub>EN_SL</sub> , SLEEP_ENTRY_TIME = 10b | 14 | 20 | 26 | ms | | | | SPEED_MODE = 00b (analog mode),<br>V <sub>SPEED</sub> <<br>V <sub>EN_SL</sub> , SLEEP_ENTRY_TIME = 11b | 140 | 200 | 260 | ms | | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|------| | t <sub>det_sl_pwm</sub> | | SPEED_MODE = 01b (PWM mode) or 11b (Frequency mode), V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 00b | 0.035 | 0.05 | 0.065 | ms | | | Time needed to detect sleep command | SPEED_MODE = 01b (PWM mode) or 11b (Frequency mode), V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 01b | 0.14 | 0.2 | 0.26 | ms | | | Time needed to detect sleep command | SPEED_MODE = 01b (PWM mode)<br>or 11b (Frequency mode),<br>V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME =<br>10b | 14 | 20 26 | 26 | ms | | | | SPEED_MODE = 01b (PWM mode) or 11b (Frequency mode), V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 11b | 140 | 200 | | ms | | t <sub>EN_SL</sub> | Time needed to stop driving motor after detecting sleep command | $\begin{split} & V_{SPEED} < V_{EN\_SL} (analog \\ & \text{mode}) \text{or} V_{SPEED} < V_{IL} (PWM \text{mode}) \\ & \text{or} Frequency \text{mode}) \text{or} V_{SPEED} < \\ & V_{IL} \text{and} \text{DIGITAL\_SPEED\_CTRL} = 0b \\ & (I^2C \text{mode}) \end{split}$ | | 1 | 2 | ms | | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |--------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------|-----------------|------| | STANDBY N | IODE | | | | | | | EX_SB_DR_A<br>NA | Time taken to drive motor after exiting standby state | SPEED_MODE = 00b (analog mode)<br>V <sub>SPEED</sub> > V <sub>EX_SB</sub> , ISD detection disabled | | | 6 | ms | | EX_SB_DR_P | Time taken to drive motor after exiting standby state | SPEED_MODE = 01b (PWM mode)<br>V <sub>SPEED</sub> > V <sub>IH</sub> , ISD detection disabled | | | 6 | ms | | DET_SB_ANA | Time needed to detect standby command | SPEED_MODE = 00b (analog mode) V <sub>SPEED</sub> < V <sub>EN_SB</sub> | 0.5 | 1 | 2 | ms | | | | SPEED_MODE = 01b (PWM mode) V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 00b | 0.035 | 0.05 | 0.065 | ms | | | Time needed to detect standby | SPEED_MODE = 01b (PWM mode) V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 01b | 0.14 | 0.2 | 0.26 | ms | | EN_SB_PWM | command | SPEED_MODE = 01b (PWM mode) V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 10b | 14 | 14 20 26 | 26 | ms | | | | SPEED_MODE = 01b (PWM mode) V <sub>SPEED</sub> < V <sub>IL</sub> , SLEEP_ENTRY_TIME = 11b | 140 | 200 | 260 | ms | | EN_SB_DIG | Time needed to detect standby command | SPEED_MODE = 10b (I <sup>2</sup> C mode), DIGITAL_SPEED_CTRL = 0b | | 1 | 2 | ms | | t <sub>EN_SB_FREQ</sub> | Time needed to detect standby command | SPEED_MODE = 11b (Frequency mode), V <sub>SPEED</sub> < V <sub>IL</sub> | | 4000 | | ms | | <sup>t</sup> EN_SB | Time needed to stop driving motor after detecting standby command | V <sub>SPEED</sub> < V <sub>EN_SL</sub> (analog<br>mode) or V <sub>SPEED</sub> <<br>V <sub>IL</sub> (PWM or Frequency mode)<br>or DIGITAL_SPEED_CTRL = 0b (I <sup>2</sup> C<br>mode) | | 1 | 2 | ms | | LOGIC-LEV | EL INPUTS (BRAKE, DIR, EXT_CLK, EX | T_WD, SCL, SDA, SPEED) | | | | | | V <sub>IL</sub> | Input logic low voltage | AVDD = 3 to 3.6 V | | | 0.25*AV<br>DD | V | | V <sub>IH</sub> | Input logic high voltage | AVDD = 3 to 3.6 V | 0.65*AV<br>DD | | | V | | V <sub>HYS</sub> | Input hysteresis | | 50 | 500 | 800 | mV | | IIL | Input logic low current | AVDD = 3 to 3.6 V | -0.15 | - | 0.15 | μA | | Ін | Input logic high current | AVDD = 3 to 3.6 V | -0.4 | | 0.15 | μΑ | | R <sub>PD_SPEED</sub> | Input pulldown resistance | SPEED pin To GND | 0.6 | 1 | 1.4 | МΩ | | | N OUTPUTS (nFAULT, FG) | | | | ' | | | V <sub>OL</sub> | Output logic low voltage | I <sub>OD</sub> =-5 mA | | | 0.4 | V | | OZ | Output logic high current | V <sub>OD</sub> = 3.3 V | 0 | | 0.5 | μA | | <sup>2</sup> C Serial In | terface | | | | | | | V <sub>I2C_L</sub> | LOW-level input voltage | | -0.5 | | 0.3*AVD<br>D | V | | V <sub>I2C_H</sub> | HIGH-level input voltage | | 0.7*AVD<br>D | | 5.5 | V | | V <sub>I2C_HYS</sub> | Hysterisis | | 0.05*AV<br>DD | | | V | | / <sub>I2C_OL</sub> | LOW-level output voltage | open-drain at 2mA sink current | 0 | | 0.4 | V | | I2C_OL | LOW-level output current | V <sub>I2C_OL</sub> = 0.6V | | | 6 | mA | | I <sub>12C_IL</sub> | Input current on SDA and SCL | _ | -10 <sup>2</sup> | | 10 <sup>2</sup> | μA | | C <sub>i</sub> | Capacitance for SDA and SCL | | | | 10 | pF | | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|-------------------------------------------------------------------|------------------------------------------|-------|------|------------------|--------| | <b>+</b> . | Output fall time from V <sub>I2C H</sub> (min) to | Standard Mode | | | 250 <sup>3</sup> | ns | | t <sub>of</sub> | V <sub>I2C_L</sub> (max) | Fast Mode | | | 250 <sup>3</sup> | ns | | t <sub>SP</sub> | Pulse width of spikes that must be suppressed by the input filter | Fast Mode | 0 | | 50 <sup>4</sup> | ns | | OSCILLATO | DR | | | | | | | | | EXT_CLK_CONFIG = 000b | | 8 | | kHz | | | | EXT_CLK_CONFIG = 001b | | 16 | | kHz | | | | EXT_CLK_CONFIG = 010b | | 32 | | kHz | | e. | Fotom all also de materia de | EXT_CLK_CONFIG = 011b | | 64 | | kHz | | foscref | External clock reference | EXT_CLK_CONFIG = 100b | | 128 | | kHz | | | | EXT_CLK_CONFIG = 101b | | 256 | | kHz | | | | EXT_CLK_CONFIG = 110b | | 512 | | kHz | | | | EXT_CLK_CONFIG = 111b | | 1024 | | kHz | | EEPROM | | | | | | | | EE <sub>Prog</sub> | Programming voltage | | 1.35 | 1.5 | 1.65 | V | | | Deterrine | T <sub>A</sub> = 25 °C | | 100 | | Years | | EE <sub>RET</sub> | Retention | T <sub>J</sub> = -40 to 150 °C | 10 | | | Years | | | | T <sub>J</sub> = -40 to 150 °C | 1000 | | | Cycles | | EE <sub>END</sub> | Endurance | T <sub>J</sub> = -40 to 85 °C | 20000 | | | Cycles | | PROTECTION | ON CIRCUITS | | | | l | | | . , | | VM rising | 4.3 | 4.4 | 4.5 | V | | $V_{UVLO}$ | Supply undervoltage lockout (UVLO) | -0) | 4.2 | 4.3 | V | | | V <sub>UVLO_HYS</sub> | Supply undervoltage lockout hysteresis | Rising to falling threshold | 110 | 200 | 350 | mV | | t <sub>UVLO</sub> | Supply undervoltage deglitch time | | 3 | 5 | 7 | μs | | | Supply overvoltage protection (OVP) | Supply rising, OVP_EN = 1, OVP_SEL = 0 | 32.5 | 34 | 35 | V | | V | | Supply falling, OVP_EN = 1, OVP_SEL = 0 | 31.8 | 33 | 34.3 | V | | V <sub>OVP</sub> | | Supply rising, OVP_EN = 1, OVP_SEL = 1 | 20 | 22 | 23 | V | | | | Supply falling, OVP_EN = 1, OVP_SEL = 1 | 19 | 21 | 22 | V | | V <sub>OVP_HYS</sub> | Supply overvoltage protection (OVP) | Rising to falling threshold, OVP_SEL = 1 | 0.9 | 1 | 1.1 | V | | VOVP_HYS | cupply everyonage protection (evr) | Rising to falling threshold, OVP_SEL = 0 | 0.7 | 8.0 | 0.9 | V | | t <sub>OVP</sub> | Supply overvoltage deglitch time | | 2.5 | 5 | 7 | μs | | V | Charge pump undervoltage lockout | Supply rising | 2.25 | 2.5 | 2.75 | V | | $V_{CPUV}$ | (above VM) | Supply falling | 2.2 | 2.4 | 2.6 | V | | V <sub>CPUV_HYS</sub> | Charge pump UVLO hysteresis | Rising to falling threshold | 65 | 100 | 150 | mV | | \/ | Analog regulator underveltage legiscit | Supply rising | 2.7 | 2.85 | 3 | V | | $V_{AVDD\_UV}$ | Analog regulator undervoltage lockout | Supply falling | 2.5 | 2.65 | 2.8 | V | | V <sub>AVDD</sub> _<br>uv_hys | Analog regulator undervoltage lockout hysteresis | Rising to falling threshold | 180 | 200 | 240 | mV | | | Oversument protection tale int | OCP_LVL = 0b | 9.5 | 16 | 22 | Α | | I <sub>OCP</sub> | Overcurrent protection trip point | OCP LVL = 1b | 15 | 24 | 28 | Α | Submit Document Feedback | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-------------------------------|--------------------------------------|-----------------------------------|------|-----|-----|------| | tocp | | OCP_DEG = 00b | 0.02 | 0.2 | 0.4 | μs | | | Oversurrent protection dealitch time | OCP_DEG = 01b | 0.2 | 0.6 | 1.2 | μs | | | Overcurrent protection deglitch time | OCP_DEG = 10b | 0.5 | 1.2 | 1.8 | μs | | | | OCP_DEG = 11b | 0.9 | 1.6 | 2.5 | μs | | t <sub>RETRY</sub> | Overcurrent protection retry time | | 425 | 500 | 575 | ms | | T <sub>OTW</sub> | Thermal warning temperature | Die temperature (T <sub>J</sub> ) | 135 | 145 | 155 | °C | | T <sub>OTW_HYS</sub> | Thermal warning hysteresis | Die temperature (T <sub>J</sub> ) | 15 | 20 | 25 | °C | | T <sub>TSD_BUCK</sub> | Thermal shutdown temperature (Buck) | Die temperature (T <sub>J</sub> ) | 170 | 180 | 190 | °C | | T <sub>TSD_BUCK_</sub><br>HYS | Thermal shutdown hysteresis (Buck) | Die temperature (T <sub>J</sub> ) | 15 | 20 | 25 | °C | | T <sub>TSD_FET</sub> | Thermal shutdown temperature (FET) | Die temperature (T <sub>J</sub> ) | 165 | 175 | 185 | °C | | T <sub>TSD_FET_HY</sub> | Thermal shutdown hysteresis (FET) | Die temperature (T <sub>J</sub> ) | 20 | 25 | 30 | °C | - $R_{LBK}$ is resistance of inductor $L_{BK}$ (1) - If AVDD is switched off, I/O pins must not obstruct the SDA and SCL lines. - The maximum tf for the SDA and SCL bus lines (300 ns) is longer than the specified maximum tof for the output stages (250 ns). This allows series protection resistors (Rs) to be connected between the SDA/SCL pins and the SDA/SCL bus lines without exceeding the maximum specified tf. - Input filters on the SDA and SCL inputs suppress noise spikes of less than 50 ns # 6.6 Characteristics of the SDA and SCL bus for Standard and Fast mode over operating free-air temperature range (unless otherwise noted) | | PARAMETER | TEST CONDITIONS | MIN | NOM MAX | UNIT | |---------------------|-------------------------------------------------------|-------------------------------------------------------|--------------|----------|------| | Standar | d-mode | | | | • | | f <sub>SCL</sub> | SCL clock frequency | | 0 | 100 | kHz | | t <sub>HD_STA</sub> | Hold time (repeated) START condition | After this period, the first clock pulse is generated | 4 | | μs | | t <sub>LOW</sub> | LOW period of the SCL clock | | 4.7 | | μs | | t <sub>HIGH</sub> | HIGH period of the SCL clock | | 4 | | μs | | t <sub>SU_STA</sub> | Set-up time for a repeated START condition | | 4.7 | | μs | | t <sub>HD_DAT</sub> | Data hold time <sup>(2)</sup> | I2C bus devices | 0 (3) | (4) | μs | | t <sub>SU_DAT</sub> | Data set-up time | | 250 | | ns | | t <sub>r</sub> | Rise time for both SDA and SCL signals | | | 1000 | ns | | t <sub>f</sub> | Fall time of both SDA and SCL signals (3) (6) (7) (8) | | | 300 | ns | | t <sub>SU_STO</sub> | Set-up time for STOP condition | | 4 | | μs | | t <sub>BUF</sub> | Bus free time between STOP and START condition | | 4.7 | | μs | | C <sub>b</sub> | Capacitive load for each bus line (9) | | | 400 | pF | | t <sub>VD_DAT</sub> | Data valid time (10) | | | 3.45 (4) | μs | | t <sub>VD_ACK</sub> | Data valid acknowledge time (11) | | | 3.45 (4) | μs | | V <sub>nL</sub> | Noise margin at the LOW level | For each connected device (including hysteresis) | 0.1*AVD<br>D | | V | | $V_{nh}$ | Noise margin at the HIGHlevel | For each connected device (including hysteresis) | 0.2*AVD<br>D | | V | | Fast-mo | de | | ' | | | | f <sub>SCL</sub> | SCL clock frequency | | 0 | 400 | KHz | over operating free-air temperature range (unless otherwise noted) | | PARAMETER | TEST CONDITIONS | MIN | NOM I | /IAX | UNIT | |---------------------|-------------------------------------------------------|-------------------------------------------------------|-------------------------|-------|-------|------| | t <sub>HD_STA</sub> | Hold time (repeated) START condition | After this period, the first clock pulse is generated | 0.6 | | | μs | | t <sub>LOW</sub> | LOW period of the SCL clock | | 1.3 | | | μs | | t <sub>HIGH</sub> | HIGH period of the SCL clock | | 0.6 | | | μs | | t <sub>SU_STA</sub> | Set-up time for a repeated START condition | | 0.6 | | | μs | | t <sub>HD_DAT</sub> | Data hold time <sup>(2)</sup> | | 0 (3) | | (4) | μs | | t <sub>SU_DAT</sub> | Data set-up time | | 100 (5) | | | ns | | t <sub>r</sub> | Rise time for both SDA and SCL signals | | 20 | | 300 | ns | | t <sub>f</sub> | Fall time of both SDA and SCL signals (3) (6) (7) (8) | | 20 x<br>(AVDD/<br>5.5V) | | 300 | ns | | t <sub>SU_STO</sub> | Set-up time for STOP condition | | 0.6 | | | μs | | t <sub>BUF</sub> | Bus free time between STOP and START condition | | 1.3 | | | μs | | C <sub>b</sub> | Capacitive load for each bus line (9) | | | | 400 | pF | | t <sub>VD_DAT</sub> | Data valid time (10) | | | 0 | 9 (4) | μs | | t <sub>VD_ACK</sub> | Data valid acknowledge time (11) | | | 0 | 9 (4) | μs | | V <sub>nL</sub> | Noise margin at the LOW level | For each connected device (including hysteresis) | 0.1*AVD<br>D | | | V | | $V_{nh}$ | Noise margin at the HIGHlevel | For each connected device (including hysteresis) | 0.2*AVD<br>D | | | V | - (1) - All values referred to $V_{IH(min)}$ and $V_{IL(max)}$ levels $t_{HD\_DAT}$ is the data hold time that is measured from the falling edge of SCL, applies to data in transmission and the acknowledge. (2) - (3) A device must internally provide a hold time of at least 300 ns for the SDA signal (with respect to the V<sub>IH(min)</sub> of the SCL signal) to bridge the undefined region of the falling edge of SCL. - The maximum $t_{HD\ DAT}$ could be 3.45 us and 0.9 $\mu s$ for Standard-mode and Fast-mode, but must be less than the maximum of $t_{VD\ DAT}$ or t<sub>VD\_ACK</sub> by a transistion time. This maximum must only be met if the device does not stretch the LOW period (t<sub>LOW</sub>) of the SCL signal. If the clock stretched the SCL, the data must be valid by the set-up time before it releases the clock. - A fast-mode I<sup>2</sup>C-bus device can be used in a standard-mode I<sup>2</sup>C-bus system, but the requirement t<sub>SU DAT</sub> 250 ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period if the SCL signal, it must output the next data bit to the SDA line $t_{r(max)} + t_{SU\_DAT} = 1000 + 250 = 1250$ ns (according to the standard-mode I<sup>2</sup>C-bus specification) before the SCL line is released. Also the acknowledge timing must meet this set-up time. - If mixed with HS-mode devices, faster fall times according to Table 10 are allowed. - The maximum $t_f$ for the SDA and SCL bus lines is specified at 300 ns. The maximum fall time for the SDA output stage $t_f$ is specified at 250 ns. This allows series protection resistors to be connected in between the SDA and the SCL pins and the SDA/SCL bus lines without exceeding the maximum specified tf. - In Fast-mode Plus, fall time is specified the same for both output stage and bus timing. If series resistors are used, designers should allow for this when considering bus timing. - The maximum bus capacitance allowable may vary from the value depending on the actual operating voltage and frequency of the - (10) t<sub>VD\_DAT</sub> = time for data signal from SCL LOW to SDA output (HIGH or LOW, depending on which one is worse). - (11) t<sub>VD</sub> ACK = time for acknowledgement signal from SCL LOW to SDA output (HIGH or LOW, depending on which one is worse). # **6.7 Typical Characteristics** # 7 Detailed Description ### 7.1 Overview The MCF8316C-Q1 provides a single-chip, code-free sensorless FOC solution for customers driving speed-controlled 12- to 24-V brushless-DC motors requiring up to 8-A peak phase currents. The MCF8316C-Q1 integrates three $\frac{1}{2}$ -bridges with 40-V absolute maximum capability and a very low $R_{DS(ON)}$ of 95-m $\Omega$ (high-side + low-side) to enable high power drive capability. Current is sensed using an integrated current sensing circuit which eliminates the need for external sense resistors. Power management features of an adjustable buck regulator and LDO generate the necessary voltage rails for the device and can also be used to power external circuits. MCF8316C-Q1 implements sensorless FOC, and so an external microcontroller is not required to spin the brushless-DC motor. The algorithm is implemented in a fixed-function state machine, so no coding is needed. The algorithm is highly configurable through register settings ranging from motor start-up behavior to closed loop operation. Register settings can be stored in non-volatile EEPROM, which allows the device to operate stand-alone once it has been configured. The device receives a speed command through a PWM input, analog voltage, frequency input or I<sup>2</sup>C command. In-built protection features include power-supply under voltage lockout (UVLO), charge-pump under voltage lockout (CPUV), over current protection (OCP), AVDD under voltage lockout (AVDD\_UV), buck regulator UVLO, motor lock detection and over temperature warning and shutdown (OTW and TSD). Fault events are indicated by the nFAULT pin with detailed fault information available in the registers. The MCF8316C-Q1 device is available in a 0.5-mm pin pitch, VQFN surface-mount package. The VQFN package size is 7 mm x 5 mm with a height of 1 mm. # 7.2 Functional Block Diagram Figure 7-1. MCF8316C-Q1 Functional Block Diagram # 7.3 Feature Description ### 7.3.1 Output Stage The MCF8316C-Q1 consists of integrated 95-mΩ (combined high-side and low-side FETs' on-state resistance) NMOS FETs connected in a three-phase bridge configuration. A doubler charge pump provides the proper gate-bias voltage to the high-side NMOS FETs across a wide operating voltage range in addition to providing 100% duty-cycle support. An internal linear regulator provides the gate-bias voltage for the low-side MOSFETs. #### 7.3.2 Device Interface The MCF8316C-Q1 supports I<sup>2</sup>C interface to provide end application design with adequate flexibility. MCF8316C-Q1 allows controlling the motor operation and system through BRAKE, DRVOFF, DIR, EXT\_CLK, EXT\_WD and SPEED/WAKE pins. MCF8316C-Q1 also provides different signals for monitoring system variables, speed, fault and phase current feedback through DACOUT1, DACOUT2, FG, nFAULT and SOX pins. # 7.3.2.1 Interface - Control and Monitoring ### **Motor Control Signals** - SPEED/WAKE pin is used to control the motor speed and to wake up MCF8316C-Q1 from sleep. SPEED pin can be configured to accept PWM, frequency or analog input signals. It is also used to enter and exit from sleep and standby mode (see Table 7-7). - When BRAKE pin is driven 'High', MCF8316C-Q1 enters brake state. Brake state can be configured to either low side brake (see Low-Side Braking) or align brake (see Align Braking) through BRAKE\_PIN\_MODE. MCF8316C-Q1 decreases output speed to value defined by BRAKE\_SPEED\_THRESHOLD before entering brake state. As long as BRAKE is driven 'High', MCF8316C-Q1 stays in brake state. Brake pin input can be overwritten by configuring BRAKE\_INPUT over the I<sup>2</sup>C interface. - The DIR pin decides the direction of motor spin; when driven 'High', the sequence is OUT A → OUT B → OUT C, and when driven 'Low', the sequence is OUT A → OUT C → OUT B. DIR pin input can be overwritten by configuring DIR\_INPUT over the I<sup>2</sup>C interface. - When DRVOFF pin is driven 'High', MCF8316C-Q1 stops driving the motor by turning OFF (Hi-Z) all MOSFETs (coast state) this could be accompanied by faults like no motor or abnormal BEMF. When DRVOFF is driven 'Low', MCF8316C-Q1 returns to normal state of operation, as if it was restarting the motor (see DRVOFF Functionality). DRVOFF does not cause the device to go to sleep or standby mode; the digital core is still active. Entry and exit from sleep or standby condition is controlled by SPEED pin. ### **External Oscillator and Watchdog Signals** - EXT\_CLK pin can be used to provide an external clock reference (see External Clock Source). - EXT\_WD pin can be used to provide an external watchdog signal (see External Watchdog). #### **Output Signals** - DACOUT1 outputs internal variable defined by address in register DACOUT1\_VAR\_ADDR. DACOUT1 is refreshed every PWM cycle (see DAC outputs). - DACOUT2 outputs internal variable defined by address in register DACOUT2\_VAR\_ADDR. DACOUT2 is refreshed every PWM cycle (see DAC outputs). - FG pin provides pulses which are proportional to motor speed (see FG Configuration). - nFAULT (active low) pin provides fault status in device or motor operation. - ALARM pin, when enabled using ALARM\_PIN\_EN, provides fault status in device or motor operation as an active high signal. When ALARM pin is enabled, report only faults are reported only on ALARM pin (as logic high) and not reported on nFAULT pin (as logic low). When ALARM pin is enabled, actionable faults are reported on ALARM pin (as logic high) as well as on nFAULT pin (as logic low). When ALARM pin is disabled, it is in Hi-Z state and all faults (actionable and report only) are reported on nFAULT as logic low. ALARM pin should be left floating when unused/disabled. - SOX pin provides the output of one of the current sense amplifiers. Submit Document Feedback #### Note - Internal pull-up resistor (to AVDD) for both FG and nFAULT pins can be enabled by configuring PULLUP\_ENABLE to 1b. Any change to this bit needs to be written to EEPROM followed by a power recycle to take effect. When PULLUP\_ENABLE is set to 1b, no external pull-up resistor should be provided. - 2. DIR and BRAKE pins each have an internal pull-down resistor of 100-k $\Omega$ . When these pins are used, an additional pull-down resistor of 10-k $\Omega$ may be added externally for additional noise immunity. - SPEED pin has an internal pull-down resistor of 1-MΩ. In analog speed input mode, a suitable R-C filter can be added externally for reducing noise. In PWM speed input mode, SPEED PIN GLITCH FILTER can be appropriately configured for glitch rejection. ### 7.3.2.2 I<sup>2</sup>C Interface The MCF8316C-Q1 supports an $I^2C$ serial communication interface that allows an external controller to send and receive data. This $I^2C$ interface lets the external controller to configure the EEPROM and read detailed fault and motor state information. The pull-down strength of the $I^2C$ pins can be configured using SLEW\_RATE\_I2C\_PINS. The $I^2C$ bus is a two-wire interface using the SCL and SDA pins which are described as follows: - The SCL pin is the clock signal input. - · The SDA pin is the data input and output. ### 7.3.3 Step-Down Mixed-Mode Buck Regulator The MCF8316C-Q1 has an integrated mixed-mode buck regulator to supply regulated 3.3-V or 5-V power for an external controller or system voltage rail. Additionally, the buck output can also be configured to 4-V or 5.7-V for supporting the extra headroom for an external LDO for generating a 3.3-V or 5-V supplies. The output voltage of the buck is set by BUCK\_SEL. The buck regulator has a low quiescent current of ~1-2 mA during light loads to prolong battery life. The device improves performance during line and load transients by implementing a pulse-frequency current-mode control scheme which requires less output capacitance and simplifies frequency compensation design. **Buck Mode** Buck output voltage | Max output Max output current **Buck current limit AVDD** power current from AVDD from Buck (I<sub>BK MAX</sub>) sequencing $(I_{AVDD\_MAX})$ Inductor - 47 µH 3.3-V or 4-V 20 mA 600 mA (BUCK CL = Not supported 170 mA - I<sub>AVDD</sub> (BUCK PS DIS = 1b) Inductor - 47 µH 5-V or 5.7-V 20 mA 170 mA - I<sub>AVDD</sub> 600 mA (BUCK CL = Supported (BUCK PS DIS = 0b) 5-V or 5.7-V 20 mA - I<sub>AVDD</sub> 150 mA (BUCK CL = Not supported Inductor - 22 µH 20 mA (BUCK PS DIS = 1b) 150 mA (BUCK CL = Inductor - 22 µH 3.3-V or 4-V 20 mA 20 mA - I<sub>AVDD</sub> Supported (BUCK PS DIS = 0b) Resistor - 22 Ω 5-V or 5.7-V 10 mA - I<sub>AVDD</sub> 150 mA (BUCK CL = Not supported 20 mA (BUCK PS DIS = 1b) 1b) Resistor - 22 Ω 3.3-V or 4-V 20 mA 10 mA - I<sub>AVDD</sub> 150 mA (BUCK CL = Supported (BUCK PS DIS = 0b) Table 7-1. Recommended settings for Buck Regulator # 7.3.3.1 Buck in Inductor Mode The buck regulator in MCF8316C-Q1 is primarily designed to support low inductance of 47-µH and 22-µH. A 47-µH inductor allows the buck regulator to operate up to 170-mA load current support, whereas applications requiring current up to 20-mA can use a 22-µH inductor which saves component size. Figure 7-2 shows the connection of buck regulator in inductor mode. Figure 7-2. Buck (Inductor Mode) #### 7.3.3.2 Buck in Resistor mode If the external load requirement is less than 10-mA, the inductor can be replaced with a resistor. In resistor mode the power is dissipated across the external resistor and the efficiency is lower than buck in inductor mode. Figure 7-3 shows the connection of buck in resistor mode. Figure 7-3. Buck (Resistor Mode) ### 7.3.3.3 Buck Regulator with External LDO The buck regulator also supports the voltage requirement to supply an external LDO to generate standard 3.3-V or 5-V output rail with higher accuracies. The buck output voltage should be configured to 4-V or 5.7-V to provide extra headroom to support the external LDO for generating 3.3-V or 5-V rail as shown in Figure 7-4. This allows for a lower-voltage LDO design to save cost and better thermal management due to low drop-out voltage. Figure 7-4. Buck Regulator with External LDO # 7.3.3.4 AVDD Power Sequencing from Buck Regulator The AVDD LDO has an option of using the power supply from mixed mode buck regulator to reduce the device power dissipation. The power sequencing mode allows on-the-fly changeover of AVDD LDO input from DC mains (VM) to buck output ( $V_{BK}$ ) as shown in Figure 7-5. This sequencing can be configured through the BUCK\_PS\_DIS bit . Power sequencing is supported only when buck output voltage is set to 5-V or 5.7-V. Figure 7-5. AVDD Power Sequencing from Mixed Mode Buck Regulator ### 7.3.3.5 Mixed Mode Buck Operation and Control The buck regulator implements a pulse frequency modulation (PFM) architecture with peak current mode control. The output voltage of the buck regulator is compared with the internal reference voltage ( $V_{BK\_REF}$ ) which is internally generated depending on the buck output voltage setting (BUCK\_SEL) which constitutes an outer voltage control loop. Depending on the comparator output going high ( $V_{BK} < V_{BK\_REF}$ ) or low ( $V_{BK} > V_{BK\_REF}$ ), the high-side power FET of the buck turns on and off respectively. An independent current control loop monitors the current in high-side power FET ( $I_{BK}$ ) and turns off the high-side FET when the current becomes higher than the buck current limit ( $I_{BK\_CL}$ set by BUCK\_CL) - this implements a current limit control for the buck regulator. Figure 7-6 shows the architecture of the buck and various control/protection loops. Figure 7-6. Buck Operation and Control Loops # 7.3.4 AVDD Linear Voltage Regulator A 3.3-V linear regulator is integrated into MCF8316C-Q1 and is available for use by external circuitry. This AVDD LDO regulator is used for powering up the internal circuitry of the device and additionally, this regulator can also provide the supply voltage for a low-power MCU or other external circuitry supporting up to 20-mA. The output of the AVDD regulator should be bypassed near the AVDD pin with a X5R or X7R, 1-µF, 6.3-V ceramic capacitor routed directly back to the adjacent AGND ground pin. The AVDD nominal, no-load output voltage is 3.3-V. Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated Figure 7-7. AVDD Linear Regulator Block Diagram Use Equation 1 to calculate the power dissipated in the device by the AVDD linear regulator with VM as supply (BUCK\_PS\_DIS = 1b) $$P = (V_{VM} - V_{AVDD}) \times I_{AVDD} \tag{1}$$ For example, at a $V_{VM}$ of 24-V, drawing 20-mA out of AVDD results in a power dissipation as shown in Equation 2. $$P = (24 \text{ V} - 3.3 \text{ V}) \times 20 \text{ mA} = 414 \text{ mW}$$ (2) Use Equation 3 to calculate the power dissipated in the device by the AVDD linear regulator with buck output as supply (BUCK\_PS\_DIS = 0b) $$P = (V_{FB\ BK} - V_{AVDD}) \times I_{AVDD} \tag{3}$$ # 7.3.5 Charge Pump Since the output stages use N-channel FETs, the device requires a gate-drive voltage higher than the VM power supply to turn-on the high-side FETs. The MCF8316C-Q1 integrates a charge-pump circuit that generates a voltage above the VM supply for this purpose. The charge pump requires two external capacitors ( $C_{CP}$ , $C_{FLY}$ ) for operation. See Figure 7-1 and Table 5-1 for details on these capacitors (value, connection, and so forth). Figure 7-8. Charge Pump ### 7.3.6 Slew Rate Control An adjustable gate-drive current control is provided for the output stage MOSFETs to achieve configurable slew rate for EMI mitigation. The MOSFET VDS slew rate is a critical factor for optimizing conducted and radiated emissions, total energy and duration of diode recovery spikes and switching voltage transients related to parasitic elements of the PCB. This slew rate is predominantly determined by the control of the internal MOSFET gate current as shown in Figure 7-9. Figure 7-9. Slew Rate Circuit Implementation The slew rate of each half-bridge can be adjusted through SLEW\_RATE. Slew rate can be configured as either $125\text{-V/}\mu\text{s}$ or $200\text{-V/}\mu\text{s}$ . The slew rate is calculated by the rise-time and fall-time of the voltage on OUTx pin as shown in Figure 7-10. Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated Figure 7-10. Slew Rate Timings # 7.3.7 Cross Conduction (Dead Time) The device is fully protected against any cross conduction of MOSFETs - during the switching of high-side and low-side MOSFETs, MCF8316C-Q1 avoids shoot-through events by inserting a dead time ( $t_{dead}$ ). This is implemented by sensing the gate-source voltage (VGS) of the high-side and low-side MOSFETs and ensuring that VGS of high-side MOSFET has dropped below turn-off level before switching on the low-side MOSFET of same half-bridge (or vice-versa) as shown in Figure 7-11 and Figure 7-12. The VGS of the high-side and low-side MOSFETs (VGS HS and VGS LS) shown in Figure 7-12 are internal signals. Figure 7-11. Cross Conduction Protection Figure 7-12. Dead Time ## 7.3.8 Motor Control Input Sources MCF8316C-Q1 provides two modes of controlling the motor based on SPEED\_LOOP\_DIS setting, - 1. Speed control: In speed control mode (SPEED\_LOOP\_DIS = 0b), the speed of the motor is controlled according to the input reference using a closed loop PI control. - 2. Current control: In current control mode (SPEED\_LOOP\_DIS = 1b), the torque controlling current ( $I_q$ ) is controlled according to the input reference using a closed loop PI control. MCF8316C-Q1 offers four methods of directly controlling the input reference of the motor. The input reference source is configured by SPEED MODE. The input reference source can be provided in one of the following four ways, - Analog input on SPEED pin by varying amplitude of input signal (SPEED MODE = 00b) - PWM input on SPEED pin by varying duty cycle of input signal (SPEED MODE = 01b) - Over I<sup>2</sup>C by configuring DIGITAL\_SPEED\_CTRL register (SPEED\_MODE = 10b) - Frequency input on SPEED pin by varying frequency of input signal (SPEED\_MODE = 11b) The signal path from SPEED pin input (or I<sup>2</sup>C based speed input) to motor control reference (SPEED\_REF or CURRENT\_REF in Figure 7-32) is as shown in Figure 7-13. Figure 7-13. Multiplexing the Input Reference Source ### 7.3.8.1 Analog-Mode Motor Control Analog input based motor control can be configured by setting SPEED\_MODE to 00b. In this mode, the duty command (DUTY\_CMD) varies with the analog voltage input on the SPEED pin (V<sub>SPEED</sub>). When $0 \le V_{SPEED} \le V_{EN\_SB}$ , DUTY\_CMD is set to zero and the motor is stopped. When $V_{EX\_SB} \le V_{SPEED} \le V_{ANA\_FS}$ , DUTY\_CMD varies linearly with $V_{SPEED}$ as shown in Figure 7-14. $V_{EX\_SB}$ and $V_{EN\_SB}$ are the standby entry and exit thresholds - refer Section 7.4.1.2 for more information on $V_{EX\_SB}$ and $V_{EN\_SB}$ . When $V_{SPEED} > V_{ANA\_FS}$ , DUTY\_CMD is clamped to 100%. Figure 7-14. Analog-Mode Motor Control ### 7.3.8.2 PWM-Mode Motor Control PWM based motor control can be configured by setting SPEED\_MODE to 01b. In this mode, the PWM duty cycle applied to the SPEED pin can be varied from 0 to 100% and duty command (DUTY\_CMD) varies linearly with the applied PWM duty cycle. When $0 \le \text{Duty}_{\text{SPEED}} \le \text{Duty}_{\text{EN}\_SB}$ , DUTY\_CMD is set to zero and the motor is stopped. When $\text{Duty}_{\text{EX}\_SB} \le \text{Duty}_{\text{SPEED}} \le 100\%$ , DUTY\_CMD varies linearly with $\text{Duty}_{\text{SPEED}}$ as shown in Figure 7-15. $\text{Duty}_{\text{EX}\_SB}$ and $\text{Duty}_{\text{EN}\_SB}$ are the standby entry and exit thresholds - refer Section 7.4.1.2 for more information on $\text{Duty}_{\text{EX}\_SB}$ and $\text{Duty}_{\text{EN}\_SB}$ . The frequency of the PWM input signal applied to the SPEED pin is defined as $f_{\text{PWM}}$ and the range for this frequency can be configured through SPEED RANGE SEL. # Note - f<sub>PWM</sub> is the frequency of the PWM signal the device can accept at SPEED pin to control motor speed. It does not correspond to the PWM output frequency that is applied to the motor phases. The PWM output frequency can be configured through PWM\_FREQ\_OUT (see Section 7.3.16). - SLEEP\_ENTRY\_TIME should be set longer than the off time in PWM signal (V<sub>SPEED</sub> < V<sub>IL</sub>) at lowest duty input. For example, if f<sub>PWM</sub> is 10 kHz and lowest duty input is 2%, SLEEP\_ENTRY\_TIME should be more than 98 μs to ensure there is no unintended sleep/standby entry. Figure 7-15. PWM-Mode Motor Control #### 7.3.8.3 I<sup>2</sup>C-based Motor Control I²C based serial interface can be used for motor control by setting SPEED\_MODE to 10b. In this mode, the speed command can be written directly into DIGITAL\_SPEED\_CTRL register. The SPEED pin can be used to control the sleep entry and exit - if SPEED pin input is set to a value lower than $V_{EN\_SL}$ after DIGITAL\_SPEED\_CTRL register has been set to 0b for a time longer than SLEEP\_ENTRY\_TIME, MCF8316C-Q1 enters sleep state. When SPEED pin > $V_{EX\_SL}$ , MCF8316C-Q1 exits sleep state and speed is controlled through DIGITAL\_SPEED\_CTRL register. If 0 ≤ DIGITAL\_SPEED\_CTRL register ≤ DIGITAL\_SPEED\_CTRLEN\_SB and SPEED pin > $V_{EX\_SL}$ , MCF8316C-Q1 is in standby state. The relationship between DUTY\_CMD and DIGITAL\_SPEED\_CTRL register is shown in Figure 7-16. Refer Section 7.4.1.2 for more information on DIGITAL\_SPEED\_CTRLEN\_SB\_EX\_SB and DIGITAL\_SPEED\_CTRLEN\_SB\_EN\_SB. Figure 7-16. I<sup>2</sup>C-Mode Motor Control # 7.3.8.4 Frequency-Mode Motor Control Frequency based motor control is configured by setting SPEED\_MODE to 11b. In this mode, duty command varies linearly as a function of the frequency of the square wave input at SPEED pin. When $0 \le \text{Freq}_{\text{SPEED}} \le \text{Freq}_{\text{EN}\_SB}$ , DUTY\_CMD is set to zero and the motor is stopped. When $\text{Freq}_{\text{EX}\_SB} \le \text{Freq}_{\text{SPEED}} \le \text{INPUT}\_\text{MAXIMUM}\_\text{FREQ}$ , DUTY\_CMD varies linearly with $\text{Freq}_{\text{SPEED}}$ as shown in Figure 7-17. FreqEX\_SB and $\text{Freq}_{\text{EN}\_SB}$ are the standby entry and exit thresholds - refer Section 7.4.1.2 for more information on $\text{Freq}_{\text{EX}\_SB}$ and $\text{Freq}_{\text{EN}\_SB}$ . Input frequency greater than INPUT\_MAXIMUM\_FREQ clamps the DUTY\_CMD to 100%. Figure 7-17. Frequency-Mode Motor Control ### 7.3.8.5 Input Reference Profiles MCF8316C-Q1 supports three different kinds of input reference profiles (linear, staircase, bi-directional) to configure custom reference-duty command transfer function to meet specific application requirements. The input reference profile can be configured through REF\_PROFILE\_CONFIG. When REF\_PROFILE\_CONFIG is set to 00b, the input reference (SPEED\_REF or CURRENT\_REF) is set by the duty command (DUTY\_CMD) as shown in equations Equation 4 or Equation 5. $$CURRENT_REF (A) = DUTY_CMD \times ILIMIT (when SPEED_LOOP_DIS = 1b)$$ (5) When REF\_PROFILE\_CONFIG is set to 00b, any change in DUTY\_CMD by a value less than DUTY\_HYS does not produce any change in SPEED\_REF or CURRENT\_REF; DUTY\_HYS provides a hysteresis window around DUTY\_CMD for noise immunity. ### 7.3.8.5.1 Linear Reference Profiles #### Note - For all types of reference profiles, a zero input reference (0-V in analog mode, 0% duty in PWM mode, DIGITAL\_SPEED\_CTRL = 0b I<sup>2</sup>C mode or 0-Hz in frequency mode) stops the motor irrespective of the reference profile configuration. - 2. The reference value in Figure 7-18, Figure 7-19, Figure 7-20 is decided by control mode (SPED LOOP DIS) as follows, - Speed control mode (SPEED\_LOOP\_DIS = 0b): SPEED\_REF (Hz) = (REF\_x/255) x MAX\_SPEED (Hz) - Current control mode (SPEED\_LOOP\_DIS = 1b): CURRENT\_REF (A) = (REF\_x/255) x ILIMIT (A) www.ti.com Figure 7-18. Linear Reference Profile Linear reference profiles can be configured by setting REF PROFILE CONFIG to 01b. Linear profiles feature input references (SPEED REF or CURRENT\_REF) which change linearly between REF\_CLAMP1 and REF CLAMP2 with different slopes which can be set by configuring DUTY x and REF x. - DUTY OFF1 configures the duty command below which the reference will be REF OFF1. - DUTY OFF1 and DUTY ON1 configure a hysteresis between reference levels, REF CLAMP1 and REF OFF1 as shown in Figure 7-18. - DUTY CLAMP1 configures the duty command till which reference will be constant with a value REF CLAMP1. DUTY CLAMP1 can be placed anywhere between DUTY ON1 and DUTY A. - DUTY A configures the duty command for reference REF A. The reference changes from REF CLAMP1 to REF A linearly between DUTY CLAMP1 and DUTY A. DUTY A to DUTY E has to be in the same order as shown in Figure 7-18. - DUTY B configures the duty command for reference REF B. The reference changes linearly between DUTY A and DUTY B. - DUTY C configures the duty command for reference REF C. The reference changes linearly between DUTY B and DUTY C. - DUTY D configures the duty command for reference REF D. The reference changes linearly between DUTY C and DUTY D. - DUTY E configures the duty command for reference REF E. The reference changes linearly between DUTY D and DUTY E. - DUTY CLAMP2 configures the duty command above which the reference will be constant at REF CLAMP2. REF CLAMP2 configures this constant reference between DUTY CLAMP2 and DUTY OFF2 . The reference changes linearly between DUTY E and DUTY CLAMP2. DUTY CLAMP2 can be placed anywhere between DUTY\_E and DUTY\_ON2. - DUTY OFF2 and DUTY ON2 configure a hysteresis between reference levels REF CLAMP2 and REF OFF2 as shown in Figure 7-18. DUTY\_OFF2 configures the duty command above which the reference will change from REF\_CLAMP2 to REF\_OFF2. #### 7.3.8.5.2 Staircase Speed Profile Figure 7-19. Staircase Reference Profile Staircase control profiles can be configured by setting REF\_PROFILE\_CONFIG to 10b. Staircase profiles feature input control reference changes in steps between REF\_CLAMP1 and REF\_CLAMP2, by configuring DUTY x and REF\_x. - DUTY OFF1 configures the duty command below which the reference will be REF OFF1. - DUTY\_OFF1 and DUTY\_ON1 configure a hysteresis between reference levels REF\_CLAMP1 and REF\_OFF1 as shown in Figure 7-19. - DUTY\_CLAMP1 configures the duty command till which reference will be constant. REF\_CLAMP1 configures this constant reference between DUTY\_OFF1 and DUTY\_CLAMP1. DUTY\_CLAMP1 can be placed anywhere between DUTY\_ON1 and DUTY\_A. - DUTY\_A configures the duty command for reference REF\_A. There is a step change in reference from REF\_CLAMP1 to REF\_A at DUTY\_CLAMP1. DUTY\_A to DUTY\_E has to be in the same order as shown in Figure 7-19. - DUTY\_B configures the duty command for reference REF\_B. There is a step change in reference from REF\_A to REF\_B at DUTY\_A. - DUTY\_C configures the duty command for reference REF\_C. There is a step change in reference from REF\_B to REF\_C at DUTY\_B. - DUTY\_D configures the duty command for reference REF\_D. There is a step change in reference from REF\_C to REF\_D at DUTY\_C. - DUTY\_E configures the duty command for reference REF\_E. There is a step change in reference from REF\_D to REF\_E at DUTY\_D. - DUTY\_CLAMP2 configures the duty command above which the reference will be constant at REF\_CLAMP2. REF\_CLAMP2 configures this constant reference between DUTY\_CLAMP2 and DUTY\_OFF2. There is a step change in reference from REF\_E to REF\_CLAMP2 at DUTY\_E. DUTY\_CLAMP2 can be placed anywhere between DUTY\_E and DUTY\_ON2. - DUTY\_OFF2 and DUTY\_ON2 configure a hysteresis between reference levels REF\_CLAMP2 and REF\_OFF2 as shown in Figure 7-19. - DUTY\_OFF2 configures the duty command above which the reference will change from REF\_CLAMP2 to REF\_OFF2. #### 7.3.8.5.3 Forward-Reverse Speed Profile Figure 7-20. Forward-Reverse Reference Profile Forward-Reverse control profiles can be configured by setting REF\_PROFILE\_CONFIG to 11b. Forward-Reverse profiles feature direction change through adjusting the duty command. DUTY\_C configures duty command at which the direction will be changed. The Forward-Reverse speed profile can be used to eliminate the separate signal used to control the motor direction. # Note The direction change functionality through DIR pin and DIR\_INPUT bits are disabled in forward reverse profile mode. - DUTY OFF1 configures the duty command below which the reference will be REF OFF1. - DUTY\_OFF1 and DUTY\_ON1 configures a hysteresis between reference levels REF\_CLAMP1 and REF\_OFF1 as shown in Figure 7-20. Copyright © 2023 Texas Instruments Incorporated - DUTY\_CLAMP1 configures the duty command till which reference will be constant. REF\_CLAMP1 configures this constant reference between DUTY\_OFF1 and DUTY\_CLAMP1. DUTY\_CLAMP1 can be placed anywhere between DUTY\_ON1 and DUTY\_A. - DUTY\_A configures the duty command for reference REF\_A. The reference changes linearly between DUTY\_CLAMP1 and DUTY\_A. DUTY\_A to DUTY\_E has to be in the same order as shown in Figure 7-20. - DUTY\_B configures the duty command above which MCF8316C-Q1 will be in idle/off state. The reference remains constant at REF\_A between DUTY\_A and DUTY\_B. - DUTY C configures the duty command at which the direction is changed - DUTY\_D configures the duty command above which the MCF8316C-Q1 will be in running state in the reverse direction. REF\_D configures constant reference between DUTY\_D and DUTY\_E. - DUTY\_E configures the duty command above which reference changes linearly between DUTY\_E and DUTY\_CLAMP2. - DUTY\_CLAMP2 configures the duty command above which the reference will be constant at REF\_CLAMP2. REF\_CLAMP2 configures this constant reference between DUTY\_CLAMP2 and DUTY\_OFF2. DUTY\_CLAMP2 can be placed anywhere between DUTY\_E and DUTY\_ON2. - DUTY\_OFF2 and DUTY\_ON2 configure a hysteresis between reference levels REF\_CLAMP2 and REF\_OFF2 as shown in Figure 7-20. - DUTY\_OFF2 configures the duty command above which the reference changes in the reverse direction from REF\_CLAMP2 to REF\_OFF2. # 7.3.9 Starting the Motor Under Different Initial Conditions The motor can be in one of three states when MCF8316C-Q1 begins the start-up process. The motor may be stationary, spinning in the forward direction, or spinning in the reverse direction. The MCF8316C-Q1 includes a number of features to allow for reliable motor start-up under all of these conditions. Figure 7-21 shows the motor start-up flow for each of the three initial motor states. Figure 7-21. Starting the motor under different initial conditions #### Note <sup>&</sup>quot;Forward" means "spinning in the same direction as the commanded direction", and "Reverse" means "spinning in the opposite direction as the commanded direction". ## 7.3.9.1 Case 1 – Motor is Stationary If the motor is stationary, the commutation must be initialized to be in phase with the position of the motor. The MCF8316C-Q1 provides various options to initialize the commutation logic to the motor position and reliably start the motor. - The align and double align techniques force the motor into alignment by applying a voltage across particular motor phases to force the motor to rotate in alignment with this phase. - Initial position detect (IPD) determines the position of the motor based on the deterministic inductance variation, which is often present in BLDC motors. - The slow first cycle method starts the motor by applying a low frequency cycle to align the rotor position to the applied commutation by the end of one electrical rotation. MCF8316C-Q1 also provides a configurable brake option to ensure the motor is stationary before initiating one of the above start-up methods. Device enters open loop acceleration after going through the configured start-up method. ### 7.3.9.2 Case 2 – Motor is Spinning in the Forward Direction If the motor is spinning forward (same direction as the commanded direction) with sufficient speed (BEMF), the MCF8316C-Q1 resynchronizes with the spinning motor and continues commutation by going directly to closed loop operation. If the motor speed is too low for closed loop operation, MCF8316C-Q1 enters open loop operation to accelerate the motor till it reaches sufficient speed to enter closed loop operation. By resynchronizing to the spinning motor, the user achieves the fastest possible start-up time for this initial condition. This resynchronization feature can be enabled or disabled through RESYNC\_EN. If resynchronization is disabled, the MCF8316C-Q1 can be configured to wait for the motor to coast to a stop and/or apply a brake. After the motor has stopped spinning, the motor start-up sequence proceeds as in Case 1, considering the motor is stationary. ## 7.3.9.3 Case 3 – Motor is Spinning in the Reverse Direction If the motor is spinning in the reverse direction (the opposite direction as the commanded direction), the MCF8316C-Q1 provides several methods to change the direction and drive the motor to the target speed reference in the commanded direction. The reverse drive method allows the motor to be driven so that it decelerates through zero speed. The motor achieves the shortest possible spin-up time when spinning in the reverse direction. If reverse drive is not enabled, then the MCF8316C-Q1 can be configured to wait for the motor to coast to a stop and/or apply a brake. After the motor has stopped spinning, the motor start-up sequence proceeds as in Case 1, considering the motor is stationary. #### Note Take care when using the reverse drive or brake feature to ensure that the current is limited to an acceptable level and that the supply voltage does not surge as a result of energy being returned to the power supply. # 7.3.10 Motor Start Sequence (MSS) Figure 7-22 shows the motor-start sequence implemented in the MCF8316C-Q1 device. Figure 7-22. Motor Start Sequence Figure 7-23. Brake Routine **Power-On State** This is the initial state of the Motor Start Sequence (MSS) when MCF8316C-Q1 is powered on. In this state, MCF8316C-Q1 configures the peripherals, initializes the algorithm parameters from EEPROM and prepares for driving the motor. Sleep/Standby In this state, SPEED\_REF is set to zero and MCF8316C-Q1 is either in sleep or standby mode depending on DEV\_MODE and SPEED/WAKE pin voltage. SPEED\_REF > 0 Judgement When SPEED\_REF is set to greater than zero, MCF8316C-Q1 exits the sleep/standby state and proceeds to ISD\_EN judgement. As long as SPEED\_REF is set to zero, MCF8316C-Q1 stays in sleep/standby state. Direction Change Command Judgement When a direction change command is received, MCF8316C-Q1 proceeds to DIR\_CHANGE\_MODE judgement. DIR\_CHANGE\_MODE Judgement If DIR\_CHANGE\_MODE is set to 0b, MCF8316C-Q1 initiates direction change by proceeding to ISD\_EN judgement. Instead, if DIR\_CHANGE\_MODE is set to 1b, MCF8316C-Q1 initiates direction change by proceeding to Speed > OPN\_CL\_HANDOFF\_THR judgement. ISD\_EN Judgement MCF8316C-Q1 checks to see if the initial speed detect (ISD) function is enabled (ISD\_EN = 1b). If ISD is enabled, MSS proceeds to the BEMF < STAT\_DETECT\_THR judgement. Instead, if ISD is disabled, the MSS proceeds directly to the BRAKE EN judgement. BEMF < STAT\_DETECT\_THR or BEMF < FG\_BEMF\_THR Judgement ISD determines the initial condition (speed, angle, direction of spin) of the motor (see Section 7.3.10.1). If motor is deemed to be stationary (BEMF < STAT\_DETECT\_THR or BEMF < FG\_BEMF\_THR), the MSS proceeds to BRAKE\_EN judgement. If the motor is not stationary, MSS proceeds to verify the direction of spin. Direction of spin Judgement The MSS determines whether the motor is spinning in the forward or the reverse direction. If the motor is spinning in the forward direction, the MCF8316C-Q1 proceeds to the RESYNC EN judgement. If the motor is spinning in the reverse direction, the MSS proceeds to the RVS DR EN judgement. **RESYNC\_EN Judgement** If RESYNC\_EN is set to 1b, MCF8316C-Q1 proceeds to Speed > Open to Closed Loop Handoff (Resync) judgement. If RESYNC\_EN is set to 0b, MSS proceeds to HIZ EN judgement. Speed > FW DRV RESYN THR **Judgement** If motor speed > FW DRV RESYN THR, MCF8316C-Q1 uses the speed and position information from the ISD to transition to the closed loop state (see Section 7.3.10.2) directly. If motor speed < FW DRV RESYN THR, MCF8316C-Q1 transitions to open loop state. **RVS\_DR\_EN Judgement** The MSS checks to see if the reverse drive function is enabled (RVS DR EN = 1b). If it is enabled, the MSS transitions to check speed of the motor in reverse direction. If the reverse drive function is not enabled (RVS DR EN = 0b), the MSS advances to the HIZ EN judgement. Speed > OPN CL HANDOFF THR Judgement The MSS checks to see if the reverse speed is high enough for MCF8316C-Q1 to decelerate in closed loop. Till the speed (in reverse direction) is above OL\_CL\_HANDOFF\_THR, MSS stays in closed loop deceleration. If speed is below OPN\_CL\_HANDOFF\_THR, then the MSS transitions to open loop deceleration. Reverse Closed Loop, Open **Loop Deceleration and Zero Speed Crossover** The MCF8316C-Q1 resynchronizes in the reverse direction, decelerates the motor in closed loop till motor speed falls below the handoff threshold. (see Reverse Drive). When motor speed in reverse direction is too low, the MCF8316C-Q1 switches to open-loop, decelerates the motor in open-loop, crosses zero speed, and accelerates in the forward direction in open-loop before entering closed loop operation after motor speed is sufficiently high. **HIZ\_EN Judgement** The MSS checks to determine whether the coast (Hi-Z) function is enabled (HIZ EN = 1b). If the coast function is enabled (HIZ EN = 1b), the MSS advances to the coast routine. If the coast function is disabled (HIZ EN = 0b), the MSS advances to the BRAKE EN judgement. Coast (Hi-Z) Routine The device coasts the motor by turning OFF all six MOSFETs for a certain time configured by HIZ TIME. **BRAKE EN Judgement** The MSS checks to determine whether the brake function is enabled (BRAKE EN = 1b). If the brake function is enabled (BRAKE EN = 1b), the MSS advances to the brake routine. If the brake function is disabled (BRAKE EN = 0b), the MSS advances to the motor start-up state (see Section 7.3.10.4). **Brake Routine** MCF8316C-Q1 implements either a time based brake (duration configured by BRK TIME) or a current based brake (brake applied till phase currents < BRK CURR THR for BRAKE CURRENT PERSIST) based on BRK CONFIG. Current based brake has a timeout to ensure brake state ends in case phase currents do not drop below BRK CURR THR within BRK TIME. Time based brake can be applied either using high-side or lowside MOSFETs based on BRK MODE configuration. Current based brake is applied using low-side MOSFETs only. **Closed Loop State** In this state, the MCF8316C-Q1 drives the motor with sensorless FOC based on rotor angle estimation. Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated ## 7.3.10.1 Initial Speed Detect (ISD) The ISD function is used to identify the initial condition of the motor and is enabled by setting ISD\_EN to 1b. The initial speed, position and direction is determined by sensing the three phase voltages. ISD can be disabled by setting ISD\_EN to 0b. If the function is disabled (ISD\_EN set to 0b), the MCF8316C-Q1 does not perform the initial speed detect function and proceeds to check if the brake routine (BRAKE\_EN) is enabled. ## 7.3.10.2 Motor Resynchronization The motor resynchronization function works when the ISD and resynchronization functions are both enabled and the device determines that the initial state of the motor is spinning in the forward direction (same direction as the commanded direction). The speed and position information measured during ISD are used to initialize the drive state of the MCF8316C-Q1, which can transition directly into closed loop (or open loop if motor speed is not sufficient for closed loop operation) state without needing to stop the motor. In the MCF8316C-Q1, motor resynchronization can be enabled/disabled through RESYNC\_EN bit. If motor resynchronization is disabled, the device proceeds to check if the motor coast (Hi-Z) routine is enabled. #### 7.3.10.3 Reverse Drive The MCF8316C-Q1 uses the reverse drive function to change the direction of the motor rotation when ISD\_EN and RVS\_DR\_EN are both set to 1b and the ISD determines the motor spin direction to be opposite to that of the commanded direction. Reverse drive includes synchronizing with the motor speed in the reverse direction, reverse decelerating the motor through zero speed, changing direction, and accelerating in open loop in forward (or commanded) direction until the device transitions into closed loop in forward direction (see Figure 7-24). MCF8316C-Q1 provides the option of using the forward direction parameters or a separate set of reverse drive parameters by configuring REV\_DRV\_CONFIG. Figure 7-24. Reverse Drive Function ### 7.3.10.3.1 Reverse Drive Tuning MCF8316C-Q1 provides the option of tuning the open to closed loop handoff threshold, open loop acceleration (and deceleration) rates and open loop current limit in reverse drive to values different to those used in forward drive operation; the reverse drive specific parameters can be used by setting REV\_DRV\_CONFIG to 1b. If REV\_DRV\_CONFIG is set to 0b, MCF8316C-Q1 uses the equivalent parameters configured for forward drive operation during the reverse drive operation too. The speed at which motor would enter the open loop in reverse direction can be configured using REV\_DRV\_HANDOFF\_THR. For a smooth transition without jerks or loss of synchronism, user can configure an appropriate current limit when the motor is spinning in open loop during speed reversal using REV DRV OPEN LOOP CURRENT. The open loop acceleration rates for the forward direction during speed reversal are defined using REV\_DRV\_OPEN\_LOOP\_ACCEL\_A1 and REV\_DRV\_OPEN\_LOOP\_ACCEL\_A2. The reverse drive open loop deceleration rate, when the motor is decelerating in the opposite direction to zero speed, can be configured as a percentage of reverse drive open loop acceleration using REV DRV OPEN LOOP DEC. ### 7.3.10.4 Motor Start-up There are different options available for motor start-up from a stationary position and these options can be configured by MTR STARTUP. In align and double align mode, the motor is aligned to a known position by injecting a DC current. In IPD mode, the rotor position is estimated by applying 6 different high-frequency pulses. In slow first cycle mode, the motor is started by applying a low frequency cycle. #### 7.3.10.4.1 Align Align is enabled by configuring MTR STARTUP to 00b. The MCF8316C-Q1 aligns the motor by injecting a DC current through a particular phase pattern for a certain time configured by ALIGN\_TIME. The phase pattern during align is generated based on ALIGN ANGLE. In the MCF8316C-Q1, the current limit during align is configured through ALIGN OR SLOW CURRENT ILIMIT. A fast change in the phase current may result in a sudden change in the driving torque and this could result in acoustic noise. To avoid this, the MCF8316C-Q1 ramps up the current from 0 to the current limit at a configurable ramp rate set by ALIGN\_SLOW\_RAMP\_RATE. At the end of align routine, the motor will be aligned at the known position. ### 7.3.10.4.2 Double Align Double align is enabled by configuring MTR STARTUP to 01b. Single align is not reliable when the initial position of the rotor is 180° out of phase with the applied phase pattern. In this case, it is possible to have start-up failures using single align. In order to improve the reliability of align based start-up, the MCF8316C-Q1 provides the option of double align start-up. In double align start-up, MCF8316C-Q1 uses a phase pattern for the second align that is 90° ahead of the first align phase pattern. In double align, relevant parameters like align time, current limit, ramp rate are the same as in the case of single align - two different phase patterns are applied in succession with the same parameters to ensure that the motor will be aligned to a known position irrespective of initial rotor position. ## 7.3.10.4.3 Initial Position Detection (IPD) Initial Position Detection (IPD) can be enabled by configuring MTR STARTUP to 10b. In IPD, inductive sense method is used to determine the initial position of the motor using the spatial variation in the motor inductance. Align or double align may result in the motor spinning in the reverse direction before starting open loop acceleration. IPD can be used in such applications where reverse rotation of the motor is unacceptable. IPD does not wait for the motor to align with the commutation and therefore can allow for a faster motor start-up sequence. IPD works well when the inductance of the motor varies as a function of position. IPD works by pulsing current in to the motor and hence can generate acoustics which must be taken into account when determining the best start-up method for a particular application. #### 7.3.10.4.3.1 IPD Operation IPD operates by sequentially applying six different phase patterns according to the following sequence: BC-> CB-> AB-> BA-> CA-> AC (see Figure 7-25). When the current reaches the threshold configured by IPD CURR THR, the MCF8316C-Q1 stops driving the particular phase pattern and measures the time taken to reach the current threshold from when the particular phase pattern was applied. Thus, the time taken to reach IPD CURR THR is measured for all six phase patterns - this time varies as a function of the inductance in the motor windings. The state with the shortest time represents the state with the minimum inductance. The minimum inductance is because of the alignment of the north pole of the motor with this particular driving state. Figure 7-25. IPD Function #### 7.3.10.4.3.2 IPD Release Mode Two modes are available for configuring the way the MCF8316C-Q1 stops driving the motor when the current threshold is reached. The recirculate (or brake) mode is selected if IPD\_RLS\_MODE = 0b. In this configuration, the low-side (LSC) MOSFET remains ON to allow the current to recirculate between the MOSFET (LSC) and body diode (LSA) (see Figure 7-26). Hi-Z mode is selected if IPD\_RLS\_MODE = 1b. In Hi-Z mode, both the high-side (HSA) and low-side (LSC) MOSFETs are turned OFF and the current recirculates through the body diodes back to the power supply (see Figure 7-27). In the Hi-Z mode, the phase current has a faster settle-down time, but that can result in a voltage increase on $V_M$ . The user must manage this with an appropriate selection of either a clamp circuit or by providing sufficient capacitance between $V_M$ and PGND to absorb the energy. If the voltage surge cannot be contained or if it is unacceptable for the application, recirculate mode must be used. When using the recirculate mode, select the IPD\_CLK\_FREQ appropriately to give the current in the motor windings enough time to decay to 0-A before the next IPD phase pattern is applied. Figure 7-26. IPD Release Mode - Brake (0b) Figure 7-27. IPD Release Mode - Tristate (1b) #### 7.3.10.4.3.3 IPD Advance Angle After the initial position is detected, the MCF8316C-Q1 begins driving the motor in open loop at an angle specified by IPD ADV ANGLE. Advancing the drive angle anywhere from 0° to 180° results in positive torque. Advancing the drive angle by 90° results in maximum initial torque. Applying maximum initial torque could result in uneven acceleration to the rotor. Select the IPD ADV ANGLE to allow for smooth acceleration in the application (see Figure 7-28). Figure 7-28. IPD Advance Angle ## 7.3.10.4.4 Slow First Cycle Startup Slow First Cycle start-up is enabled by configuring MTR\_STARTUP to 11b. In slow first cycle start-up, the MCF8316C-Q1 starts motor commutation at a frequency defined by SLOW FIRST CYCLE FREQ. The frequency configured is used only for first cycle, and then the motor commutation follows acceleration profile configured by open loop acceleration coefficients A1 and A2. The slow first cycle frequency has to be configured to be slow enough to allow motor to synchronize with the commutation sequence. This mode is useful when fast startup is desired as it significantly reduces the align time. #### 7.3.10.4.5 Open Loop Upon completing the motor position initialization with either align, double align, IPD or slow first cycle, the MCF8316C-Q1 begins to accelerate the motor in open loop. In MCF8316C-Q1, the current limit in open loop is set by ILIMIT or OL\_ILIMIT based on the configuration of OL\_ILIMIT\_CONFIG and the speed is increased using this current limit. In open loop, the control PI loops for I<sub>a</sub> and I<sub>d</sub> actively control the currents. The angle during open loop is provided from the ramp generator as shown in Figure 7-29. ALIGN\_SLOW\_ RAMP RATE LILIMN CONFIG = 1b ILIMIT OL\_ILIMIT QL\_ILIMIT\_CONFIG = 0b ACTIVE BRAKE BUS CURR ENT SLEW RATE CURRENT\_REF CL ACC/ SW1 SPEED REF SPEED REF Torque (I<sub>n</sub>) P Inverse Controller Inverse $I_{d\_ref} = 0$ Clarke/ Park Flux (I<sub>d</sub>) PI SVM Controller Open Loop Ramp θ SW<sub>2</sub> Generator (Coeff A1 and A2) $I_b$ Park Clarke Back-EMF Figure 7-29. Open Loop The function of the open-loop operation is to drive the motor to a speed at which the motor generates sufficient BEMF to allow the back-EMF observer to accurately detect the position of the rotor. The motor is accelerated in open loop and speed at any given time is determined by Equation 6. In MCF8316C-Q1, open loop acceleration coefficients, A1 and A2 are configured through OL\_ACC\_A1 and OL\_ACC\_A2 respectively. Speed(t) = A1 \* t + 0.5 \* A2 \* $$t^2$$ (6) ### 7.3.10.4.6 Transition from Open to Closed Loop Once the motor has reached a sufficient speed for the back-EMF observer to estimate the angle and speed of the motor, the MCF8316C-Q1 transitions into closed loop state. This handoff speed is automatically determined based on the measured back-EMF and motor speed. Users also have an option to manually set the handoff speed by configuring OPN\_CL\_HANDOFF\_THR and setting AUTO\_HANDOFF\_EN to 0b. In order to have smooth transition and avoid speed transients, the theta error ( $\Theta_{gen}$ - $\Theta_{est}$ ) is decreased linearly after transition. The ramp rate of theta error reduction can be configured using THETA\_ERROR\_RAMP\_RATE. If the current limit set during the open loop is high and if it is not reduced before transition to closed loop, the motor speed may momentarily rise to higher values than SPEED\_REF after transition into closed loop. In order to avoid such speed variations, configure the IQ\_RAMP\_EN to 1b, so that $i_{q_ref}$ decreases prior to transition into closed loop. However if the final speed reference (SPEED\_REF) is more than two times the open loop to closed loop hand off speed (OPN\_CL\_HANDOFF\_THR), then $i_{q_ref}$ is not decreased independent of the IQ\_RAMP\_EN setting, to enable faster motor acceleration. After hand off to closed loop at a sufficient speed, there could be still some theta error, as the estimators may not be fully aligned. A slow acceleration can be used after the open loop to closed loop transition, ensuring that the theta error reduces to zero. The slow acceleration can be configured using CL\_SLOW\_ACC. Figure 7-30 shows the control sequence in open to closed loop transition. The current $i_{q\_ref}$ reduces to a lower value in current decay region, if $IQ\_RAMP\_EN$ is set to 1b. If $IQ\_RAMP\_EN$ is set to 0b, then the current decay region will not be present in the transition sequence. I. Open Loop Acceleration, II. Current Decay, III. Closed loop slow acceleration IV. Closed loop acceleration, V. Closed loop steady state Figure 7-30. Control Sequence in Open to Closed Loop Transition Figure 7-31. Open to Closed Loop Transition Control Block Diagram # 7.3.11 Closed Loop Operation The MCF8316C-Q1 drives the motor using Field Oriented Control (FOC) as shown in Figure 7-32. In closed loop operation, the motor angle ( $\Theta_{est}$ ) and speed (Speed\_meas) are estimated using the back-EMF observer. The speed and current regulation are achieved using PI control loop. In order to achieve maximum efficiency, the direct axis current is set to zero ( $I_{d\_ref} = 0$ ), which will ensure that stator and rotor field are orthogonal ( $90^{\circ}$ out of phase) to each other. Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated Figure 7-32. Closed Loop FOC Control ## 7.3.11.1 Closed Loop Acceleration/Deceleration Slew Rate During closed loop acceleration/deceleration, MCF8316C-Q1 provides the option of configuring the slew rate of the speed reference input to the speed PI controller (SPEED\_REF\_SLEW in Figure 7-32). This allows for a linear change in speed reference input (SPEED REF SLEW) even when there is a step change in speed reference (SPEED\_REF from Analog, PWM, Frequency or I<sup>2</sup>C) as seen in Figure 7-33. This slew rate can be configured so as to prevent sudden changes in the torque applied to the motor which could result in acoustic noise. The closed loop acceleration/deceleration slew rate parameter, CL\_ACC/CL\_DEC, sets the slew rate of SPEED REF SLEW during acceleration and deceleration (when AVS is not active) respectively. Figure 7-33. Closed Loop Acceleration/Deceleration Slew Rate ## 7.3.11.2 Speed PI Control The integrated speed control loop helps maintain a constant speed over varying operating conditions. The $K_p$ and $K_i$ coefficients are configured through SPD\_LOOP\_KP and SPD\_LOOP\_KI. The output of the speed loop is used to generate the current reference for torque control ( $I_{q\_ref}$ ). The output of the speed loop is limited to implement a current limit. The current limit is set by configuring ILIMIT. When output of the speed loop saturates, the integrator is disabled to prevent integral wind-up. SPEED\_REF\_SLEW is derived from the duty command input, speed profiles and closed loop acceleration/deceleration rates configured by the user and SPEED\_EST is the estimated speed from the back-EMF observer. Figure 7-34. Speed PI Control #### 7.3.11.3 Current PI Control The MCF8316C-Q1 has two PI controllers, one each for $I_d$ and $I_q$ to control flux and torque separately. $K_p$ and $K_i$ coefficients are the same for both PI controllers and are configured through CURR\_LOOP\_KP and CURR\_LOOP\_KI. The outputs of the current control loops are used to generate voltage signals $V_d$ and $V_g$ to be Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated applied to the motor. The outputs of the current loops are clamped to supply voltage $V_M$ . $I_d$ current PI loop is executed first and output of $I_d$ current PI loop $V_d$ is checked for saturation. When the output of the current loop saturates, the integration is disabled to prevent integral wind-up. Figure 7-35. I<sub>d</sub> Current PI Control Figure 7-36. I<sub>a</sub> Current PI Control ### 7.3.11.4 Torque Mode MCF8316C-Q1 provides the option of disabling the speed loop by setting SPEED\_LOOP\_DIS to 1b. In this mode, the q-axis current reference, $I_{q\_ref}$ is directly set by the product of duty cycle input, DUTY\_CMD (from PWM or $I^2C$ ) and ILIMIT instead of the speed PI loop output as shown in Figure 7-32. Thus, this mode enables torque control through setting $I_{q\_ref}$ directly and hence can be used for torque mode operation. #### 7.3.11.5 Overmodulation MCF8316C-Q1 provides an overmodulation option to operate the motor at a higher speed at the same VM voltage by increasing the applied fundamental phase voltage by suitably modifying the applied PWM pattern - the higher fundamental phase voltage is accompanied by an increase in higher order harmonics. This feature can be enabled by setting OVERMODULATION ENABLE to 1b. ### 7.3.12 Motor Parameters The MCF8316C-Q1 uses the motor resistance, motor inductance and motor back-EMF constant to estimate motor position when operating in closed loop. The MCF8316C-Q1 has the capability of measuring these motor parameters in the offline state (see Motor Parameter Extraction Tool (MPET)). Offline measurement of parameters, when enabled, takes place before normal motor operation. The user can also disable the offline measurement and configure motor parameters through EEPROM. This feature of offline motor parameter measurement is useful to account for motor to motor variation during manufacturing. ### 7.3.12.1 Motor Resistance For a wye-connected motor, the motor phase resistance refers to the resistance from the phase output to the center tap, R<sub>PH</sub> (denoted as R<sub>PH</sub> in Figure 7-37). For a delta-connected motor, the motor phase resistance refers to the equivalent phase to center tap in the wye configuration in Figure 7-37. Figure 7-37. Motor Resistance For both the delta-connected and the wye-connected motor, the easy way to get the equivalent $R_{\text{PH}}$ is to measure the resistance between two phase terminals ( $R_{PH}$ PH), and then divide this value by two, $R_{PH}$ = $\frac{1}{2}$ R<sub>PH PH</sub>. In wye-connected motor, if user has access to center tap (CT), R<sub>PH</sub> can also be measured between center tap (CT) and phase terminal. Configure the motor resistance (R<sub>PH</sub>) to a nearest value from Table 7-2. Table 7-2. Motor Resistance Look-Up Table | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | |--------------------|---------------------------------------------------------------|--------------------|---------------------|--------------------|---------------------|--------------------|---------------------| | 0x00 | Self Measurement (see Motor Parameter Extraction Tool (MPET)) | 0x40 | 0.145 | 0x80 | 0.465 | 0xC0 | 2.1 | | 0x01 | 0.006 | 0x41 | 0.150 | 0x81 | 0.470 | 0xC1 | 2.2 | | 0x02 | 0.007 | 0x42 | 0.155 | 0x82 | 0.475 | 0xC2 | 2.3 | | 0x03 | 0.008 | 0x43 | 0.160 | 0x83 | 0.480 | 0xC3 | 2.4 | | 0x04 | 0.009 | 0x44 | 0.165 | 0x84 | 0.485 | 0xC4 | 2.5 | | 0x05 | 0.010 | 0x45 | 0.170 | 0x85 | 0.490 | 0xC5 | 2.6 | | 0x06 | 0.011 | 0x46 | 0.175 | 0x86 | 0.495 | 0xC6 | 2.7 | | 0x07 | 0.012 | 0x47 | 0.180 | 0x87 | 0.50 | 0xC7 | 2.8 | | 0x08 | 0.013 | 0x48 | 0.185 | 0x88 | 0.51 | 0xC8 | 2.9 | | 0x09 | 0.014 | 0x49 | 0.190 | 0x89 | 0.52 | 0xC9 | 3.0 | | 0x0A | 0.015 | 0x4A | 0.195 | 0x8A | 0.53 | 0xCA | 3.2 | | 0x0B | 0.016 | 0x4B | 0.200 | 0x8B | 0.54 | 0xCB | 3.4 | | 0x0C | 0.017 | 0x4C | 0.205 | 0x8C | 0.55 | 0xCC | 3.6 | | 0x0D | 0.018 | 0x4D | 0.210 | 0x8D | 0.56 | 0xCD | 3.8 | | 0x0E | 0.019 | 0x4E | 0.215 | 0x8E | 0.57 | 0xCE | 4.0 | | 0x0F | 0.020 | 0x4F | 0.220 | 0x8F | 0.58 | 0xCF | 4.2 | | 0x10 | 0.022 | 0x50 | 0.225 | 0x90 | 0.59 | 0xD0 | 4.4 | | 0x11 | 0.024 | 0x51 | 0.230 | 0x91 | 0.60 | 0xD1 | 4.6 | | 0x12 | 0.026 | 0x52 | 0.235 | 0x92 | 0.61 | 0xD2 | 4.8 | **Table 7-2. Motor Resistance Look-Up Table (continued)** | | | Table 7-2. Woto | 110010101100 | | (oonanaoa) | | | |--------------------|---------------------|--------------------|---------------------|--------------------|---------------------|--------------------|---------------------| | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | | 0x13 | 0.028 | 0x53 | 0.240 | 0x93 | 0.62 | 0xD3 | 5.0 | | 0x14 | 0.030 | 0x54 | 0.245 | 0x94 | 0.63 | 0xD4 | 5.2 | | 0x15 | 0.032 | 0x55 | 0.250 | 0x95 | 0.64 | 0xD5 | 5.4 | | 0x16 | 0.034 | 0x56 | 0.255 | 0x96 | 0.65 | 0xD6 | 5.6 | | 0x17 | 0.036 | 0x57 | 0.260 | 0x97 | 0.66 | 0xD7 | 5.8 | | 0x18 | 0.038 | 0x58 | 0.265 | 0x98 | 0.67 | 0xD8 | 6.0 | | 0x19 | 0.040 | 0x59 | 0.270 | 0x99 | 0.68 | 0xD9 | 6.2 | | 0x1A | 0.042 | 0x5A | 0.275 | 0x9A | 0.69 | 0xDA | 6.4 | | 0x1B | 0.044 | 0x5B | 0.280 | 0x9B | 0.70 | 0xDB | 6.6 | | 0x1C | 0.046 | 0x5C | 0.285 | 0x9C | 0.72 | 0xDC | 6.8 | | 0x1D | 0.048 | 0x5D | 0.290 | 0x9D | 0.74 | 0xDD | 7.0 | | 0x1E | 0.050 | 0x5E | 0.295 | 0x9E | 0.76 | 0xDE | 7.2 | | 0x1F | 0.052 | 0x5F | 0.300 | 0x9F | 0.78 | 0xDF | 7.4 | | 0x20 | 0.054 | 0x60 | 0.305 | 0xA0 | 0.80 | 0xE0 | 7.6 | | 0x21 | 0.056 | 0x61 | 0.310 | 0xA1 | 0.82 | 0xE1 | 7.8 | | 0x22 | 0.058 | 0x62 | 0.315 | 0xA2 | 0.84 | 0xE2 | 8.0 | | 0x23 | 0.060 | 0x63 | 0.320 | 0xA3 | 0.86 | 0xE3 | 8.2 | | 0x24 | 0.062 | 0x64 | 0.325 | 0xA4 | 0.88 | 0xE4 | 8.4 | | 0x25 | 0.064 | 0x65 | 0.330 | 0xA5 | 0.90 | 0xE5 | 8.6 | | 0x26 | 0.066 | 0x66 | 0.335 | 0xA6 | 0.92 | 0xE6 | 8.8 | | 0x27 | 0.068 | 0x67 | 0.340 | 0xA7 | 0.94 | 0xE7 | 9 | | 0x28 | 0.070 | 0x68 | 0.345 | 0xA8 | 0.96 | 0xE8 | 9.2 | | 0x29 | 0.072 | 0x69 | 0.350 | 0xA9 | 0.98 | 0xE9 | 9.4 | | 0x2A | 0.074 | 0x6A | 0.355 | 0xAA | 1.00 | 0xEA | 9.6 | | 0x2B | 0.076 | 0x6B | 0.360 | 0xAB | 1.05 | 0xEB | 9.8 | | 0x2C | 0.078 | 0x6C | 0.365 | 0xAC | 1.10 | 0xEC | 10.0 | | 0x2D | 0.080 | 0x6D | 0.370 | 0xAD | 1.15 | 0xED | 10.5 | | 0x2E | 0.082 | 0x6E | 0.375 | 0xAE | 1.20 | 0xEE | 11.0 | | 0x2F | 0.084 | 0x6F | 0.380 | 0xAF | 1.25 | 0xEF | 11.5 | | 0x30 | 0.086 | 0x70 | 0.385 | 0xB0 | 1.30 | 0xF0 | 12.0 | | 0x31 | 0.088 | 0x71 | 0.390 | 0xB1 | 1.35 | 0xF1 | 12.5 | | 0x32 | 0.090 | 0x72 | 0.395 | 0xB2 | 1.40 | 0xF2 | 13.0 | | 0x33 | 0.092 | 0x73 | 0.400 | 0xB3 | 1.45 | 0xF3 | 13.5 | | 0x34 | 0.094 | 0x74 | 0.405 | 0xB4 | 1.50 | 0xF4 | 14.0 | | 0x35 | 0.096 | 0x75 | 0.410 | 0xB5 | 1.55 | 0xF5 | 14.5 | | 0x36 | 0.098 | 0x76 | 0.415 | 0xB6 | 1.60 | 0xF6 | 15.0 | | 0x37 | 0.100 | 0x77 | 0.420 | 0xB7 | 1.65 | 0xF7 | 15.5 | | 0x38 | 0.105 | 0x78 | 0.425 | 0xB8 | 1.70 | 0xF8 | 16.0 | | 0x39 | 0.110 | 0x79 | 0.430 | 0xB9 | 1.75 | 0xF9 | 16.5 | | 0x3A | 0.115 | 0x7A | 0.435 | 0xBA | 1.80 | 0xFA | 17.0 | | 0x3B | 0.120 | 0x7B | 0.440 | 0xBB | 1.85 | 0xFB | 17.5 | | 0x3C | 0.125 | 0x7C | 0.445 | 0xBC | 1.90 | 0xFC | 18.0 | | 0x3D | 0.130 | 0x7D | 0.450 | 0xBD | 1.95 | 0xFD | 18.5 | | 0x3E | 0.135 | 0x7E | 0.455 | 0xBE | 2.00 | 0xFE | 19.0 | | | | | | | | | | Table 7-2. Motor Resistance Look-Up Table (continued) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | MOTOR_RES<br>(HEX) | R <sub>PH</sub> (Ω) | |--------------------|---------------------|--------------------|---------------------|--------------------|---------------------|--------------------|---------------------| | 0x3F | 0.140 | 0x7F | 0.460 | 0xBF | 2.05 | 0xFF | 20.0 | ### 7.3.12.2 Motor Inductance For a wye-connected motor, the motor phase inductance refers to the inductance from the phase output to the center tap, $L_{PH}$ (denoted as $L_{PH}$ in Figure 7-38). For a delta-connected motor, the motor phase inductance refers to the equivalent phase to center tap in the wye configuration in Figure 7-38. Figure 7-38. Motor Inductance For both the delta-connected motor and the wye-connected motor, the easy way to get the equivalent $L_{PH}$ is to measure the inductance between two phase terminals ( $L_{PH\_PH}$ ), and then divide this value by two, $L_{PH}$ = ½ $L_{PH\_PH}$ . In wye-connected motor, if user has access to center tap (CT), $L_{PH}$ can also be measured between center tap (CT) and phase terminal. Configure the motor inductance (L<sub>PH</sub>) to a nearest value from Table 7-3. Table 7-3. Motor Inductance Look-Up Table | | | | . Motor induc | tarres Essit Sp | | | | |--------------------|------------------------------------------------------------------------------|--------------------|----------------------|--------------------|----------------------|--------------------|----------------------| | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | | 0x00 | Self<br>Measurement<br>(see Motor<br>Parameter<br>Extraction Tool<br>(MPET)) | 0x40 | 0.145 | 0x80 | 0.465 | 0xC0 | 2.1 | | 0x01 | 0.006 | 0x41 | 0.150 | 0x81 | 0.470 | 0xC1 | 2.2 | | 0x02 | 0.007 | 0x42 | 0.155 | 0x82 | 0.475 | 0xC2 | 2.3 | | 0x03 | 0.008 | 0x43 | 0.160 | 0x83 | 0.480 | 0xC3 | 2.4 | | 0x04 | 0.009 | 0x44 | 0.165 | 0x84 | 0.485 | 0xC4 | 2.5 | | 0x05 | 0.010 | 0x45 | 0.170 | 0x85 | 0.490 | 0xC5 | 2.6 | | 0x06 | 0.011 | 0x46 | 0.175 | 0x86 | 0.495 | 0xC6 | 2.7 | | 0x07 | 0.012 | 0x47 | 0.180 | 0x87 | 0.50 | 0xC7 | 2.8 | | 0x08 | 0.013 | 0x48 | 0.185 | 0x88 | 0.51 | 0xC8 | 2.9 | | 0x09 | 0.014 | 0x49 | 0.190 | 0x89 | 0.52 | 0xC9 | 3.0 | | 0x0A | 0.015 | 0x4A | 0.195 | 0x8A | 0.53 | 0xCA | 3.2 | | 0x0B | 0.016 | 0x4B | 0.200 | 0x8B | 0.54 | 0xCB | 3.4 | | 0x0C | 0.017 | 0x4C | 0.205 | 0x8C | 0.55 | 0xCC | 3.6 | | 0x0D | 0.018 | 0x4D | 0.210 | 0x8D | 0.56 | 0xCD | 3.8 | | 0x0E | 0.019 | 0x4E | 0.215 | 0x8E | 0.57 | 0xCE | 4.0 | | 0x0F | 0.020 | 0x4F | 0.220 | 0x8F | 0.58 | 0xCF | 4.2 | | 0x10 | 0.022 | 0x50 | 0.225 | 0x90 | 0.59 | 0xD0 | 4.4 | | 0x11 | 0.024 | 0x51 | 0.230 | 0x91 | 0.60 | 0xD1 | 4.6 | | 0x12 | 0.026 | 0x52 | 0.235 | 0x92 | 0.61 | 0xD2 | 4.8 | | 0x13 | 0.028 | 0x53 | 0.240 | 0x93 | 0.62 | 0xD3 | 5.0 | | 0x14 | 0.030 | 0x54 | 0.245 | 0x94 | 0.63 | 0xD4 | 5.2 | | 0x15 | 0.032 | 0x55 | 0.250 | 0x95 | 0.64 | 0xD5 | 5.4 | | 0x16 | 0.034 | 0x56 | 0.255 | 0x96 | 0.65 | 0xD6 | 5.6 | | 0x17 | 0.036 | 0x57 | 0.260 | 0x97 | 0.66 | 0xD7 | 5.8 | | 0x18 | 0.038 | 0x58 | 0.265 | 0x98 | 0.67 | 0xD8 | 6.0 | | 0x19 | 0.040 | 0x59 | 0.270 | 0x99 | 0.68 | 0xD9 | 6.2 | | 0x1A | 0.042 | 0x5A | 0.275 | 0x9A | 0.69 | 0xDA | 6.4 | | 0x1B | 0.044 | 0x5B | 0.280 | 0x9B | 0.70 | 0xDB | 6.6 | | 0x1C | 0.046 | 0x5C | 0.285 | 0x9C | 0.72 | 0xDC | 6.8 | | 0x1D | 0.048 | 0x5D | 0.290 | 0x9D | 0.74 | 0xDD | 7.0 | | 0x1E | 0.050 | 0x5E | 0.295 | 0x9E | 0.76 | 0xDE | 7.2 | | 0x1F | 0.052 | 0x5F | 0.300 | 0x9F | 0.78 | 0xDF | 7.4 | | 0x20 | 0.054 | 0x60 | 0.305 | 0xA0 | 0.80 | 0xE0 | 7.6 | | 0x21 | 0.056 | 0x61 | 0.310 | 0xA1 | 0.82 | 0xE1 | 7.8 | | 0x22 | 0.058 | 0x62 | 0.315 | 0xA2 | 0.84 | 0xE2 | 8.0 | | 0x23 | 0.060 | 0x63 | 0.320 | 0xA3 | 0.86 | 0xE3 | 8.2 | | 0x24 | 0.062 | 0x64 | 0.325 | 0xA4 | 0.88 | 0xE4 | 8.4 | | 0x25 | 0.064 | 0x65 | 0.330 | 0xA5 | 0.90 | 0xE5 | 8.6 | | 0x26 | 0.066 | 0x66 | 0.335 | 0xA6 | 0.92 | 0xE6 | 8.8 | | 0x27 | 0.068 | 0x67 | 0.340 | 0xA7 | 0.94 | 0xE7 | 9 | | 0x28 | 0.070 | 0x68 | 0.345 | 0xA8 | 0.96 | 0xE8 | 9.2 | Table 7-3. Motor Inductance Look-Up Table (continued) | | | | | LOOK OP TUDIC | (00:::::::::::::::::::::::::::::::::::: | | | |--------------------|----------------------|--------------------|----------------------|--------------------|-----------------------------------------|-----------------|----------------------| | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND<br>(HEX) | L <sub>PH</sub> (mH) | MOTOR_IND (HEX) | L <sub>PH</sub> (mH) | | 0x29 | 0.072 | 0x69 | 0.350 | 0xA9 | 0.98 | 0xE9 | 9.4 | | 0x2A | 0.074 | 0x6A | 0.355 | 0xAA | 1.00 | 0xEA | 9.6 | | 0x2B | 0.076 | 0x6B | 0.360 | 0xAB | 1.05 | 0xEB | 9.8 | | 0x2C | 0.078 | 0x6C | 0.365 | 0xAC | 1.10 | 0xEC | 10.0 | | 0x2D | 0.080 | 0x6D | 0.370 | 0xAD | 1.15 | 0xED | 10.5 | | 0x2E | 0.082 | 0x6E | 0.375 | 0xAE | 1.20 | 0xEE | 11.0 | | 0x2F | 0.084 | 0x6F | 0.380 | 0xAF | 1.25 | 0xEF | 11.5 | | 0x30 | 0.086 | 0x70 | 0.385 | 0xB0 | 1.30 | 0xF0 | 12.0 | | 0x31 | 0.088 | 0x71 | 0.390 | 0xB1 | 1.35 | 0xF1 | 12.5 | | 0x32 | 0.090 | 0x72 | 0.395 | 0xB2 | 1.40 | 0xF2 | 13.0 | | 0x33 | 0.092 | 0x73 | 0.400 | 0xB3 | 1.45 | 0xF3 | 13.5 | | 0x34 | 0.094 | 0x74 | 0.405 | 0xB4 | 1.50 | 0xF4 | 14.0 | | 0x35 | 0.096 | 0x75 | 0.410 | 0xB5 | 1.55 | 0xF5 | 14.5 | | 0x36 | 0.098 | 0x76 | 0.415 | 0xB6 | 1.60 | 0xF6 | 15.0 | | 0x37 | 0.100 | 0x77 | 0.420 | 0xB7 | 1.65 | 0xF7 | 15.5 | | 0x38 | 0.105 | 0x78 | 0.425 | 0xB8 | 1.70 | 0xF8 | 16.0 | | 0x39 | 0.110 | 0x79 | 0.430 | 0xB9 | 1.75 | 0xF9 | 16.5 | | 0x3A | 0.115 | 0x7A | 0.435 | 0xBA | 1.80 | 0xFA | 17.0 | | 0x3B | 0.120 | 0x7B | 0.440 | 0xBB | 1.85 | 0xFB | 17.5 | | 0x3C | 0.125 | 0x7C | 0.445 | 0xBC | 1.90 | 0xFC | 18.0 | | 0x3D | 0.130 | 0x7D | 0.450 | 0xBD | 1.95 | 0xFD | 18.5 | | 0x3E | 0.135 | 0x7E | 0.455 | 0xBE | 2.00 | 0xFE | 19.0 | | 0x3F | 0.140 | 0x7F | 0.460 | 0xBF | 2.05 | 0xFF | 20.0 | | | | | | | | | | ## 7.3.12.3 Motor Back-EMF constant The back-EMF constant describes the motor phase-to-neutral back-EMF voltage as a function of the motor speed. For a wye-connected motor, the motor BEMF constant refers to the BEMF as a function of time from the phase output to the center tap, $Kt_{PH_N}$ (denoted as $Kt_{PH_N}$ in Figure 7-39). For a delta-connected motor, the motor BEMF constant refers to the equivalent phase to center tap in the wye configuration in Figure 7-39. Figure 7-39. Motor back-EMF constant For both the delta-connected motor and the wye-connected motor, the easy way to get the equivalent $\mathsf{Kt}_{\mathsf{PH}_N}$ is to measure the peak value of BEMF on scope for one electrical cycle between two phase terminals $(\mathsf{E}_{\mathsf{PH}})$ , and then multiply by time duration of one electrical cycle and in order to convert from phase-to-phase to phase-to-neutral divide by $\mathsf{sqrt}(3)$ as shown in Equation 7 . $$Kt_{PH}N = \frac{1}{\sqrt{3}} \times E_{PH} \times t_E \tag{7}$$ Configure the motor BEMF constant ( $Kt_{PH\_N}$ ) to a nearest value from Table 7-4. Table 7-4. Motor BEMF constant Look-Up Table | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEM<br>F_CONST<br>(HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | |----------------------------|---------------------------------------------------------------|----------------------------|-------------------------------|----------------------------|-------------------------------|-------------------------------|-------------------------------| | 0x00 | Self Measurement (see Motor Parameter Extraction Tool (MPET)) | 0x40 | 14.5 | 0x80 | 46.5 | 0xC0 | 210 | | 0x01 | 0.6 | 0x41 | 15.0 | 0x81 | 47.0 | 0xC1 | 220 | | 0x02 | 0.7 | 0x42 | 15.5 | 0x82 | 47.5 | 0xC2 | 230 | | 0x03 | 0.8 | 0x43 | 16.0 | 0x83 | 48.0 | 0xC3 | 240 | | 0x04 | 0.9 | 0x44 | 16.5 | 0x84 | 48.5 | 0xC4 | 250 | | 0x05 | 1.0 | 0x45 | 17.0 | 0x85 | 49.0 | 0xC5 | 260 | | 0x06 | 1.1 | 0x46 | 17.5 | 0x86 | 49.5 | 0xC6 | 270 | | 0x07 | 1.2 | 0x47 | 18.0 | 0x87 | 50.0 | 0xC7 | 280 | | 0x08 | 1.3 | 0x48 | 18.5 | 0x88 | 51 | 0xC8 | 290 | | 0x09 | 1.4 | 0x49 | 19.0 | 0x89 | 52 | 0xC9 | 300 | | 0x0A | 1.5 | 0x4A | 19.5 | 0x8A | 53 | 0xCA | 320 | | 0x0B | 1.6 | 0x4B | 20.0 | 0x8B | 54 | 0xCB | 340 | | 0x0C | 1.7 | 0x4C | 20.5 | 0x8C | 55 | 0xCC | 360 | | 0x0D | 1.8 | 0x4D | 21.0 | 0x8D | 56 | 0xCD | 380 | | 0x0E | 1.9 | 0x4E | 21.5 | 0x8E | 57 | 0xCE | 400 | | 0x0F | 2.0 | 0x4F | 22.0 | 0x8F | 58 | 0xCF | 420 | **Table 7-4. Motor BEMF constant Look-Up Table (continued)** | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEMF_<br>CONST (HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEM<br>F_CONST<br>(HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | |----------------------------|-------------------------------|----------------------------|-------------------------------|----------------------------|-------------------------------|-------------------------------|-------------------------------| | 0x10 | 2.2 | 0x50 | 22.5 | 0x90 | 59 | 0xD0 | 440 | | 0x11 | 2.4 | 0x51 | 23.0 | 0x91 | 60 | 0xD1 | 460 | | 0x12 | 2.6 | 0x52 | 23.5 | 0x92 | 61 | 0xD2 | 480 | | 0x13 | 2.8 | 0x53 | 24.0 | 0x93 | 62 | 0xD3 | 500 | | 0x14 | 3.0 | 0x54 | 24.5 | 0x94 | 63 | 0xD4 | 520 | | 0x15 | 3.2 | 0x55 | 25.0 | 0x95 | 64 | 0xD5 | 540 | | 0x16 | 3.4 | 0x56 | 25.5 | 0x96 | 65 | 0xD6 | 560 | | 0x17 | 3.6 | 0x57 | 26.0 | 0x97 | 66 | 0xD7 | 580 | | 0x18 | 3.8 | 0x58 | 26.5 | 0x98 | 67 | 0xD8 | 600 | | 0x19 | 4.0 | 0x59 | 27.0 | 0x99 | 68 | 0xD9 | 620 | | 0x1A | 4.2 | 0x5A | 27.5 | 0x9A | 69 | 0xDA | 640 | | 0x1B | 4.4 | 0x5B | 28.0 | 0x9B | 70 | 0xDB | 660 | | 0x1C | 4.6 | 0x5C | 28.5 | 0x9C | 72 | 0xDC | 680 | | 0x1D | 4.8 | 0x5D | 29.0 | 0x9D | 74 | 0xDD | 700 | | 0x1E | 5.0 | 0x5E | 29.5 | 0x9E | 76 | 0xDE | 720 | | 0x1F | 5.2 | 0x5F | 30.0 | 0x9F | 78 | 0xDF | 740 | | 0x20 | 5.4 | 0x60 | 30.5 | 0xA0 | 80 | 0xE0 | 760 | | 0x21 | 5.6 | 0x61 | 31.0 | 0xA1 | 82 | 0xE1 | 780 | | 0x22 | 5.8 | 0x62 | 31.5 | 0xA2 | 84 | 0xE2 | 800 | | 0x23 | 6.0 | 0x63 | 32.0 | 0xA3 | 86 | 0xE3 | 820 | | 0x24 | 6.2 | 0x64 | 32.5 | 0xA4 | 88 | 0xE4 | 840 | | 0x25 | 6.4 | 0x65 | 33.0 | 0xA5 | 90 | 0xE5 | 860 | | 0x26 | 6.6 | 0x66 | 33.5 | 0xA6 | 92 | 0xE6 | 880 | | 0x27 | 6.8 | 0x67 | 34.0 | 0xA7 | 94 | 0xE7 | 900 | | 0x28 | 7.0 | 0x68 | 34.5 | 0xA8 | 96 | 0xE8 | 920 | | 0x29 | 7.2 | 0x69 | 35.0 | 0xA9 | 98 | 0xE9 | 940 | | 0x2A | 7.4 | 0x6A | 35.5 | 0xAA | 100 | 0xEA | 960 | | 0x2B | 7.6 | 0x6B | 36.0 | 0xAB | 105 | 0xEB | 980 | | 0x2C | 7.8 | 0x6C | 36.5 | 0xAC | 110 | 0xEC | 1000 | | 0x2D | 8.0 | 0x6D | 37.0 | 0xAD | 115 | 0xED | 1050 | | 0x2E | 8.2 | 0x6E | 37.5 | 0xAE | 120 | 0xEE | 1100 | | 0x2F | 8.4 | 0x6F | 38.0 | 0xAF | 125 | 0xEF | 1150 | | 0x30 | 8.6 | 0x70 | 38.5 | 0xB0 | 130 | 0xF0 | 1200 | | 0x31 | 8.8 | 0x71 | 39.0 | 0xB1 | 135 | 0xF1 | 1250 | | 0x32 | 9.0 | 0x72 | 39.5 | 0xB2 | 140 | 0xF2 | 1300 | | 0x33 | 9.2 | 0x73 | 40.0 | 0xB3 | 145 | 0xF3 | 1350 | | 0x34 | 9.4 | 0x74 | 40.5 | 0xB4 | 150 | 0xF4 | 1400 | | 0x35 | 9.6 | 0x75 | 41.0 | 0xB5 | 155 | 0xF5 | 1450 | | 0x36 | 9.8 | 0x76 | 41.5 | 0xB6 | 160 | 0xF6 | 1500 | | 0x37 | 10.0 | 0x77 | 42.0 | 0xB7 | 165 | 0xF7 | 1550 | | 0x38 | 10.5 | 0x78 | 42.5 | 0xB8 | 170 | 0xF8 | 1600 | | 0x39 | 11.0 | 0x79 | 43.0 | 0xB9 | 175 | 0xF9 | 1650 | | 0x3A | 11.5 | 0x7A | 43.5 | 0xBA | 180 | 0xFA | 1700 | | 0x3B | 12.0 | 0x7B | 44.0 | 0xBB | 185 | 0xFB | 1750 | SLLSFV2 - AUGUST 2023 | Table 7-4. Motor BEMF constant Look-Up Table (continued) | |----------------------------------------------------------| |----------------------------------------------------------| | | Kt <sub>PH_N</sub><br>(mV/Hz) | | Kt <sub>PH_N</sub><br>(mV/Hz) | | Kt <sub>PH_N</sub><br>(mV/Hz) | MOTOR_BEM<br>F_CONST<br>(HEX) | Kt <sub>PH_N</sub><br>(mV/Hz) | |------|-------------------------------|------|-------------------------------|------|-------------------------------|-------------------------------|-------------------------------| | 0x3C | 12.5 | 0x7C | 44.5 | 0xBC | 190 | 0xFC | 1800 | | 0x3D | 13.0 | 0x7D | 45.0 | 0xBD | 195 | 0xFD | 1850 | | 0x3E | 13.5 | 0x7E | 45.5 | 0xBE | 200 | 0xFE | 1900 | | 0x3F | 14.0 | 0x7F | 46.0 | 0xBF | 205 | 0xFF | 2000 | ## 7.3.13 Motor Parameter Extraction Tool (MPET) The MCF8316C-Q1 uses motor winding resistance, motor winding inductance and Back-EMF constant to estimate motor position in closed loop operation. The MCF8316C-Q1 has capability of automatically measuring motor parameters in offline state, rather than having the user enter the values themselves. The MPET routine measures motor winding resistance, inductance, back EMF constant and mechanical load inertia and frictional coefficients. Offline measurement of parameters takes place before normal motor operation. TI recommends to estimate the motor parameters before motor startup to minimize the impact caused due to possible parameter variations. Figure 7-40 shows the sequence of operation in the MPET routine. The MPET routine is entered when either the MPET CMD bit is set to 1b or a non-zero target speed is set. The MPET routine consists of four steps namely, IPD, Open Loop Acceleration, Current Ramp Down and Coasting. Each one of these steps are executed if the condition shown below the step evaluates to TRUE; if the condition evaluates to FALSE, the algorithm bypasses that particular step and moves on to the next step in the sequence. Once all the 4 steps are completed (or bypassed), the algorithm exits the MPET routine. If target speed is set to a non-zero value, the algorithm begins the start-up and acceleration sequence (to target speed reference) once MPET routine is exited. Figure 7-40. MPET Sequence TI proprietary MPET routine includes following sequence of operation. - IPD: The MPET routine starts with IPD, if the user enables motor winding resistance or inductance measurement by setting MPET R = 1b and MPET L = 1b or if the user defines MOTOR RES = 0 or MOTOR IND = 0. The IPD during MPET can be configured using MPET specific configuration parameters or using the normal motor operation IPD configuration parameters. The IPD configuration selection is done using MPET IPD SELECT. With MPET IPD SELECT = 1b, the IPD current limit is configured using MPET IPD CURRENT LIMIT and the IPD repeat number is configured using MPET IPD FREQ. With MPET IPD SELECT = 0b, the IPD current limit and the repeat number is configured using IPD CURR THR and IPD REPEAT. The IPD timer over flow or the IPD current decay time more than three times the current ramp up time can result in MPET IPD FAULT. TI recommends to run the MPET multiple times to observe for consistent resistance and inductance reading. - Open loop Acceleration: After IPD, the MPET routine run align and then open loop acceleration if the back-EMF constant or mechanical parameter measurement are enabled by setting MPET KE = 1b and MPET MECH = 1b. The MPET routine incorporates the sequences for mechanical parameter measurement, if the speed loop PI constants are defined as zero, even if MPET\_MECH = 0b. User can configure MPET specific open loop configuration parameters or use normal motor operation open loop configuration parameters. The open loop configuration selection is done using MPET\_KE\_MEAS\_PARAMETER\_SELECT. With MPET\_KE\_MEAS\_PARAMETER\_SELECT = 1b, the speed slew rate is defined using MPET\_OPEN\_LOOP\_SLEW\_RATE, the open loop current reference is defined using MPET\_OPEN\_LOOP\_CURR\_REF and the open loop speed reference is defined using MPET\_OPEN\_LOOP\_SPEED\_REF. With MPET\_KE\_MEAS\_PARAMETER\_SELECT = 0b, the speed slew rate is defined using OL\_ACC\_A1 and OL\_ACC\_A2, 80% of ILIMIT for current reference and 50% of MAX\_SPEED for speed reference. - Current Ramp Down: After open loop acceleration, if the mechanical parameter measurement is enabled, then the MPET routine optimizes the motor current to lower value sufficient to support the load. If mechanical parameter measurement is disabled (MPET\_MECH = 0b, or non-zero speed loop PI parameters) then the MPET will not have the current ramp down sequence. - Coasting: MPET routine completes the sequence by allowing the motor to coast by enabling Hi-Z. The motor back EMF and indicative values of mechanical parameters are measured during the motor coasting period. If the motor back EMF is lower than the threshold defined in STAT\_DETECT\_THR, the MPET\_BEMF\_FAULT is generated. ## **Selecting the parameters from EEPROM or MPET** The MPET estimated values are available in the MTR\_PARAMS Register. Setting the MPET\_WRITE\_SHADOW bit to 1, writes the MPET estimated values to the shadow registers and the user-configured (from EEPROM) values in MOTOR\_RES, MOTOR\_IND, MOTOR\_BEMF\_CONST, CURR\_LOOP\_KP, CURR\_LOOP\_KI, SPD\_LOOP\_KP and SPD\_LOOP\_KI shadow registers will be overwritten by the estimated values from MPET. If any of the shadow registers are initialized to zero (from EEPROM registers), the MPET estimated values are used for those registers independent of the MPET\_WRITE\_SHADOW setting. The MPET calculates the current loop KP and KI by using the measured resistance and inductance. The MPET does an estimation of the mechanical parameters including the inertia and frictional coefficient at the shaft (includes both motor and shaft coupled load). These values are used to set an initial values speed loop KP and KI. The estimated speed loop KP and KI setting can be used as an initial setting only and TI recommends to tune these parameters on application by the user based on the performance requirement. # 7.3.14 Anti-Voltage Surge (AVS) When a motor is driven, energy is transferred from the power supply into the motor. Some of this energy is stored in the form of inductive and mechanical energy. If the speed command suddenly drops such that the BEMF voltage generated by the motor is greater than the voltage that is applied to the motor, then the mechanical energy of the motor is returned to the power supply and the $V_M$ voltage surges. The AVS feature works to prevent this voltage surge on $V_M$ and can be enabled by setting AVS\_EN to 1b. AVS can be disabled by setting AVS\_EN to 0b. When AVS is disabled, the deceleration rate is configured through CL\_DEC\_CONFIG. #### 7.3.15 Active Braking Decelerating the motor quickly requires the motor mechanical energy to be extracted from the rotor in a fast and controlled manner. However, the supply voltage (VM) increases if the motor mechanical energy is returned to the power supply during the deceleration process. MCF8316C-Q1 is capable of decelerating the motor quickly without pumping energy back into the supply voltage by using a novel technique called active braking. ACTIVE\_BRAKE\_EN should be set to 1b to enable active braking and prevent DC bus voltage (VM) spike during fast motor deceleration. Active braking can also be used during reverse drive (see Reverse Drive) or motor stop (see Active Spin-Down) to reduce the motor speed quickly without DC bus voltage (VM) spike. The maximum limit on the current sourced from the DC bus $(i_{dc\_ref})$ during active braking can be configured using ACTIVE\_BRAKE\_CURRENT\_LIMIT. The D-axis current reference $(i_{d\_ref})$ is generated from the error between DC bus current limit $(i_{dc\_ref})$ and the estimated DC bus current $(i_{dc})$ using a PI controller as shown in Figure 7-41. The gain constants of PI controller can be configured using ACTIVE\_BRAKE\_KP and ACTIVE\_BRAKE\_KI. During active braking, the DC bus current limit $(i_{dc\_ref})$ starts from zero and linearly increases to ACTIVE\_BRAKE\_CURRENT\_LIMIT with current slew rate as defined by ACTIVE\_BRAKE\_BUS\_CURRENT\_SLEW\_RATE. Figure 7-41. Active Braking Current Control Loop for id ref ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_ENTRY sets the minimum difference between the initial and target speed above which active braking will be entered. For example, consider ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_ENTRY is set to 10%; if the initial speed is 100% and target speed is set to 95%, MCF8316C-Q1 uses AVS instead of active braking to reach 95% speed since the difference in commanded speed change (5%) is less than ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_ENTRY (10%). ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_EXIT sets the difference between the current and target speed below which active braking will be exited. For example, consider ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_EXIT is set to 5%; if the initial motor speed is 100% and target speed is set to 10%, MCF8316C-Q1 uses active braking to reduce the motor speed to 15%; upon reaching 15% speed, MCF8316C-Q1 exits active braking and uses AVS to decelerate the motor speed to 10%. ACTIVE BRAKE MOD INDEX LIMIT sets modulation index below the which active braking will be used. For example, consider ACTIVE\_BRAKE\_MOD\_INDEX\_LIMIT set 50%, ACTIVE BRAKE SPEED DELTA LIMIT ENTRY is set to 5%, ACTIVE BRAKE SPEED DELTA LIMIT EXIT is set to 2.5%. If the initial motor speed is at 70% (corresponding modulation index is 90%) and target speed is 40% (corresponding modulation index is 60%), MCF8316C-Q1 uses AVS to decelerate the motor till target speed of 40% since the modulation index (60%) corresponding to final speed is higher than ACTIVE BRAKE MOD INDEX LIMIT of 50%. In the same case, if final speed command is 10% (corresponding modulation index is 30%), MCF8316C-Q1 uses AVS till 30% speed (corresponding modulation index is 50%), switches to active braking from 30% to 15% speed (final speed of 10% + ACTIVE BRAKE SPEED DELTA LIMIT EXIT of 5%) and uses AVS again from 15% to 10% speed to complete the active braking. TI recommends starting active braking tuning with ACTIVE BRAKE MOD INDEX LIMIT set to 100%; if there is a DC bus voltage (VM) spike observed during active braking, reduce ACTIVE BRAKE MOD INDEX LIMIT in steps so as to eliminate this voltage spike. If ACTIVE BRAKE MOD INDEX LIMIT is set to 0%, MCF8316C-Q1 decelerates in AVS (even when ACTIVE BRAKE EN is set to 1b) in the forward direction; in reverse direction (during direction change), ACTIVE BRAKE MOD INDEX LIMIT is not applicable and therefore MCF8316C-Q1 decelerates in active braking. # Note - ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_ENTRY, ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_EXIT and ACTIVE\_BRAKE\_MOD\_INDEX\_LIMIT are applicable only during deceleration in forward direction and not used during direction change. - 2. ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_ENTRY should be set higher than ACTIVE\_BRAKE\_SPEED\_DELTA\_LIMIT\_EXIT for active braking operation. - 3. During active (or closed loop) braking, I<sub>q\_ref</sub> is clamped to -ILIMIT. This (I<sub>q\_ref</sub> being clamped to -ILIMIT) may result in the speed PI loop getting saturated and SPEED\_LOOP\_SATURATION bit getting set to 1b during deceleration. This bit is automatically set to 0b once the deceleration is completed and the speed PI loop is out of saturation. Hence, speed loop saturation fault should be ignored during deceleration. - 4. Active braking is not available in torque mode. ## 7.3.16 Output PWM Switching Frequency MCF8316C-Q1 provides the option to configure the output PWM switching frequency of the MOSFETs through PWM\_FREQ\_OUT. PWM\_FREQ\_OUT has range of 10-60 kHz. In order to select optimal output PWM switching frequency, user has to make tradeoff between the current ripple and the switching losses. Generally, motors having lower L/R ratio require higher PWM switching frequency to reduce current ripple. #### 7.3.17 PWM Modulation Schemes The MCF8316C-Q1 supports two different modulation schemes, namely, continuous and discontinuous space vector PWM modulation schemes. In continuous PWM modulation, all the three phases switch all the time as per the defined switching frequency. In discontinuous PWM modulation, one of the phases is clamped to ground for 120° electrical period, and the other two phases are pulse width modulated. The modulation scheme is configured using PWM\_MODE. Figure 7-42 shows the modulated average phase voltages for different modulation schemes. Figure 7-42. Continuous and Discontinuous PWM Modulation Phase Voltages Continuous modulation helps in reducing current ripple for motors having low inductance but it results in higher switching losses because all three phases are switching. Discontinuous modulation has lower switching losses due to only two phases switching at a time, but higher current ripple. ### 7.3.18 Dead Time Compensation Dead time is inserted between the switching instants of high-side and low-side MOSFETs in a half-bridge leg to avoid shoot-through condition. Due to dead time insertion, the expected voltage and applied voltage at the phase node differ based on the phase current direction. The phase node voltage distortion introduces undesired distortion in the phase current causing audible noise. MCF8316C-Q1 integrates a proprietary dead time compensation technique to remove this phase current distortion and greatly reduce the audible noise, thereby significantly improving the acoustic performance of the FOC in MCF8316C-Q1. This dead time compensation can be enabled or disabled by configuring DEADTIME\_COMP\_EN. Even when DEADTIME\_COMP\_EN is set to 1b (compensation enabled), dead time compensation is disabled when motor electrical frequency exceeds 135-Hz and re-enabled when motor electrical frequency drops below 127-Hz. ### 7.3.19 Motor Stop Options The MCF8316C-Q1 provides different options for stopping the motor which can be configured by MTR\_STOP. 7.3.19.1 Coast (Hi-Z) Mode Coast (Hi-Z) mode is configured by setting MTR\_STOP to 000b. When motor stop command is received, the MCF8316C-Q1 will transition into a high impedance (Hi-Z) state by turning off all MOSFETs. When the MCF8316C-Q1 transitions from driving the motor into a Hi-Z state, the inductive current in the motor windings continues to flow and the energy returns to the power supply through the body diodes in the MOSFET output stage (see example Figure 7-43). Figure 7-43. Coast (Hi-Z) Mode In this example, current is applied to the motor through the high-side phase-A MOSFET (HSA), high-side phase-B MOSFET(HSB) and returned through the low-side phase-C MOSFET (LSC). When motor stop command is received all 6 MOSFETs transition to Hi-Z state and the inductive energy returns to supply through body diodes of MOSFETs LSA, LSB and HSC. ## 7.3.19.2 Low-Side Braking Low-side braking mode is configured by setting MTR\_STOP to 010b. When a motor stop command is received, the output speed is reduced to a value defined by BRAKE\_SPEED\_THRESHOLD prior to turning all low-side MOSFETs ON (see example Figure 7-44) for a time configured by MTR\_STOP\_BRK\_TIME. If the motor speed is below BRAKE\_SPEED\_THRESHOLD prior to receiving stop command, then the MCF8316C-Q1 transitions directly into the brake state. After applying the brake for MTR\_STOP\_BRK\_TIME, the MCF8316C-Q1 transitions into the Hi-Z state by turning OFF all MOSFETs. Figure 7-44. Low-Side Braking The MCF8316C-Q1 can also enter low-side braking through BRAKE pin input. When BRAKE pin is pulled to HIGH state, the output speed is reduced to a value defined by BRAKE\_SPEED\_THRESHOLD prior to turning all low-side MOSFETs ON. In this case, MCF8316C-Q1 stays in low-side brake state till BRAKE pin changes to LOW state. # 7.3.19.3 High-Side Braking High-side braking mode is configured by setting MTR\_STOP to 011b. When a motor stop command is received, the output speed is reduced to a value defined by BRAKE\_SPEED\_THRESHOLD prior to turning all high-side MOSFETs ON (see example Figure 7-45) for a time configured by MTR\_STOP\_BRK\_TIME. If the motor speed is below BRAKE\_SPEED\_THRESHOLD prior to receiving stop command, then the MCF8316C-Q1 transitions directly into the brake state. After applying the brake for MTR\_STOP\_BRK\_TIME, the MCF8316C-Q1 transitions into Hi-Z state by turning OFF all MOSFETs. Figure 7-45. High-Side Braking ## 7.3.19.4 Active Spin-Down Active spin down mode is configured by setting MTR\_STOP to 100b. When a motor stop command is received, the MCF8316C-Q1 reduces SPEED\_REF to ACT\_SPIN\_THR and then transitions to Hi-Z state by turning all MOSFETs OFF. The advantage of this mode is that by reducing SPEED\_REF, the motor is decelerated to lower speed thereby reducing the phase currents before entering Hi-Z. Now, when the motor transitions into Hi-Z state, the energy transfer to the power supply is reduced. The threshold ACT\_SPIN\_THR needs to configured high enough for MCF8316C-Q1 to not lose synchronization with the motor. ### 7.3.19.5 Align Braking Align braking based stop mode is configured by setting MTR\_STOP to 101b. In this mode, on receiving the motor stop command, MCF8316C-Q1 reduces the motor speed to a value defined by BRAKE\_SPEED\_THRSHOLD before bringing the motor to align stop by injecting a DC current through a particular phase pattern for a time configured by MTR\_STOP\_BRK\_TIME. The phase pattern during align stop is generated based on the angle at which align needs to be performed and this angle can be configured through ALIGN\_ANGLE or the last commutation angle. ALIGN\_BRAKE\_ANGLE\_SEL can be configured to decide which align angle is to be used by MCF8316C-Q1. The current limit threshold during align braking is configured through ALIGN OR SLOW CURRENT ILIMIT. ## 7.3.20 FG Configuration The MCF8316C-Q1 provides information about the motor speed through the Frequency Generate (FG) pin. In MCF8316C-Q1, the FG pin output is configured through FG\_CONFIG. When FG\_CONFIG is configured to 0b, the FG output is active as long as the MCF8316C-Q1 is driving the motor. When FG\_CONFIG is configured to 1b, the MCF8316C-Q1 provides an FG output until the motor back-EMF falls below FG\_BEMF\_THR. ## 7.3.20.1 FG Output Frequency The FG output frequency can be configured by FG\_DIV. Many applications require the FG output to provide a pulse for every mechanical rotation of the motor Different FG\_DIV configurations can accomplish this for 2-pole up to 30-pole motors. Figure 7-46 shows the FG output when MCF8316C-Q1 has been configured to provide FG pulses once every electrical cycle (2 poles), once every two electrical cycle (4 poles), once every three electrical cycles (6 poles), once every four electrical cycles (8 poles), and so on. Figure 7-46. FG Frequency Divider ### 7.3.20.2 FG during Open and Closed Loop States During closed loop operation, the driving speed (FG output frequency) and the actual motor speed are synchronized. During open-loop operation, however, FG may not reflect the actual motor speed. The MCF8316C-Q1 provides three options for controlling the FG output during open loop, as shown in Figure 7-47. The selection of these options is configured through FG\_SEL. If FG SEL is set to, - 00b: When in open loop, the FG output is based on the driving frequency. - 01b: When in open loop, the FG output will be driven high. - 10b: The FG output will reflect the driving frequency during open loop operation in the first motor start-up cycle after power-on, sleep/standby; FG will be held high during open loop operation in subsequent start-up cycles. Figure 7-47. FG Behavior During Open Loop #### 7.3.20.3 FG during Fault and Idle States MCF8316C-Q1 provides the option of configuring FG output during fault and idle (motor stopped due to zero speed command) states. FG output during fault state is configured by FG\_FAULT\_CONFIG and FG output during idle state is configured by FG\_IDLE\_CONFIG - FG can be configured as a low or high signal during fault and can also be configured as a low or high signal during idle state. This allows the use of FG signal to uniquely determine the motor operating condition (fault, idle, spinning). For example, FG output during fault can be configured as a low signal and FG output during idle state can be configured as a high signal and FG during motor spinning can be configured to be at mechanical speed - a low FG output indicates MCF8316C-Q1 encountered a fault condition, a high FG output indicates motor is in idle state and a FG signal at 50% duty indicates motor spinning at a speed equal to FG frequency. #### 7.3.21 DC Bus Current Limit The DC bus current limit feature can be used to limit the current supplied by the DC input source (VM). This feature can be enabled by setting BUS\_CURRENT\_LIMIT\_ENABLE to 1b. The DC bus current limit can be configured using BUS\_CURRENT\_LIMIT. This feature limits the DC bus current by limiting the speed (SPEED\_REF\_LIM)/current (CURRENT\_REF\_LIM) reference as shown in Figure 7-48. Enabling this feature may restrict the speed/phase current of the motor from reaching the set point (SPEED\_REF or CURRENT\_REF) in order to limit the DC bus current. The DC bus current limit status is reported on BUS\_CURRENT\_LIMIT\_STATUS. ## Speed Control Mode Figure 7-48. DC Bus Current Limit #### Note - 1. DC bus current limit feature is not available when active braking is enabled. - 2. MCF8316C-Q1 implements a 5% hysteresis around BUS\_CURRENT\_LIMIT to avoid chattering around this set-point. ### 7.3.22 Protections The MCF8316C-Q1 is protected from a host of fault events including motor lock, VM undervoltage, AVDD undervoltage, buck undervoltage, charge pump undervoltage, overtemperature and overcurrent events. Table 7-5 summarizes the response, recovery modes, power stage status, reporting mechanism for different faults. Product Folder Links: MCF8316C-Q1 Copyright © 2023 Texas Instruments Incorporated #### Note - 1. Actionable faults (latched or retry) are always reported on nFAULT pin (as logic low). - 2. Actionable faults (latched or retry) are reported on ALARM pin (as logic high) when ALARM PIN EN is set to 1b. - 3. Report only faults are reported on nFAULT (as logic low) only when ALARM\_PIN\_EN is set to 0b. When ALARM\_PIN\_EN is set to 1b, report only faults are reported only on ALARM pin (as logic high) while nFAULT stays high (external or internal pull-up). - 4. Priority order for multi-fault scenarios is latched > slower retry time fault > faster retry time fault > report only fault. For example, if a latched and retry fault happen simultaneously, the device stays latched in fault mode until user issues clear fault command by writing 1b to CLR\_FLT. If two retry faults with different retry times happen simultaneously, the device retries only after the longer (slower) retry time lapses. - 5. Recovery refers only to state of FETs (Hi-Z or active) after the fault condition is removed. Automatic indicates that the device automatically recovers (and FETs are active) when retry time lapses after the fault condition is removed. Latched indicates that the device waits for clearing of fault condition (by writing 1b to CLR FLT bit) to make the FETs active again. - 6. Actionable (latched or retry) faults can take up to 200-ms after fault response (FETs in Hi-Z) to be reported on nFAULT pin (as logic low), ALARM pin (as logic high) and fault status registers. - 7. Latched faults can take up to 200-ms after CLR\_FLT command is issued (over I<sup>2</sup>C) to be cleared. Table 7-5. Fault Action and Response | FAULT | CONDITION | CONFIGURATION | REPORT | FETs | DIGITAL | RECOVERY | |-----------------------------------------|----------------------------------------------------|----------------|--------------------------------------------------------|-------------|-----------------|-----------------------------------------------------------------| | VM undervoltage | V <sub>VM</sub> < V <sub>UVLO</sub> (falling) | _ | _ | Hi-Z | Disabled | Automatic:<br>V <sub>VM</sub> > V <sub>UVLO</sub> (rising) | | AVDD undervoltage | V <sub>AVDD</sub> < V <sub>AVDD_UV</sub> (falling) | _ | _ | Hi-Z | Disabled | Automatic:<br>V <sub>AVDD</sub> > V <sub>AVDD_UV</sub> (rising) | | Buck undervoltage<br>(BUCK_UV) | V <sub>FB_BK</sub> < V <sub>BK_UV</sub> (falling) | _ | _ | Active/Hi-Z | Active/Disabled | Automatic:<br>V <sub>FB_BK</sub> > V <sub>BK_UV</sub> (rising) | | Charge pump<br>undervoltage<br>(VCP_UV) | V <sub>CP</sub> < V <sub>CPUV</sub> (falling) | - | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Automatic:<br>V <sub>VCP</sub> > V <sub>CPUV</sub> (rising) | | | V <sub>VM</sub> > V <sub>OVP</sub> (rising) | OVP_EN = 0b | None | Active | Active | No action | | Over Voltage<br>Protection<br>(OVP) | | OVP_EN = 1b | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Automatic:<br>V <sub>VM</sub> < V <sub>OVP</sub> (falling) | | Over Current | I <sub>PHASE</sub> > I <sub>OCP</sub> | OCP_MODE = 00b | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | Protection<br>(OCP) | | OCP_MODE = 01b | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry:<br><sup>t</sup> retry | | Buck Overcurrent Protection (BUCK_OCP) | I <sub>BK</sub> > I <sub>BK_OCP</sub> | _ | _ | Hi-Z | Disabled | Automatic | Table 7-5. Fault Action and Response (continued) | FAULT | CONDITION | CONFIGURATION | REPORT | FETs | DIGITAL | RECOVERY | |----------------------------------------------|----------------------------------------------------------------|------------------------------------------|-------------------------------------------------------|-----------------|---------|----------------------------------| | | | MTR_LCK_MODE = 0000b or 0001b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | Motor Lock<br>(MTR_LCK) | | MTR_LCK_MODE = 0010b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High side brake | Active | Latched:<br>CLR_FLT | | | | MTR_LCK_MODE = 0011b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low side brake | Active | Latched:<br>CLR_FLT | | | Motor lock: Abnormal<br>Speed; No Motor Lock;<br>Abnormal BEMF | MTR_LCK_MODE = 0100b or 0101b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry:<br>t <sub>LCK_RETRY</sub> | | | ADIIOIIIIAI BEIVIF | MTR_LCK_MODE = 0110b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High side brake | Active | Retry:<br>t <sub>LCK_RETRY</sub> | | | | MTR_LCK_MODE = 0111b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low side brake | Active | Retry:<br>t <sub>LCK_RETRY</sub> | | | | MTR_LCK_MODE = 1000b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active | Active | No action | | | | MTR_LCK_MODE = 1xx1b | None | Active | Active | No action | | | | HW_LOCK_ILIMIT_MOD<br>E = 0000b or 0001b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | | | HW_LOCK_ILIMIT_MOD<br>E = 0010b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High-side brake | Active | Latched:<br>CLR_FLT | | | | HW_LOCK_ILIMIT_MOD<br>E = 0011b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low-side brake | Active | Latched:<br>CLR_FLT | | Hardware Lock-<br>Detection Current<br>Limit | V <sub>SOX</sub> > HW_LOCK_ILIMIT | HW_LOCK_ILIMIT_MOD<br>E = 0100b or 0101b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry:<br>t <sub>LCK_RETRY</sub> | | (HW_LOCK_LIMIT) | | HW_LOCK_ILIMIT_MOD<br>E = 0110b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High-side brake | Active | Retry:<br><sup>t</sup> LCK_RETRY | | | | HW_LOCK_ILIMIT_MOD<br>E = 0111b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low-side brake | Active | Retry:<br><sup>t</sup> LCK_RETRY | | | | HW_LOCK_ILIMIT_MOD<br>E= 1000b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active | Active | No action | | | | HW_LOCK_ILIMIT_MOD<br>E = 1xx1b | None | Active | Active | No action | **Table 7-5. Fault Action and Response (continued)** | Table 7-5. Fault Action and Response (continued) | | | | | | | |--------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------|-------------------------------------------------------|-----------------|---------|--------------------------------------------------------| | FAULT | CONDITION | CONFIGURATION | REPORT | FETs | DIGITAL | RECOVERY | | | | LOCK_ILIMIT_MODE = 00000b or 0001b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | | | LOCK_ILIMIT_MODE = 0010b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High-side brake | Active | Latched:<br>CLR_FLT | | | V <sub>SOX</sub> > LOCK_ILIMIT | LOCK_ILIMIT_MODE = 0011b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low-side brake | Active | Latched:<br>CLR_FLT | | Software Lock-<br>Detection Current<br>Limit | | LOCK_ILIMIT_MODE = 0100b or 0101b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry:<br>t <sub>LCK_RETRY</sub> | | (LOCK_LIMIT) | | LOCK_ILIMIT_MODE = 0110b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | High-side brake | Active | Retry:<br><sup>t</sup> LCK_RETRY | | | | LOCK_ILIMIT_MODE = 0111b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Low-side brake | Active | Retry: t <sub>LCK_RETRY</sub> | | | | LOCK_ILIMIT_MODE=<br>1000b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active | Active | No action | | | | LOCK_ILIMIT_MODE = 1xx1b | None | Active | Active | No action | | IPD Timeout Fault | IPD TIME > 500ms | IPD_TIMEOUT_FAULT_E<br>N = 0b | _ | Active | Active | No action | | (IPD_T1_FAULT<br>and<br>IPD_T2_FAULT) | (approx.), during IPD current ramp up or ramp down | IPD_TIMEOUT_FAULT_E<br>N = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry: t <sub>LCK_RETRY</sub> | | IPD Frequency | IPD Frequency Fault (IPD_FREQ_FAULT ) IPD pulse before the current decay in previous IPD pulse | IPD_FREQ_FAULT_EN = 0b | _ | Active | Active | No action | | Fault<br>(IPD_FREQ_FAULT | | IPD_FREQ_FAULT_EN = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Retry: t <sub>LCK_RETRY</sub> | | MPET IPD Fault<br>(MPET_IPD_FAULT<br>) | Same as IPD Timeout<br>Fault during MPET R, L<br>measurement | _ | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | MPET Back-EMF<br>Fault<br>(MPET_BEMF_FA<br>ULT) | Motor Back EMF < STAT_DETECT_THR during MPET Ke and mechanical parameters measurement | _ | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | Maximum VM | V <sub>VM</sub> > MAX_VM_MOTOR,<br>if MAX_VM_MOTOR ≠ | MAX_VM_MODE = 0b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | (overvoltage) fault | 000b | MAX_VM_MODE = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Automatic:<br>(V <sub>VM</sub> < MAX_VM_MOTOR - 1)-V | | Minimum VM | V <sub>VM</sub> < MIN_VM_MOTOR,<br>if MIN_VM_MOTOR ≠ | MIN_VM_MODE = 0b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | | (undervoltage) fault | 000b | MIN_VM_MODE = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Automatic:<br>(V <sub>VM</sub> > MIN_VM_MOTOR + 0.5)-V | | External Watchdog | Watchdog tickle does not arrive before configured time interval when | EXT_WDT_FAULT_MOD<br>E = 0b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active | Active | No action | | | time interval when EXT_WDT_EN =1b. Refer Section 7.5.5 | EXT_WDT_FAULT_MOD<br>E = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Latched:<br>CLR_FLT | **Table 7-5. Fault Action and Response (continued)** | FAULT | CONDITION | CONFIGURATION | REPORT | FETs | DIGITAL | RECOVERY | |--------------------------------------|-----------------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------|----------------------------------------------------------------------|---------|----------------------------------------------------------------------------------| | Bus Current Limit | I <sub>VM</sub> > BUS_CURRENT_LIMIT. Refer Section 7.3.21 | BUS_CURRENT_LIMIT_E<br>NABLE = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active; motor speed<br>will be restricted to<br>limit DC bus current | Active | Automatic: Speed restriction is removed when I <sub>VM</sub> < BUS_CURRENT_LIMIT | | Current Loop<br>Saturation | Indication of current loop<br>saturation due to lower<br>V <sub>VM</sub> | SATURATION_FLAGS_E<br>N = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active; motor speed<br>may not reach<br>speed reference | Active | Automatic: motor will reach reference operating point upon exiting saturation | | Speed Loop<br>Saturation | Indication of speed loop saturation due to lower V <sub>VM</sub> , lower ILIMIT setting etc., | SATURATION_FLAGS_E<br>N = 1b | nFAULT and<br>CONTROLLER_FA<br>ULT_STATUS<br>register | Active; motor speed<br>may not reach<br>speed reference | Active | Automatic: motor will reach reference operating point upon exiting saturation | | Thermal warning (OTW) | T <sub>J</sub> > T <sub>OTW</sub> | OTW_REP = 0b | _ | Active | Active | No action | | | | OTW_REP = 1b | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Active | Active | No action | | FET thermal<br>shutdown<br>(TSD_FET) | T <sub>J</sub> > T <sub>TSD_FET</sub> | _ | nFAULT and<br>GATE_DRIVER_FA<br>ULT_STATUS<br>register | Hi-Z | Active | Automatic:<br>T <sub>J</sub> < T <sub>TSD_FET</sub> - T <sub>TSD_FET_HYS</sub> | # 7.3.22.1 VM Supply Undervoltage Lockout If at any time the input supply voltage on the VM pin falls lower than the $V_{UVLO}$ threshold (VM UVLO falling threshold), all the integrated FETs, driver charge-pump and digital logic are disabled as shown in Figure 7-49. MCF8316C-Q1 goes into reset state whenever VM UVLO event occurs. Figure 7-49. VM Supply Undervoltage Lockout ## 7.3.22.2 AVDD Undervoltage Lockout (AVDD\_UV) If at any time the voltage on the AVDD pin falls lower than the $V_{AVDD\_UV}$ threshold, all the integrated FETs, driver charge-pump and digital logic controller are disabled. Since internal circuitry in MCF8316C-Q1 is powered through the AVDD regulator, MCF8316C-Q1 goes into reset state whenever AVDD UV event occurs. ## 7.3.22.3 BUCK Under Voltage Lockout (BUCK UV) If at any time the voltage on the FB\_BK pin falls lower than the $V_{BK\_UVLO}$ threshold, a buck UV fault is recognized - MCF8316C-Q1 continues to attempt regulating the FB\_BK voltage to set value. Since internal circuitry in MCF8316C-Q1 is powered through the buck regulator, MCF8316C-Q1 may go into reset state if FB\_BK voltage drops low enough to trigger UV on the internal circuits. ## 7.3.22.4 VCP Charge Pump Undervoltage Lockout (CPUV) If at any time the voltage on the VCP pin (charge pump) falls lower than the $V_{CPUV}$ threshold, all the integrated FETs are disabled and the nFAULT pin is driven low. The DRIVER\_FAULT and VCP\_UV bits are set to 1b in the status registers. Normal operation resumes (driver operation and the nFAULT pin is released) when the VCP undervoltage condition clears. The VCP\_UV bit stays set until cleared through the CLR\_FLT bit. # 7.3.22.5 Overvoltage Protection (OVP) If at any time input supply voltage on the VM pins rises higher than $V_{OVP}$ , all the integrated FETs are disabled and the nFAULT pin is driven low. The DRIVER\_FAULT and OVP bits are set to 1b in the status registers. Normal operation resumes (driver operation and the nFAULT pin is released) when the OVP condition clears. The OVP bit stays set until cleared through the CLR\_FLT bit. Setting the OVP\_EN to 0b disables this protection feature. The OVP threshold can be set to 22-V or 34-V based on the OVP\_SEL bit. Figure 7-50. Over Voltage Protection # 7.3.22.6 Overcurrent Protection (OCP) MOSFET overcurrent event is sensed by monitoring the current flowing through the FETs. If the current across a FET exceeds the $I_{OCP}$ threshold for longer than the deglitch time $t_{OCP}$ , an OCP event is recognized and action is taken according to OCP\_MODE. The $I_{OCP}$ threshold is set through the OCP\_LVL, $t_{OCP}$ is set through OCP\_DEG and the OCP\_MODE can be configured in four different modes: latched shutdown, automatic retry, report only and disabled. ## 7.3.22.6.1 OCP Latched Shutdown (OCP\_MODE = 00b) When an OCP event happens in this mode, all MOSFETs are disabled and the nFAULT pin is driven low. The DRIVER\_FAULT, OCP and corresponding FET's OCP bits are set to 1b in the status registers. Normal operation resumes (driver operation and the nFAULT pin is released) when the OCP condition clears and a clear fault command is issued through the CLR\_FLT bit. Figure 7-51. Overcurrent Protection - Latched Shutdown Mode # 7.3.22.6.2 OCP Automatic Retry (OCP\_MODE = 01b) When an OCP event happens in this mode, all the FETs are disabled and the nFAULT pin is driven low. The DRIVER\_FAULT, OCP and corresponding FET's OCP bits are set to 1b in the fault status registers. Normal operation resumes automatically (gate driver operation and the nFAULT pin is released) after the t<sub>RETRY</sub> (TRETRY) time elapses. The DRIVER\_FAULT bit is reset to 0b after the t<sub>RETRY</sub> period expires. The OCP and corresponding FET's OCP bits are set to 1b until cleared through the CLR FLT bit. Figure 7-52. Overcurrent Protection - Automatic Retry Mode ## 7.3.22.7 Buck Overcurrent Protection The buck overcurrent event is sensed by monitoring the current flowing through high-side MOSFET of the buck regulator. If the current through the high-side MOSFET exceeds the $I_{BK\_OCP}$ threshold for a time longer than the deglitch time ( $t_{OCP}$ ), a buck OCP event is recognized and the buck regulator MOSFETs are disabled (Hi-Z). MCF8316C-Q1 goes into reset state whenever buck OCP event occurs, since the internal circuitry in MCF8316C-Q1 is powered from the buck regulator output. #### 7.3.22.8 Hardware Lock Detection Current Limit (HW LOCK ILIMIT) The hardware lock detection current limit function provides a configurable threshold for limiting the current to prevent damage to the system. The MCF8316C-Q1 continuously motor phase currents are using comparators. If at any time, any phase current exceeds $HW\_LOCK\_ILIMIT$ threshold for a time longer than $t_{HW\_LOCK\_ILIMIT}$ , a $HW\_LOCK\_ILIMIT$ event is recognized and action is taken according to the $HW\_LOCK\_ILIMIT\_MODE$ . The current threshold is set by $HW\_LOCK\_ILIMIT$ and the deglitch time, $t_{HW\_LCK\_ILIMIT}$ is set by $HW\_LOCK\_ILIMIT\_DEG$ . $HW\_LOCK\_ILIMIT\_MODE$ can be set in four different modes: $HW\_LOCK\_ILIMIT$ latched shutdown, $HW\_LOCK\_ILIMIT$ automatic retry, $HW\_LOCK\_ILIMIT$ report only, and $HW\_LOCK\_ILIMIT$ disabled. # 7.3.22.8.1 HW\_LOCK\_ILIMIT Latched Shutdown (HW\_LOCK\_ILIMIT\_MODE = 00xxb) When a HW\_LOCK\_ILIMIT event happens in this mode, the status of MOSFET will be configured by HW\_LOCK\_ILIMIT\_MODE and nFAULT is driven low. Status of MOSFETs during HW\_LOCK\_ILIMIT: - HW LOCK ILIMIT MODE = 0000b or 0001b: All MOSFETs are turned OFF. - HW LOCK ILIMIT MODE = 0010b; All-high side MOSFETs are turned ON. - HW LOCK ILIMIT MODE = 0011b: All-low side MOSFETs are turned ON. The CONTROLLER FAULT and HW LOCK ILIMIT bits are set to 1b in the fault status registers. Normal operation resumes (gate driver operation and the nFAULT pin is released) when the HW LOCK ILIMIT condition clears and a clear fault command is issued through the CLR FLT bit. ### 7.3.22.8.2 HW\_LOCK\_ILIMIT Automatic recovery (HW\_LOCK\_ILIMIT\_MODE = 01xxb) When a HW LOCK ILIMIT event happens in this mode, the status of MOSFET will be configured by HW\_LOCK\_ILIMIT\_MODE and nFAULT is driven low. Status of MOSFET during HW\_LOCK\_ILIMIT: - HW LOCK ILIMIT MODE = 0100b or 0101b: All MOSFETs are turned OFF. - HW LOCK ILIMIT MODE = 0110b: All high-side MOSFETs are turned ON - HW LOCK ILIMIT MODE = 0111b: All low-side MOSFETs are turned ON The CONTROLLER\_FAULT and HW\_LOCK\_ILIMIT bits are set to 1b in the fault status registers. Normal operation resumes automatically (gate driver operation and the nFAULT pin is released) after the t<sub>LCK RFTRY</sub> (configured by LCK\_RETRY) time lapses. The CONTROLLER\_FAULT and HW\_LOCK\_ILIMIT bits are reset to 0b after the $t_{LCK}$ RETRY period expires. # 7.3.22.8.3 HW\_LOCK\_ILIMIT Report Only (HW\_LOCK\_ILIMIT\_MODE = 1000b) No protective action is taken when a HW\_ LOCK\_ILIMIT event happens in this mode. The hardware lock detection current limit event is reported by setting the CONTROLLER FAULT and HW LOCK ILIMIT bits to 1b in the fault status registers. The gate drivers continue to operate. The external controller manages this condition by acting appropriately. The reporting clears when the HW LOCK ILIMIT condition clears and a clear fault command is issued through the CLR FLT bit. ### 7.3.22.8.4 HW\_LOCK\_ILIMIT Disabled (HW\_LOCK\_ILIMIT\_MODE= 1xx1b) No action is taken when a HW\_LOCK\_ILIMIT event happens in this mode. ## 7.3.22.9 Lock Detection Current Limit (LOCK ILIMIT) The lock detection current limit function provides a configurable threshold for limiting the current to prevent damage to the system. The MCF8316C-Q1 continuously monitors the motor phase currents through the ADC. If at any time, any phase current exceeds LOCK\_ILIMIT for a time longer than t<sub>LCK ILIMIT</sub>, a LOCK\_ILIMIT event is recognized and action is taken according to LOCK ILIMIT MODE. The current threshold is set by LOCK\_ILIMIT and the deglitch time, t<sub>LCK ILIMIT</sub> is set by LOCK\_ILIMIT\_DEG. LOCK\_ILIMIT\_MODE can be set in four different modes: LOCK ILIMIT latched shutdown, LOCK ILIMIT automatic retry, LOCK ILIMIT report only and LOCK ILIMIT disabled. ### 7.3.22.9.1 LOCK ILIMIT Latched Shutdown (LOCK ILIMIT MODE = 00xxb) When a LOCK ILIMIT event happens in this mode, the status of MOSFETs will be configured by LOCK ILIMIT MODE and nFAULT is driven low. Status of MOSFETs during LOCK ILIMIT: - LOCK ILIMIT MODE = 0000b or 0001b: All MOSFETs are turned OFF. - LOCK ILIMIT MODE = 0010b: All high-side MOSFETs are turned ON. - LOCK ILIMIT MODE = 0011b: All low-side MOSFETs are turned ON. The CONTROLLER\_FAULT and LOCK\_ILIMIT bits are set to 1b in the fault status registers. Normal operation resumes (gate driver operation and the nFAULT pin is released) when the LOCK ILIMIT condition clears and a clear fault command is issued through the CLR FLT bit. ## 7.3.22.9.2 LOCK\_ILIMIT Automatic Recovery (LOCK\_ILIMIT\_MODE = 01xxb) When a LOCK\_ILIMIT event happens in this mode, the status of MOSFETs will be configured by LOCK ILIMIT MODE and nFAULT is driven low. Status of MOSFETs during LOCK ILIMIT: - LOCK ILIMIT MODE = 0100b or 0101b: All MOSFETs are turned OFF. - LOCK ILIMIT MODE = 0110b: All high-side MOSFETs are turned ON - LOCK\_ILIMIT\_MODE = 0111b: All low-side MOSFETs are turned ON The CONTROLLER FAULT and LOCK ILIMIT bits are set to 1b in the fault status registers. Normal operation resumes automatically (gate driver operation and the nFAULT pin is released) after the tick RETRY (configured by LCK RETRY) time lapses. The CONTROLLER FAULT and LOCK ILIMIT bits are reset to 0b after the t<sub>LCK</sub> RETRY period expires. ## 7.3.22.9.3 LOCK\_ILIMIT Report Only (LOCK\_ILIMIT\_MODE = 1000b) No protective action is taken when a LOCK\_ILIMIT event happens in this mode. The lock detection current limit event is reported by setting the CONTROLLER FAULT and LOCK ILIMIT bits to 1b in the fault status registers. The gate drivers continue to operate. The external controller manages this condition by acting appropriately. The reporting clears when the LOCK ILIMIT condition clears and a clear fault command is issued through the CLR FLT bit. #### 7.3.22.9.4 LOCK ILIMIT Disabled (LOCK ILIMIT MODE = 1xx1b) No action is taken when a LOCK ILIMIT event happens in this mode. ## 7.3.22.10 FET Thermal Warning (OTW) If the FET temperature exceeds the FET thermal warning limit (T<sub>OTW</sub>), nFAULT is pulled low and the OT and OTW bits in the gate driver status register are set to 1b. The reporting of OTW (on nFAULT and status bits) can be enabled by setting OTW REP to 1b. The device performs no additional action and continues to function. The nFAULT pin is pulled low and OTW bit remains set until cleared through the CLR FLT bit and the die temperature is lower than thermal warning limit. (T<sub>OTW</sub> - T<sub>OTW</sub> HYS). ## 7.3.22.11 FET Thermal Shutdown (TSD FET) If the FET temperature exceeds the FET thermal shutdown limit ( $T_{TSD\ FET}$ ), all the FETs are disabled, the charge pump is shut down, and the nFAULT pin is driven low. In addition, the DRIVER FAULT, OT and OTS bit in the status register are set to 1b. Normal operation resumes (driver operation and the nFAULT pin is released) when the die temperature decreases below the hysteresis point of the thermal shutdown limit (T<sub>TSD FFT</sub> -T<sub>TSD FET HYS</sub>). The OTS bit stays latched high indicating that a thermal event occurred until a clear fault command is issued through the CLR FLT bit. This protection feature cannot be disabled. ## Note If die temperature increases to $T_{TSD\ BUCK}$ , MCF8316C-Q1 will undergo a reset and all fault status bits in this case will be reset to 0b. ## 7.3.22.12 Motor Lock (MTR LCK) The MCF8316C-Q1 continuously checks for different motor lock conditions (see Motor Lock Detection) during motor operation. When one of the enabled lock condition happens, a MTR LCK event is recognized and action is taken according to the MTR\_LCK\_MODE. All locks can be enabled or disabled individually and retry times can be configured through LCK\_RETRY. MTR LCK MODE bit can operate in four different modes: MTR LCK latched shutdown, MTR LCK automatic retry, MTR LCK report only and MTR LCK disabled. ### 7.3.22.12.1 MTR LCK Latched Shutdown (MTR LCK MODE = 00xxb) When a MTR LCK event happens in this mode, the status of MOSFETs will be configured by MTR LCK MODE and nFAULT is driven low. Status of MOSFETs during MTR LCK: - MTR LCK MODE = 0000b or 0001b: All MOSFETs are turned OFF. - MTR LCK MODE = 0010b: All high-side MOSFETs are turned ON. - MTR LCK MODE = 0011b: All low-side MOSFETs are turned ON. The CONTROLLER FAULT, MTR LCK and respective motor lock condition bits are set to 1b in the fault status registers. Normal operation resumes (gate driver operation and the nFAULT pin is released) when the MTR LCK condition clears and a clear fault command is issued through the CLR FLT bit. #### 7.3.22.12.2 MTR\_LCK Automatic Recovery (MTR\_LCK\_MODE= 01xxb) When a MTR\_LCK event happens in this mode, the status of MOSFETs will be configured by MTR\_LCK\_MODE and nFAULT is driven low. Status of MOSFETs during MTR LCK: MTR LCK MODE = 0100b or 0101b: All MOSFETs are turned OFF. - MTR LCK MODE = 0110b: All high-side MOSFETs are turned ON. - MTR LCK MODE = 0111b: All low-side MOSFETs are turned ON. The CONTROLLER\_FAULT, MTR\_LCK and respective motor lock condition bits are set to 1b in the fault status registers. Normal operation resumes automatically (gate driver operation and the nFAULT pin is released) after the $t_{LCK\_RETRY}$ (configured by LCK\_RETRY) time lapses. The CONTROLLER\_FAULT, MTR\_LCK and respective motor lock condition bits are reset to 0b after the $t_{LCK\_RETRY}$ period expires. #### 7.3.22.12.3 MTR\_LCK Report Only (MTR\_LCK\_MODE = 1000b) No protective action is taken when a MTR\_LCK event happens in this mode. The motor lock event is reported by setting the CONTROLLER\_FAULT, MTR\_LCK and respective motor lock condition bits to 1b in the fault status registers. The gate drivers continue to operate. The external controller manages this condition by acting appropriately. The reporting clears when the MTR\_LCK condition clears and a clear fault command is issued through the CLR FLT bit. #### 7.3.22.12.4 MTR\_LCK Disabled (MTR\_LCK\_MODE = 1xx1b) No action is taken when a MTR LCK event happens in this mode. #### 7.3.22.13 Motor Lock Detection The MCF8316C-Q1 provides different lock detect mechanisms to determine if the motor is in a locked state. Multiple detection mechanisms work together to ensure the lock condition is detected quickly and reliably. In addition to detecting if there is a locked motor condition, the MCF8316C-Q1 can also identify and take action if there is no motor connected to the system. Each of the lock detect mechanisms and the no-motor detection can be disabled by their respective register bits (LOCK1/2/3 EN). #### 7.3.22.13.1 Lock 1: Abnormal Speed (ABN\_SPEED) MCF8316C-Q1 monitors the speed continuously and at any time the speed exceeds LOCK\_ABN\_SPEED, an ABN\_SPEED lock event is recognized and action is taken according to the MTR\_LCK\_MODE. The threshold is set through the LOCK\_ABN\_SPEED register. ABN\_SPEED lock can be enabled/disabled by LOCK1\_EN. #### 7.3.22.13.2 Lock 2: Abnormal BEMF (ABN BEMF) MCF8316C-Q1 estimates back-EMF in order to run motor optimally in closed loop. This estimated back-EMF is compared against the expected back-EMF calculated using the estimated speed and the BEMF constant. Whenever motor is stalled the estimated back-EMF is inaccurate due to lower back-EMF at low speed. When the difference between estimated and expected back-EMF exceeds ABNORMAL\_BEMF\_THR, an abnormal BEMF fault is triggered and action is taken according to the MTR\_LCK\_MODE. ABN BEMF lock can be enabled/disabled by LOCK2 EN. ### 7.3.22.13.3 Lock3: No-Motor Fault (NO\_MTR) The MCF8316C-Q1 continuously monitors phase currents on all three phases; if any phase current stays below NO\_MTR\_THR for 500ms, a NO\_MTR event is recognized. The response to the NO\_MTR event is configured through MTR\_LCK\_MODE. NO\_MTR lock can be enabled/disabled by LOCK3\_EN. ### 7.3.22.14 MPET Faults An error during resistance and inductance measurement is reported using MPET\_IPD\_FAULT. The MPET\_IPD\_FAULT gets triggered when the IPD timer overflows due to unsuccessful attempt to ramp up the current to the threshold value, same as explained in Section 7.3.22.15. The fault typically gets triggered when there is no motor connected to MCF8316C-Q1 or when the MPET IPD current threshold is set high for motors with high resistance. An error during BEMF constant measurement is reported using MPET\_BEMF\_FAULT. This fault gets triggered when the measured back EMF is less than the threshold set in STAT\_DETECT\_THR. One example of such fault scenario can be the motor stall while running in open loop due to incorrect open loop configuration used. Copyright © 2023 Texas Instruments Incorporated #### 7.3.22.15 IPD Faults The MCF8316C-Q1 uses 12-bit timers to estimate the time during the current ramp up and ramp down during IPD, when the motor start-up is configured as IPD (MTR\_STARTUP is set to 10b). During IPD, the algorithm checks for a successful current ramp-up to IPD\_CURR\_THR, starting with an IPD clock of 10MHz; if unsuccessful (timer overflow before current reaches IPD\_CURR\_THR), IPD is repeated with lower frequency clocks of 1MHz, 100kHz, and 10kHz sequentially. If the IPD timer overflows (current does not reach IPD\_CURR\_THR) with all the four clock frequencies, then the IPD\_T1\_FAULT gets triggered. Similarly the algorithm checks for a successful current decay to zero during IPD current ramp down using all the mentioned IPD clock frequencies. If the IPD timer overflows (current does not ramp down to zero) in all the four attempts, then the IPD\_T2\_FAULT gets triggered. The user can enable IPD timeout (IPD timer overflow) by setting IPD\_TIMEOUT\_FAULT\_EN to 1b. IPD gives incorrect results if the next IPD pulse is commanded before the complete decay of current due to present IPD pulse. The MCF8316C-Q1 can generate a fault called IPD\_FREQ\_FAULT during such a scenario by setting IPD\_FREQ\_FAULT\_EN to 1b. The IPD\_FREQ\_FAULT maybe triggered if the IPD frequency is too high for the IPD current limit and the IPD release mode or if the motor inductance is too high for the IPD frequency, IPD current limit and IPD release mode. On the occurrence of any IPD fault, MCF8316C-Q1 stops the IPD based start-up process and FETs are in Hi-Z. MCF8316C-Q1 automatically retries IPD based start-up after $t_{LCK\ RETRY}$ elapses. #### 7.4 Device Functional Modes #### 7.4.1 Functional Modes #### 7.4.1.1 Sleep Mode In sleep mode, the MOSFETs, sense amplifiers, buck regulator, charge pump, AVDD LDO regulator and the I<sup>2</sup>C bus are disabled. The device can be configured to enter sleep (instead of standby) mode by configuring DEV\_MODE to 1b. SPEED pin and I<sup>2</sup>C speed command determine entry and exit from sleep state as described in Table 7-7. #### 7.4.1.2 Standby Mode The device can be configured to operate as a standby device by setting DEV\_MODE to 0b. In standby mode, the charge pump, AVDD LDO, buck regulator and I<sup>2</sup>C bus are active while the motor is in stopped state waiting for a suitable non-zero speed command. SPEED pin (analog, PWM or frequency based speed input) or I<sup>2</sup>C speed command (I<sup>2</sup>C based speed input) determines entry and exit from standby state as described in Table 7-7. The thresholds for entering and exiting standby mode in different input modes are as follows, Table 7-6. Standby Mode Entry/Exit Thresholds | Input Source (SPEED_MODE) | Standby entry/exit thresholds | REF_PROFILE_CONFIG = 00b | REF_PROFILE_CONFIG ≠ 00b | | | |---------------------------|--------------------------------------------|----------------------------------------------------------------------------|--------------------------|--|--| | Analog (00b) | V <sub>EN_SB</sub> | 1% x V <sub>ANA_FS</sub> | 1% x V <sub>ANA_FS</sub> | | | | | V <sub>EX_SB</sub> | 5% x V <sub>ANA_FS</sub> | 5% x V <sub>ANA_FS</sub> | | | | PWM (01b) | Duty <sub>EX_SB/EN_SB</sub> | Maximum of (1%, DUTY_HYS) | 0% | | | | l <sup>2</sup> C (10b) | DIGITAL_SPEED_CTRL <sub>EX_SB/</sub> EN_SB | Maximum of (1%, DUTY_HYS) x<br>32767 | 0 | | | | Frequency (11b) | Freq <sub>EX_SB/EN_SB</sub> | Maximum of (1%, DUTY_HYS) x INPUT_MAXIMUM_FREQ (subject to minimum of 3Hz) | < 3Hz | | | Table 7-7. Conditions to Enter or Exit Sleep/Standby Modes | SPEED<br>COMMAND<br>MODE | ENTER STANDBY<br>CONDITION | EXIT FROM STANDBY<br>CONDITION | ENTER SLEEP CONDITION | EXIT FROM SLEEP<br>CONDITION | | |--------------------------|----------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--| | Analog | V <sub>SPEED</sub> < V <sub>EN_SB</sub> | V <sub>SPEED</sub> > V <sub>EX_SB</sub> | V <sub>SPEED</sub> < V <sub>EN_SL</sub> for t <sub>DET_SL_ANA</sub> | V <sub>SPEED</sub> > V <sub>EX_SL</sub> for t <sub>DET_ANA</sub> | | | PWM | Duty <sub>SPEED</sub> < Duty <sub>EN_SB</sub> | Duty <sub>SPEED</sub> > Duty <sub>EX_SB</sub> | $V_{SPEED} < V_{IL}$ for $t_{DET\_SL\_PWM}$ | V <sub>SPEED</sub> > V <sub>IH</sub> for t <sub>DET_PWM</sub> | | | l <sup>2</sup> C | DIGITAL_SPEED_CTRL < DIGITAL_SPEED_CTRL <sub>EN_SB</sub> | DIGITAL_SPEED_CTRL > DIGITAL_SPEED_CTRL <sub>EX_S</sub> B | DIGITAL_SPEED_CTRL is<br>set to 0b for<br>SLEEP_ENTRY_TIME and<br>V <sub>SPEED</sub> < V <sub>IL</sub> | V <sub>SPEED</sub> > V <sub>IH</sub> for t <sub>DET_PWM</sub> | | | Frequency | Freq <sub>SPEED</sub> < Freq <sub>EN_SB</sub> | Freq <sub>SPEED</sub> > Freq <sub>EX_SB</sub> | V <sub>SPEED</sub> < V <sub>IL</sub> for t <sub>DET_SL_PWM</sub> | V <sub>SPEED</sub> > V <sub>IH</sub> for t <sub>DET_PWM</sub> | | ### Note $V_{SPEED}$ : SPEED pin input voltage, Duty\_{SPEED} : SPEED pin input PWM duty, Freq\_{SPEED} : SPEED pin input frequency ### 7.4.1.3 Fault Reset (CLR\_FLT) In the case of latched faults, the device goes into a partial shutdown state to help protect the power MOSFETs and system. When the fault condition clears, the device can go to the operating state again by setting the CLR\_FLT to 1b. Copyright © 2023 Texas Instruments Incorporated ### 7.5 External Interface #### 7.5.1 DRVOFF Functionality When DRVOFF pin is driven high, all six MOSFETs are put in Hi-Z state, irrespective of speed command. If motor speed command is non-zero when DRVOFF is driven high, device may encounter a fault like no motor or abnormal BEMF. Whenever DRVOFF is driven high, it should be held high for a minimum of 10s for safe operation. #### 7.5.2 DAC outputs MCF8316C-Q1 has two 12-bit DACs which output analog voltage equivalent of digital variables on the DACOUT1 and DACOUT2 pins. The maximum DAC output voltage is 3-V. Signals available on DACOUT pins are useful in tracking internal variables in real-time and can be used for tuning speed controller or motor acceleration time. The address for variables to be tracked on DACOUT1 and DACOUT2 are configured using DACOUT1\_VAR\_ADDR and DACOUT2\_VAR\_ADDR respectively. DACOUT1 is available on pin 36 and DACOUT2 can be configured on pin 38 by setting DAC\_SOx\_SEL to 00b. DACOUT2 is also available on pin 37. DAC\_ENABLE should be configured to 1b for pins 36, 37 to function as DAC outputs. #### 7.5.3 Current Sense Output MCF8316C-Q1 can provide the built-in current sense amplifiers' output on the SOX pin. SOX output is available on pin 38 and can be configured by DAC SOx SEL. #### 7.5.4 Oscillator Source MCF8316C-Q1 has a built-in oscillator that is used as the clock source for all digital peripherals and timing measurements. Default configuration for MCF8316C-Q1 is to use the internal oscillator and it is sufficient to drive the motor without need for any external crystal or clock sources. In case MCF8316C-Q1 does not meet accuracy requirements of timing measurement or speed loop, then MCF8316C-Q1 has an option to support an external clock reference. In order to improve EMI performance, MCF8316C-Q1 provides the option of modulating the clock frequency by enabling Spread Spectrum Modulation (SSM) through SPREAD SPECTRUM MODULATION DIS. ## 7.5.4.1 External Clock Source Speed loop accuracy of MCF8316C-Q1 over the operating temperature range can be improved by providing a more accurate clock reference on EXT\_CLK pin as shown in Figure 7-53. EXT\_CLK will be used to calibrate the internal clock oscillator - this will help match the accuracy of the internal clock oscillator to that of the external clock. External clock source can be selected by configuring CLK\_SEL to 11b and setting EXT\_CLK\_EN to 1b. The external clock source frequency can be configured through EXT\_CLK\_CONFIG. Figure 7-53. External Clock Reference ### Note External clock is optional and can be used when higher clock accuracy is needed. MCF8316C-Q1 will always power up using the internal oscillator in all modes. Product Folder Links: MCF8316C-Q1 Copyright © 2023 Texas Instruments Incorporated ### 7.5.5 External Watchdog MCF8316C-Q1 provides an external watchdog feature - EXT\_WDT\_EN bit should be set to 1b to enable the external watchdog. When this feature is enabled, the device waits for a tickle (low to high transition in EXT\_WD pin, WATCHDOG\_TICKLE set to 1b in I<sup>2</sup>C mode) from the external watchdog input for a configured time interval; if the time interval between two consecutive tickles is higher than the configured time, a watchdog fault is triggered. The watchdog fault response can be configured using EXT\_WDT\_FAULT\_MODE either as a report only fault or as a latched fault with MOSFETs in Hi-Z state. The latched fault can be cleared by writing 1b to CLR\_FLT. When a watchdog timeout occurs, WATCHDOG\_FAULT bit is set to 1b. In case, the next tickle arrives before the configured time interval elapses, the watchdog timer is reset and it begins to wait for the next tickle. This can be used to continuously monitor the health of an external MCU (which is the external watchdog input) and put the MCF8316C-Q1 MOSFETs in Hi-Z, in case the external MCU is in a fault/hang state. The external watchdog input is selected using EXT\_WDT\_INPUT\_MODE and can either be the EXT\_WD pin or the I<sup>2</sup>C interface. The time interval between two tickles to trigger a watchdog fault is configured by EXT\_WDT\_CONFIG; there are 4 time settings - 100, 200, 500 and 1000ms for the EXT\_WD pin based watchdog and 4 time settings - 1, 2, 5 and 10s for the I<sup>2</sup>C based watchdog. #### Note Watchdog should be disabled by setting EXT\_WDT\_EN to 0b before changing EXT\_WDT\_CONFIG configuration. ### 7.6 EEPROM access and I<sup>2</sup>C interface #### 7.6.1 EEPROM Access MCF8316C-Q1 has 1024 bits (16 rows of 64 bits each) of EEPROM, which are used to store the motor configuration parameters. Erase operations are row-wise (all 64 bits are erased in a single erase operation), but 32-bit write and read operations are supported. EEPROM can be written and read using the I<sup>2</sup>C serial interface but erase cannot be performed using I2C serial interface. The shadow registers corresponding to the EEPROM are located at addresses 0x000080-0x0000AE. #### Note MCF8316C-Q1 allows EEPROM write and read operations only when the motor is not spinning. #### 7.6.1.1 **EEPROM Write** In MCF8316C-Q1, EEPROM write procedure is as follows, - 1. Write register 0x000080 (ISD\_CONFIG) with ISD and reverse drive configuration like resync enable, reverse drive enable, stationary detect threshold, reverse drive handoff threshold etc. - 2. Write register 0x000082 (REV DRIVE CONFIG) with reverse drive and active brake configuration like reverse drive open loop acceleration, active brake current limit, Kp, Ki values etc. - 3. Write register 0x000084 (MOTOR STARTUP1) with motor start-up configuration like start-up method, IPD parameters, align parameters etc. - 4. Write register 0x000086 (MOTOR STARTUP2) with motor start-up configuration like open loop acceleration. open loop current limit, first cycle frequency etc. - 5. Write register 0x000088 (CLOSED LOOP1) with motor control configuration like closed loop acceleration, overmodulation enable, PWM frequency, FG signal parameters etc. - 6. Write register 0x00008A (CLOSED LOOP2) with motor control configuration like motor winding resistance and inductance, motor stop options, brake speed threshold etc. - 7. Write register 0x00008C (CLOSED LOOP3) with motor control configuration like motor BEMF constant, current loop Kp, Ki etc. - 8. Write register 0x00008E (CLOSED LOOP4) with motor control configuration like speed loop Kp, Ki and maximum speed. - 9. Write register 0x000090 (FAULT CONFIG1) with fault control configuration software and hardware current limits, lock current limit and actions, retry times etc. - 10. Write register 0x000092 (FAULT CONFIG2) with fault control configuration like hardware current limit actions, OV, UV limits and actions, abnormal speed level, no motor threshold etc. - 11. Write registers 0x000094 0x00009E (SPEED\_PROFILES1-6) with speed profile configuration like profile type, duty cycle, speed clamp level, duty cycle clamp level etc. - 12. Write register 0x0000A0 (INT\_ALGO\_1) with miscellaneous configuration like ISD run time and timeout, MPET parameters etc. - 13. Write register 0x0000A2 (INT ALGO 2) with miscellaneous configuration like additional MPET parameters, IPD high resolution enable, active brake current slew rate, closed loop slow acceleration etc. - 14. Write registers 0x0000A4 (PIN\_CONFIG1) with pin configuration for speed input mode (analog or PWM), BRAKE pin mode etc. - 15. Write registers 0x0000A6 and 0x0000A8 (DEVICE CONFIG1 and DEVICE CONFIG2) with device configuration like pins 36, 37 configuration, pin 38 configuration, dynamic CSA gain enable, dynamic voltage gain enable, clock source select, speed range select etc. - 16. Write register 0x0000AA (PERI\_CONFIG1) with peripheral configuration like dead time, bus current limit, DIR input, SSM enable etc. - 17. Write registers 0x0000AC and 0x0000AE (GD CONFIG1 and GD CONFIG2) with gate driver configuration like slew rate, CSA gain, OCP level, mode, OVP enable, level, buck voltage level, buck current limit etc. - 18. Write 0x8A500000 into register 0x0000EA to write the shadow register(0x000080-0x0000AE) values into the EEPROM. - 19. Wait for 300ms for the EEPROM write operation to complete Steps 1-17 can be selectively executed based on registers/parameters that need to be modified. After all shadow registers have been updated with the required values, step 18 should be executed to copy the contents of the shadow registers into the EEPROM. #### 7.6.1.2 EEPROM Read In MCF8316C-Q1, EEPROM read procedure is as follows, - 1. Write 0x4000000 into register 0x0000EA to read the EEPROM data into the shadow registers (0x000080-0x0000AE). - 2. Wait for 100ms for the EEPROM read operation to complete. - 3. Read the shadow register values,1 or 2 registers at a time, using the I<sup>2</sup>C read command as explained in Section 7.6.2. Shadow register addresses are in the range of 0x000080-0x0000AE. Register address increases in steps of 2 for 32-bit read operation (since each address is a 16-bit location). #### 7.6.2 I<sup>2</sup>C Serial Interface MCF8316C-Q1 interfaces with an external MCU over an $I^2C$ serial interface. MCF8316C-Q1 is an $I^2C$ target to be interfaced with a controller. External MCU can use this interface to read/write from/to any non-reserved register in MCF8316C-Q1. #### Note For reliable communication, a 100- $\mu$ s delay should be used between every byte transferred over the $I^2C$ bus. #### 7.6.2.1 I<sup>2</sup>C Data Word The I<sup>2</sup>C data word format is shown in Table 7-8. #### Table 7-8. I<sup>2</sup>C Data Word Format | TARGET_ID | R/W | CONTROL WORD | DATA | CRC-8 | |-----------|-----|--------------|---------------------|---------| | A6 - A0 | W0 | CW23 - CW0 | D15 / D31/ D63 - D0 | C7 - C0 | **Target ID and R/W Bit**: The first byte includes the 7-bit $I^2C$ target ID, followed by the read/write command bit. Every packet in MCF8316C-Q1 the communication protocol starts with writing a 24-bit control word and hence the R/W bit is always 0. **24-bit Control Word**: The Target Address is followed by a 24-bit control bit. The control word format is shown in Table 7-9. #### Table 7-9. 24-bit Control Word Format | OP_R/W | CRC_EN | DLEN | MEM_SEC | MEM_PAGE | MEM_ADDR | |--------|--------|------------|-------------|-------------|------------| | CW23 | CW22 | CW21- CW20 | CW19 - CW16 | CW15 - CW12 | CW11 - CW0 | Each field in the control word is explained in detail below. **OP\_R/W – Read/Write**: R/W bit gives information on whether this is a read (1b) operation or write (0b) operation. For write operation, MCF8316C-Q1 will expect data bytes to be sent after the 24-bit control word. For read operation, MCF8316C-Q1 will expect an I<sup>2</sup>C read request with repeated start or normal start after the 24-bit control word. **CRC\_EN – Cyclic Redundancy Check(CRC) Enable**: MCF8316C-Q1 supports CRC to verify the data integrity. This bit controls whether the CRC feature is enabled or not. **DLEN – Data Length**: DLEN field determines the length of the data that will be sent by external MCU to MCF8316C-Q1. MCF8316C-Q1 protocol supports three data lengths: 16-bit, 32-bit and 64-bit. Table 7-10. Data Length Configuration | DLEN Value | Data Length | |------------|-------------| | 00b | 16-bit | Copyright © 2023 Texas Instruments Incorporated **Table 7-10. Data Length Configuration (continued)** | DLEN Value | Data Length | | | | | |------------|-------------|--|--|--|--| | 01b | 32-bit | | | | | | 10b | 64-bit | | | | | | 11b | Reserved | | | | | **MEM\_SEC – Memory Section**: Each memory location in MCF8316C-Q1 is addressed using three separate entities in the control word – Memory Section, Memory Page, Memory Address. Memory Section is a 4-bit field which denotes the memory section to which the memory location belongs like RAM, ROM etc. **MEM\_PAGE – Memory Page**: Memory page is a 4-bit field which denotes the memory page to which the memory location belongs. **MEM\_ADDR – Memory Address**: Memory address is the last 12-bits of the address. The complete 22-bit address is constructed internally by MCF8316C-Q1 using all three fields – Memory Section, Memory Page, Memory Address. For memory locations 0x0000000-0x000800, memory section is 0x0, memory page is 0x0 and memory address is the lowest 12 bits(0x000 for 0x000000, 0x080 for 0x000080 and 0x800 for 0x000800). All relevant memory locations (EEPROM and RAM variables) have MEM\_SEC and MEM\_PAGE values both corresponding to 0x0. All other MEM\_SEC, MEM\_PAGE values are reserved and not for external use. **Data Bytes**: For a write operation to MCF8316C-Q1, the 24-bit control word is followed by data bytes. The DLEN field in the control word should correspond with the number of bytes sent in this section. In case of mismatch between number of data bytes and DLEN, the write operation is discarded. **CRC Byte**: If the CRC feature is enabled in the control word, CRC byte has to be sent at the end of a write transaction. Refer to Section 7.6.2.6 for detailed information on CRC byte calculation. #### 7.6.2.2 I<sup>2</sup>C Write Transaction MCF8316C-Q1 write transaction over I<sup>2</sup>C involves the following sequence (see Figure 7-54). - 1. I<sup>2</sup>C start condition. - 2. Start is followed by the I<sup>2</sup>C target ID byte, made up of 7-bit target ID along with the R/W bit set to 0b. ACK in yellow box indicates that MCF8316C-Q1 has processed the received target ID which has matched with it's I<sup>2</sup>C target ID and therefore will proceed with this transaction. If target ID received does not match with the I<sup>2</sup>C ID of MCF8316C-Q1, then the transaction is ignored, and no ACK is sent by MCF8316C-Q1. - 3. The target ID byte is followed by the 24-bit control word sent one byte at a time. Bit 23 in the control word is 0b as it is a write transaction. ACK in blue boxes correspond to acknowledgements sent by MCF8316C-Q1 to the controller that the previous byte (of control word) has been received and next byte can be sent. - 4. The 24-bit control word is then followed by the data bytes. The number of data bytes sent by the controller depends on the DLEN field in the control word. - a. While sending data bytes, the LSB byte is sent first. Refer to Section 7.6.2.4 for more details. - b. 16-bit/32-bit write The data sent is written to the address mentioned in control word. - c. 64-bit Write 64-bit is treated as two successive 32-bit writes. The address mentioned in control word is taken as Addr\_1. Addr\_2 is internally calculated by MCF8316C-Q1 by incrementing Addr\_1 by 0x2. A total of 8 data bytes are sent. The first 4 bytes (sent in LSB first) are written to Addr\_1 and the next 4 bytes are written to Addr\_2. - d. ACK in blue boxes (after every data byte) correspond to the acknowledgement sent by MCF8316C-Q1 to the controller that the previous data byte has been received and next data byte can be sent. - 5. If CRC is enabled, the packet ends with a CRC byte. CRC is calculated for the entire packet (Target ID + W bit, Control Word, Data Bytes). MCF8316C-Q1 will send an ACK on receiving the CRC byte. - 6. I<sup>2</sup>C Stop condition from the controller to terminate the transaction. CRC includes {TARGET ID,0}, CONTROL WORD[23:0], DATA BYTES Figure 7-54. I<sup>2</sup>C Write Transaction Sequence #### 7.6.2.3 I<sup>2</sup>C Read Transaction MCF8316C-Q1 read transaction over I<sup>2</sup>C involves the following sequence (see Figure 7-55). - 1. I<sup>2</sup>C Start condition from the controller to initiate the transaction. - 2. Start is followed by the I<sup>2</sup>C target ID byte, made up of 7-bit target ID along with the R/W bit set to 0b. ACK (in yellow box) indicates that MCF8316C-Q1 has processed the received target ID which has matched with it's I<sup>2</sup>C target ID and therefore will proceed with this transaction. If target ID received does not match with the I<sup>2</sup>C ID of MCF8316C-Q1, then the transaction is ignored and no ACK is sent by MCF8316C-Q1. - 3. The target ID byte is followed by the 24-bit control word sent one byte at a time. Bit 23 in the control word is set to 1b as it is a read transaction. ACK (in blue boxes) correspond to acknowledgements sent by MCF8316C-Q1 to the controller that the previous byte (of control word) has been received and next byte can be sent. - 4. The control word is followed by a Repeated Start (RS, start without a preceding stop) or normal Start (P followed by S) to initiate the data (to be read back) transfer from MCF8316C-Q1 to I<sup>2</sup>C controller. RS or S is followed by the 7-bit target ID along with R/W bit set to 1b to initiate the read transaction. MCF8316C-Q1 sends an ACK (in grey box after RS) to the controller to acknowledge the receipt of read transaction request. - 5. Post acknowledgement of read transaction request, MCF8316C-Q1 sends the data bytes on SDA one byte at a time. The number of data bytes sent by MCF8316C-Q1 depends on the DLEN field in the control word. - a. While sending data bytes, the LSB byte is sent first. Refer the examples in Section 7.6.2.4 for more details. - b. 16-bit/32-bit Read The data from the address mentioned in control word is sent back to the controller. - c. 64-bit Read 64-bit is treated as two successive 32-bit reads. The address mentioned in control word is taken as Addr\_1. Addr\_2 is internally calculated by MCF8316C-Q1 by incrementing Addr\_1 by 0x2. A total of 8 data bytes are sent by MCF8316C-Q1. The first 4 bytes (sent in LSB first) are read from Addr\_1 and the next 4 bytes are read from Addr\_2. - d. ACK in orange boxes correspond to acknowledgements sent by the controller to MCF8316C-Q1 that the previous byte has been received and next byte can be sent. - 6. If CRC is enabled in the control word, then MCF8316C-Q1 sends an additional CRC byte at the end. Controller has to read the CRC byte and then send the last ACK (in orange). CRC is calculated for the entire packet (Target ID + W bit, Control Word, Target ID + R bit, Data Bytes). - 7. I<sup>2</sup>C Stop condition from the controller to terminate the transaction. CRC includes {TARGET ID,0}, CONTROL WORD[23:0], {TARGET ID,1}, DATA BYTES Figure 7-55. I<sup>2</sup>C Read Transaction Sequence ## 7.6.2.4 I<sup>2</sup>C Communication Protocol Packet Examples All values used in this example section are in hex format. I<sup>2</sup>C target ID used in the examples is 0x60. **Example for 32-bit Write Operation**: Address – 0x00000080, Data – 0x1234ABCD, CRC Byte – 0x45 (Sample value; does not match with the actual CRC calculation) Table 7-11. Example for 32-bit Write Operation Packet | Start Byte | | Control V | Vord 0 | | | - | | Control<br>Word 2 | Data Bytes | | | CRC | | |--------------|---------------------------|------------|------------|---------------|---------------|---------------|--------------|-------------------|------------|-------|-------|-------|-------------| | Target<br>ID | I <sup>2</sup> C<br>Write | OP_R/<br>W | CRC_E<br>N | DLEN | MEM_S<br>EC | MEM_P<br>AGE | MEM_A<br>DDR | MEM_A<br>DDR | DB0 | DB1 | DB2 | DB3 | CRC<br>Byte | | A6-A0 | W0 | CW23 | CW22 | CW21-<br>CW20 | CW19-<br>CW16 | CW15-<br>CW12 | CW11-<br>CW8 | CW7-<br>CW0 | D7-D0 | D7-D0 | D7-D0 | D7-D0 | C7-C0 | | 0x60 | 0x0 | 0x0 | 0x1 | 0x1 | 0x0 | 0x0 | 0x0 | 0x80 | 0xCD | 0xAB | 0x34 | 0x12 | 0x45 | | 0xC0 | | 0x50 | | | 0x00 | | 0x80 | 0xCD | 0xAB | 0x34 | 0x12 | 0x45 | | **Example for 64-bit Write Operation**: Address - 0x00000080, Data Address 0x00000080 - Data 0x01234567, Data Address 0x00000082 - Data 0x89ABCDEF, CRC Byte - 0x45 (Sample value; does not match with the actual CRC calculation) Table 7-12. Example for 64-bit Write Operation Packet | Start Byte Control Word 0 | | | ord 0 | | | Control Word 1 | | Control Word<br>2 | Data Bytes | CRC | |---------------------------|---------------------------|--------|--------|---------------|--------------------|----------------|----------|-------------------|--------------------|-------------| | Target<br>ID | I <sup>2</sup> C<br>Write | OP_R/W | CRC_EN | DLEN | MEM_SEC | MEM_PAGE | MEM_ADDR | MEM_ADDR | DB0 - DB7 | CRC<br>Byte | | A6-A0 | W0 | CW23 | CW22 | CW21-<br>CW20 | CW19-<br>CW16 | CW15-<br>CW12 | CW11-CW8 | CW7-CW0 | [D7-D0] x 8 | C7-C0 | | 0x60 | 0x0 | 0x0 | 0x1 | 0x2 | 0x0 | 0x0 | 0x0 | 0x80 | 0x67452301EFCDAB89 | 0x45 | | 0xC0 0x60 | | 0x00 | | 0x80 | 0x67452301EFCDAB89 | 0x45 | | | | | **Example for 32-bit Read Operation**: Address – 0x00000080, Data – 0x1234ABCD, CRC Byte – 0x56 (Sample value; does not match with the actual CRC calculation) Table 7-13. Example for 32-bit Read Operation Packet | Start Byte | | Control Word 0 | | | Control Word 1 Control Word 2 | | Start Byte | | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 4 | | | |--------------|---------------------------|----------------|------------|---------------|-------------------------------|---------------|--------------|--------------|--------------|--------------------------|--------|--------|--------|-------|-------------| | Target<br>ID | I <sup>2</sup> C<br>Write | R/W | CRC_<br>EN | DLEN | MEM_<br>SEC | MEM_<br>PAGE | MEM_<br>ADDR | MEM_<br>ADDR | Target<br>ID | I <sup>2</sup> C<br>Read | DB0 | DB1 | DB2 | DB3 | CRC<br>Byte | | A6-A0 | W0 | CW23 | CW22 | CW21-<br>CW20 | CW19-<br>CW16 | CW15-<br>CW12 | CW11-<br>CW8 | CW7-<br>CW0 | A6-A0 | W0 | D7-D0 | D7-D0 | D7-D0 | D7-D0 | C7-C0 | | 0x60 | 0x0 | 0x1 | 0x1 | 0x1 | 0x0 | 0x0 | 0x0 | 0x80 | 0x60 | 0x1 | 0xCD | 0xAB | 0x34 | 0x12 | 0x56 | | 0xC0 | • | 0xD0 | • | | • | 0x00 | | 0x80 | 0xC1 | | 0xCD | 0xAB | 0x34 | 0x12 | 0x56 | ### 7.6.2.5 I<sup>2</sup>C Clock Stretching The $I^2C$ peripheral in MCF8316C-Q1 implements clock stretching under certain conditions when there are pending $I^2C$ interrupts waiting to be processed. During clock stretching, MCF8316C-Q1 pulls SCL low and the $I^2C$ bus is unavailable for use by other devices. The following is a list of conditions under which clock stretching can occur: - 1. Start interrupt pending: There are two scenarios when a start interrupt can result in clock stretching, - a. When target ID is a match, I<sup>2</sup>C peripheral in MCF8316C-Q1 raises a start interrupt request. Until this start interrupt request is processed, clock is stretched. Upon processing this request, clock is released and an ACK (marked in yellow or grey in Figure 7-54 and Figure 7-55) is sent to the controller for continuing with the transaction. - b. If Start (followed by target ID match) for a new transaction is received when a receive interrupt from previous transaction is yet to be processed, clock is stretched until both the receive interrupt and start interrupt are processed in chronological order. This process ensures that previous transaction is executed correctly before initiating the next transaction. - 2. Receive interrupt pending: When a receive interrupt is waiting to be processed and the receive register is full which occurs when two successive bytes (data or control) have been received by MCF8316C-Q1 (separated by one ACK shown as blue boxes in Figure 7-54 and Figure 7-55) without the receive interrupt generated by the first byte being processed. Upon receive of second byte, clock is stretched until receive interrupt generated by the first byte is processed. - 3. **Transmit buffer is empty**: In case of a transmit interrupt pending (to send data back to controller), if the transmit buffer is waiting to be populated with data to be read back to the controller, clock stretching is done until the transmit buffer is populated with requested data. After the buffer is populated, clock is released and data is sent to controller. #### Note I<sup>2</sup>C clock stretching is timed out after 5 ms by MCF8316C-Q1 to allow I<sup>2</sup>C bus access for other devices on the same bus. ### 7.6.2.6 CRC Byte Calculation An 8-bit CCIT polynomial ( $x^8 + x^2 + x + 1$ ) and CRC initial value 0xFF is used for CRC computation. **CRC Calculation in Write Operation**: When the external MCU writes to MCF8316C-Q1, if the CRC is enabled, the external MCU has to compute an 8-bit CRC byte and add the CRC byte at the end of the data. MCF8316C-Q1 will compute CRC using the same polynomial internally and if there is a mismatch, the write request is discarded. Input data for CRC calculation by external MCU for write operation are listed below: - 1. Target ID + write bit. - 2. Control word 3 bytes - 3. Data bytes 2/4/8 bytes **CRC Calculation in Read Operation**: When the external MCU reads from MCF8316C-Q1, if the CRC is enabled, MCF8316C-Q1 sends the CRC byte at the end of the data. The CRC computation in read operation involves the start byte, control words sent by external MCU along with data bytes sent by MCF8316C-Q1. Input data for CRC calculation by external MCU to verify the data sent by MCF8316C-Q1 are listed below: - 1. Target ID + write bit - 2. Control word 3 bytes - 3. Target ID + read bit - 4. Data bytes 2/4/8 bytes # 7.7 EEPROM (Non-Volatile) Register Map # 7.7.1 Algorithm\_Configuration Registers Table 7-14 lists the memory-mapped registers for the Algorithm\_Configuration registers. All register offset addresses not listed in Table 7-14 should be considered as reserved locations and the register contents should not be modified. Table 7-14. ALGORITHM\_CONFIGURATION Registers | Offset | Acronym | Register Name | Section | |--------|------------------|----------------------------------|---------| | 80h | ISD_CONFIG | ISD Configuration | Go | | 82h | REV_DRIVE_CONFIG | Reverse Drive Configuration | Go | | 84h | MOTOR_STARTUP1 | Motor Startup Configuration1 | Go | | 86h | MOTOR_STARTUP2 | Motor Startup Configuration2 | Go | | 88h | CLOSED_LOOP1 | Close Loop Configuration1 | Go | | 8Ah | CLOSED_LOOP2 | Close Loop Configuration2 | Go | | 8Ch | CLOSED_LOOP3 | Close Loop Configuration3 | Go | | 8Eh | CLOSED_LOOP4 | Close Loop Configuration4 | Go | | 94h | REF_PROFILES1 | Reference Profile Configuration1 | Go | | 96h | REF_PROFILES2 | Reference Profile Configuration2 | Go | | 98h | REF_PROFILES3 | Reference Profile Configuration3 | Go | | 9Ah | REF_PROFILES4 | Reference Profile Configuration4 | Go | | 9Ch | REF_PROFILES5 | Reference Profile Configuration5 | Go | | 9Eh | REF_PROFILES6 | Reference Profile Configuration6 | Go | Complex bit access types are encoded to fit into small table cells. Table 7-15 shows the codes that are used for access types in this section. Table 7-15. Algorithm\_Configuration Access Type Codes | Access Type | Code | Description | | | | | | | |------------------|-------|----------------------------------------|--|--|--|--|--|--| | Read Type | | | | | | | | | | R | R | Read | | | | | | | | Write Type | | | | | | | | | | W | W | Write | | | | | | | | Reset or Default | Value | | | | | | | | | -n | | Value after reset or the default value | | | | | | | # 7.7.1.1 ISD\_CONFIG Register (Offset = 80h) [Reset = 00000000h] ISD\_CONFIG is shown in Figure 7-56 and described in Table 7-16. Return to the Summary Table. Register to configure initial speed detect settings ## Figure 7-56. ISD CONFIG Register | rigure 7-30. IOD_CONTIO Register | | | | | | | | | |----------------------------------|----------|----------|-----------------------|------------|-------------------------------|------------------|----------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED ISD_EN | | BRAKE_EN | HIZ_EN | RVS_DR_EN | RESYNC_EN | FW_DRV_RESYN_THR | | | | R/W-0h R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/V | V-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | FW_DRV_R | ESYN_THR | BRK_MODE | BRK_CONFIG | | BRK_CURR_THE | 2 | BRK_TIME | | | R/M | /-0h | R/W-0h | R/W-0h | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 10 | | 9 | 8 | | | | BRK_TIME | | HIZ_TIME STAT_DETETHR | | | | | | | | R/W-0h | | | R/W | V-0h | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | STAT_DET | ECT_THR | | REV_DRV_HA | ANDOFF_THR | REV_DRV_OPEN_LOOP_CURR<br>ENT | | | | | R/M | /-0h | | R/W | /-0h | R/W-0h | | | | ## Table 7-16. ISD\_CONFIG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|-----------|------|-------|---------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30 | ISD_EN | R/W | Oh | ISD Enable 0h = Disable 1h = Enable | | 29 | BRAKE_EN | R/W | 0h | Brake enable 0h = Disable 1h = Enable | | 28 | HIZ_EN | R/W | Oh | Hi-Z enable 0h = Disable 1h = Enable | | 27 | RVS_DR_EN | R/W | Oh | Reverse Drive Enable 0h = Disable 1h = Enable | | 26 | RESYNC_EN | R/W | Oh | Resynchronization Enable 0h = Disable 1h = Enable | # Table 7-16. ISD\_CONFIG Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 25-22 | FW_DRV_RESYN_THR | R/W | Oh | Minimum Speed threshold to resynchronize to close loop (% of MAX_SPEED) 0h = 5% 1h = 10% 2h = 15% 3h = 20% 4h = 25% 5h = 30% 6h = 35% 7h = 40% 8h = 45% 9h = 50% Ah = 55% Bh = 60% Ch = 70% Dh = 80% Eh = 90% Fh = 100% | | 21 | BRK_MODE | R/W | 0h | Brake mode 0h = All three high side FETs turned ON 1h = All three low side FETs turned ON | | 20 | BRK_CONFIG | R/W | 0h | Brake configuration 0h = Brake time is used to exit Brake state 1h = Brake current threshold and Brake time are used to exit Brake state | | 19-17 | BRK_CURR_THR | R/W | Oh | Brake current threshold<br>0h = 0.1 A<br>1h = 0.2 A<br>2h = 0.3 A<br>3h = 0.5 A<br>4h = 1.0 A<br>5h = 2.0 A<br>6h = 4.0 A<br>7h = 8.0 A | | 16-13 | BRK_TIME | R/W | Oh | Brake time 0h = 10 ms 1h = 50 ms 2h = 100 ms 3h = 200 ms 4h = 300 ms 5h = 400 ms 6h = 500 ms 7h = 750 ms 8h = 1 s 9h = 2 s Ah = 3 s Bh = 4 s Ch = 5 s Dh = 7.5 s Eh = 10 s Fh = 15 s | Product Folder Links: MCF8316C-Q1 # Table 7-16. ISD\_CONFIG Register Field Descriptions (continued) | D:4 | | | | Posserintian | |------|-------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 12-9 | HIZ_TIME | R/W | Oh | Hi-Z time 0h = 10 ms 1h = 50 ms 2h = 100 ms 3h = 200 ms 4h = 300 ms 5h = 400 ms 6h = 500 ms 7h = 750 ms 8h = 1 s 9h = 2 s Ah = 3 s Bh = 4 s Ch = 5 s Dh = 7.5 s Eh = 10 s Fh = 15 s | | 8-6 | STAT_DETECT_THR | R/W | Oh | BEMF threshold to detect if motor is stationary 0h = 50 mV 1h = 75 mV 2h = 100 mV 3h = 250 mV 4h = 500 mV 5h = 750 mV 6h = 1000 mV 7h = 1500 mV | | 5-2 | REV_DRV_HANDOFF_T<br>HR | R/W | Oh | Speed threshold used to transition to open loop during reverse drive (% of MAX_SPEED) 0h = 2.5% 1h = 5% 2h = 7.5% 3h = 10% 4h = 12.5% 5h = 15% 6h = 20% 7h = 25% 8h = 30% 9h = 40% Ah = 50% Bh = 60% Ch = 70% Dh = 80% Eh = 90% Fh = 100% | | 1-0 | REV_DRV_OPEN_LOOP<br>_CURRENT | R/W | 0h | Open loop current limit during reverse drive 0h = 1.5 A 1h = 2.5 A 2h = 3.5 A 3h = 5.0 A | # 7.7.1.2 REV\_DRIVE\_CONFIG Register (Offset = 82h) [Reset = 00000000h] REV\_DRIVE\_CONFIG is shown in Figure 7-57 and described in Table 7-17. Return to the Summary Table. Register to configure reverse drive settings ## Figure 7-57. REV DRIVE CONFIG Register | | | i igaic i | -31. INE V_DIN | V | i togistoi | | | |------------------------------------|----------|--------------|----------------|-----------|------------|--------------|----------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | R | EV_DRV_OPEN_ | LOOP_ACCEL_A | <b>\1</b> | REV_DRV | _OPEN_LOOP_A | ACCEL_A2 | | R/W-0h | | R/V | V-0h | | | R/W-0h | | | 23 | 22 21 20 | | | | 18 | 17 | 16 | | REV_DRV_OP<br>EN_LOOP_AC<br>CEL_A2 | ACTIVE_ | BRAKE_CURRE | NT_LIMIT | | ACTIVE_B | RAKE_KP | | | R/W-0h | R/W-0h | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | ACTIVE_E | BRAKE_KP | | | ACTIVE_E | BRAKE_KI | | | R/W-0h | | | | | R/W | /-0h | | 7 | 6 5 4 | | | 3 | 2 | 1 | 0 | | | | | ACTIVE_E | BRAKE_KI | | | | | | R/W-0h | | | | | | | ## Table 7-17. REV\_DRIVE\_CONFIG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-27 | REV_DRV_OPEN_LOOP<br>_ACCEL_A1 | R/W | Oh | Open loop acceleration coefficient A1 during reverse drive 0h = 0.01 Hz/s 1h = 0.05 Hz/s 2h = 1 Hz/s 3h = 2.5 Hz/s 4h = 5 Hz/s 5h = 10 Hz/s 6h = 25 Hz/s 7h = 50 Hz/s 8h = 75 Hz/s 9h = 100 Hz/s Ah = 250 Hz/s Bh = 500 Hz/s Ch = 750 Hz/s Dh = 1000 Hz/s Eh = 5000 Hz/s Fh = 10000 Hz/s | Table 7-17. REV\_DRIVE\_CONFIG Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (Softanded) | |-------|--------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26-23 | REV_DRV_OPEN_LOOP<br>_ACCEL_A2 | R/W | Oh | Open loop acceleration coefficient A2 during reverse drive 0h = 0.0 Hz/s2 1h = 0.05 Hz/s2 2h = 1 Hz/s2 3h = 2.5 Hz/s2 4h = 5 Hz/s2 5h = 10 Hz/s2 6h = 25 Hz/s2 7h = 50 Hz/s2 8h = 75 Hz/s2 9h = 100 Hz/s2 Ah = 250 Hz/s2 Bh = 500 Hz/s2 Ch = 750 Hz/s2 Dh = 1000 Hz/s2 Eh = 5000 Hz/s2 Fh = 10000 Hz/s2 Fh = 10000 Hz/s2 Fh = 10000 Hz/s2 | | 22-20 | ACTIVE_BRAKE_CURRE<br>NT_LIMIT | R/W | Oh | Bus current limit during active braking 0h = 0.5 A 1h = 1 A 2h = 2 A 3h = 3 A 4h = 4 A 5h = 5 A 6h = 6 A 7h = 7 A | | 19-10 | ACTIVE_BRAKE_KP | R/W | 0h | 10-bit value for active braking loop Kp. Kp = ACTIVE_BRAKE_KP / $2^7$ | | 9-0 | ACTIVE_BRAKE_KI | R/W | 0h | 10-bit value for active braking loop Ki. Ki = ACTIVE_BRAKE_KI / 29 | # 7.7.1.3 MOTOR\_STARTUP1 Register (Offset = 84h) [Reset = 00000000h] MOTOR\_STARTUP1 is shown in Figure 7-58 and described in Table 7-18. Return to the Summary Table. Register to configure motor startup settings1 ## Figure 7-58. MOTOR STARTUP1 Register | | | ga.o | 000 | 0:\ | tog.oto. | | | |----------|------------|--------|-------|----------------------|---------------|---------------------|--------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | MTR_S | TARTUP | | ALIGN_SLOW | _RAMP_RATE | | ALIGN_TIME | | R/W-0h | R/W | /-0h | | R/V | V-0h | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | ALIGN_TIME | | | ALIGN_OR_SLOW | _CURRENT_ILIM | IIT | IPD_CLK_FRE Q | | | R/W-0h | | | R/V | V-0h | | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | IPD_CLI | K_FREQ | | | IPD_CURR_THR | | | IPD_RLS_MOD<br>E | | R/V | V-0h | | | R/W-0h | | | R/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | IPD_AD\ | /_ANGLE | IPD_R | EPEAT | OL_ILIMIT_CO<br>NFIG | IQ_RAMP_EN | ACTIVE_BRAK<br>E_EN | REV_DRV_CO<br>NFIG | | R/V | V-0h | R/W | /-0h | R/W-0h | R/W-0h | R/W-0h | R/W-0h | ## Table 7-18. MOTOR STARTUP1 Register Field Descriptions | | Tuble 7 To: Mo Fort_OTAICTOT Freeglotes Field Beschptions | | | | | | | |-------|-----------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 31 | RESERVED | R/W | 0h | Reserved | | | | | 30-29 | MTR_STARTUP | R/W | 0h | Motor start-up method 0h = Align 1h = Double Align 2h = IPD 3h = Slow first cycle | | | | | 28-25 | ALIGN_SLOW_RAMP_RA<br>TE | R/W | Oh | Align, slow first cycle and open loop current ramp rate 0h = 0.1 A/s 1h = 1 A/s 2h = 5 A/s 3h = 10 A/s 4h = 15 A/s 5h = 25 A/s 6h = 50 A/s 7h = 100 A/s 8h = 150 A/s 9h = 200 A/s Bh = 250 A/s Ch = 1000 A/s Ch = 1000 A/s Ch = 1000 A/s Ch = 5000 A/s Fh = No Limit A/s | | | | | Bit | Field | Type | Reset | Description | |-------|----------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 24-21 | ALIGN_TIME | R/W | Oh | Align time 0h = 10 ms 1h = 50 ms 2h = 100 ms 3h = 200 ms 4h = 300 ms 5h = 400 ms 6h = 500 ms 7h = 750 ms 8h = 1 s 9h = 1.5 s Ah = 2 s Bh = 3 s Ch = 4 s Dh = 5 s Eh = 7.5 s Fh = 10 s | | 20-17 | ALIGN_OR_SLOW_CUR<br>RENT_ILIMIT | R/W | Oh | Align or slow first cycle current limit 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | | 16-14 | IPD_CLK_FREQ | R/W | Oh | IPD Clock Frequency 0h = 50 Hz 1h = 100 Hz 2h = 250 Hz 3h = 500 Hz 4h = 1000 Hz 5h = 2000 Hz 6h = 5000 Hz 7h = 10000 Hz | | Bit | Field | Туре | Reset | Description | |------|------------------|---------|-------|--------------------------------------------------------------------| | 13-9 | IPD_CURR_THR | R/W | 0h | IPD Current Threshold | | | | | ••• | 0h = 0.25 A | | | | | | 1h = 0.5 A | | | | | | 2h = 0.75 A | | | | | | 3h = 1.0 A | | | | | | 4h = 1.25 A | | | | | | 5h = 1.5 A | | | | | | 6h = 2.0 A | | | | | | 7h = 2.5 A | | | | | | 8h = 3.0 A | | | | | | | | | | | | 9h = 3.667 A | | | | | | Ah = 4.0 A | | | | | | Bh = 4.667 A | | | | | | Ch = 5.0 A | | | | | | Dh = 5.333 A | | | | | | Eh = 6.0 A | | | | | | Fh = 6.667 A | | | | | | 10h = 7.333 A | | | | | | 11h = 8.0 A | | | | | | 12h = Not Applicable | | | | | | 13h = Not Applicable | | | | | | 14h = Not Applicable | | | | | | 15h = Not Applicable | | | | | | 16h = Not Applicable | | | | | | 17h = Not Applicable | | | | | | 18h = Not Applicable | | | | | | 19h = Not Applicable | | | | | | 1Ah = Not Applicable | | | | | | 1Bh = Not Applicable | | | | | | 1Ch = Not Applicable | | | | | | 1Dh = Not Applicable | | | | | | 1Eh = Not Applicable | | | | | | 1Fh = Not Applicable | | | IDD DI O MODE | D04/ | 01 | 11 | | 8 | IPD_RLS_MODE | R/W | 0h | IPD release mode | | | | | | 0h = Brake | | | | | | 1h = Tristate | | 7-6 | IPD_ADV_ANGLE | R/W | 0h | IPD advance angle | | | | | | 0h = 0° | | | | | | 1h = 30° | | | | | | 2h = 60° | | | | | | 3h = 90° | | | IDD DEDE:T | | | | | 5-4 | IPD_REPEAT | R/W | 0h | Number of times IPD is executed | | | | | | 0h = 1 time | | | | | | 1h = 2 times | | | | | | 2h = 3 times | | | | | | 3h = 4 times | | 3 | OL_ILIMIT_CONFIG | R/W | 0h | Open loop current limit configuration | | | | ' ' ' ' | 011 | 0h = Open loop current limit defined by OL_ILIMIT | | | | | | 1h = Open loop current limit defined by ULIMIT | | | | | | | | 2 | IQ_RAMP_EN | R/W | 0h | Iq ramp down for transition from open loop to closed loop | | | | | | 0h = Disable Iq ramp down | | | | | | 1h = Enable Iq ramp down | | 1 | ACTIVE RDAKE EN | R/W | 0h | | | ' | ACTIVE_BRAKE_EN | LC/ VV | UII | Enables active braking during deceleration | | | | | | 0h = Disable Active Brake | | | | | | 1h = Enable Active Brake | | 0 | REV_DRV_CONFIG | R/W | 0h | Choose between forward and reverse drive setting for reverse drive | | | | | | 0h = Open loop current, A1, A2 based on forward drive | | | | | | 1h = Open loop current, A1, A2 based on reverse drive | | | | | | , , , , , , , , , , , , , , , , , , , , | ## 7.7.1.4 MOTOR\_STARTUP2 Register (Offset = 86h) [Reset = 00000000h] MOTOR\_STARTUP2 is shown in Figure 7-59 and described in Table 7-19. Return to the Summary Table. Register to configure motor startup settings2 ### Figure 7-59. MOTOR STARTUP2 Register ## Table 7-19. MOTOR\_STARTUP2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-27 | OL_ILIMIT | R/W | Oh | Open Loop current limit 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | | Bit | Field | Type | Reset | Description (continued) | |-------|-----------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26-23 | OL_ACC_A1 | R/W | Oh | Open loop acceleration coefficient A1 0h = 0.01 Hz/s 1h = 0.05 Hz/s 2h = 1 Hz/s 3h = 2.5 Hz/s 4h = 5 Hz/s 5h = 10 Hz/s 6h = 25 Hz/s 7h = 50 Hz/s 8h = 75 Hz/s 9h = 100 Hz/s Ah = 250 Hz/s Bh = 500 Hz/s Ch = 750 Hz/s Dh = 1000 Hz/s Eh = 5000 Hz/s Fh = 10000 Hz/s | | 22-19 | OL_ACC_A2 | R/W | Oh | Open loop acceleration coefficient A2 0h = 0.0 Hz/s2 1h = 0.05 Hz/s2 2h = 1 Hz/s2 3h = 2.5 Hz/s2 4h = 5 Hz/s2 5h = 10 Hz/s2 6h = 25 Hz/s2 7h = 50 Hz/s2 8h = 75 Hz/s2 9h = 100 Hz/s2 Bh = 550 Hz/s2 Bh = 550 Hz/s2 Ch = 750 Hz/s2 Dh = 1000 Hz/s2 Eh = 5000 Hz/s2 Fh = 10000 Hz/s2 Fh = 10000 Hz/s2 | | 18 | AUTO_HANDOFF_EN | R/W | 0h | Auto Handoff Enable 0h = Disable Auto Handoff (and use OPN_CL_HANDOFF_THR) 1h = Enable Auto Handoff | | Bit | Field | Туре | Reset | Description | |-----------|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit 17-13 | | | | Open to closed loop handoff threshold (% of MAX_SPEED) 0h = 1% 1h = 2% 2h = 3% 3h = 4% 4h = 5% 5h = 6% 6h = 7% 7h = 8% 8h = 9% 9h = 10% Ah = 11% Bh = 12% Ch = 13% Dh = 14% Eh = 15% Fh = 16% 10h = 17% 11h = 18% 12h = 19% 13h = 20% 14h = 22.5% 15h = 25% 16h = 27.5% | | | | | | 13h = 20%<br>14h = 22.5%<br>15h = 25% | | Bit | Field | Туре | Reset | Description | |------|--------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12-8 | ALIGN_ANGLE | R/W | Oh | Align angle 0h = 0 deg 1h = 10 deg 2h = 20 deg 3h = 30 deg 4h = 45 deg 5h = 60 deg 6h = 70 deg 7h = 80 deg 8h = 90 deg 9h = 110 deg Ah = 120 deg Bh = 135 deg Ch = 150 deg Dh = 160 deg Eh = 170 deg Fh = 180 deg 10h = 190 deg 11h = 210 deg 12h = 225 deg 13h = 240 deg 14h = 250 deg 15h = 260 deg 16h = 270 deg 17h = 280 deg 18h = 330 deg 18h = 330 deg 18h = 340 deg 1Ch = 350 deg 1Dh = Reserved 1Fh = Reserved | | 7-4 | SLOW_FIRST_CYC_FREQ | R/W | Oh | Frequency of first cycle during start-up (% of MAX_SPEED) 0h = 1% 1h = 2% 2h = 3% 3h = 5% 4h = 7.5% 5h = 10% 6h = 12.5% 7h = 15% 8h = 17.5% 9h = 20% Ah = 25% Bh = 30% Ch = 35% Dh = 40% Eh = 45% Fh = 50% | | 3 | FIRST_CYCLE_FREQ_S<br>EL | R/W | Oh | First cycle frequency in open loop for align, double align and IPD start-up 0h = 0 Hz 1h = Defined by SLOW_FIRST_CYC_FREQ | | Bit | Field | Туре | Reset | Description | |-----|---------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2-0 | THETA_ERROR_RAMP_<br>RATE | R/W | Oh | Ramp rate for reducing difference between estimated theta and open loop theta 0h = 0.01 deg/ms 1h = 0.05 deg/ms 2h = 0.1 deg/ms 3h = 0.15 deg/ms 4h = 0.2 deg / ms 5h = 0.5 deg/ms 6h = 1 deg/ms 7h = 2 deg/ms | # 7.7.1.5 CLOSED\_LOOP1 Register (Offset = 88h) [Reset = 00000000h] CLOSED\_LOOP1 is shown in Figure 7-60 and described in Table 7-20. Return to the Summary Table. Register to configure close loop settings1 ## Figure 7-60. CLOSED LOOP1 Register | | | 1.1941. | | | | | | | |------------------|---------------------------|-----------------|------|--------|----------------------|--------------------|-------------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | OVERMODULA<br>TION_ENABLE | | | CL_ACC | | | CL_DEC_CON<br>FIG | | | R/W-0h | R/W-0h | | | R/W-0h | | | R/W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | CL_DEC | | | F | PWM_FREQ_OUT | Γ | | | | | R/W-0h | | R/W-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | PWM_FREQ_O<br>UT | PWM_MODE | FG <sub>.</sub> | _SEL | FG_DIV | | | | | | R/W-0h | R/W-0h | R/\ | V-0h | | R/W | /-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | FG_CONFIG | FG_BEMF_THR | | | AVS_EN | DEADTIME_CO<br>MP_EN | SPEED_LOOP<br>_DIS | RESERVED | | | R/W-0h | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | ## Table 7-20. CLOSED\_LOOP1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|------------------------|------|-------|--------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30 | OVERMODULATION_EN ABLE | R/W | 0h | Enable overmodulation 0h = Disable overmodulation 1h = Enable overmodulation | # Table 7-20. CLOSED\_LOOP1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 29-25 | CL_ACC | R/W | Oh | Closed loop acceleration 0h = 0.5 Hz/s 1h = 1 Hz/s 2h = 2.5 Hz/s 3h = 5 Hz/s 4h = 7.5 Hz/s 5h = 10 Hz/s 6h = 20 Hz/s 7h = 40 Hz/s 8h = 60 Hz/s 9h = 80 Hz/s Ah = 100 Hz/s Bh = 200 Hz/s Ch = 300 Hz/s Ch = 300 Hz/s Ch = 300 Hz/s Fh = 600 Hz/s 10h = 700 Hz/s 11h = 800 Hz/s 12h = 900 Hz/s 13h = 1000 Hz/s 15h = 4000 Hz/s 15h = 4000 Hz/s 15h = 4000 Hz/s 17h = 8000 Hz/s 18h = 10000 Hz/s 18h = 10000 Hz/s 18h = 30000 Hz/s 18h = 30000 Hz/s 18h = 30000 Hz/s 18h = 40000 Hz/s 18h = 40000 Hz/s 18h = 40000 Hz/s 18h = 50000 Hz/s 18h = 60000 700000 Hz/s 18h = 70000 Hz/s 18h = 70000 Hz/s | | 24 | CL_DEC_CONFIG | R/W | Oh | Closed loop deceleration configuration 0h = Closed loop deceleration defined by CL_DEC 1h = Closed loop deceleration defined by CL_ACC | # Table 7-20. CLOSED\_LOOP1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-------|--------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 23-19 | CL_DEC | R/W | Oh | Closed loop deceleration. This setting is used only if AVS is disabled and CL_DEC_CONFIG is set to 0b 0h = 0.5 Hz/s 1h = 1 Hz/s 2h = 2.5 Hz/s 3h = 5 Hz/s 4h = 7.5 Hz/s 5h = 10 Hz/s 6h = 20 Hz/s 7h = 40 Hz/s 8h = 60 Hz/s 9h = 80 Hz/s Ah = 100 Hz/s Bh = 200 Hz/s Ch = 300 Hz/s Ch = 300 Hz/s Dh = 400 Hz/s Fh = 600 Hz/s 10h = 700 Hz/s 11h = 800 Hz/s 12h = 900 Hz/s 13h = 1000 Hz/s 14h = 2000 Hz/s 15h = 4000 Hz/s 18h = 10000 Hz/s 18h = 10000 Hz/s 18h = 30000 Hz/s 18h = 30000 Hz/s 18h = 30000 Hz/s 18h = 40000 70000 Hz/s 18h = 70000 Hz/s 18h = 70000 Hz/s 18h = 70000 Hz/s 18h = 70000 Hz/s | | 18-15 | PWM_FREQ_OUT | R/W | Oh | PWM output frequency 0h = 10 kHz 1h = 15 kHz 2h = 20 kHz 3h = 25 kHz 4h = 30 kHz 5h = 35 kHz 6h = 40 kHz 7h = 45 kHz 8h = 50 kHz 9h = 55 kHz Ah = 60 kHz Bh = Not Applicable Ch = Not Applicable Dh = Not Applicable Eh = Not Applicable Fh = Not Applicable | | 14 | PWM_MODE | R/W | Oh | PWM modulation 0h = Continuous Space Vector Modulation 1h = Discontinuous Space Vector Modulation | | 13-12 | FG_SEL | R/W | Oh | FG select 0h = Output FG in open loop and closed loop 1h = Output FG in only closed loop 2h = Output FG in open loop for the first motor run after power-up/ wake-up 3h = Not Applicable | Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated # Table 7-20. CLOSED\_LOOP1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |------|------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 11-8 | FG_DIV | R/W | 0h | FG Division factor 0h = Divide by 1 (2-pole motor mechanical speed) 1h = Divide by 1 (2-pole motor mechanical speed) 2h = Divide by 2 (4-pole motor mechanical speed) 3h = Divide by 3 (6-pole motor mechanical speed) 4h = Divide by 4 (8-pole motor mechanical speed) Fh = Divide by 15 (30-pole motor mechanical speed) | | 7 | FG_CONFIG | R/W | 0h | FG output configuration 0h = FG active as long as motor is driven 1h = FG active till BEMF drops below BEMF threshold defined by FG_BEMF_THR | | 6-4 | FG_BEMF_THR | R/W | Oh | FG output BEMF threshold $0h = +/- 1mV$ $1h = +/- 2mV$ $2h = +/- 5mV$ $3h = +/- 10mV$ $4h = +/- 20mV$ $5h = +/- 30mV$ $6h = Not Applicable$ $7h = Not Applicable$ | | 3 | AVS_EN | R/W | 0h | AVS enable 0h = Disable 1h = Enable | | 2 | DEADTIME_COMP_EN | R/W | 0h | Deadtime compensation enable 0h = Disable 1h = Enable | | 1 | SPEED_LOOP_DIS | R/W | 0h | Speed loop disable (or torque mode enable) 0h = Speed loop enable (Torque mode disable) 1h = Speed loop disable (Torque mode enable) | | 0 | RESERVED | R/W | 0h | Reserved | # 7.7.1.6 CLOSED\_LOOP2 Register (Offset = 8Ah) [Reset = 00000000h] CLOSED\_LOOP2 is shown in Figure 7-61 and described in Table 7-21. Return to the Summary Table. Register to configure close loop settings2 ## Figure 7-61. CLOSED LOOP2 Register | | | 946 | 7 011 02002 | | - 9.0 .0. | | | | |----------|-----------|----------|-------------|--------|-------------|------------|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | MTR_STOP | | | MTR_STOP | _BRK_TIME | | | | R/W-0h | | R/W-0h | | | R/W | ′-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | ACT_SF | PIN_THR | | | BRAKE_SPEED | _THRESHOLD | | | | | R/W | /-0h | | R/W-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | | МОТО | R_RES | | | | | | | | | R/W | /-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MOTOR_IND | | | | | | | | | | | | R/W | /-0h | | | | | | 1 | | | | | | | 1 | | # Table 7-21. CLOSED\_LOOP2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-28 | MTR_STOP | R/W | Oh | Motor stop options 0h = Hi-Z 1h = Not Applicable 2h = Low side braking 3h = High side braking 4h = Active spin down 5h = Align braking 6h = Not Defined 7h = Not Defined | | 27-24 | MTR_STOP_BRK_TIME | R/W | Oh | Brake time during motor stop 0h = 1 ms 1h = 1 ms 2h = 1 ms 3h = 1 ms 4h = 1 ms 5h = 5 ms 6h = 10 ms 7h = 50 ms 8h = 100 ms 9h = 250 ms Ah = 500 ms Bh = 1000 ms Ch = 2500 ms Dh = 5000 ms Eh = 10000 ms Fh = 15000 ms | # Table 7-21. CLOSED LOOP2 Register Field Descriptions (continued) | <b>D</b> '' | Table 7-21. CLOSED_LOOP2 Register Field Descriptions (continued) | | | | | | | | | | |-------------|------------------------------------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | | | 23-20 | ACT_SPIN_THR | R/W | Oh | Speed threshold for active spin down (% of MAX_SPEED) 0h = 100 % 1h = 90 % 2h = 80 % 3h = 70 % 4h = 60% 5h = 50 % 6h = 45 % 7h = 40 % 8h = 35 % 9h = 30 % Ah = 25 % Bh = 20 % Ch = 15 % Dh = 10 % Eh = 5 % Fh = 2.5 % | | | | | | | | 19-16 | BRAKE_SPEED_THRES HOLD | R/W | Oh | Speed threshold for BRAKE pin and motor stop options (Low side Braking or High Side Braking or Align Braking) (% of MAX_SPEED) 0h = 100 % 1h = 90 % 2h = 80 % 3h = 70 % 4h = 60% 5h = 50 % 6h = 45 % 7h = 40 % 8h = 35 % 9h = 30 % Ah = 25 % Bh = 20 % Ch = 15 % Dh = 10 % Eh = 5 % Fh = 2.5 % | | | | | | | | 15-8 | MOTOR_RES | R/W | 0h | 8-bit values for motor phase resistance See Table 7-2 for values of phase resistance | | | | | | | | 7-0 | MOTOR_IND | R/W | 0h | 8-bit values for motor phase inductance See Table 7-3 for values of phase inductance | | | | | | | # 7.7.1.7 CLOSED\_LOOP3 Register (Offset = 8Ch) [Reset = 00000000h] CLOSED\_LOOP3 is shown in Figure 7-62 and described in Table 7-22. Return to the Summary Table. Register to configure close loop settings3 ## Figure 7-62. CLOSED LOOP3 Register | | | i iguic | 1-02. OLOG | LD_LOOI 3 IVE | gistei | | | | | | |----------------------|--------------|------------------|--------------|---------------|-------------|----|----|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | MOTOR_BEMF_CONST | | | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | MOTOR_BEMF<br>_CONST | | | | CURR_LOOP_KP | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | ( | CURR_LOOP_KP | , | CURR_LOOP_KI | | | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | CURR_LOOP_KI | | | SPD_LOOP_KP | | | | | | | | | R/W-0h | | | R/W-0h | | | | | | Table 7-22. CLOSED\_LOOP3 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-23 | MOTOR_BEMF_CONST | R/W | 0h | 8-bit values for motor BEMF Constant See Table 7-4 for values of BEMF constant | | 22-13 | CURR_LOOP_KP | R/W | Oh | 10-bit value for current lq and ld loop Kp. CURR_LOOP_KP is divided in 2 sections, SCALE(9:8) and VALUE(7:0). Kp = VALUE / 10^SCALE. Please set to 0 for auto calculation of current Kp and Ki | | 12-3 | CURR_LOOP_KI | R/W | 0h | 10-bit value for current Iq and Id loop Ki. CURR_LOOP_KI is divided in 2 sections, SCALE(9:8) and VALUE(7:0). Ki = 1000 * VALUE / 10^SCALE. Please set to 0 for auto calculation of current Kp and Ki | | 2-0 | SPD_LOOP_KP | R/W | 0h | 3 MSB bits for speed loop Kp. SPD_LOOP_KP is divided in 2 sections, SCALE(9:8) and VALUE(7:0). Kp = 0.01 * VALUE / 10^SCALE. | # 7.7.1.8 CLOSED\_LOOP4 Register (Offset = 8Eh) [Reset = 00000000h] CLOSED\_LOOP4 is shown in Figure 7-63 and described in Table 7-23. Return to the Summary Table. Register to configure close loop settings4 ## Figure 7-63. CLOSED LOOP4 Register | | | 94.0 | , 1-00. OLOGE | | 9.010. | | | | | |----------|--------|-----------|---------------|-------------|--------|----|----|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | RESERVED | | | | SPD_LOOP_KP | | | | | | | R/W-0h | | | R/W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | SPD_L0 | DOP_KI | | | | | | | | | | R/W | /-0h | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | SPD_L | OOP_KI | MAX_SPEED | | | | | | | | | RΛ | V-0h | | | R/W | /-0h | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | MAX_S | SPEED | | | | | | | | | | R/W | /-0h | | | | | | | | | | | | | | | | | ## Table 7-23. CLOSED\_LOOP4 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-24 | SPD_LOOP_KP | R/W | 0h | 7 LSB bits for speed loop Kp. SPD_LOOP_KP is divided in 2 sections, SCALE(10:9) and VALUE(8:0). Kp = 0.01 * VALUE / 10^SCALE. | | 23-14 | SPD_LOOP_KI | R/W | Oh | 10 bit value for speed loop Ki. SPD_LOOP_KI is divided in 2 sections, SCALE(9:8) and VALUE(7:0). Ki = 0.1 * VALUE / 10^SCALE. | | 13-0 | MAX_SPEED | R/W | 0h | 14-bit value for setting maximum value of speed in electrical Hz Maximum motor electrical speed (Hz): {MOTOR_SPEED/6} For example: if MOTOR_SPEED is 0x2710, then maximum motor speed (Hz) = 10000(0x2710)/6 = 1666 Hz | Copyright © 2023 Texas Instruments Incorporated # 7.7.1.9 REF\_PROFILES1 Register (Offset = 94h) [Reset = 00000000h] REF\_PROFILES1 is shown in Figure 7-64 and described in Table 7-24. Return to the Summary Table. Register to configure reference profile1 # Figure 7-64. REF\_PROFILES1 Register | | | <u> </u> | | | <del>- </del> | | | | |-------------|-----------|-----------|---------------|----|--------------------------------------------------|----|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | REF_PROFI | LE_CONFIG | NFIG DUTY_ON1 | | | | | | | R/W-0h | R/M | /-0h | | | R/W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | DUTY_ON1 | | | | | DUTY_OFF1 | | | | | | R/W-0h | | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DUTY_OFF1 | | DUTY_CLAMP1 | | | | | | | | R/W-0h | | | | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | DUTY_CLAMP1 | | | | | DUTY_A | | | | | | R/W-0h | | | | R/W-0h | | | | | 1 | | | | | | | | | ## Table 7-24. REF\_PROFILES1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-29 | REF_PROFILE_CONFIG | R/W | 0h | Configuration for Reference profiles 0h = Reference/Equation 1h = Linear Profile 2h = Staircase Profile 3h = Forward-Reverse Profile | | 28-21 | DUTY_ON1 | R/W | 0h | Turn On Duty Cycle (%) = {(DUTY_ON1/255)*100} | | 20-13 | DUTY_OFF1 | R/W | 0h | Turn Off Duty Cycle (%) = {(DUTY_OFF1/255)*100} | | 12-5 | DUTY_CLAMP1 | R/W | 0h | Duty Cycle for clamping Duty Input (%) = {(DUTY_CLAMP1/255)*100} | | 4-0 | DUTY_A | R/W | 0h | 5 MSB bits for Duty Cycle A | # 7.7.1.10 REF\_PROFILES2 Register (Offset = 96h) [Reset = 00000000h] REF\_PROFILES2 is shown in Figure 7-65 and described in Table 7-25. Return to the Summary Table. Register to configure reference profile2 ## Figure 7-65. REF PROFILES2 Register | | | 9 a. c | / -00: IXEI _I | | g.o.o. | | | | |----------|--------|--------|----------------|--------|--------|-----|----|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | DUTY_A | | DUTY_B | | | | | | R/W-0h | R/W-0h | | | R/W-0h | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | DUTY_B | | | DUTY_C | | | | | | | R/W-0h | | | R/W-0h | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | DUT | ΓY_C | | DUTY_D | | | | | | | R/V | V-0h | | | R/W | -0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DUTY_D | | | | DUTY_E | | | | | | R/W-0h | | | | R/W | -0h | | | ## Table 7-25. REF\_PROFILES2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-28 | DUTY_A | R/W | 0h | 3 LSB bits for Duty Cycle A. Duty Cycle A (%) = {(DUTY_A/<br>255)*100} | | 27-20 | DUTY_B | R/W | 0h | Duty Cycle B (%) = {(DUTY_B/255)*100} | | 19-12 | DUTY_C | R/W | 0h | Duty Cycle C (%) = {(DUTY_C/255)*100} | | 11-4 | DUTY_D | R/W | 0h | Duty Cycle D (%) = {(DUTY_D/255)*100} | | 3-0 | DUTY_E | R/W | 0h | 4 MSB bits for Duty Cycle E | # 7.7.1.11 REF\_PROFILES3 Register (Offset = 98h) [Reset = 00000000h] REF\_PROFILES3 is shown in Figure 7-66 and described in Table 7-26. Return to the Summary Table. Register to configure reference profile3 ## Figure 7-66. REF PROFILES3 Register | | | 9 | . ••• | | 9.0.0. | | | | |----------|----------------------|-----------|-------|-----------|-------------|----------|----------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | | DUT | Y_E | | | DUTY_ON2 | | | | R/W-0h | | R/W | /-0h | | | R/W-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | DUTY_ON2 | | DUTY_OFF2 | | | | | | | | R/W-0h | | R/W-0h | | | | | | 15 | 14 13 12 11 | | | | 10 | 9 | 8 | | | | | DUTY_OFF2 | | | DUTY_CLAMP2 | | | | | | | R/W-0h | | | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DUTY_CLAMP2 DUTY_HYS | | | | | | RESERVED | | | | | R/W-0h | | | R/\ | V-0h | R/W-0h | | ## Table 7-26. REF\_PROFILES3 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|------|-------|-----------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-27 | DUTY_E | R/W | 0h | 4 LSB bits for Duty Cycle E. Duty_E Configuration Duty Cycle E (%) = {(DUTY_E/255)*100} | | 26-19 | DUTY_ON2 | R/W | 0h | Turn On Duty Cycle (%) = {(DUTY_ON2/255)*100} | | 18-11 | DUTY_OFF2 | R/W | 0h | Turn Off Duty Cycle (%) = {(DUTY_OFF2/255)*100} | | 10-3 | DUTY_CLAMP2 | R/W | 0h | Duty Cycle for clamping Duty Input(%) = {(DUTY_CLAMP1/255)*100} | | 2-1 | DUTY_HYS | R/W | Oh | Duty hysteresis<br>0h = 0%<br>1h = 0.5%<br>2h = 1%<br>3h = 2% | | 0 | RESERVED | R/W | 0h | Reserved | # 7.7.1.12 REF\_PROFILES4 Register (Offset = 9Ah) [Reset = 00000000h] REF\_PROFILES4 is shown in Figure 7-67 and described in Table 7-27. Return to the Summary Table. Register to configure reference profile4 #### Figure 7-67. REF PROFILES4 Register | | | ı ıgalı | , , o, | INOI ILLOT INC | giotoi | | | |------------|----|---------|--------|----------------|--------|----|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | | | REF_OFF1 | | | | | R/W-0h | | | | R/W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | REF_OFF1 | | | | REF_CLAMP1 | | | | | R/W-0h | | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | REF_CLAMP1 | | | | REF_A | | | | | R/W-0h | | | | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | REF_A | | | | REF_B | | | | | R/W-0h | | | | R/W-0h | | | | # Table 7-27. REF\_PROFILES4 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|--------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-23 | REF_OFF1 | R/W | 0h | Turn off reference (% of Maximum Reference) = {(REF_OFF1/255)*100} | | 22-15 | REF_CLAMP1 | R/W | 0h | Clamp Ref 1 (% of Maximum Reference) = {(REF_CLAMP1/255)*100} | | 14-7 | REF_A | R/W | 0h | Ref A (% of Maximum Reference) = {(REF_A/255)*100} | | 6-0 | REF_B | R/W | 0h | 7 MSB of REF_B configuration | # 7.7.1.13 REF\_PROFILES5 Register (Offset = 9Ch) [Reset = 00000000h] REF\_PROFILES5 is shown in Figure 7-68 and described in Table 7-28. Return to the Summary Table. Register to configure reference profile5 #### Figure 7-68. REF PROFILES5 Register | | | 1.94.3 | , , oo. itali | | 9.010. | | | |----------|--------|--------|---------------|------|--------|----|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | REF_B | | | REF | :_C | | | | R/W-0h | R/W-0h | | | R/W | '-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | REF | =_C | | | REF | :_D | | | | R/M | /-0h | | | R/W | '-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | REF | =_D | | | REF | _E | | | | R/M | /-0h | | | R/W | '-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | REF | =_E | | | RESE | RVED | | | | R/M | /-0h | | | R/W | '-0h | | | #### Table 7-28. REF\_PROFILES5 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|---------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30 | REF_B | R/W | 0h | 1 LSB of REF_B configuration. Ref B(% of Maximum Reference) = {(REF_B/255)*100} | | 29-22 | REF_C | R/W | 0h | Ref C (% of Maximum Reference) = {(REF_C/255)*100} | | 21-14 | REF_D | R/W | 0h | Ref D (% of Maximum Reference) = {(REF_D/255)*100} | | 13-6 | REF_E | R/W | 0h | Ref E(% of Maximum Reference) = {(REF_E/255)*100} | | 5-0 | RESERVED | R/W | 0h | Reserved | #### 7.7.1.14 REF\_PROFILES6 Register (Offset = 9Eh) [Reset = 00000000h] REF\_PROFILES6 is shown in Figure 7-69 and described in Table 7-29. Return to the Summary Table. Register to configure reference profile6 Figure 7-69. REF PROFILES6 Register | | | i igui e | : 1-03. IXLI _F | KOFILESO KE | gistei | | | |------------|--------|------------|-----------------|-------------|--------|----|----| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | | | REF_OFF2 | | | | | R/W-0h | | | | R/W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | REF_OFF2 | | REF_CLAMP2 | | | | | | | R/W-0h | R/W-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | REF_CLAMP2 | | | | RESERVED | | | | | R/W-0h | | | | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESE | RVED | | | | | | | | R/V | V-0h | | | | | | | | | | | | | #### Table 7-29. REF\_PROFILES6 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------|------|-------|---------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-23 | REF_OFF2 | R/W | 0h | Turn off Ref (% of Maximum Reference)) = {(REF_OFF2/255)*100} | | 22-15 | REF_CLAMP2 | R/W | | Clamp Ref 2 (% of Maximum Reference) = {(REF_CLAMP2/255)*100} | | 14-0 | RESERVED | R/W | 0h | Reserved | #### 7.7.2 Fault\_Configuration Registers Table 7-30 lists the memory-mapped registers for the Fault\_Configuration registers. All register offset addresses not listed in Table 7-30 should be considered as reserved locations and the register contents should not be modified. Table 7-30. FAULT\_CONFIGURATION Registers | Offset | Acronym | Register Name | Section | |--------|---------------|----------------------|---------| | 90h | FAULT_CONFIG1 | Fault Configuration1 | Go | | 92h | FAULT_CONFIG2 | Fault Configuration2 | Go | Complex bit access types are encoded to fit into small table cells. Table 7-31 shows the codes that are used for access types in this section. Table 7-31. Fault\_Configuration Access Type Codes | inner i o ii i dani_com garadon i iococo i jpo codoc | | | | | | | | |------------------------------------------------------|------|-------------|--|--|--|--|--| | Access Type | Code | Description | | | | | | | Read Type | | | | | | | | | R | R | Read | | | | | | | Write Type | | | | | | | | | W Write | | | | | | | | | Reset or Default Value | | | | | | | | Copyright © 2023 Texas Instruments Incorporated # Table 7-31. Fault\_Configuration Access Type Codes (continued) | Access Type | Code | Description | |-------------|------|----------------------------------------| | -n | | Value after reset or the default value | # 7.7.2.1 FAULT\_CONFIG1 Register (Offset = 90h) [Reset = 00000000h] FAULT\_CONFIG1 is shown in Figure 7-70 and described in Table 7-32. Return to the Summary Table. Register to configure fault settings1 #### Figure 7-70. FAULT CONFIG1 Register | | | ı ıgaı | <i>, , ,</i> ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | _00::::0::::: | 9.0.0. | | | |----------------------|--------------|---------|----------------------------------------------|---------------|--------------------------|-----------------------|-------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | ILI | MIT | | I | HW_LOCK_ILIMI | Г | | R/W-0h | | R/V | V-0h | | | R/W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | HW_LOCK_ILI<br>MIT | LOCK_ILIMIT | | | | LC | OCK_ILIMIT_MOD | DE | | R/W-0h | R/W-0h | | | | R/W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | LOCK_ILIMIT_<br>MODE | | LOCK_IL | IMIT_DEG | | | LCK_RETRY | | | R/W-0h | | R/V | V-0h | | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LCK_RETRY | MTR_LCK_MODE | | | | IPD_TIMEOUT<br>_FAULT_EN | IPD_FREQ_FA<br>ULT_EN | SATURATION_<br>FLAGS_EN | | R/W-0h | | R/V | V-0h | | R/W-0h | R/W-0h | R/W-0h | #### Table 7-32. FAULT\_CONFIG1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-27 | ILIMIT | R/W | Oh | Current limit for Iq axis (torque) current reference in closed loop 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | # Table 7-32. FAULT\_CONFIG1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|----------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 26-23 | HW_LOCK_ILIMIT | R/W | Oh | Comparator based lock detection current threshold 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | | 22-19 | LOCK_ILIMIT | R/W | Oh | ADC based lock detection current threshold 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated # Table 7-32. FAULT CONFIG1 Register Field Descriptions (continued) | D:4 | | | 1 | ster Field Descriptions (continued) | |-------|------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 18-15 | LOCK_ILIMIT_MODE | R/W | Oh | Lock current limit mode 0h = llimit lock detection causes latched fault; nFAULT active; Gate driver is tristated 1h = llimit lock detection causes latched fault; nFAULT active; Gate driver is tristated 2h = llimit lock detection causes latched fault; nFAULT active; Gate driver is in high side brake mode (All high side FETs are turned ON) 3h = llimit lock detection causes latched fault; nFAULT active; Gate driver is in low side brake mode (All low side FETs are turned ON) 4h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 5h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 6h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in high side brake mode (All high side FETs are turned ON); nFAULT active 7h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in low side brake mode (All low side FETs are turned ON); nFAULT active 8h = Ilimit lock detection current limit is in report only but no action is taken; nFAULT active 9h = ILIMIT LOCK is disabled Ah = ILIMIT LOCK is disabled Ch | | 14-11 | LOCK_ILIMIT_DEG | R/W | Oh | Lock detection current limit deglitch time 0h = Not Applicable 1h = Not Applicable 2h = 0.2 ms 3h = 0.5 ms 4h = 1 ms 5h = 2.5 ms 6h = 5 ms 7h = 7.5 ms 8h = 10 ms 9h = 25 ms Ah = 50 ms Bh = 75 ms Ch = 100 ms Dh = 200 ms Eh = 500 ms Fh = 1000 ms | # Table 7-32. FAULT\_CONFIG1 Register Field Descriptions (continued) | Bit | Field | Type | Reset | Description (continued) | |------|--------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 10-7 | LCK_RETRY | R/W | Oh | Lock detection retry time 0h = 300 ms 1h = 500 ms 2h = 1 s 3h = 2 s 4h = 3 s 5h = 4 s 6h = 5 s 7h = 6 s 8h = 7 s 9h = 8 s Ah = 9 s Bh = 10 s Ch = 11 s Dh = 12 s Eh = 13 s Fh = 14 s | | 6-3 | MTR_LCK_MODE | R/W | Oh | Motor Lock Mode Oh = Motor lock detection causes latched fault; nFAULT active; Gate driver is tristated 1h = Motor lock detection causes latched fault; nFAULT active; Gate driver is tristated 2h = Motor lock detection causes latched fault; nFAULT active; Gate driver is in high side brake mode (All high side FETs are turned ON) 3h = Motor lock detection causes latched fault; nFAULT active; Gate driver is in low side brake mode (All low side FETs are turned ON) 4h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 5h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 6h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in high side brake mode (All high side FETs are turned ON); nFAULT active 7h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in low side brake mode (All low side FETs are turned ON); nFAULT active 8h = Motor lock detection current limit is in report only but no action is taken; nFAULT active 9h = Motor lock detection is disabled Ah = Motor lock detection is disabled Bh = Motor lock detection is disabled Ch = Motor lock detection is disabled Ch = Motor lock detection is disabled Ch = Motor lock detection is disabled En = Motor lock detection is disabled Ch = Motor lock detection is disabled Ch = Motor lock detection is disabled | | 2 | IPD_TIMEOUT_FAULT_E<br>N | R/W | 0h | IPD timeout fault enable 0h = Disable 1h = Enable | | 1 | IPD_FREQ_FAULT_EN | R/W | Oh | IPD frequency fault enable 0h = Disable 1h = Enable | | 0 | SATURATION_FLAGS_E<br>N | R/W | 0h | Enables indication of current loop and speed loop saturation 0h = Disable 1h = Enable | Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated # 7.7.2.2 FAULT\_CONFIG2 Register (Offset = 92h) [Reset = 00000000h] FAULT\_CONFIG2 is shown in Figure 7-71 and described in Table 7-33. Return to the Summary Table. Register to configure fault settings2 #### Figure 7-71. FAULT CONFIG2 Register | | rigate / / I. I Adel _ down los register | | | | | | | |-------------------------|------------------------------------------|--------------|----------|---------------------|----------------|---------------|--------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | LOCK1_EN | LOCK2_EN | LOCK3_EN | LC | LOCK_ABN_SPEED | | | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | | R/W-0h | | R/W-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | ABNORMAL | DRMAL_BEMF_THR NO_MTR_THR | | | HW_LOCK_ILIMIT_MODE | | | | | R/M | R/W-0h R/W-0h | | | R/W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | HW_LOCK_ILI<br>MIT_MODE | HW_LOCK_ILIMIT_DEG | | | RESERVED | | MIN_VM_MOTOR | ₹ | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MIN_VM_MOD<br>E | N | MAX_VM_MOTOR | | | Al | UTO_RETRY_TIM | IES | | R/W-0h | | R/W-0h | | R/W-0h | | R/W-0h | | # Table 7-33. FAULT\_CONFIG2 Register Field Descriptions | | Table 7-33. I AOLI_OOM TOZ Register T leid Descriptions | | | | | | |-------|---------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31 | RESERVED | R/W | 0h | Reserved | | | | 30 | LOCK1_EN | R/W | Oh | Lock 1 (Abnormal Speed) Enable 0h = Disable 1h = Enable | | | | 29 | LOCK2_EN | R/W | 0h | Lock 2 (Abnormal BEMF) Enable 0h = Disable 1h = Enable | | | | 28 | LOCK3_EN | R/W | Oh | Lock 3 (No Motor) Enable 0h = Disable 1h = Enable | | | | 27-25 | LOCK_ABN_SPEED | R/W | Oh | Abnormal speed lock threshold (% of MAX_SPEED) 0h = 130% 1h = 140% 2h = 150% 3h = 160% 4h = 170% 5h = 180% 6h = 190% 7h = 200% | | | | 24-22 | ABNORMAL_BEMF_THR | R/W | Oh | Abnormal BEMF lock threshold (% of expected BEMF) 0h = 40% 1h = 45% 2h = 50% 3h = 55% 4h = 60% 5h = 65% 6h = 67.5% 7h = 70% | | | # Table 7-33. FAULT\_CONFIG2 Register Field Descriptions (continued) | Dit | Field | | | Ster Field Descriptions (continued) | |-------|---------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | | Type | Reset | Description No mater leak threshold | | 21-19 | NO_MTR_THR | R/W | Oh | No motor lock threshold 0h = 0.075 A 1h = 0.075 A 2h = 0.1A 3h = 0.125 A 4h = 0.25 A 5h = 0.5 A 6h = 0.75 A 7h = 1.0 A | | 18-15 | HW_LOCK_ILIMIT_MODE | R/W | Oh | Hardware lock detection current mode 0h = Hardware llimit lock detection causes latched fault; nFAULT active; Gate driver is tristated 1h = Hardware llimit lock detection causes latched fault; nFAULT active; Gate driver is tristated 2h = Hardware llimit lock detection causes latched fault; nFAULT active; Gate driver is in high side brake mode (All high side FETs are turned ON) 3h = Hardware llimit lock detection causes latched fault; nFAULT active; Gate driver is in low side brake mode (All low side FETs are turned ON) 4h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 5h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is tristated; nFAULT active 6h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in high side brake mode (All high side FETs are turned ON); nFAULT active 7h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in low side brake mode (All high side FETs are turned ON); nFAULT active 7h = Fault automatically cleared after LCK_RETRY time. Number of retries limited to AUTO_RETRY_TIMES. If number of retries exceed AUTO_RETRY_TIMES, fault is latched; Gate driver is in low side brake mode (All high side FETs are turned ON); nFAULT active 8h = Hardware ILIMIT lock detection is disabled Ah = Hardware ILIMIT lock detection is disabled Ch = Hardware ILIMIT lock detection is disabled Ch = Hardware ILIMIT lock detection is disabled Ch = Hardware ILIMIT lock detection is disabled Ch = Hardware ILIMIT lock detection is disabled | | 14-12 | HW_LOCK_ILIMIT_DEG | R/W | Oh | Hardware lock detection current limit deglitch time $0h = No$ deglitch $1h = 1 \mu s$ $2h = 2 \mu s$ $3h = 3 \mu s$ $4h = 4 \mu s$ $5h = 5 \mu s$ $6h = 6 \mu s$ $7h = 7 \mu s$ | | 11 | RESERVED | R/W | 0h | Reserved | | 10-8 | MIN_VM_MOTOR | R/W | Oh | Minimum DC Bus voltage for running motor (V) 0h = No Limit 1h = 4.5 V 2h = 5 V 3h = 5.5 V 4h = 6 V 5h = 7.5 V 6h = 10 V 7h = 12.5 V | Table 7-33. FAULT\_CONFIG2 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-----|------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------| | | | - | | · | | 7 | MIN_VM_MODE | R/W | Oh | DC Bus Undervoltage Fault Recovery Mode 0h = Latch on undervoltage 1h = Automatic clear if voltage in bounds | | 6-4 | MAX_VM_MOTOR | R/W | Oh | Maximum DC Bus voltage for running motor 0h = No Limit 1h = 20 V 2h = 22.5 V 3h = 25 V 4h = 27.5 V 5h = 30 V 6h = 32.5 V 7h = 35 V | | 3 | MAX_VM_MODE | R/W | 0h | DC Bus Overvoltage Fault Recovery Mode 0h = Latch on overvoltage 1h = Automatic clear if voltage in bounds | | 2-0 | AUTO_RETRY_TIMES | R/W | Oh | Automatic retry attempts 0h = No Limit 1h = 2 2h = 3 3h = 5 4h = 7 5h = 10 6h = 15 7h = 20 | ### 7.7.3 Hardware\_Configuration Registers Table 7-34 lists the memory-mapped registers for the Hardware\_Configuration registers. All register offset addresses not listed in Table 7-34 should be considered as reserved locations and the register contents should not be modified. Table 7-34. HARDWARE\_CONFIGURATION Registers | Offset | Acronym | Register Name | Section | | | | | | |--------|----------------|----------------------------|---------|--|--|--|--|--| | A4h | PIN_CONFIG | Hardware Pin Configuration | Go | | | | | | | A6h | DEVICE_CONFIG1 | Device configuration1 | Go | | | | | | | A8h | DEVICE_CONFIG2 | Device configuration2 | Go | | | | | | | AAh | PERI_CONFIG1 | Peripheral Configuration1 | Go | | | | | | | ACh | GD_CONFIG1 | Gate Driver Configuration1 | Go | | | | | | | AEh | GD_CONFIG2 | Gate Driver Configuration2 | Go | | | | | | Complex bit access types are encoded to fit into small table cells. Table 7-35 shows the codes that are used for access types in this section. Table 7-35. Hardware\_Configuration Access Type Codes | Access Type | Code | Description | | | | | |---------------------------|------|-------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | W1C W Write 1C 1 to clear | | | | | | | | Reset or Default Value | | | | | | | # Table 7-35. Hardware\_Configuration Access Type Codes (continued) | Access Type | Code | Description | |-------------|------|----------------------------------------| | -n | | Value after reset or the default value | # 7.7.3.1 PIN\_CONFIG Register (Offset = A4h) [Reset = 00000000h] PIN\_CONFIG is shown in Figure 7-72 and described in Table 7-36. Return to the Summary Table. Register to configure hardware pins # Figure 7-72. PIN\_CONFIG Register | | | 9. | | COM IC INCH | oto. | | | |---------------------|------------------|--------------------|---------------------------|----------------------|---------|----------|---------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | RESERVED | | | VdcFilterDisabl<br>e | | RESERVED | | | R/W-0h | R/W-0h | | | R/W-0h | | R/W-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESERVED | | | | | | | | | | | R/W | /-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | RESERVED | | RESE | RVED | FG_IDLE | _CONFIG | FG_FAULT_CO<br>NFIG | | | R/W-0h | | R/W | /-0h | R/V | V-0h | R/W-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | FG_FAULT_CO<br>NFIG | ALARM_PIN_E<br>N | BRAKE_PIN_M<br>ODE | ALIGN_BRAKE<br>_ANGLE_SEL | BRAKE. | _INPUT | SPEED | _MODE | | R/W-0h | R/W-0h | R/W-0h | R/W-0h | R/W | /-0h | R/V | V-0h | # Table 7-36. PIN\_CONFIG Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-28 | RESERVED | R/W | 0h | Reserved | | 27 | VdcFilterDisable | R/W | Oh | Vdc (VM) filter disable 0h = Vdc filter Enable 1h = Vdc filter Disable | | 26-13 | RESERVED | R/W | 0h | Reserved | | 12-11 | RESERVED | R/W | 0h | Reserved | | 10-9 | FG_IDLE_CONFIG | R/W | 0h | FG configuration during stop 0h = FG state decided by FG_CONFIG 1h = FG is pulled to High 2h = FG is pulled to Low 3h = FG is pulled to High | | 8-7 | FG_FAULT_CONFIG | R/W | 0h | FG configuration during fault 0h = Use last FG Signal when motor is driven before fault 1h = FG is pulled to High 2h = FG is pulled to Low 3h = FG state decided by FG_CONFIG | | 6 | ALARM_PIN_EN | R/W | Oh | Alarm pin enable 0h = Disable 1h = Enable | | 5 | BRAKE_PIN_MODE | R/W | 0h | Brake pin mode 0h = Low side brake 1h = Align brake | | 4 | ALIGN_BRAKE_ANGLE_<br>SEL | R/W | 0h | Align brake angle select 0h = Use last commutation angle before entering align braking 1h = Use ALIGN_ANGLE configuration for align braking | Copyright © 2023 Texas Instruments Incorporated Submit Document Feedback # Table 7-36. PIN\_CONFIG Register Field Descriptions (continued) | | | | | , , , | |-----|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 3-2 | BRAKE_INPUT | R/W | 0h | Brake pin override 0h = Hardware Pin BRAKE 1h = Override pin and brake/align according to BRAKE_PIN_MODE 2h = Override pin and do not brake/align 3h = Hardware Pin BRAKE | | 1-0 | SPEED_MODE | R/W | 0h | Configure motor control input source 0h = Controlled by analog voltage on SPEED pin 1h = Controlled by duty cycle (PWM) on SPEED pin 2h = Controlled by DIGITAL_SPEED_CTRL value (I2C) 3h = Controlled by frequency on SPEED pin | # 7.7.3.2 DEVICE\_CONFIG1 Register (Offset = A6h) [Reset = 00000000h] DEVICE\_CONFIG1 is shown in Figure 7-73 and described in Table 7-37. Return to the Summary Table. Register to configure device #### Figure 7-73. DEVICE CONFIG1 Register | rigate / 76. DE VIOE_GOIN TO I Register | | | | | | | | | | | |-----------------------------------------|----------|----------|---------------|-------------------|-----------------|--------|------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | RESERVED | DAC_S | Ox_SEL | DAC_ENABLE | I2C_TARGET_ADDR | | | | | | | R/W-0h | R/W-0h | R/W | /-0h | R/W-0h | • | R/W-0h | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | I2C_TARG | ET_ADDR | | | RESE | RVED | | | | | | R/W-0h | | | | R/W-0h | | | | | | | | 15 | 14 | 13 | 13 12 11 10 9 | | | | 8 | | | | | | | | RESE | RVED | | | | | | | | | | | R/V | V-0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | SLEW_RAT | E_I2C_PINS | PULLUP_ENAB<br>LE | BUS_ | VOLT | | | | | | | R/W-0h | | R/V | V-0h | R/W-0h | R/W | /-0h | | | | Table 7-37. DEVICE\_CONFIG1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|--------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31 | RESERVED | R/W | 0h | Reserved | | | | 30 | RESERVED | R/W | 0h | Reserved | | | | 29-28 | DAC_SOx_SEL | R/W | Oh | Selects between DAC2 and SOx channels 0h = DACOUT2 1h = SOA 2h = SOB 3h = SOC | | | | 27 | DAC_ENABLE | R/W | 0h | DAC1 and DAC2 enables 0h = DACOUT1 and DACOUT2 on dedicated DAC pins disabled 1h = DACOUT1 and DACOUT2 on dedicated DAC pins enabled | | | | 26-20 | I2C_TARGET_ADDR | R/W | 0h | I2C target address | | | | 19-5 | RESERVED | R/W | 0h | Reserved | | | | 4-3 | SLEW_RATE_I2C_PINS | R/W | 0h | Slew rate control for I2C pins<br>0h = 4.8 mA<br>1h = 3.9 mA<br>2h = 1.86 mA<br>3h = 30.8 mA | | | | 2 | PULLUP_ENABLE | R/W | 0h | Pull-up enable for nFAULT and FG pins 0h = Disable 1h = Enable | | | | 1-0 | BUS_VOLT | R/W | Oh | Maximum DC bus voltage configuration 0h = 15 V 1h = 30 V 2h = 60 V 3h = Not defined | | | # 7.7.3.3 DEVICE\_CONFIG2 Register (Offset = A8h) [Reset = 00000000h] DEVICE\_CONFIG2 is shown in Figure 7-74 and described in Table 7-38. Return to the Summary Table. Register to configure device #### Figure 7-74. DEVICE CONFIG2 Register | | | i igui e | 7-74. DEVICE | _CONTIGE K | egistei | | | | | | |----------------|-----------|-------------------------|---------------------------------|------------|---------|------------------------|------------------------|--|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | | RESERVED | | INPUT_MAXIMUM_FREQ | | | | | | | | | | R/W-0h | | | | R/W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | | | | INPUT_MAXI | MUM_FREQ | | | | | | | | | | | R/W | '-0h | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | SLEEP_EN | ITRY_TIME | DYNAMIC_CSA<br>_GAIN_EN | DYNAMIC_VOL<br>TAGE_GAIN_E<br>N | DEV_MODE | CL | K_SEL | EXT_CLK_EN | | | | | R/V | V-0h | R/W-0h | R/W-0h | R/W-0h | R | W-0h | R/W-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | EXT_CLK_CONFIG | | | EXT_WDT_EN | EXT_WDT | _CONFIG | EXT_WDT_INP<br>UT_MODE | EXT_WDT_FA<br>ULT_MODE | | | | | | R/W-0h | | R/W-0h | R/W | /-0h | R/W-0h | R/W-0h | | | | #### Table 7-38. DEVICE\_CONFIG2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | | | |-------|-----------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 31 | RESERVED | R/W | 0h | Reserved | | | | 30-16 | INPUT_MAXIMUM_FREQ | R/W | Oh | Input frequency on speed pin for frequency based motor control that corresponds to 100% duty cycle. Input duty cycle = Input frequency / INPUT_MAXIMUM_FREQ | | | | 15-14 | SLEEP_ENTRY_TIME | R/W | Oh | Device enters sleep mode when input source is held at or below the sleep entry threshold for SLEEP_ENTRY_TIME 0h = Sleep entry when SPEED pin remains low for 50µs 1h = Sleep entry when SPEED pin remains low for 200µs 2h = Sleep entry when SPEED pin remains low for 20ms 3h = Sleep entry when SPEED pin remains low for 200ms | | | | 13 | DYNAMIC_CSA_GAIN_E<br>N | R/W | Oh | Adjust CSA gain dynamically for optimal resolution across current levels 0h = Dynamic CSA gain is disabled 1h = Dynamic CSA gain is enabled | | | | 12 | DYNAMIC_VOLTAGE_GA<br>IN_EN | R/W | Oh | Adjust voltage gain dynamically for optimal voltage resolution across voltage levels 0h = Dynamic voltage gain is disabled 1h = Dynamic voltage gain is enabled | | | | 11 | DEV_MODE | R/W | Oh | Device mode select<br>0h = Standby Mode<br>1h = Sleep Mode | | | | 10-9 | CLK_SEL | R/W | 0h | Clock source 0h = Internal Oscillator 1h = Crude Oscillator - WDT 2h = Not Applicable 3h = External Clock input | | | | 8 | EXT_CLK_EN | R/W | 0h | Enable external clock mode 0h = Disable 1h = Enable | | | # Table 7-38. DEVICE\_CONFIG2 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 7-5 | EXT_CLK_CONFIG | R/W | Oh | External clock configuration 0h = 8 kHz 1h = 16 kHz 2h = 32 kHz 3h = 64 kHz 4h = 128 kHz 5h = 256 kHz 6h = 512 kHz 7h = 1024 kHz | | 4 | EXT_WDT_EN | R/W | Oh | Enable external watchdog 0h = Disable 1h = Enable | | 3-2 | EXT_WDT_CONFIG | R/W | 0h | Time between watchdog tickles (GPIO/I2C) 0h = 100ms/1s 1h = 200ms/2s 2h = 500ms/5s 3h = 1000ms/10s | | 1 | EXT_WDT_INPUT_MODE | R/W | 0h | External watchdog input mode 0h = Watchdog tickle over I2C 1h = Watchdog tickle over GPIO | | 0 | EXT_WDT_FAULT_MOD<br>E | R/W | Oh | External watchdog fault mode 0h = Report Only 1h = Latch with FETs in Hi-Z | # 7.7.3.4 PERI\_CONFIG1 Register (Offset = AAh) [Reset = 00000000h] PERI\_CONFIG1 is shown in Figure 7-75 and described in Table 7-39. Return to the Summary Table. Register to peripheral1 # Figure 7-75. PERI\_CONFIG1 Register | | | 1 1941 0 | | | 9.010. | | | | |--------------|----------------------------------------|----------------------------------|------------------------------|------|--------|---------------------|--------------------------------------------------|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | RESERVED | SPREAD_SPE<br>CTRUM_MODU<br>LATION_DIS | | RESERVED BUS_CURRENT_LIMIT | | | | | | | R/W-0h | R/W-1h | | R/W | /-0h | | R/W | /-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | BUS_CURF | RENT_LIMIT | BUS_CURREN<br>T_LIMIT_ENAB<br>LE | Γ_LIMIT_ENAB | | | | ACTIVE_BRAK<br>E_SPEED_DEL<br>TA_LIMIT_ENT<br>RY | | | R/V | V-0h | R/W-0h | R/W | /-0h | R/W-0h | R/W-0h | R/W-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | ACTIVE_BRAKI | E_SPEED_DELTA | A_LIMIT_ENTRY | ACTIVE_BRAKE_MOD_INDEX_LIMIT | | | SPEED_RANG<br>E_SEL | RESERVED | | | | R/W-0h | | R/W-0h | | | R/W-0h | R/W-0h | | | 7 | 6 | 5 | 5 4 3 2 1 | | | | | | | | RESERVED | | | | | | | | | | | | R/W | /-0h | | | | | #### Table 7-39. PERI CONFIG1 Register Field Descriptions | | Table 1-33.1 EN_OOM TOT Register Field Descriptions | | | | | | | | |-------|-----------------------------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | | 31 | RESERVED | R/W | 0h | Reserved | | | | | | 30 | SPREAD_SPECTRUM_M<br>ODULATION_DIS | R/W | 1h | Spread Spectrum Modulation disable 0h = SSM is Enabled 1h = SSM is Disabled | | | | | | 29-26 | RESERVED | R/W | 0h | Reserved | | | | | | 25-22 | BUS_CURRENT_LIMIT | R/W | Oh | Bus current limit 0h = 0.125 A 1h = 0.25 A 2h = 0.5 A 3h = 1.0 A 4h = 1.5 A 5h = 2.0 A 6h = 2.5 A 7h = 3.0 A 8h = 3.5 A 9h = 4.0 A Ah = 4.5 A Bh = 5.0 A Ch = 5.5 A Dh = 6.0 A Eh = 7.0 A Fh = 8.0 A | | | | | | 21 | BUS_CURRENT_LIMIT_E<br>NABLE | R/W | 0h | Bus current limit enable 0h = Disable 1h = Enable | | | | | # Table 7-39. PERI\_CONFIG1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description (continued) | |-------|---------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | · | | 20-19 | DIR_INPUT | R/W | Oh | DIR pin override 0h = Hardware Pin DIR 1h = Override DIR pin with clockwise rotation OUTA-OUTB-OUTC 2h = Override DIR pin with counter clockwise rotation OUTA-OUTC-OUTB 3h = Hardware Pin DIR | | 18 | DIR_CHANGE_MODE | R/W | 0h | Response to change of DIR pin status 0h = Follow motor stop options and ISD routine on detecting DIR change 1h = Change the direction through Reverse Drive while continuously driving the motor | | 17 | SELF_TEST_ENABLE | R/W | 0h | Enables self-test on power up 0h = STL is disabled 1h = STL is enabled | | 16-13 | ACTIVE_BRAKE_SPEED _DELTA_LIMIT_ENTRY | R/W | Oh | Difference between final speed and present speed below which active braking will be applied 0h = Not Applicable 1h = 5% 2h = 10% 3h = 15% 4h = 20% 5h = 25% 6h = 30% 7h = 35% 8h = 40% 9h = 45% Ah = 50% Bh = 60% Ch = 70% Dh = 80% Eh = 90% Fh = 100% | | 12-10 | ACTIVE_BRAKE_MOD_I<br>NDEX_LIMIT | R/W | Oh | Modulation Index limit below which active braking will be applied 0h = 0% 1h = 40% 2h = 50% 3h = 60% 4h = 70% 5h = 80% 6h = 90% 7h = 100% | | 9 | SPEED_RANGE_SEL | R/W | 0h | Frequency range selection for PWM/duty based motor control input 0h = 325Hz to 100kHz 1h = 10Hz to 325Hz | | 8 | RESERVED | R/W | 0h | Reserved | | 7-0 | RESERVED | R/W | 0h | Reserved | | | | | | 1 | # 7.7.3.5 GD\_CONFIG1 Register (Offset = ACh) [Reset = 00000000h] GD\_CONFIG1 is shown in Figure 7-76 and described in Table 7-40. Return to the Summary Table. Register to configure gated driver settings1 # Figure 7-76. GD CONFIG1 Register | rigule 7-70. Ob_CONTIOT Register | | | | | | | | | | |----------------------------------|----------|----------|----------|-----------|----------|----------|---------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | PARITY | RESE | RVED | RESERVED | SLEW_RATE | | RESE | RVED | | | | R/W-0h | R/W | /-0h | R/W-1h | R/W | V-0h | R/W | /-0h | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | RESERVED | RESERVED | RESERVED | RESERVED | OVP_SEL | OVP_EN | RESERVED | OTW_REP | | | | R/W-0h | R/W-0h | R/W-1h | R/W-0h | R/W-0h | R/W-0h | R/W-1h | R/W-0h | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | RESERVED | OCP_ | _DEG | RESERVED | OCP_LVL | OCP_I | MODE | | | | R/W-1h | R/W-0h | R/W | /-0h | R/W-0h | R/W-0h | R/W | /-1h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | CSA_GAIN | | | | | R/W-0h | | | #### Table 7-40. GD\_CONFIG1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | | |-------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31 | PARITY | R/W | 0h | Parity bit | | | 30-29 | RESERVED | R/W | 0h | Reserved | | | 28 | RESERVED | R/W | 1h | Reserved | | | 27-26 | SLEW_RATE | R/W | Oh | Slew rate 0h = Not Applicable 1h = Not Applicable 2h = Slew rate is 125 V/µs 3h = Slew rate is 200 V/µs | | | 25-24 | RESERVED | R/W | 0h | Reserved | | | 23 | RESERVED | R/W | 0h | Reserved | | | 22 | RESERVED | R/W | 0h | Reserved | | | 21 | RESERVED | R/W | 1h | Reserved | | | 20 | RESERVED | R/W | 0h | Reserved | | | 19 | OVP_SEL | R/W | 0h | Overvoltage level 0h = VM overvoltage level is 34-V 1h = VM overvoltage level is 22-V | | | 18 | OVP_EN | R/W | 0h | Overvoltage enable 0h = Overvoltage protection is disabled 1h = Overvoltage protection is enabled | | | 17 | RESERVED | R/W | 1h | Reserved | | | 16 | OTW_REP | R/W | Oh | Overtemperature warning enable 0h = Over temperature reporting on nFAULT is disabled 1h = Over temperature reporting on nFAULT is enabled | | | 15 | RESERVED | R/W | 1h | Reserved | | | 14 | RESERVED | R/W | 0h | Reserved | | | 13-12 | OCP_DEG | R/W | Oh | OCP Deglitch Time Settings<br>0h = OCP deglitch time is $0.2 \mu s$<br>1h = OCP deglitch time is $0.6 \mu s$<br>2h = OCP deglitch time is $1.1 \mu s$<br>3h = OCP deglitch time is $1.6 \mu s$ | | # Table 7-40. GD\_CONFIG1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | | | |-----|----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 11 | RESERVED | R/W | 0h | Reserved | | | | | 10 | OCP_LVL | R/W | 0h | Overcurrent Level Setting 0h = OCP level is 16 A (Typical) 1h = OCP level is 24 A (Typical) | | | | | 9-8 | OCP_MODE | R/W | 1h | OCP Fault Mode 0h = Overcurrent causes a latched fault 1h = Overcurrent causes an automatic retrying fault after 500ms 2h = Not Applicable 3h = Not Applicable | | | | | 7 | RESERVED | R/W | 0h | Reserved | | | | | 6 | RESERVED | R/W | 0h | Reserved | | | | | 5 | RESERVED | R/W | 0h | Reserved | | | | | 4 | RESERVED | R/W | 0h | Reserved | | | | | 3 | RESERVED | R/W | 0h | Reserved | | | | | 2 | RESERVED | R/W | 0h | Reserved | | | | | 1-0 | CSA_GAIN | R/W | 0h | Current Sense Amplifier gain (used only if DYNAMIC_CSA_GAIN_EN = 0b) 0h = CSA gain is 0.15 V/A 1h = CSA gain is 0.3 V/A 2h = CSA gain is 0.6 V/A 3h = CSA gain is 1.2 V/A | | | | # 7.7.3.6 GD\_CONFIG2 Register (Offset = AEh) [Reset = 00000000h] GD\_CONFIG2 is shown in Figure 7-77 and described in Table 7-41. Return to the Summary Table. Register to configure gated driver settings2 #### Figure 7-77. GD CONFIG2 Register | | | ı ıg | uie <i>i -i i</i> . GD_C | JOHN 102 IN | gistei | | | |---------|----------|------|--------------------------|-------------|-------------|----------|-------------| | 31 | 30 | 29 | 28 | 25 | 24 | | | | PARITY | RESERVED | | RESE | RVED | | RESERVED | BUCK_PS_DIS | | R/W-0h | R/W-0h | | R/V | V-0h | | R/W-0h | R/W1C-1h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | BUCK_CL | BUCK | SEL | RESERVED | | MIN_ON_TIME | | RESERVED | | R/W-0h | R/M | /-1h | R/W-0h | | R/W-0h | | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | RESE | RVED | | | | | | | | R/V | V-0h | | | | | 7 | 6 | 5 | 5 4 3 2 1 | | | | | | | | | RESE | RVED | | | | | | | | R/V | V-0h | | | | | | | | | | | | | #### Table 7-41. GD\_CONFIG2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | PARITY | R/W | 0h | Parity bit | | 30 | RESERVED | R/W | 0h | Reserved | | 29-26 | RESERVED | R/W | 0h | Reserved | | 25 | RESERVED | R/W | 0h | Reserved | | 24 | BUCK_PS_DIS | R/W1C | 1h | Buck power sequencing disable 0h = Buck power sequencing is enabled 1h = Buck power sequencing is disabled | | 23 | BUCK_CL | R/W | Oh | Buck current limit 0h = Buck regulator current limit is set to 600 mA 1h = Buck regulator current limit is set to 150 mA | | 22-21 | BUCK_SEL | R/W | 1h | Buck voltage 0h = Buck voltage is 3.3 V 1h = Buck voltage is 5.0 V 2h = Buck voltage is 4.0 V 3h = Buck voltage is 5.7 V | | 20 | RESERVED | R/W | 0h | Reserved | | 19-17 | MIN_ON_TIME | R/W | Oh | Minimum ON time for low side MOSFET $0h = 0 \mu s$ $1h = Automatic based on Slew rate 2h = 0.5 \mu s 3h = 0.75 \mu s 4h = 1 \mu s 5h = 1.25 \mu s 6h = 1.5 \mu s 7h = 2 \mu s$ | | 16-0 | RESERVED | R/W | 0h | Reserved | # 7.7.4 Internal\_Algorithm\_Configuration Registers Table 7-42 lists the memory-mapped registers for the Internal\_Algorithm\_Configuration registers. All register offset addresses not listed in Table 7-42 should be considered as reserved locations and the register contents should not be modified. Table 7-42. INTERNAL\_ALGORITHM\_CONFIGURATION Registers | Offset | Acronym | Register Name | Section | |--------|------------|-----------------------------------|---------| | A0h | INT_ALGO_1 | Internal Algorithm Configuration1 | Go | | A2h | INT_ALGO_2 | Internal Algorithm Configuration2 | Go | Complex bit access types are encoded to fit into small table cells. Table 7-43 shows the codes that are used for access types in this section. | Access Type | Code | Description | | | | | |------------------|-------|----------------------------------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | Reset or Default | Value | | | | | | | -n | | Value after reset or the default value | | | | | # 7.7.4.1 INT\_ALGO\_1 Register (Offset = A0h) [Reset = 00000000h] INT\_ALGO\_1 is shown in Figure 7-78 and described in Table 7-44. Return to the Summary Table. Register to configure internal algorithm parameters1 # Figure 7-78. INT ALGO 1 Register | | riguic 7-70. INT_ALOO_1 Register | | | | | | | |--------------------------------|----------------------------------------|--------------------|-------------------------|-----------------------|----------------------------|-------|---------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | ACTIVE_BRAKE_SPEEDDEL<br>TA_LIMIT_EXIT | | SPEED_PIN_GLITCH_FILTER | | FAST_ISD_EN ISD_STOP_TIME | | OP_TIME | | R/W-0h | R/W | V-0h | R/W-0h | | R/W-0h R/W | | V-0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | ISD_RU | ISD_RUN_TIME ISD_TIM | | MEOUT AUTO_ | | _HANDOFF_MIN_BEMF | | BRAKE_CURR<br>ENT_PERSIST | | R/M | R/W-0h F | | V-0h | | R/W-0h | | R/W-0h | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | BRAKE_CURR<br>ENT_PERSIST | MPET_IPD_CU | JRRENT_LIMIT | MPET_IPD_FREQ | | MPET_OPEN_LOOP_CURRENT_REF | | RENT_REF | | R/W-0h | R/W | V-0h | R/W-0h | | R/W-0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MPET_OPEN_LOOP_SPEED_R MPET_OI | | PEN_LOOP_SLEW_RATE | | REV_DRV_OPEN_LOOP_DEC | | P_DEC | | | R/M | /-0h | | R/W-0h | | R/W-0h | | | # Table 7-44. INT\_ALGO\_1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-29 | ACTIVE_BRAKE_SPEEDDELTA_LIMIT_EXIT | R/W | 0h | Difference between final speed and present speed below which active braking will be stopped 0h = 2.5% 1h = 5% 2h = 7.5% 3h = 10% | | 28-27 | SPEED_PIN_GLITCH_FIL<br>TER | R/W | 0h | Glitch filter applied on speed pin input $0h = No$ Glitch Filter $1h = 0.2 \ \mu s$ $2h = 0.5 \ \mu s$ $3h = 1.0 \ \mu s$ | | 26 | FAST_ISD_EN | R/W | Oh | Enable fast speed detection during ISD 0h = Disable Fast ISD 1h = Enable Fast ISD | | 25-24 | ISD_STOP_TIME | R/W | 0h | Persistence time for declaring motor has stopped 0h = 1 ms 1h = 5 ms 2h = 50 ms 3h = 100 ms | | 23-22 | ISD_RUN_TIME | R/W | 0h | Persistence time for declaring motor is running 0h = 1 ms 1h = 5 ms 2h = 50 ms 3h = 100 ms | | 21-20 | ISD_TIMEOUT | R/W | 0h | Timeout in case ISD is unable to reliably detect speed or direction 0h = 500ms 1h = 750 ms 2h = 1000 ms 3h = 2000 ms | # Table 7-44. INT\_ALGO\_1 Register Field Descriptions (continued) | Bit | Field | Type | Reset | Descriptions (continued) | |-------|--------------------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 19-17 | | | Oh | Minimum BEMF for handoff | | 19-17 | AUTO_HANDOFF_MIN_B<br>EMF | IVVV | OII | Minimum Bewir for handon<br>0h = 0 mV<br>1h = 50 mV<br>2h = 100 mV<br>3h = 250 mV<br>4h = 500 mV<br>5h = 1000 mV<br>6h = 1250 mV<br>7h = 1500 mV | | 16-15 | BRAKE_CURRENT_PER<br>SIST | R/W | 0h | Persistence time for current below threshold during current based ISD brake 0h = 50 ms 1h = 100 ms 2h = 250 ms 3h = 500 ms | | 14-13 | MPET_IPD_CURRENT_LI<br>MIT | R/W | 0h | IPD current limit for MPET 0h = 0.1 A 1h = 0.5 A 2h = 1.0 A 3h = 2.0 A | | 12-11 | MPET_IPD_FREQ | R/W | 0h | Number of times IPD is executed for MPET 0h = 1 1h = 2 2h = 4 3h = 8 | | 10-8 | MPET_OPEN_LOOP_CU<br>RRENT_REF | R/W | Oh | Open loop current reference for MPET 0h = 1 A 1h = 2 A 2h = 3 A 3h = 4 A 4h = 5 A 5h = 6 A 6h = 7 A 7h = 8 A | | 7-6 | MPET_OPEN_LOOP_SP<br>EED_REF | R/W | 0h | Open loop speed reference for MPET (% of MAX_SPEED) 0h = 15% 1h = 25% 2h = 35% 3h = 50% | | 5-3 | MPET_OPEN_LOOP_SL<br>EW_RATE | R/W | Oh | Open loop acceleration for MPET 0h = 0.1 Hz/s 1h = 0.5 Hz/s 2h = 1 Hz/s 3h = 2 Hz/s 4h = 3 Hz/s 5h = 5 Hz/s 6h = 10 Hz/s 7h = 20 Hz/s | | 2-0 | REV_DRV_OPEN_LOOP<br>_DEC | R/W | Oh | % of open loop acceleration to be applied during open loop deceleration in reverse drive 0h = 50% 1h = 60% 2h = 70% 3h = 80% 4h = 90% 5h = 100% 6h = 125% 7h = 150% | # 7.7.4.2 INT\_ALGO\_2 Register (Offset = A2h) [Reset = 00000000h] INT\_ALGO\_2 is shown in Figure 7-79 and described in Table 7-45. Return to the Summary Table. Register to configure internal algorithm parameters2 #### Figure 7-79. INT ALGO 2 Register | | | ອ | aic | ,ug. | 0.01 | | | |------------------------------------------------|------|------|--------|----------|---------------------|---------------------------------------|----------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | | | | RESERVED | | | | | R/W-0h | | | | R/W-0h | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | | RESE | RVED | | | | | R/W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESI | ERVED | | | CL_SLC | W_ACC | | | | R/ | W-0h | | | R/V | V-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CL_SLOW_ACC ACTIVE_BRAKE_BUS_CURRENT_SLEW_RATE | | | | | MPET_IPD_SE<br>LECT | MPET_KE_ME<br>AS_PARAMET<br>ER_SELECT | IPD_HIGH_RE<br>SOLUTION_EN | | R/W | /-0h | | R/W-0h | | R/W-0h | R/W-0h | R/W-0h | # Table 7-45. INT\_ALGO\_2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|----------------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | R/W | 0h | Reserved | | 30-10 | RESERVED | R/W | 0h | Reserved | | 9-6 | CL_SLOW_ACC | R/W | Oh | Close loop acceleration when estimator is not yet fully aligned just after transition to closed loop 0h = 0.1 Hz/s 1h = 1 Hz/s 2h = 2 Hz/s 3h = 3 Hz/s 4h = 5 Hz/s 5h = 10 Hz/s 6h = 20 Hz/s 7h = 30 Hz/s 8h = 40 Hz/s 9h = 50 Hz/s Ah = 100 Hz/s Bh = 200 Hz/s Ch = 500 Hz/s Ch = 500 Hz/s Eh = 1000 Hz/s Fh = 2000 Hz/s | | 5-3 | ACTIVE_BRAKE_BUS_C<br>URRENT_SLEW_RATE | R/W | Oh | Bus current slew rate during active braking 0h = 10 A/s 1h = 50 A/s 2h = 100 A/s 3h = 250 A/s 4h = 500 A/s 5h = 1000 A/s 6h = 5000 A/s 7h = No Limit | # Table 7-45. INT\_ALGO\_2 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|-----------------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2 | MPET_IPD_SELECT | R/W | 0h | Selection between MPET_IPD_CURRENT_LIMIT for IPD current limit, MPET_IPD_FREQ for IPD Repeat OR IPD_CURR_THR for IPD current limit, IPD_REPEAT for IPD Repeat 0h = Configured parameters for normal motor operation 1h = MPET specific parameters | | 1 | MPET_KE_MEAS_PARA<br>METER_SELECT | R/W | Oh | Selection between MPET_OPEN_LOOP_SLEW_RATE for slew rate, MPET_OPEN_LOOP_CURR_REF for current reference, MPET_OPEN_LOOP_SPEED_REF for speed reference OR OL_ACC_A1, OL_ACC_A2 for slew rate, open loop current reference for current reference and open to closed loop speed threshold for speed reference 0h = Configured parameters for normal motor operation 1h = MPET specific parameters | | 0 | IPD_HIGH_RESOLUTION<br>_EN | R/W | 0h | IPD high resolution enable 0h = Disable 1h = Enable | ### 7.8 RAM (Volatile) Register Map #### 7.8.1 Fault\_Status Registers Table 7-46 lists the memory-mapped registers for the Fault Status registers. All register offset addresses not listed in Table 7-46 are considered as reserved locations and the register contents are not be modified. Table 7-46. FAULT\_STATUS Registers | Offset | Acronym | Register Name | Section | |--------|--------------------------|-----------------------|---------| | E0h | GATE_DRIVER_FAULT_STATUS | Fault Status Register | Go | | E2h | CONTROLLER_FAULT_STATUS | Fault Status Register | Go | Complex bit access types are encoded to fit into small table cells. Table 7-47 shows the codes that are used for access types in this section. Table 7-47. Fault\_Status Access Type Codes | Access Type | Code | Description | | | | | |------------------|-------|----------------------------------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Reset or Default | Value | | | | | | | -n | | Value after reset or the default value | | | | | # 7.8.1.1 GATE\_DRIVER\_FAULT\_STATUS Register (Offset = E0h) [Reset = 00000000h] GATE\_DRIVER\_FAULT\_STATUS is shown in Figure 7-80 and described in Table 7-48. Return to the Summary Table. Status of various gate driver faults # Figure 7-80. GATE\_DRIVER\_FAULT\_STATUS Register | | 1 iguio 7 001 07 112_57(171021_0171100 110gioto) | | | | | | | | | |------------------|--------------------------------------------------|----------|---------|----------|--------|----------|----------|--|--| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | | | DRIVER_FAUL<br>T | BK_FLT | RESERVED | OCP | RESERVED | OVP | ОТ | RESERVED | | | | R-0h | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | OTW | OTS | OCP_HC | OCP_LC | OCP_HB | OCP_LB | OCP_HA | OCP_LA | | | | R-0h | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | RESERVED | OTP_ERR | BUCK_OCP | BUCK_UV | VCP_UV | | RESERVED | | | | | R-0h | R-0h | R-0h | R-0h | R-0h | | R-0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | RESERVED | | | | | | | | | | | R-0h | | | | | | | | | #### Table 7-48. GATE\_DRIVER\_FAULT\_STATUS Register Field Descriptions | Bit | Field | Туре | Reset | Description | | |-----|--------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 31 | DRIVER_FAULT | R | 0h | Logic OR of FAULT status registers. Mirrors nFAULT pin. | | | 30 | BK_FLT | R | Oh | Buck Fault Bit 0h = No buck regulator fault condition is detected 1h = Buck regulator fault condition is detected | | | 29 | RESERVED | R | 0h | Reserved | | | 28 | OCP | R | Oh | Over Current Protection Status Bit 0h = No overcurrent condition is detected 1h = Overcurrent condition is detected | | | 27 | RESERVED | R | 0h | Reserved | | | 26 | OVP | R | Oh | Supply Overvoltage Protection Status Bit 0h = No overvoltage condition is detected on VM 1h = Overvoltage condition is detected on VM | | | 25 | ОТ | R | Oh | Overtemperature Fault Status Bit 0h = No overtemperature warning / shutdown is detected 1h = Overtemperature warning / shutdown is detected | | | 24 | RESERVED | R | 0h | Reserved | | | 23 | ОТЖ | R | Oh | Overtemperature Warning Status Bit 0h = No overtemperature warning is detected 1h = Overtemperature warning is detected | | | 22 | ОТЅ | R | Oh | Overtemperature Shutdown Status Bit 0h = No overtemperature shutdown is detected 1h = Overtemperature shutdown is detected | | | 21 | OCP_HC | R | Oh | Overcurrent Status on High-side switch of OUTC 0h = No overcurrent detected on high-side switch of OUTC 1h = Overcurrent detected on high-side switch of OUTC | | | 20 | OCP_LC | R | Oh | Overcurrent Status on Low-side switch of OUTC 0h = No overcurrent detected on low-side switch of OUTC 1h = Overcurrent detected on low-side switch of OUTC | | Copyright © 2023 Texas Instruments Incorporated Submit Document Feedback Table 7-48. GATE DRIVER FAULT STATUS Register Field Descriptions (continued) | | Table 7-46. GATE_DRIVER_FAULT_STATUS Register Fleid Descriptions (continued) | | | | | | | |------|------------------------------------------------------------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Bit | Field | Туре | Reset | Description | | | | | 19 | OCP_HB | R | Oh | Overcurrent Status on High-side switch of OUTB 0h = No overcurrent detected on high-side switch of OUTB 1h = Overcurrent detected on high-side switch of OUTB | | | | | 18 | OCP_LB | R | 0h | Overcurrent Status on Low-side switch of OUTB 0h = No overcurrent detected on low-side switch of OUTB 1h = Overcurrent detected on low-side switch of OUTB | | | | | 17 | OCP_HA | R | Oh | Overcurrent Status on High-side switch of OUTA 0h = No overcurrent detected on high-side switch of OUTA 1h = Overcurrent detected on high-side switch of OUTA | | | | | 16 | OCP_LA | R | 0h | Overcurrent Status on Low-side switch of OUTA 0h = No overcurrent detected on low-side switch of OUTA 1h = Overcurrent detected on low-side switch of OUTA | | | | | 15 | RESERVED | R | 0h | Reserved | | | | | 14 | OTP_ERR | R | 0h | OTP Error 0h = No OTP error is detected 1h = OTP Error is detected | | | | | 13 | BUCK_OCP | R | Oh | Buck Regulator Overcurrent Status Bit Oh = No buck regulator overcurrent is detected 1h = Buck regulator overcurrent is detected | | | | | 12 | BUCK_UV | R | Oh | Buck Regulator Undervoltage Status Bit Oh = No buck regulator undervoltage is detected 1h = Buck regulator undervoltage is detected | | | | | 11 | VCP_UV | R | Oh | Charge Pump Undervoltage Status Bit 0h = No charge pump undervoltage is detected 1h = Charge pump undervoltage is detected | | | | | 10-0 | RESERVED | R | 0h | Reserved | | | | | | | | | | | | | Submit Document Feedback Product Folder Links: MCF8316C-Q1 # 7.8.1.2 CONTROLLER\_FAULT\_STATUS Register (Offset = E2h) [Reset = 00000000h] CONTROLLER\_FAULT\_STATUS is shown in Figure 7-81 and described in Table 7-49. Return to the Summary Table. Status of various controller faults # Figure 7-81. CONTROLLER\_FAULT\_STATUS Register | | rigule 7-01. CONTROLLER_I ACEI_CIATOO Register | | | | | | | |---------------------------|------------------------------------------------|--------------------|--------------|--------------|----------------------------------|-------------------------|------------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | CONTROLLER<br>_FAULT | RESERVED | IPD_FREQ_FA<br>ULT | IPD_T1_FAULT | IPD_T2_FAULT | BUS_CURREN<br>T_LIMIT_STAT<br>US | MPET_IPD_FA<br>ULT | MPET_BEMF_<br>FAULT | | R-0h | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | ABN_SPEED | ABN_BEMF | NO_MTR | MTR_LCK | LOCK_LIMIT | HW_LOCK_LIM<br>IT | DCBUS_UNDE<br>R_VOLTAGE | DCBUS_OVER<br>_VOLTAGE | | R-0h | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | SPEED_LOOP<br>_SATURATION | CURRENT_LO<br>OP_SATURATI<br>ON | RESERVED | | | | | | | R-0h | R-0h | | | R- | 0h | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | RESERVED | RESERVED | RESERVED | | | R- | 0h | | R-0h | R-0h | R-0h | R-0h | Table 7-49. CONTROLLER\_FAULT\_STATUS Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-----|------------------------------|------|-------|--------------------------------------------------------------| | 31 | CONTROLLER_FAULT | R | 0h | Logic OR of Controller FAULT status registers | | 30 | RESERVED | R | 0h | Reserved | | 29 | IPD_FREQ_FAULT | R | 0h | Indicates IPD frequency fault | | 28 | IPD_T1_FAULT | R | 0h | Indicates IPD T1 fault | | 27 | IPD_T2_FAULT | R | 0h | Indicates IPD T2 fault | | 26 | BUS_CURRENT_LIMIT_S<br>TATUS | R | 0h | Indicates status of Bus Current limit | | 25 | MPET_IPD_FAULT | R | 0h | Indicates error during resistance and inductance measurement | | 24 | MPET_BEMF_FAULT | R | 0h | Indicates error during BEMF constant measurement | | 23 | ABN_SPEED | R | 0h | Indicates Abnormal speed motor lock condition | | 22 | ABN_BEMF | R | 0h | Indicates Abnormal BEMF motor lock condition | | 21 | NO_MTR | R | 0h | Indicates No Motor fault | | 20 | MTR_LCK | R | 0h | Indicates when one of the motor lock is triggered | | 19 | LOCK_LIMIT | R | 0h | Indicates Lock Ilimit fault | | 18 | HW_LOCK_LIMIT | R | 0h | Indicates Hardware Lock Ilimit fault | | 17 | DCBUS_UNDER_VOLTA<br>GE | R | 0h | Indicates DC bus undervoltage fault | | 16 | DCBUS_OVER_VOLTAG | R | 0h | Indicates DC bus overvoltage fault | | 15 | SPEED_LOOP_SATURAT ION | R | 0h | Indicates speed loop saturation | | 14 | CURRENT_LOOP_SATU<br>RATION | R | 0h | Indicates current loop saturation | Table 7-49. CONTROLLER\_FAULT\_STATUS Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | | |------|----------------|------|-------|--------------------------|--| | 13-4 | RESERVED | R | 0h | Oh Reserved | | | 3 | WATCHDOG_FAULT | R | 0h | indicates Watchdog fault | | | 2 | RESERVED | R | 0h | Reserved | | | 1 | RESERVED | R | 0h | Reserved | | | 0 | RESERVED | R | 0h | Reserved | | #### 7.8.2 System\_Status Registers Table 7-50 lists the memory-mapped registers for the System\_Status registers. All register offset addresses not listed in Table 7-50 should be considered as reserved locations and the register contents should not be modified. Table 7-50. SYSTEM\_STATUS Registers | Offset | Acronym | Register Name | Section | |--------|------------------|------------------------|---------| | E4h | ALGO_STATUS | System Status Register | | | E6h | MTR_PARAMS | System Status Register | | | E8h | ALGO_STATUS_MPET | System Status Register | | Complex bit access types are encoded to fit into small table cells. Table 7-51 shows the codes that are used for access types in this section. Table 7-51. System\_Status Access Type Codes | , , = , ,, | | | | | | | | |------------------------|------|----------------------------------------|--|--|--|--|--| | Access Type | Code | Description | | | | | | | Read Type | | | | | | | | | R | R | Read | | | | | | | Reset or Default Value | | | | | | | | | -n | | Value after reset or the default value | | | | | | #### 7.8.3 Device\_Control Registers Table 7-52 lists the memory-mapped registers for the Device\_Control registers. All register offset addresses not listed in Table 7-52 should be considered as reserved locations and the register contents should not be modified. Table 7-52. DEVICE\_CONTROL Registers | Offset | Acronym | Register Name | Section | |--------|------------|-------------------------|---------| | EAh | ALGO_CTRL1 | Device Control Register | Go | Complex bit access types are encoded to fit into small table cells. Table 7-53 shows the codes that are used for access types in this section. Table 7-53. Device\_Control Access Type Codes | Access Type | Code | Description | | | | | |------------------------|------|----------------------------------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | #### 7.8.3.1 ALGO\_CTRL1 Register (Offset = EAh) [Reset = 00000000h] ALGO\_CTRL1 is shown in Figure 7-82 and described in Table 7-54. Return to the Summary Table. Control settings #### Figure 7-82. ALGO CTRL1 Register | | rigule 7-02. ALGO_CTILLI Register | | | | | | | |------------|-----------------------------------|--------------|-------------------------|----------|---------------------|---------|-------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | EEPROM_WRT | EEPROM_REA<br>D | CLR_FLT | CLR_FLT_RET<br>RY_COUNT | RESERVED | | | | | R/W-0h | R/W-0h | W-0h | W-0h | | W-0h | l | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | RESE | RVED | | | FORCED_ALIG | N_ANGLE | | | | W- | 0h | | W-0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | FOR | CED_ALIGN_AN | IGLE | | WATCHDOG_T<br>ICKLE | RESE | ERVED | | | W-0h R/W-0h W-0h | | | | | | /-0h | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RESERVED | | | | | | | | | W-0h | | | | | | | #### Table 7-54. ALGO\_CTRL1 Register Field Descriptions | | 14515 1 0 11 / 12 0 _ 0 11 (12 1 1 to glotto) 1 10 to 2 0 0 0 1 pt 0 10 | | | | | | |-------|-------------------------------------------------------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 31 | EEPROM_WRT | R/W | 0h | Write the configuration to EEPROM | | | | 30 | EEPROM_READ | R/W | 0h | Read the default configuration from EEPROM | | | | 29 | CLR_FLT | W | 0h | Clears all faults | | | | 28 | CLR_FLT_RETRY_COUN<br>T | W | 0h | Clears fault retry count | | | | 27-20 | RESERVED | W | 0h | Reserved | | | | 19-11 | FORCED_ALIGN_ANGLE | W | Oh | 9-bit value (in degrees) used during forced Align state ( FORCE_ALIGN_EN = 1) Angle applied = FORCED_ALIGN_ANGLE % 360deg | | | | 10 | WATCHDOG_TICKLE | R/W | 0h | RAM bit to tickle watchdog in I2C mode. This bit should be written 1 by external controller every EXT_WDT_CFG. The MCF will reset this bit | | | | 9-0 | RESERVED | W | 0h | Reserved | | | #### 7.8.4 Algorithm\_Control Registers Table 7-55 lists the memory-mapped registers for the Algorithm\_Control registers. All register offset addresses not listed in Table 7-55 should be considered as reserved locations and the register contents should not be modified. Table 7-55. ALGORITHM CONTROL Registers | Offset | Acronym | Register Name | Section | | | | | |--------|-------------|----------------------------|---------|--|--|--|--| | ECh | ALGO_DEBUG1 | Algorithm Control Register | Go | | | | | | EEh | ALGO_DEBUG2 | Algorithm Control Register | Go | | | | | | F0h | CURRENT_PI | Current PI Controller used | Go | | | | | | F2h | SPEED_PI | Speed PI controller used | Go | | | | | | F4h | DAC_1 | DAC1 Control Register | Go | | | | | Copyright © 2023 Texas Instruments Incorporated #### Table 7-55. ALGORITHM\_CONTROL Registers (continued) | Offset | Acronym | Register Name | Section | |--------|---------|-----------------------|---------| | F6h | DAC_2 | DAC2 Control Register | Go | Complex bit access types are encoded to fit into small table cells. Table 7-56 shows the codes that are used for access types in this section. Table 7-56. Algorithm\_Control Access Type Codes | Access Type Code Description | | | | | | | |------------------------------|-----------|----------------------------------------|--|--|--|--| | Access Type | Code | Description | | | | | | Read Type | Read Type | | | | | | | R | R | Read | | | | | | Write Type | | | | | | | | W | W | Write | | | | | | Reset or Default Value | | | | | | | | -n | | Value after reset or the default value | | | | | # 7.8.4.1 ALGO\_DEBUG1 Register (Offset = ECh) [Reset = 00000000h] ALGO\_DEBUG1 is shown in Figure 7-83 and described in Table 7-57. Return to the Summary Table. Algorithm control register for debug #### Figure 7-83. ALGO DEBUG1 Register | rigule 7-03. ALOO_DEDOOT Register | | | | | | | | |-----------------------------------|--------------------------|-----------------------------------|------------------|------------------|-----------------------------------|----|---------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | OVERRIDE | DIGITAL_SPEED_CTRL | | | | | | | | W-0h | W-0h | | | | | | | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | DIGITAL_SPEED_CTRL | | | | | | | | W-0h | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | CLOSED_LOO<br>P_DIS | FORCE_ALIGN<br>_EN | FORCE_SLOW<br>_FIRST_CYCL<br>E_EN | FORCE_IPD_E<br>N | FORCE_ISD_E<br>N | FORCE_ALIGN<br>_ANGLE_SRC_<br>SEL | | F_SPEED_LOOP<br>DIS | | W-0h | W-0h W-0h W-0h W-0h W-0h | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | FORCE_IQ_REF_SPEED_LOOP_DIS | | | | | | | | | W-0h | | | | | | | | #### Table 7-57. ALGO\_DEBUG1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | OVERRIDE | W | 0h | Use to control the SPD_CTRL bits. If OVERRIDE = '1', speed command can be written by the user through serial interface. 0h = SPEED_CMD using Analog/PWM mode 1h = SPEED_CMD using DIGITAL_SPEED_CTRL | | 30-16 | DIGITAL_SPEED_CTRL | W | 0h | Digital Speed Control If OVERRIDE = 0b1, then SPEED_CMD is control using DIGITAL_SPEED_CTRL | | 15 | CLOSED_LOOP_DIS | W | Oh | Use to disable Closed loop 0h = Enable Closed Loop 1h = Disable Closed loop, motor commutation in open loop | | 14 | FORCE_ALIGN_EN | W | 0h | Force Align State Enable 0h = Disable Force Align state, device comes out of align state if MTR_STARTUP is selected as ALIGN or DOUBLE ALIGN 1h = Enable Force Align state, device stays in align state if MTR_STARTUP is selected as ALIGN or DOUBLE ALIGN | | 13 | FORCE_SLOW_FIRST_C<br>YCLE_EN | W | 0h | Force Slow First Cycle Enable 0h = Disable Force Slow First Cycle state, device comes out of slow first cycle state if MTR_STARTUP is selected as SLOW FIRST CYCLE 1h = Enable Force Slow First Cycle state, device stays in slow first cycle state if MTR_STARTUP is selected as SLOW FIRST CYCLE | | 12 | FORCE_IPD_EN | W | 0h | Force IPD Enable 0h = Disable Force IPD state, device comes out of IPD state if MTR_STARTUP is selected as IPD 1h = Enable Force IPD state, device stays in IPD state if MTR_STARTUP is selected as IPD | | 11 | FORCE_ISD_EN | W | 0h | Force ISD enable 0h = Disable Force ISD state, device comes out of ISD state if ISD_EN is set 1h = Enable Force ISD state, device stays in ISD state if ISD_EN is set | # Table 7-57. ALGO\_DEBUG1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |-----|---------------------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | FORCE_ALIGN_ANGLE_<br>SRC_SEL | W | 0h | Force Align Angle State Source Select 0h = Force Align Angle defined by ALIGN_ANGLE 1h = Force Align Angle defined by FORCED_ALIGN_ANGLE | | 9-0 | FORCE_IQ_REF_SPEED<br>_LOOP_DIS | W | Oh | Sets IQ Ref (% of BASE_CURRENT) when speed loop is disabled If SPEED_LOOP_DIS = 0b1, then Iq_ref is control using IQ_REF_SPEED_LOOP_DIS iqRef = (FORCE_IQ_REF_SPEED_LOOP_DIS /500) * BASE_CURRENT if FORCE_IQ_REF_SPEED_LOOP_DIS < 500 (FORCE_IQ_REF_SPEED_LOOP_DIS - 1024)/500 * BASE_CURRENT if FORCE_IQ_REF_SPEED_LOOP_DIS > 512 Valid values are 0 to 500 and 512 to 1000 | # 7.8.4.2 ALGO\_DEBUG2 Register (Offset = EEh) [Reset = 00000000h] ALGO\_DEBUG2 is shown in Figure 7-84 and described in Table 7-58. Return to the Summary Table. Algorithm control register for debug ### Figure 7-84. ALGO DEBUG2 Register | | rigate / 04. ALGO_DEBGGE Register | | | | | | | |----------|-----------------------------------|---------------|-------------|-----------------------------------|----------------------|------------------|-----------------------| | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | | RESERVED | FORCE_REG | CIRCULATE_STO | P_SECTOR | FORCE_RECIR<br>CULATE_STOP<br>_EN | CURRENT_LO<br>OP_DIS | FORCE_VD_CL<br>D | IRRENT_LOOP_<br>IS | | W-0h | | W-0h | | W-0h | W-0h | W | -0h | | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | | | | F | ORCE_VD_CUR | RENT_LOOP_DIS | 5 | | | | | | | W | -0h | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | F | ORCE_VQ_CUR | RENT_LOOP_DIS | S | | | | | | | W | -0h | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | JRRENT_LOOP_<br>DIS | MPET_CMD | MPET_R | MPET_L | MPET_KE | MPET_MECH | MPET_WRITE_<br>SHADOW | | W | -0h | W-0h | W-0h | W-0h | W-0h | W-0h | W-0h | ### Table 7-58. ALGO\_DEBUG2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31 | RESERVED | W | 0h | Reserved | | 30-28 | FORCE_RECIRCULATE_<br>STOP_SECTOR | W | Oh | use to do the recirculation at specific sector during force motor stop condition 0h = The last sector before stop condition 1h = Sector1 2h = Sector2 3h = Sector3 4h = Sector4 5h = Sector5 6h = Sector6 7h = The last sector before stop condition | | 27 | FORCE_RECIRCULATE_<br>STOP_EN | W | Oh | Force recirculate stop Enable 0h = Enable Force recirculate stop 1h = Disable Force recirculate stop | | 26 | CURRENT_LOOP_DIS | W | 0h | Use to control the FORCE_VD_CURRENT_LOOP_DIS and FORCE_VQ_CURRENT_LOOP_DIS. If CURRENT_LOOP_DIS = '1', Current loop and speed loop is disabled 0h = Enable Current Loop 1h = Disable Current Loop | | 25-16 | FORCE_VD_CURRENT_<br>LOOP_DIS | W | 0h | Sets Vd when current loop speed loop are disabled If CURRENT_LOOP_DIS = 0b1, then Vd is control using FORCE_VD_CURRENT_LOOP_DIS mdRef = (FORCE_VD_CURRENT_LOOP_DIS /500) if FORCE_VD_CURRENT_LOOP_DIS < 500 (FORCE_VD_CURRENT_LOOP_DIS - 1024)/500 if FORCE_VD_CURRENT_LOOP_DIS > 512 Valid values: 0 to 500 and 512 to 1000 | ### Table 7-58. ALGO\_DEBUG2 Register Field Descriptions (continued) | | Table 7-36. ALGO_DEBOG2 Register Field Descriptions (continued) | | | | | | |------|-----------------------------------------------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Bit | Field | Туре | Reset | Description | | | | 15-6 | FORCE_VQ_CURRENT_<br>LOOP_DIS | W | Oh | Sets Vq when current loop speed loop are disabled If CURRENT_LOOP_DIS = 0b1, then Vq is control using FORCE_VQ_CURRENT_LOOP_DIS mqRef = (FORCE_VQ_CURRENT_LOOP_DIS /500) if FORCE_VQ_CURRENT_LOOP_DIS < 500 (FORCE_VQ_CURRENT_LOOP_DIS - 1024)/500 if FORCE_VQ_CURRENT_LOOP_DIS > 512 Valid values: 0 to 500 and 512 to 1000 | | | | 5 | MPET_CMD | W | 0h | Initiates motor parameter measurement routine when set to 1 | | | | 4 | MPET_R | W | 0h | Enables motor resistance measurement during motor parameter measurement routine 0h = Disables Motor Resistance measurement during motor parameter measurement routine 1h = Enable Motor Resistance measurement during motor parameter measurement routine | | | | 3 | MPET_L | W | 0h | Enables motor inductance measurement during motor parameter measurement routine 0h = Disables Motor Inductance measurement during motor parameter measurement routine 1h = Enable Motor Inductance measurement during motor parameter measurement routine | | | | 2 | MPET_KE | W | 0h | Enables motor BEMF constant measurement during motor parameter measurement routine 0h = Disables Motor BEMF constant measurement during motor parameter measurement routine 1h = Enable Motor BEMF constant measurement during motor parameter measurement routine | | | | 1 | MPET_MECH | W | 0h | Enables motor mechanical parameter measurement during motor parameter measurement routine 0h = Disables Motor mechanical parameter measurement during motor parameter measurement routine 1h = Enable Motor mechanical parameter measurement during motor parameter measurement routine | | | | 0 | MPET_WRITE_SHADOW | W | 0h | Write measured parameters to shadow register when set to 1 | | | # 7.8.4.3 CURRENT\_PI Register (Offset = F0h) [Reset = 00000000h] CURRENT\_PI is shown in Figure 7-85 and described in Table 7-59. Return to the Summary Table. Current PI controller used ### Figure 7-85. CURRENT\_PI Register # Table 7-59. CURRENT\_PI Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|-----------------|------|-------|---------------------------------------------------------| | 31-16 | CURRENT_LOOP_KI | R | 0h | 10 bit for current loop ki Same Scaling as CURR_LOOP_KI | | 15-0 | CURRENT_LOOP_KP | R | 0h | 10 bit for current loop kp Same Scaling as CURR_LOOP_KP | # 7.8.4.4 SPEED\_PI Register (Offset = F2h) [Reset = 00000000h] SPEED\_PI is shown in Figure 7-86 and described in Table 7-60. Return to the Summary Table. Speed PI controller used ### Figure 7-86. SPEED\_PI Register #### Table 7-60. SPEED\_PI Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|---------------|------|-------|------------------------------------------------------| | 31-16 | SPEED_LOOP_KI | R | 0h | 10 bit for Speed loop ki Same Scaling as SPD_LOOP_KI | | 15-0 | SPEED_LOOP_KP | R | 0h | 10 bit for Speed loop kp Same Scaling as SPD_LOOP_KP | # 7.8.4.5 DAC\_1 Register (Offset = F4h) [Reset = 00000000h] DAC\_1 is shown in Figure 7-87 and described in Table 7-61. Return to the Summary Table. **DAC1 Control Register** Figure 7-87. DAC\_1 Register Table 7-61. DAC\_1 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-21 | RESERVED | R | 0h | Reserved | | 20-17 | DACOUT1_ENUM_SCALI<br>NG | W | 8h | Multiplication Factor for DACOUT1 Algorithm Variable extracted from the address contained in DACOUT1_VAR_ADDR multiplied with 2DACOUT1_ENUM_SCALING. DACOUT1_ENUM_SCALING comes into effect only if DACOUT1_SCALING is zero | | 16-13 | DACOUT1_SCALING | W | 8h | Scaling factor for DACOUT1 Algorithm Variable extracted from the address contained in DACOUT1_VAR_ADDR scaled with DACOUT1_SCALING / 8. Actual voltage depends on DACOUT1_UNIPOLAR. If DACOUT1_UNIPOLAR = 1, 0V == 0pu of algorithmVariable * DACOUT1_SCALING / 8, 3V == 1pu of algorithmVariable * DACOUT1_SCALING / 8 If DACOUT1_UNIPOLAR = 0, 0V == -1pu of algorithmVariable * DACOUT1_SCALING / 8, 3V == 1pu of algorithmVariable * DACOUT1_SCALING / 8 0h = Treated as Enum with max value being 31 1h = 1 / 8 2h = 2 / 8 3h = 3 / 8 4h = 4 / 8 5h = 5 / 8 6h = 6 / 8 7h = 7 / 8 8h = 8 / 8 9h = 9 / 8 Ah = 10 / 8 Bh = 11 / 8 Ch = 12 / 8 Dh = 13 / 8 Eh = 14 / 8 Fh = 15 / 8 | # Table 7-61. DAC\_1 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12 | DACOUT1_UNIPOLAR | W | Oh | Configures output of DACOUT1 If DACOUT1_UNIPOLAR = 1, 0V == 0pu of algorithmVariable * DACOUT1_SCALING / 16, 3V == 1pu of algorithmVariable * DACOUT1_SCALING / 16 If DACOUT1_UNIPOLAR = 0, 0V == -1pu of algorithmVariable * DACOUT1_SCALING / 16, 3V == 1pu of algorithmVariable * DACOUT1_SCALING / 16 0h = Bipolar (Offset of 1.5 V) 1h = Unipolar (No Offset) | | 11-0 | DACOUT1_VAR_ADDR | R/W | 0h | 12-bit address of variable to be monitored | # 7.8.4.6 DAC\_2 Register (Offset = F6h) [Reset = 80XX0000h] DAC\_2 is shown in Figure 7-88 and described in Table 7-62. Return to the Summary Table. **DAC2 Control Register** ### Figure 7-88. DAC\_2 Register Table 7-62. DAC\_2 Register Field Descriptions | Bit | Field | Туре | Reset | Description | |-------|--------------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-23 | RESERVED | R | 0h | Reserved | | 22-19 | DACOUT2_ENUM_SCALI<br>NG | W | Х | Multiplication Factor for DACOUT2 Algorithm Variable extracted from the address contained in DACOUT2_VAR_ADDR multiplied with 2DACOUT2_ENUM_SCALING. DACOUT2_ENUM_SCALING comes into effect only if DACOUT2_SCALING is zero | | 18-15 | DACOUT2_SCALING | W | 8h | Scaling factor for DACOUT2 Algorithm Variable extracted from the address contained in DACOUT2_VAR_ADDR scaled with DACOUT2_SCALING / 8. Actual voltage depends on DACOUT2_UNIPOLAR. If DACOUT2_UNIPOLAR = 1, 0V == 0pu of algorithmVariable * DACOUT2_SCALING / 8, 3V == 1pu of algorithmVariable * DACOUT2_SCALING / 8 If DACOUT2_UNIPOLAR = 0, 0V == -1pu of algorithmVariable * DACOUT2_SCALING / 8, 3V == 1pu of algorithmVariable * DACOUT2_SCALING / 8 0h = Treated s Enum with max value being 31 1h = 1 / 8 2h = 2 / 8 3h = 3 / 8 4h = 4 / 8 5h = 5 / 8 6h = 6 / 8 7h = 7 / 8 8h = 8 / 8 9h = 9 / 8 Ah = 10 / 8 Bh = 11 / 8 Ch = 12 / 8 Dh = 13 / 8 Eh = 14 / 8 Fh = 15 / 8 | # Table 7-62. DAC\_2 Register Field Descriptions (continued) | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 14 | DACOUT2_UNIPOLAR | W | | Configures output of DACOUT2 If DACOUT2_UNIPOLAR = 1, 0V == 0pu of algorithmVariable * DACOUT2_SCALING / 16, 3V == 1pu of algorithmVariable * DACOUT2_SCALING / 16 If DACOUT2_UNIPOLAR = 0, 0V == -1pu of algorithmVariable * DACOUT2_SCALING / 16, 3V == 1pu of algorithmVariable * DACOUT2_SCALING / 16 0h = Bipolar (Offset of 1.5 V) 1h = Unipolar (No Offset) | | 13-0 | DACOUT2_VAR_ADDR | R/W | 0h | 14-bit address of variable to be monitored | # 7.8.5 Algorithm\_Variables Registers Table 7-63 lists the memory-mapped registers for the Algorithm\_Variables registers. All register offset addresses not listed in Table 7-63 should be considered as reserved locations and the register contents should not be modified. Table 7-63. ALGORITHM\_VARIABLES Registers | Offset | Acronym | Register Name | Section | |--------|-----------------------|--------------------------------------|---------| | 190h | ALGORITHM_STATE | Current Algorithm State Register | Go | | 196h | FG_SPEED_FDBK | FG Speed Feedback Register | Go | | 410h | BUS_CURRENT | Calculated DC Bus Current Register | Go | | 440h | PHASE_CURRENT_A | Measured Current on Phase A Register | Go | | 442h | PHASE_CURRENT_B | Measured Current on Phase B Register | Go | | 444h | PHASE_CURRENT_C | Measured Current on Phase C Register | Go | | 468h | CSA_GAIN_FEEDBACK | CSA Gain Register | Go | | 472h | VOLTAGE_GAIN_FEEDBACK | Voltage Gain Register | Go | | 476h | VM_VOLTAGE | VM Voltage Register | Go | | 47Ah | PHASE_VOLTAGE_VA | Phase A Voltage Register | Go | | 47Ch | PHASE_VOLTAGE_VB | Phase B Voltage Register | Go | | 47Eh | PHASE_VOLTAGE_VC | Phase C Voltage Register | Go | | 4B6h | SIN_COMMUTATION_ANGLE | Sine of Commutation Angle | Go | | 4B8h | COS_COMMUTATION_ANGLE | Cosine of Commutation Angle | Go | | 4D2h | IALPHA | IALPHA Current Register | Go | | 4D4h | IBETA | IBETA Current Register | Go | | 4D6h | VALPHA | VALPHA Voltage Register | Go | | 4D8h | VBETA | VBETA Voltage Register | Go | | 4E2h | ID | Measured d-axis Current Register | Go | | 4E4h | IQ | Measured q-axis Current Register | Go | | 4E6h | VD | VD Voltage Register | Go | | 4E8h | VQ | VQ Voltage Register | Go | | 524h | IQ_REF_ROTOR_ALIGN | Align Current Reference | Go | | 53Ch | SPEED_REF_OPEN_LOOP | Open Loop Speed Register | Go | | 54Ch | IQ_REF_OPEN_LOOP | Open Loop Current Reference | Go | | 5D4h | SPEED_REF_CLOSED_LOOP | Speed Reference Register | Go | | 606h | ID_REF_CLOSED_LOOP | Reference for Current Loop Register | Go | | 608h | IQ_REF_CLOSED_LOOP | Reference for Current Loop Register | Go | | 682h | ISD_STATE | ISD State Register | Go | | 68Ch | ISD_SPEED | ISD Speed Register | Go | | 6C0h | IPD_STATE | IPD State Register | Go | www.ti.com SLLSFV2 – AU | | Table 7-63. ALGORITHM_VARIABLES Registers (continued) | | | | | | | | |--------|-------------------------------------------------------|-----------------------------------|---------|--|--|--|--|--| | Offset | Acronym | Register Name | Section | | | | | | | 704h | IPD_ANGLE | Calculated IPD Angle Register | Go | | | | | | | 74Ah | ED | Estimated BEMF EQ Register | Go | | | | | | | 74Ch | EQ | Estimated BEMF ED Register | Go | | | | | | | 75Ah | SPEED_FDBK | Speed Feedback Register | Go | | | | | | | 75Eh | THETA_EST | Estimated rotor Position Register | Go | | | | | | Complex bit access types are encoded to fit into small table cells. Table 7-64 shows the codes that are used for access types in this section. Table 7-64. Algorithm\_Variables Access Type Codes | Access Type | Code | Description | | | | | |------------------|------------------------|----------------------------------------|--|--|--|--| | Read Type | | | | | | | | R | R | Read | | | | | | Reset or Default | Reset or Default Value | | | | | | | -n | | Value after reset or the default value | | | | | # 7.8.5.1 ALGORITHM\_STATE Register (Offset = 190h) [Reset = 0000h] ALGORITHM\_STATE is shown in Figure 7-89 and described in Table 7-65. Return to the Summary Table. Current Algorithm State Register ### Figure 7-89. ALGORITHM\_STATE Register Table 7-65. ALGORITHM\_STATE Register Field Descriptions | | | | | TE Register Field Descriptions | |------|-----------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 15-0 | ALGORITHM_STATE | R | Oh | 16-bit value indicating current state of device 0h = MOTOR_IDLE 1h = MOTOR_ISD 2h = MOTOR_TRISTATE 3h = MOTOR_BRAKE_ON_START 4h = MOTOR_IPD 5h = MOTOR_SLOW_FIRST_CYCLE 6h = MOTOR_ALIGN 7h = MOTOR_OPEN_LOOP 8h = MOTOR_CLOSED_LOOP_UNALIGNED 9h = MOTOR_CLOSED_LOOP_ALIGNED Ah = MOTOR_CLOSED_LOOP_ACTIVE_BRAKING Bh = MOTOR_SOFT_STOP Ch = MOTOR_RECIRCULATE_STOP Dh = MOTOR_BRAKE_ON_STOP Eh = MOTOR_FAULT Fh = MOTOR_MPET_MOTOR_STOP_CHECK 10h = MOTOR_MPET_MOTOR_STOP_WAIT 11h = MOTOR_MPET_ALGORITHM_PARAMETERS_INIT 13h = MOTOR_MPET_ALGORITHM_PARAMETERS_INIT 13h = MOTOR_MPET_KE_MEASURE 14h = MOTOR_MPET_STALL_CURRENT_MEASURE 16h = MOTOR_MPET_TORQUE_MODE 17h = MOTOR_MPET_TORQUE_MODE 17h = MOTOR_MPET_FAULT | # 7.8.5.2 FG\_SPEED\_FDBK Register (Offset = 196h) [Reset = 00000000h] FG\_SPEED\_FDBK is shown in Figure 7-90 and described in Table 7-66. Return to the Summary Table. Speed Feedback from FG ### Figure 7-90. FG\_SPEED\_FDBK Register ### Table 7-66. FG\_SPEED\_FDBK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | FG_SPEED_FDBK | R | | 32-bit unsigned value indicating absolute estimated rotor speed estimatedSpeed = (FG_SPEED_FDBK / 2 <sup>27</sup> )*MAXIMUM_SPEED_HZ | # 7.8.5.3 BUS\_CURRENT Register (Offset = 410h) [Reset = 00000000h] BUS\_CURRENT is shown in Figure 7-91 and described in Table 7-67. Return to the Summary Table. Calculated Supply Current Register ### Figure 7-91. BUS\_CURRENT Register # Table 7-67. BUS\_CURRENT Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | BUS_CURRENT | R | | 32-bit signed value indicating bus current. Negative value is represented in two's complement iBus = (BUS_CURRENT / 2 <sup>27</sup> ) * Base_Current/8 | ### 7.8.5.4 PHASE\_CURRENT\_A Register (Offset = 440h) [Reset = 00000000h] PHASE\_CURRENT\_A is shown in Figure 7-92 and described in Table 7-68. Return to the Summary Table. Measured current on Phase A Register ### Figure 7-92. PHASE\_CURRENT\_A Register Table 7-68. PHASE\_CURRENT\_A Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_CURRENT_A | R | | 32-bit signed value indicating measured current on Phase A. Negative value is represented in two's complement iA = (PHASE_CURRENT_A / 2 <sup>27</sup> ) * Base_Current/8 | ### 7.8.5.5 PHASE\_CURRENT\_B Register (Offset = 442h) [Reset = 00000000h] PHASE\_CURRENT\_B is shown in Figure 7-93 and described in Table 7-69. Return to the Summary Table. Measured current on Phase B Register ### Figure 7-93. PHASE\_CURRENT\_B Register Table 7-69. PHASE\_CURRENT\_B Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_CURRENT_B | R | | 32-bit signed value indicating measured current on Phase B. Negative value is represented in two's complement iB = (PHASE_CURRENT_B / 2 <sup>27</sup> ) * Base_Current/8 | ### 7.8.5.6 PHASE\_CURRENT\_C Register (Offset = 444h) [Reset = 00000000h] PHASE\_CURRENT\_C is shown in Figure 7-94 and described in Table 7-70. Return to the Summary Table. Measured current on Phase C Register #### Figure 7-94. PHASE\_CURRENT\_C Register Table 7-70. PHASE\_CURRENT\_C Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_CURRENT_C | R | | 32-bit signed value indicating measured current on Phase C. Negative value is represented in two's complement iC = (PHASE_CURRENT_C / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.7 CSA\_GAIN\_FEEDBACK Register (Offset = 468h) [Reset = 0000h] CSA\_GAIN\_FEEDBACK is shown in Figure 7-95 and described in Table 7-71. Return to the Summary Table. VM Voltage Register Figure 7-95. CSA\_GAIN\_FEEDBACK Register Table 7-71. CSA\_GAIN\_FEEDBACK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------| | 15-0 | CSA_GAIN_FEEDBACK | R | | 16-bit value indicating current sense gain 0h = MAX_CSA_GAIN * 8 1h = MAX_CSA_GAIN * 4 2h = MAX_CSA_GAIN * 2 3h = MAX_CSA_GAIN * 1 | # 7.8.5.8 VOLTAGE\_GAIN\_FEEDBACK Register (Offset = 472h) [Reset = 0000h] VOLTAGE\_GAIN\_FEEDBACK is shown in Figure 7-96 and described in Table 7-72. Return to the Summary Table. Voltage Gain Register ### Figure 7-96. VOLTAGE\_GAIN\_FEEDBACK Register Table 7-72. VOLTAGE\_GAIN\_FEEDBACK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------------------|------|-------|-----------------------------------------------------------------| | 15-0 | VOLTAGE_GAIN_FEEDB<br>ACK | R | 0h | 16-bit value indicating voltage gain 0h = 60V 1h = 30V 2h = 15V | Copyright © 2023 Texas Instruments Incorporated Submit Document Feedback # 7.8.5.9 VM\_VOLTAGE Register (Offset = 476h) [Reset = 00000000h] VM\_VOLTAGE is shown in Figure 7-97 and described in Table 7-73. Return to the Summary Table. Supply voltage register ### Figure 7-97. VM\_VOLTAGE Register ### Table 7-73. VM VOLTAGE Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|-------------------------------------------------------------------------------------------| | 31-0 | VM_VOLTAGE | R | | 32-bit value indicating dc bus voltage DC Bus Voltage = VM_VOLTAGE * 60 / 2 <sup>27</sup> | # 7.8.5.10 PHASE\_VOLTAGE\_VA Register (Offset = 47Ah) [Reset = 00000000h] PHASE\_VOLTAGE\_VA is shown in Figure 7-98 and described in Table 7-74. Return to the Summary Table. Phase A Voltage Register #### Figure 7-98. PHASE\_VOLTAGE\_VA Register Table 7-74. PHASE\_VOLTAGE\_VA Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_VOLTAGE_VA | R | | 32-bit value indicating Phase Voltage Va during ISD Phase A voltage = PHASE_VOLTAGE_VA * 60 / (sqrt(3) * 2 <sup>27</sup> ) | # 7.8.5.11 PHASE\_VOLTAGE\_VB Register (Offset = 47Ch) [Reset = 00000000h] PHASE\_VOLTAGE\_VB is shown in Figure 7-99 and described in Table 7-75. Return to the Summary Table. Phase B Voltage Register #### Figure 7-99. PHASE\_VOLTAGE\_VB Register # Table 7-75, PHASE VOLTAGE VB Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_VOLTAGE_VB | R | | 32-bit value indicating Phase Voltage Vb during ISD Phase B voltage = PHASE_VOLTAGE_VB * 60 / (sqrt(3) * 2 <sup>27</sup> ) | # 7.8.5.12 PHASE\_VOLTAGE\_VC Register (Offset = 47Eh) [Reset = 00000000h] PHASE\_VOLTAGE\_VC is shown in Figure 7-100 and described in Table 7-76. Return to the Summary Table. Phase C Voltage Register ### Figure 7-100. PHASE\_VOLTAGE\_VC Register # Table 7-76. PHASE\_VOLTAGE\_VC Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|----------------------------------------------------------------------------------------------------------------------------| | 31-0 | PHASE_VOLTAGE_VC | R | | 32-bit value indicating Phase Voltage Vc during ISD Phase C voltage = PHASE_VOLTAGE_VC * 60 / (sqrt(3) * 2 <sup>27</sup> ) | Product Folder Links: MCF8316C-Q1 ### 7.8.5.13 SIN\_COMMUTATION\_ANGLE Register (Offset = 4B6h) [Reset = 00000000h] SIN\_COMMUTATION\_ANGLE is shown in Figure 7-101 and described in Table 7-77. Return to the Summary Table. Sine of Commutation Angle ### Figure 7-101. SIN\_COMMUTATION\_ANGLE Register ### Table 7-77, SIN COMMUTATION ANGLE Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SIN_COMMUTATION_AN<br>GLE | R | 0h | 32-bit signed value indicating sine of commutation Angle. Negative value is represented in two's complement sinCommutationAngle = (SIN_COMMUTATION_ANGLE / 2 <sup>27</sup> ) | ### 7.8.5.14 COS\_COMMUTATION\_ANGLE Register (Offset = 4B8h) [Reset = 00000000h] COS\_COMMUTATION\_ANGLE is shown in Figure 7-102 and described in Table 7-78. Return to the Summary Table. Cosine of Commutation Angle #### Figure 7-102. COS\_COMMUTATION\_ANGLE Register #### Table 7-78. COS\_COMMUTATION\_ANGLE Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | COS_COMMUTATION_A<br>NGLE | R | | 32-bit signed value indicating cosine of commutation Angle. Negative value is represented in two's complement cosCommutationAngle = (COS_COMMUTATION_ANGLE / 2 <sup>27</sup> ) | # 7.8.5.15 IALPHA Register (Offset = 4D2h) [Reset = 00000000h] IALPHA is shown in Figure 7-103 and described in Table 7-79. Return to the Summary Table. IALPHA Current Register ### Figure 7-103. IALPHA Register # Table 7-79. IALPHA Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IALPHA | R | | 32-bit signed value indicating calculated IALPHA. Negative value is represented in two's complement iAlpha = (IALPHA / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.16 IBETA Register (Offset = 4D4h) [Reset = 00000000h] IBETA is shown in Figure 7-104 and described in Table 7-80. Return to the Summary Table. IBETA Current Register # Figure 7-104. IBETA Register # Table 7-80. IBETA Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IBETA | R | | 32-bit signed value indicating calculated IBETA. Negative value is represented in two's complement iBeta = (IBETA / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.17 VALPHA Register (Offset = 4D6h) [Reset = 00000000h] VALPHA is shown in Figure 7-105 and described in Table 7-81. Return to the Summary Table. VALPHA Voltage Register ### Figure 7-105. VALPHA Register # Table 7-81. VALPHA Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | VALPHA | R | | 32-bit signed value indicating calculated VALPHA. Negative value is represented in two's complement vAlpha = (VALPHA / $2^{27}$ ) * 60 / sqrt(3) | # 7.8.5.18 VBETA Register (Offset = 4D8h) [Reset = 00000000h] VBETA is shown in Figure 7-106 and described in Table 7-82. Return to the Summary Table. VBETA Voltage Register # Figure 7-106. VBETA Register # Table 7-82. VBETA Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | VBETA | R | | 32-bit signed value indicating calculated VBETA. Negative value is represented in two's complement vBeta = (VBETA / 2 <sup>27</sup> ) * 60 / sqrt(3) | # 7.8.5.19 ID Register (Offset = 4E2h) [Reset = 00000000h] ID is shown in Figure 7-107 and described in Table 7-83. Return to the Summary Table. Measured d-axis Current Register ### Figure 7-107. ID Register ### Table 7-83. ID Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|-------------------------------------------------------------------------------| | 31-0 | ID | R | 0h | 32-bit signed value indicating estimated Id. Negative value is | | | | | | represented in two's complement id = (ID / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.20 IQ Register (Offset = 4E4h) [Reset = 00000000h] IQ is shown in Figure 7-108 and described in Table 7-84. Return to the Summary Table. Measured q-axis Current Register ### Figure 7-108. IQ Register # Table 7-84. IQ Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IQ | R | | 32-bit signed value indicating estimated Iq. Negative value is represented in two's complement iq = (IQ / 2 <sup>27</sup> ) * Base_Current/8 | Copyright © 2023 Texas Instruments Incorporated Submit Document Feedback # 7.8.5.21 VD Register (Offset = 4E6h) [Reset = 00000000h] VD is shown in Figure 7-109 and described in Table 7-85. Return to the Summary Table. VD Voltage Register ### Figure 7-109. VD Register # Table 7-85. VD Register Field Descriptions | | | | | • | |------|-------|------|-------|-----------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-0 | VD | R | 0h | 32-bit signed value indicating applied Vd. Negative value is | | | | | | represented in two's complement vd = (VD / 2 <sup>27</sup> ) * 60 / sqrt(3) | # 7.8.5.22 VQ Register (Offset = 4E8h) [Reset = 00000000h] VQ is shown in Figure 7-110 and described in Table 7-86. Return to the Summary Table. VQ Voltage Register ### Figure 7-110. VQ Register # Table 7-86. VQ Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | VQ | R | | 32-bit signed value indicating applied Vq. Negative value is represented in two's complement vq = (VQ / 2 <sup>27</sup> ) * 60 / sqrt(3) | # 7.8.5.23 IQ\_REF\_ROTOR\_ALIGN Register (Offset = 524h) [Reset = 00000000h] IQ\_REF\_ROTOR\_ALIGN is shown in Figure 7-111 and described in Table 7-87. Return to the Summary Table. Align Current Reference #### Figure 7-111. IQ\_REF\_ROTOR\_ALIGN Register ### Table 7-87. IQ\_REF\_ROTOR\_ALIGN Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IQ_REF_ROTOR_ALIGN | R | | 32-bit signed value indicating Align Current Reference. Negative value is represented in two's complement iqRefRotorAlign = (IQ_REF_ROTOR_ALIGN / 2 <sup>27</sup> ) * Base_Current/8 | ### 7.8.5.24 SPEED\_REF\_OPEN\_LOOP Register (Offset = 53Ch) [Reset = 00000000h] SPEED\_REF\_OPEN\_LOOP is shown in Figure 7-112 and described in Table 7-88. Return to the Summary Table. Speed at which motor transitions to close loop # Figure 7-112. SPEED\_REF\_OPEN\_LOOP Register ### Table 7-88. SPEED\_REF\_OPEN\_LOOP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SPEED_REF_OPEN_LO<br>OP | R | | 32-bit signed value indicating Open Loop Speed. The value is positive for OUTA-OUTB-OUTC and Negative and represented in two's complement for OUTA-OUTC-OUTB openLoopSpeedRef = (SPEED_REF_OPEN_LOOP / 2 <sup>27</sup> ) * MAX_SPEED (Hz) | # 7.8.5.25 IQ\_REF\_OPEN\_LOOP Register (Offset = 54Ch) [Reset = 00000000h] IQ\_REF\_OPEN\_LOOP is shown in Figure 7-113 and described in Table 7-89. Return to the Summary Table. Open Loop Current Reference #### Figure 7-113. IQ\_REF\_OPEN\_LOOP Register Table 7-89. IQ\_REF\_OPEN\_LOOP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------------|------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IQ_REF_OPEN_LOOP | R | | 32-bit signed value indicating Open Loop Current Reference. Negative value is represented in two's complement iqRefOpenLoop = (IQ_REF_OPEN_LOOP / 2 <sup>27</sup> ) * Base_Current/8 | ### 7.8.5.26 SPEED\_REF\_CLOSED\_LOOP Register (Offset = 5D4h) [Reset = 00000000h] SPEED\_REF\_CLOSED\_LOOP is shown in Figure 7-114 and described in Table 7-90. Return to the Summary Table. Speed Reference Register # Figure 7-114. SPEED\_REF\_CLOSED\_LOOP Register Table 7-90. SPEED\_REF\_CLOSED\_LOOP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|---------------------------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SPEED_REF_CLOSED_L<br>OOP | R | | 32-bit signed value indicating reference for speed loop. The value is positive for OUTA-OUTB-OUTC and Negative and represented in two's complement for OUTA-OUTC-OUTB Speed Reference in closed loop (Hz) = (SPEED_REF_CLOSED_LOOP/ 2 <sup>27</sup> ) * MAX_SPEED (Hz) | ### 7.8.5.27 ID\_REF\_CLOSED\_LOOP Register (Offset = 606h) [Reset = 00000000h] ID\_REF\_CLOSED\_LOOP is shown in Figure 7-115 and described in Table 7-91. Return to the Summary Table. Reference for Current Loop Register ### Figure 7-115. ID\_REF\_CLOSED\_LOOP Register #### Table 7-91. ID\_REF\_CLOSED\_LOOP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------------------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | ID_REF_CLOSED_LOOP | R | | 32-bit signed value indicating Id_ref for flux loop. Negative value is represented in two's complement idRefClosedLoop = (ID_REF_CLOSED_LOOP / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.28 IQ\_REF\_CLOSED\_LOOP Register (Offset = 608h) [Reset = 00000000h] IQ\_REF\_CLOSED\_LOOP is shown in Figure 7-116 and described in Table 7-92. Return to the Summary Table. Reference for Current Loop Register # Figure 7-116. IQ\_REF\_CLOSED\_LOOP Register # Table 7-92. IQ\_REF\_CLOSED\_LOOP Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|--------------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | IQ_REF_CLOSED_LOOP | R | | 32-bit signed value indicating lq_ref for torque loop. Negative value is represented in two's complement iqRefClosedLoop = (IQ_REF_CLOSED_LOOP / 2 <sup>27</sup> ) * Base_Current/8 | # 7.8.5.29 ISD\_STATE Register (Offset = 682h) [Reset = 0000h] ISD\_STATE is shown in Figure 7-117 and described in Table 7-93. Return to the Summary Table. ISD state Register # Figure 7-117. ISD\_STATE Register Table 7-93. ISD\_STATE Register Field Descriptions | _ | | | | | | | |---|------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | Bit | Field | Туре | Reset | Description | | | | 15-0 | ISD_STATE | R | | 16-bit value indicating current ISD state 0h = ISD_INIT 1h = ISD_MOTOR_STOP_CHECK 2h = ISD_ESTIM_INIT 3h = ISD_RUN_MOTOR_CHECK 4h = ISD_MOTOR_DIRECTION_CHECK 5h = ISD_COMPLETE 6h = ISD_FAULT | | Product Folder Links: MCF8316C-Q1 182 # 7.8.5.30 ISD\_SPEED Register (Offset = 68Ch) [Reset = 00000000h] ISD\_SPEED is shown in Figure 7-118 and described in Table 7-94. Return to the Summary Table. ISD Speed Register # Figure 7-118. ISD\_SPEED Register # Table 7-94. ISD\_SPEED Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|---------------------------------------------------------------------------------------------------------------------------------| | 31-0 | ISD_SPEED | R | | 32-bit value indicating calculated absolute speed during ISD state isdSpeed = (ISD_SPEED / 2 <sup>27</sup> ) * max_Speed- In Hz | # 7.8.5.31 IPD\_STATE Register (Offset = 6C0h) [Reset = 0000h] IPD\_STATE is shown in Figure 7-119 and described in Table 7-95. Return to the Summary Table. IPD state Register # Figure 7-119. IPD\_STATE Register Table 7-95. IPD STATE Register Field Descriptions | | Tab. | egister i leiu bescriptions | | | |------|-----------|-----------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 15-0 | IPD_STATE | R | Oh | 16-bit value indicating current IPD state 0h = IPD_INIT 1h = IPD_VECTOR_CONFIG 2h = IPD_RUN 3h = IPD_SLOW_RISE_CLOCK 4h = IPD_SLOW_FALL_CLOCK 5h = IPD_WAIT_CURRENT_DECAY 6h = IPD_GET_TIMES 7h = IPD_SET_NEXT_VECTOR 8h = IPD_CALC_SECTOR_RISE 9h = IPD_CALC_ROTOR_POSITION Ah = IPD_CALC_ANGLE Bh = IPD_COMPLETE Ch = IPD_FAULT | # 7.8.5.32 IPD\_ANGLE Register (Offset = 704h) [Reset = 00000000h] IPD\_ANGLE is shown in Figure 7-120 and described in Table 7-96. Return to the Summary Table. Calculated IPD Angle Register # Figure 7-120. IPD\_ANGLE Register # Table 7-96. IPD\_ANGLE Register Field Descriptions | Bi | it | Field | Туре | Reset | Description | |-----|----|-----------|------|-------|------------------------------------------------------------------------------------------------------------| | 31- | -0 | IPD_ANGLE | R | | 32-bit signed value indicating measured IPD angle ipdAngle = (IPD_ANGLE / 2 <sup>27</sup> ) * 360 (Degree) | # 7.8.5.33 ED Register (Offset = 74Ah) [Reset = 00000000h] ED is shown in Figure 7-121 and described in Table 7-97. Return to the Summary Table. Estimated BEMF EQ Register # Figure 7-121. ED Register # Table 7-97. ED Register Field Descriptions | · · · · · · · · · · · · · · · · · · · | | | | | |---------------------------------------|-------|------|-------|-----------------------------------------------------------------------------| | Bit | Field | Туре | Reset | Description | | 31-0 | ED | R | | 32-bit signed value indicating estimated ED. Negative value is | | | | | | represented in two's complement Ed = (ED / 2 <sup>27</sup> ) * 60 / sqrt(3) | # 7.8.5.34 EQ Register (Offset = 74Ch) [Reset = 00000000h] EQ is shown in Figure 7-122 and described in Table 7-98. Return to the Summary Table. Estimated BEMF ED Register # Figure 7-122. EQ Register # Table 7-98. EQ Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | EQ | R | | 32-bit signed value indicating estimated EQ. Negative value is represented in two's complement Eq = (EQ / 2 <sup>27</sup> ) * 60 / sqrt(3) | Copyright © 2023 Texas Instruments Incorporated # 7.8.5.35 SPEED\_FDBK Register (Offset = 75Ah) [Reset = 00000000h] SPEED\_FDBK is shown in Figure 7-123 and described in Table 7-99. Return to the Summary Table. Speed Feedback Register # Figure 7-123. SPEED\_FDBK Register # Table 7-99. SPEED FDBK Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|------------|------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | SPEED_FDBK | R | | 32-bit signed value indicating estimated rotor speed. The value is positive for OUTA-OUTB-OUTC and Negative and represented in two's complement for OUTA-OUTC-OUTB estimatedSpeed = (SPEED_FDBK / 2 <sup>27</sup> )*MAXIMUM_SPEED_HZ | # 7.8.5.36 THETA\_EST Register (Offset = 75Eh) [Reset = 00000000h] THETA\_EST is shown in Figure 7-124 and described in Table 7-100. Return to the Summary Table. Estimated rotor Position Register # Figure 7-124. THETA\_EST Register # Table 7-100. THETA\_EST Register Field Descriptions | Bit | Field | Туре | Reset | Description | |------|-----------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 31-0 | THETA_EST | R | | 32-bit signed value indicating estimated rotor angle. Negative value is represented in two's complement estimated<br>Angle = (THETA_EST / $2^{27}$ )*360 (Degree) | Copyright © 2023 Texas Instruments Incorporated # 8 Application and Implementation #### **Note** Information in the following applications sections is not part of the TI component specification, and TI does not warrant its accuracy or completeness. TI's customers are responsible for determining suitability of components for their purposes. Customers should validate and test their design implementation to confirm system functionality. # 8.1 Application Information The MCF8316C-Q1 device is used in sensorless 3-phase BLDC motor control. The driver provides a high performance, high-reliability, flexible solution for appliances, fans, pumps, residential and living fans, seat cooling fans, automotive fans and blowers. The following section shows a common application of the MCF8316C-Q1 device. ### 8.2 Typical Applications Figure 8-1 shows the typical schematic of MCF8316C-Q1. Figure 8-1. Example Application Schematic Table 8-1 lists the recommended values of the external components for MCF8316C-Q1. Table 8-1. MCF8316C-Q1 External Components | COMPONENTS | PIN 1 | PIN 2 | RECOMMENDED | |---------------------|---------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | C <sub>VM1</sub> | VM | PGND | X5R or X7R, 0.1-µF, TI recommends a capacitor voltage rating at least twice the normal operating voltage of the device | | C <sub>VM2</sub> | VM | PGND | ≥ 10-µF, TI recommends a capacitor voltage rating at least twice the normal operating voltage of the device | | C <sub>CP</sub> | СР | VM | X5R or X7R, 16-V, 1-μF capacitor | | C <sub>FLY</sub> | СРН | CPL | X5R or X7R, 47-nF, TI recommends a capacitor voltage rating at least twice the normal operating voltage of the pin | | C <sub>AVDD</sub> | AVDD | AGND | X5R or X7R, 1-µF, ≥ 6.3-V. In order for AVDD to accurately regulate output voltage, capacitor should have effective capacitance between 0.7-µF to 1.3-µF at 3.3-V across operating temperature. | | C <sub>DVDD</sub> | DVDD | DGND | X5R or X7R, 2.2-μF, ≥ 6.3-V. In order for DVDD to accurately regulate output voltage, capacitor should have effective capacitance between 1.1-μF to 2.5-μF at 1.5-V across operating temperature. | | C <sub>BK</sub> | FB_BK | GND_BK | X5R or X7R, buck-output rated capacitor | | L <sub>BK</sub> | SW_BK | FB_BK | Buck-output inductor | | R <sub>FG</sub> | 1.8 to 5-V Supply | FG | 5.1-kΩ, Pull-up resistor | | R <sub>nFAULT</sub> | 1.8 to 5-V Supply | nFAULT | 5.1-kΩ, Pull-up resistor | | R <sub>SDA</sub> | 1.8 to 3.3-V Supply | SDA | 5.1-kΩ, Pull-up resistor | | R <sub>SCL</sub> | 1.8 to 3.3-V Supply | SCL | 5.1-kΩ, Pull-up resistor | Recommended application range for MCF8316C-Q1 is shown in Table 8-2. Table 8-2. Recommended Application Range | Min | Max | Unit | |-------|-------------------------------------|---------------------------------------------------------------------| | 4.5 | 35 | V | | 0.6 | 2000 | mV/Hz | | 0.006 | 20 | Ω | | 0.006 | 20 | mH | | - | 1500 | Hz | | - | 8 | A | | | Min<br>4.5<br>0.6<br>0.006<br>0.006 | 4.5 35 0.6 2000 0.006 20 0.006 20 | Default EEPROM configuration for MCF8316C-Q1 is listed in Table 8-3. Default values are chosen for reliable motor start-up and closed loop operation. Refer to MCF8316C-Q1 tuning guide which provides step by step procedure to tune a 3-phase BLDC motor in closed loop, conform to use-case and explore features in the device. Table 8-3. Recommended Default Values | Address Name | Address | Recommended Value | |------------------|------------|-------------------| | ISD_CONFIG | 0x00000080 | 0x64738CA0 | | REV_DRIVE_CONFIG | 0x00000082 | 0x28200000 | | MOTOR_STARTUP1 | 0x00000084 | 0x0B6807D0 | | MOTOR_STARTUP2 | 0x00000086 | 0x23066004 | | CLOSED_LOOP1 | 0x00000088 | 0x113181B8 | | CLOSED_LOOP2 | 0x0000008A | 0x0BAD0000 | | CLOSED_LOOP3 | 0x0000008C | 0x00000000 | | CLOSED_LOOP4 | 0x0000008E | 0x000004B0 | | SPEED_PROFILES1 | 0x00000094 | 0x00000000 | Table 8-3. Recommended Default Values (continued) | Address Name | Address | Recommended Value | |-----------------|------------|-------------------| | SPEED_PROFILES2 | 0x00000096 | 0x0000000 | | SPEED_PROFILES3 | 0x00000098 | 0x0000006 | | SPEED_PROFILES4 | 0x000009A | 0x000D0000 | | SPEED_PROFILES5 | 0x000009C | 0x0000000 | | SPEED_PROFILES6 | 0x0000009E | 0x0000000 | | FAULT_CONFIG1 | 0x00000090 | 0x3EDA30A6 | | FAULT_CONFIG2 | 0x00000092 | 0x71522088 | | PIN_CONFIG | 0x000000A4 | 0x00000309 | | DEVICE_CONFIG1 | 0x00000A6 | 0x00100001 | | DEVICE_CONFIG2 | 0x000000A8 | 0x03E8C000 | | PERI_CONFIG1 | 0x000000AA | 0x41C45C00 | | GD_CONFIG1 | 0x00000AC | 0x1C461900 | | GD_CONFIG2 | 0x000000AE | 0x01840000 | | INT_ALGO_1 | 0x00000A0 | 0x0D48C175 | | INT_ALGO_2 | 0x000000A2 | 0x000001A7 | Once the device EEPROM is programmed with the desired configuration, device can be operated stand-alone and I<sup>2</sup>C serial interface is not required anymore. Speed can be commanded using SPEED pin. Below are the two essential parameters that are required to spin the motor in closed loop. - 1. Maximum motor speed. - 2. Current limit for torque PI loop. ### 8.2.1 Application Curves # 8.2.1.1 Motor startup Figure 8-2 shows the FG waveform and the phase current waveform at different motor operations. Instruments www.ti.com Figure 8-2. Motor Startup - FG and Phase current #### 8.2.1.2 MPET Figure 8-3 shows the phase current waveform during motor parameter measurement. Figure 8-4 shows the IPD current waveform during R, L and Ke measurement. Bottom half of Figure 8-4 shows the IPD current waveform during R and L measurement. R is measured during the rising of phase current and L is measured during the falling of phase current. After R and L measurement, motor spins in open loop. Once the speed reaches MPET open loop speed reference [MPET\_OPEN\_LOOP\_SPEED\_REF], motor is coasted. BEMF voltage of all three phases are measured and Ke is calculated. Figure 8-4. IPD current waveform during Rand L measurement # 8.2.1.3 Dead time compensation Figure 8-5 shows the phase current waveform when dead time compensation is disabled. Fundamental frequency of phase current is 40 Hz. Fast Fourier transform (FFT) of phase current plot shows harmonics at 160 Hz and 220 Hz. Figure 8-6 shows the phase current waveform when dead time compensation is enabled. Phase current looks more sinusoidal and the FFT of phase current plot does not have any harmonics. Figure 8-5. Phase current and FFT - Dead time compensation disabled Figure 8-6. Phase current and FFT - Dead time compensation enabled #### 8.2.1.4 Auto handoff Figure 8-7 shows the auto handoff feature in MCF8316C-Q1 where the motor transitions seamlessly from open loop to closed loop. Figure 8-7. Auto-handoff ### 8.2.1.5 Anti voltage surge (AVS) When motor speed decelerates at a very high deceleration rate, mechanical energy from the motor returns to the power supply which could result in pumping up the supply voltage, VM. Figure 8-8 shows overshoot in power supply voltage when AVS is disabled. Motor decelerates from 100% duty cycle to 10% duty cycle at a deceleration rate of 70,000 Hz/sec. Figure 8-9 shows no overshoot in power supply voltage when AVS is enabled. Figure 8-9. Power supply voltage and phase current waveform when AVS is enabled ### 8.2.1.6 Real time variable tracking using DACOUT MCF8316C-Q1 has two 12-bit DAC which outputs analog voltage equivalent of digital variables on DACOUT1 and DACOUT2 pins with resolution of 12 bits and max voltage of 3V. Signals available on DACOUT pins can be used for tuning speed controller or other driver configuration or bus current monitoring. Check algorithm variable registers in datasheet for list of all algorithm variables. The addresses for variables for DACOUT1 and DACOUT2 are configured using register bits DACOUT1\_VAR\_ADDR and DACOUT2\_VAR\_ADDR. This is useful in applications which require tracking algorithm variables in real time without having any delay from the communication bus. Pin 37 and 38 should be configured as DACOUT1 and DACOUT2. For example, if the user wants to read phase A current from pin 37, configure pin 37 as DACOUT1 and program the phase A current register address (0x00000440) in Hex in [DACOUT1\_VAR\_ADDR]. If the user wants to read estimated rotor angle from pin 38, configure pin 38 as DACOUT2 and program the estimated rotor angle register address (0x00000736) in Hex in [DACOUT2 VAR ADDR]. Figure 8-10 shows the outputs of DACOUT1 and DACOUT2. DACOUT1 is configured to read phase A current and DACOUT2 is configured to read estimated rotor angle. Figure 8-10. DACOUT1 and DACOUT2 Submit Document Feedback Copyright © 2023 Texas Instruments Incorporated # 9 Power Supply Recommendations # 9.1 Bulk Capacitance Having an appropriate local bulk capacitance is an important factor in motor drive system design. It is generally beneficial to have more bulk capacitance, while the disadvantages are increased cost and physical size. The amount of local capacitance needed depends on a variety of factors, including: - · The highest current required by the motor system - · The capacitance and current capability of the power supply - The amount of parasitic inductance between the power supply and motor system - · The acceptable voltage ripple - The type of motor used (brushed DC, brushless DC, stepper) - · The motor braking method The inductance between the power supply and the motor drive system limits the rate at which current can change from the power supply. If the local bulk capacitance is too small, the system responds to excessive current demands or dumps from the motor with a change in VM voltage. When adequate bulk capacitance is used, the VM voltage remains stable and high current can be quickly supplied. The data sheet generally provides a recommended value, but system-level testing is required to determine the appropriate bulk capacitor. Figure 9-1. Example Setup of Motor Drive System With External Power Supply The voltage rating for bulk capacitors should be higher than the operating voltage, to provide margin for cases when the motor transfers energy to the supply. # 10 Layout # 10.1 Layout Guidelines The bulk capacitor should be placed to minimize the distance of the high-current path through the motor driver device. The connecting metal trace widths should be as wide as possible, and numerous vias should be used when connecting PCB layers. These practices minimize parasitic inductance and allow the bulk capacitor to deliver high current. Small-value capacitors should be ceramic, and placed closely to device pins. The high-current device outputs should use wide metal traces. To reduce noise coupling and EMI interference from large transient currents into small-current signal paths, grounding should be partitioned between PGND and AGND. TI recommends connecting all non-power stage circuitry (including the thermal pad) to AGND to reduce parasitic effects and improve power dissipation from the device. Optionally, GND\_BK can be split. Ensure grounds are connected through net-ties or wide resistors to reduce voltage offsets and maintain gate driver performance. The device thermal pad should be soldered to the PCB top-layer ground plane. Multiple vias should be used to connect to a large bottom-layer ground plane. The use of large metal planes and multiple vias helps dissipate the $I^2 \times R_{DS(on)}$ heat that is generated in the device. To improve thermal performance, maximize the ground area that is connected to the thermal pad ground across all possible layers of the PCB. Using thick copper pours can lower the junction-to-air thermal resistance and improve thermal dissipation from the die surface. Separate the SW BK and FB BK traces with ground separation to reduce buck switching from coupling as noise into the buck outer feedback loop. Widen the FB BK trace as much as possible to allow for faster load switching. Figure 10-1 shows a layout example for the MCF8316C-Q1. Also, for layout example, refer to MCF8316C-Q1 EVM. # 10.2 Layout Example Figure 10-1. Recommended Layout Example #### 10.3 Thermal Considerations The MCF8316C-Q1 has thermal shutdown (TSD) as previously described. A die temperature in excess of 150°C (minimally) disables the device until the temperature drops to a safe level. Any tendency of the device to enter thermal shutdown is an indication of excessive power dissipation, insufficient heatsinking, or too high an ambient temperature. ### 10.3.1 Power Dissipation The power dissipated in the output FET resistance (R<sub>DS(on)</sub>) dominates power dissipation in MCF8316C-Q1. At start-up and fault conditions, the FET current is much higher than normal operating FET current; remember to take these peak currents and their duration into consideration. The total device power dissipation is the power dissipated in each of the three half-bridges added together along with standby power, LDO and buck regulator losses. The maximum amount of power that the device can dissipate depends on ambient temperature and heatsinking. Note that R<sub>DS(on)</sub> increases with temperature, so as the device heats, the power dissipation increases. Take this into consideration when sizing the heatsink. A summary of equations for calculating each loss is shown below in Table 10-1. Table 10-1. Power Losses for MCF8316C-Q1 | 145.5 10 11 1 01101 200000 101 11101 00100 Q1 | | | | | | | |-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Loss type | MCF8316C-Q1 | | | | | | | Standby power | $P_{\text{standby}} = VM \times I_{VM\_TA}$ | | | | | | | LDO | $P_{LDO}$ = (VM-V <sub>AVDD</sub> ) x I <sub>AVDD</sub> , if BUCK_PS_DIS = 1b<br>$P_{LDO}$ = (V <sub>BK</sub> -V <sub>AVDD</sub> ) x I <sub>AVDD</sub> , if BUCK_PS_DIS = 0b | | | | | | | FET conduction | $P_{CON} = 3 \times (I_{RMS(FOC)})^2 \times R_{ds,on(TA)}$ | | | | | | | FET switching | $P_{SW} = 3 \times I_{PK(FOC)} \times V_{PK(FOC)} \times t_{rise/fall} \times f_{PWM}$ | | | | | | | Diode | P <sub>diode</sub> = 3 x I <sub>PK(FOC)</sub> x V <sub>diode</sub> x t <sub>dead</sub> x f <sub>PWM</sub> | | | | | | | Buck | P <sub>BK</sub> = 0.11 x V <sub>BK</sub> x I <sub>BK</sub> (η <sub>BK</sub> = 90%) | | | | | | | | | | | | | | # 11 Device and Documentation Support # 11.1 Support Resources TI E2E<sup>™</sup> support forums are an engineer's go-to source for fast, verified answers and design help — straight from the experts. Search existing answers or ask your own question to get the quick design help you need. Linked content is provided "AS IS" by the respective contributors. They do not constitute TI specifications and do not necessarily reflect TI's views; see TI's Terms of Use. #### 11.2 Trademarks TI E2E<sup>™</sup> is a trademark of Texas Instruments. All trademarks are the property of their respective owners. ### 11.3 Electrostatic Discharge Caution This integrated circuit can be damaged by ESD. Texas Instruments recommends that all integrated circuits be handled with appropriate precautions. Failure to observe proper handling and installation procedures can cause damage. ESD damage can range from subtle performance degradation to complete device failure. Precision integrated circuits may be more susceptible to damage because very small parametric changes could cause the device not to meet its published specifications. ### 11.4 Glossary TI Glossary This glossary lists and explains terms, acronyms, and definitions. # 12 Mechanical, Packaging, and Orderable Information The following pages include mechanical, packaging, and orderable information. This information is the most-current data available for the designated device. This data is subject to change without notice and without revision of this document. For browser-based versions of this data sheet, see the left-hand navigation pane. Copyright © 2023 Texas Instruments Incorporated www.ti.com 18-Jul-2025 #### PACKAGING INFORMATION | Orderable part number | Status | Material type | Package Pins | Package qty Carrier | <b>RoHS</b> (3) | Lead finish/<br>Ball material | MSL rating/<br>Peak reflow | Op temp (°C) | Part marking (6) | |-----------------------|--------|---------------|-----------------|-----------------------|-----------------|-------------------------------|----------------------------|--------------|------------------| | MCF8316C1VQRGFRQ1 | Active | Production | VQFN (RGF) 40 | 3000 LARGE T&R | Yes | NIPDAU | Level-2-260C-1 YEAR | -40 to 125 | MF16C1V | | MCF8316C1VQRGFRQ1.A | Active | Production | VQFN (RGF) 40 | 3000 LARGE T&R | Yes | NIPDAU | Level-2-260C-1 YEAR | -40 to 125 | MF16C1V | | MCF8316C1VQRGFRQ1.B | Active | Production | VQFN (RGF) 40 | 3000 LARGE T&R | - | Call TI | Call TI | -40 to 125 | | <sup>(1)</sup> Status: For more details on status, see our product life cycle. Multiple part markings will be inside parentheses. Only one part marking contained in parentheses and separated by a "~" will appear on a part. If a line is indented then it is a continuation of the previous line and the two combined represent the entire part marking for that device. Important Information and Disclaimer: The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release. In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis. <sup>(2)</sup> Material type: When designated, preproduction parts are prototypes/experimental devices, and are not yet approved or released for full production. Testing and final process, including without limitation quality assurance, reliability performance testing, and/or process qualification, may not yet be complete, and this item is subject to further changes or possible discontinuation. If available for ordering, purchases will be subject to an additional waiver at checkout, and are intended for early internal evaluation purposes only. These items are sold without warranties of any kind. <sup>(3)</sup> RoHS values: Yes, No, RoHS Exempt. See the TI RoHS Statement for additional information and value definition. <sup>(4)</sup> Lead finish/Ball material: Parts may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead finish/Ball material values may wrap to two lines if the finish value exceeds the maximum column width. <sup>(5)</sup> MSL rating/Peak reflow: The moisture sensitivity level ratings and peak solder (reflow) temperatures. In the event that a part has multiple moisture sensitivity ratings, only the lowest level per JEDEC standards is shown. Refer to the shipping label for the actual reflow temperature that will be used to mount the part to the printed circuit board. <sup>(6)</sup> Part marking: There may be an additional marking, which relates to the logo, the lot trace code information, or the environmental category of the part. # **PACKAGE MATERIALS INFORMATION** www.ti.com 25-Aug-2023 # TAPE AND REEL INFORMATION | _ | Tanana and a same and a same and a same and a same s | |----|----------------------------------------------------------------------------------------------------------------| | A0 | Dimension designed to accommodate the component width | | В0 | Dimension designed to accommodate the component length | | K0 | Dimension designed to accommodate the component thickness | | W | Overall width of the carrier tape | | P1 | Pitch between successive cavity centers | ### QUADRANT ASSIGNMENTS FOR PIN 1 ORIENTATION IN TAPE #### \*All dimensions are nominal | Device | Package<br>Type | Package<br>Drawing | | SPQ | Reel<br>Diameter<br>(mm) | Reel<br>Width<br>W1 (mm) | A0<br>(mm) | B0<br>(mm) | K0<br>(mm) | P1<br>(mm) | W<br>(mm) | Pin1<br>Quadrant | |-------------------|-----------------|--------------------|----|------|--------------------------|--------------------------|------------|------------|------------|------------|-----------|------------------| | MCF8316C1VQRGFRQ1 | VQFN | RGF | 40 | 3000 | 330.0 | 16.4 | 5.25 | 7.25 | 1.45 | 8.0 | 16.0 | Q1 | # **PACKAGE MATERIALS INFORMATION** www.ti.com 25-Aug-2023 # \*All dimensions are nominal | Device | Package Type | Package Drawing | Pins | SPQ | Length (mm) | Width (mm) | Height (mm) | |-------------------|--------------|-----------------|------|------|-------------|------------|-------------| | MCF8316C1VQRGFRQ1 | VQFN | RGF | 40 | 3000 | 367.0 | 367.0 | 35.0 | 5 x 7, 0.5 mm pitch PLASTIC QUAD FLAT PACK- NO LEAD This image is a representation of the package family, actual package may vary. Refer to the product data sheet for package details. PLASTIC QUAD FLAT PACK- NO LEAD ### NOTES: - 1. All linear dimensions are in millimeters. Any dimensions in parenthesis are for reference only. Dimensioning and tolerancing per ASME Y14.5M. - 2. This drawing is subject to change without notice. - 3. The package thermal pad must be soldered to the printed circuit board for optimal thermal and mechanical performance. PLASTIC QUAD FLAT PACK- NO LEAD NOTES: (continued) - 4. This package is designed to be soldered to a thermal pad on the board. For more information, see Texas Instruments literature number SLUA271 (www.ti.com/lit/slua271). - 5. Vias are optional depending on application, refer to device data sheet. If any vias are implemented, refer to their locations shown on this view. It is recommended that vias under paste be filled, plugged or tented. PLASTIC QUAD FLAT PACK- NO LEAD NOTES: (continued) 6. Laser cutting apertures with trapezoidal walls and rounded corners may offer better paste release. IPC-7525 may have alternate design recommendations. ### IMPORTANT NOTICE AND DISCLAIMER TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATA SHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS. These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, regulatory or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources. TI's products are provided subject to TI's Terms of Sale or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products. TI objects to and rejects any additional or different terms you may have proposed. Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2025. Texas Instruments Incorporated