

#### **Application Note**

AN2521/D Rev.0 , 5/2003

BLDC Motor version II TPU Function Set (BLDC)

By Milan Brejl, Ph.D.

### **Functional Overview**

BLDC Motor version II (BLDC) is an alternative realization of the algorithm provided by BLDC Motor version I (BLDCm). This realization presents some advantages and some disadvantages when compared with the BLDC Motor version I (BLDCm). This version commutates the PWM phases immediately after the Hall sensor signals indicate a new sector (see Figure 2). This is an advantage for high speed motion systems. The disadvantage of this version is a lower maximum motor voltage amplitude (see Minimum Pulse Width). The function set consists of 6 TPU functions:

- 3-phase Hall Sensor Decoder for BLDC Motor (BLDC\_3HD)
- BLDC Motor Top (BLDC\_top)
- BLDC Motor Bottom (BLDC\_bottom)
- Synchronization Signal for BLDC Motor (BLDC\_sync)
- Resolver Reference Signal for BLDC Motor (BLDC\_res)
- Fault Input for BLDC Motor (BLDC\_fault)



#### Figure 1. Signals processed by BLDC TPU function set



© Freescale Semiconductor, Inc., 2004. All rights reserved.

For More Information On This Product, Go to: www.freescale.com

### Freescale Semiconductor, Inc.



The BLDC\_3HD function receives the Hall Sensor signals and controls the commutation of 3 PWM phases. The BLDC\_top and BLDC\_bottom TPU functions work together to generate a 6-channel 3-phase center-aligned PWM signal with dead-time between the top and bottom channels. One of the phases is always switched off while the other two generate the PWM signal. The Synchronization Signal for the BLDC function can be used to generate one or more adjustable signals for a wide range of uses, which are synchronized to the PWM, and track changes in the PWM period. The Resolver Reference Signal for the BLDC function can be used to generate one or more 50% duty-cycle adjustable signals that are also synchronized to the PWM. The Fault Input for BLDC function is a TPU input function that sets all PWM outputs low when the input signal goes low. See Figure 1.





**NOTE:** Q1 and Q2 channels are switched off and Q3 Q4 channels are switched on immediately after the change on Phase A Hall sensor signal.

### **Function Set Configuration**

None of the TPU functions in the BLDC Motor TPU function set can be used separately. The BLDC\_3HD, BLDC\_top and BLDC\_bottom functions have to be used together. The BLDC\_3HD is used on 3 input channels while the BLDC\_top is used on 3 output channels and the BLDC\_bottom is used on other 3 output channels, with higher numbers then the BLDC\_top channels. One or more channels running Synchronization Signal for BLDC as well as Resolver Reference Signal for BLDC functions can be added. They can run with different settings on each channel. The function Fault Input for BLDC can also be added. It is recommended to use it on channel 15, and to set the hardware option that



disables all TPU output pins when the channel 15 input signal is low (DTPU bit = 1). This ensures that the hardware reacts quickly to a pin fault state. Note that it is not only the PWM channels, but all TPU output channels, including the synchronization signals, that are disabled in this configuration.

 Table 1 shows the configuration options and restrictions.

| Table 1. BLDC TPU function set configuration options and restrictions |
|-----------------------------------------------------------------------|
|-----------------------------------------------------------------------|

| TPU function | Optional/<br>Mandatory | How many channels | Assignable channels                                |
|--------------|------------------------|-------------------|----------------------------------------------------|
| BLDC_3HD     | mandatory              | 3                 | any 3 channels                                     |
| BLDC_top     | mandatory              | 3                 | any 3 channels, lower than<br>BLDC_bottom channels |
| BLDC_bottom  | mandatory              | 3                 | any 3 channels, higher thea BLDC_top<br>channels   |
| BLDC_sync    | optional               | 1 or more         | any channels                                       |
| BLDC_res     | optional               | 1 or more         | any channels                                       |
| BLDC_fault   | optional               | 1                 | any, recommended is 15 and DTPU bit set            |

 Table 2 and Table 3 show two examples of configuration.

| Table 2 | Example | of configuration |
|---------|---------|------------------|
|---------|---------|------------------|

| Channel | TPU function | Priority |
|---------|--------------|----------|
| 0       | BLDC_top     | high     |
| 1       | BLDC_top     | high     |
| 2       | BLDC_top     | high     |
| 3       | BLDC_bottom  | high     |
| 4       | BLDC_bottom  | high     |
| 5       | BLDC_bottom  | high     |
| 6       | BLDC_3HD     | high     |
| 7       | BLDC_3HD     | high     |
| 8       | BLDC_3HD     | high     |
| 10      | BLDC_sync    | low      |
| 15      | BLDC_fault   | high     |

Table 3. Example of configuration

| Channel | TPU function | Priority |
|---------|--------------|----------|
| 0       | BLDC_top     | high     |
| 1       | BLDC_top     | high     |
| 2       | BLDC_top     | high     |

AN2521/D

| Channel | TPU function | Priority |
|---------|--------------|----------|
| 3       | BLDC_bottom  | high     |
| 4       | BLDC_bottom  | high     |
| 5       | BLDC_bottom  | high     |
| 10      | BLDC_sync    | low      |
| 11      | BLDC_res     | low      |
| 12      | BLDC_3HD     | high     |
| 13      | BLDC_3HD     | high     |
| 14      | BLDC_3HD     | high     |
| 15      | BLDC_fault   | high     |

#### Table 3. Example of configuration

Table 4 shows the TPU function code sizes.

| TPU function | Code size                                           |
|--------------|-----------------------------------------------------|
| BLDC_3HD     | 69 $\mu$ instructions + 8 entries = 77 long words   |
| BLDC_top     | 57 $\mu$ instructions + 8 entries = 65 long words   |
| BLDC_bottom  | 171 $\mu$ instructions + 8 entries = 179 long words |
| BLDC_sync    | 26 $\mu$ instructions + 8 entries = 34 long words   |
| BLDC_res     | 38 $\mu$ instructions + 8 entries = 46 long words   |
| BLDC_fault   | 9 $\mu$ instructions + 8 entries = 17 long words    |

**Configuration Order** The CPU configures the TPU as follows.

- 1. Disables the channels by clearing the two channel priority bits on each channel used (not necessary after reset).
- 2. Selects the channel functions on all used channels by writing the function numbers to the channel function select bits.
- 3. Initializes function parameters. The parameters *PinAddr\_A*, *PinAddr\_B*, *T*, *DT*, *MPW* and *sync\_presc\_addr* must be set before initialization. If a BLDC\_sync channel or a BLDC\_res channel is used, then also its parameters must be set before initialization.
- 4. Issues an HSR (Host Service Request) type %10 to all BLDC\_3HD channels, to initialize them, and to one of the BLDC\_bottom channels to initialize all PWM channels. Issues an HSR type %10 to the BLDC\_sync channels, BLDC\_res channels and BLDC\_fault channel, if used.
- 5. Enables servicing by assigning a high, middle or low priority to the channel priority bits. All Hall sensor channels, as well as all PWM channels, must be assigned the same priority to ensure correct operation. The CPU must ensure that BLDC\_bottom (which actually initializes all PWM channels) is initialized after the initialization of



BLDC\_3HD, and that the BLDC\_sync or BLDC\_res function is initialized even after the initialization of BLDC\_bottom:

- assign a priority to the Phase A, Phase B and Phase C Hall sensor channels to enable their initialization
- wait until the HSR bits are cleared to indicate that initialization of these channels has completed
- assign a priority to the PWM channels to enable their initialization
- if a Synchronization Signal or a Resolver Reference Signal channel is used, wait until the HSR bits are cleared to indicate that initialization of the PWM channels has completed and
- assign a priority to the BLDC\_sync or BLDC\_res channel to enable its initialization
- **NOTE:** A CPU routine that configures the TPU can be generated automatically using the MPC500\_Quick\_Start Graphical Configuration Tool.

### **Detailed Function Description**

### 3-phase Hall Sensor Decoder for BLDC Motor (BLDC\_3HD)

The BLDC\_3HD operates on three channels and processes the incoming Hall sensor signals. On each detected transition that marks a change of position in one of six sectors, a link is sent to two pairs of PWM channels to force them to commutate. One pair of PWM channels is switched ON by the link while the other pair is switched OFF.

Furthermore, as a result of this processing, the Sector parameter gets a value that reflects the position of a motion system in one of six sectors. The state of the Hall sensor signals and the corresponding Sector value is listed in Table 5.

| Phase A | Phase B | Phase C | Sector |
|---------|---------|---------|--------|
| 1       | 0       | 0       | 4      |
| 1       | 1       | 0       | 6      |
| 0       | 1       | 0       | 2      |
| 0       | 1       | 1       | 3      |
| 0       | 0       | 1       | 1      |
| 1       | 0       | 1       | 5      |
| 0       | 0       | 0       | 0      |
| 1       | 1       | 1       | 7      |

A Sector value of 0 or 7 indicates an illegal state of the Hall sensor signals.

The Sector value history determines the direction of the motion system. The Direction parameter can be assigned a value of 0 or 1. See **Table 6**.



### Table 6. Sector value sequence and corresponding Direction value

| Sector value sequence | Direction |
|-----------------------|-----------|
| 4, 6, 2, 3, 1, 5, 4,  | 0         |
| 4, 5, 1, 3, 2, 6, 4,  | 1         |

The Period value is calculated each time the sector is changed. The Period value is the TCR time of last revolution. It is measured from the last edge of similar type (low-high / high-low), on the same channel, to the current edge – see **Figure 3**. This method eliminates inaccuracies in the Hall sensor signals. The Period parameter does not contain a valid value during the first revolution after initialization, or after a change of direction.



Figure 3. Hall sensor signals and corresponding values



Two function modes are provided:

- TCR1 clock selected
- TCR2 clock selected

The selected mode is determined by the HSQ bit 1. The user has to select the same mode on all channels.

The function provides interpolation support. The parameters LastEdgeT and ActualT are updated on a Host Service Request HSR = 11. LastEdgeT then has the value of the last incoming edge time in TCR clocks and ActualT has the current value of the TCR clock.

The CPU program should use 32-bit reads to ensure coherency of the two parameters. This applies to coherent reads of LastEdgeT and ActualT as well as the Sector and TCR\_VALUE, which is necessary for interpolation calculations.

### Host Interface

| Written By CPU | Written by both CPU and TPU |
|----------------|-----------------------------|
| Written By TPU | Not Used                    |

#### Table 7. BLDC\_3HD Control Bits Name Options BLDC 3HD function number 3 2 1 0 (Assigned during assembly the Channel Function Select DPTRAM code from library TPU functions) 00 – Channel Disabled 1 0 01 – Low Priority **Channel Priority** 10 – Middle Priority 11 – High Priority 00 - No Host Service Request 1 0 01 – Not used Host Service Bits (HSR) 10 - Initialization 11 - Get LastEdgeT and ActualT x0 – Phase A or Phase B 1 0 x1 – Phase C Host Sequence Bits (HSQ) 0x -TCR1 clock selected 1x - TCR2 clock selected 0 0 – Channel Interrupt Disabled Channel Interrupt Enable 1 – Channel Interrupt Enabled 0 0 - Interrupt Not Asserted **Channel Interrupt Status** 1 – Interrupt Asserted



TPU function BLDC\_3HD generates an interrupt each time the Sector is changed.

| Channel  | Parameter | 15 1 <sup>4</sup> | 4 13       | 12 | 11 | 10 9 | 8          | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----------|-------------------|------------|----|----|------|------------|------|---|---|---|---|---|---|---|
|          | 0         |                   | TCR_VALUE  |    |    |      |            |      |   |   |   |   |   |   |   |
|          | 1         |                   |            |    |    |      | See        | ctor |   |   |   |   |   |   |   |
| ⊲        | 2         |                   |            |    |    |      | PinA       |      |   |   |   |   |   |   |   |
| Phase A  | 3         |                   |            |    |    |      | √_ch       |      |   |   |   |   |   |   |   |
| has      | 4         |                   |            |    |    |      | F_c        |      |   |   |   |   |   |   |   |
| <u>م</u> | 5         |                   |            |    |    |      | NST        |      |   |   |   |   |   |   |   |
|          | 6         |                   |            |    |    |      | lgeT       |      |   |   |   |   |   |   |   |
|          | 7         |                   |            |    |    |      | lgeT       |      |   |   |   |   |   |   |   |
|          | 0         |                   |            |    |    | L    | astE       |      |   |   |   |   |   |   |   |
|          | 1         |                   | ActualT    |    |    |      |            |      |   |   |   |   |   |   |   |
| ш        | 2         | PinAdr_B          |            |    |    |      |            |      |   |   |   |   |   |   |   |
|          | 3         |                   | ON_chans_B |    |    |      |            |      |   |   |   |   |   |   |   |
| Phase    | 4         |                   |            |    |    |      | F_c        |      |   |   |   |   |   |   |   |
|          | 5         |                   |            |    |    |      | NST        |      |   |   |   |   |   |   |   |
|          | 6         |                   |            |    |    |      | lgeT       |      |   |   |   |   |   |   |   |
|          | 7         |                   |            |    |    |      | lgeT       |      |   |   |   |   |   |   |   |
|          | 0         |                   |            |    |    |      | Dire       |      | n |   |   |   |   |   |   |
|          | 1         |                   |            |    |    |      |            | С    |   |   |   |   |   |   |   |
| O        | 2         |                   |            |    |    |      |            | riod |   |   |   |   |   |   |   |
| se       | 3         | ON_chans_C        |            |    |    |      |            |      |   |   |   |   |   |   |   |
| Phase    | 4         | OFF_chans_C       |            |    |    |      |            |      |   |   |   |   |   |   |   |
| <u>م</u> | 5         | —                 |            |    |    |      | PINSTATE_C |      |   |   |   |   |   |   |   |
|          | 6         |                   |            |    |    |      | geT        |      |   |   |   |   |   |   |   |
|          | 7         | EdgeT_HL_C        |            |    |    |      |            |      |   |   |   |   |   |   |   |

### Table 8. BLDC\_3HD Parameter RAM

Table 9. BLDC\_3HD parameter description

| Parameter                 | Format                  | Description                                                                                     |  |  |  |  |  |  |
|---------------------------|-------------------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Parameters written by CPU |                         |                                                                                                 |  |  |  |  |  |  |
| PinAdr_A                  | 16-bit unsigned integer | \$YAZA, where Y is a<br>number of Phase B<br>channel and Z is a<br>number of Phase C<br>channel |  |  |  |  |  |  |



| Parameter                                                                                         | Format                     | Description                                                                                             |  |  |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------|----------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| PinAdr_B                                                                                          | 16-bit unsigned integer    | \$ZAXA, where Z is a<br>number of Phase C<br>channel and X is a<br>number of Phase A<br>channel         |  |  |  |  |  |  |  |
| Parar                                                                                             | meters written by both TPU | and CPU                                                                                                 |  |  |  |  |  |  |  |
| RC                                                                                                | 16-bit signed integer      | Revolution Counter value                                                                                |  |  |  |  |  |  |  |
|                                                                                                   | Parameters written by TP   | U                                                                                                       |  |  |  |  |  |  |  |
| LastEdgeT                                                                                         | 16-bit unsigned integer    | TCR time of last transition *                                                                           |  |  |  |  |  |  |  |
| ActualT                                                                                           | 16-bit unsigned integer    | Actual TCR time *                                                                                       |  |  |  |  |  |  |  |
| Direction                                                                                         | 0 or 1                     | Direction<br>0 – Sector sequence<br>4, 6, 2, 3, 1, 5, 4,<br>1 – Sector sequence<br>4, 5, 1, 3, 2, 6, 4, |  |  |  |  |  |  |  |
| TCR_VALUE                                                                                         | 16-bit unsigned integer    | TCR time of last transition                                                                             |  |  |  |  |  |  |  |
| Sector                                                                                            | 4, 6, 2, 3, 1 or 5         | Sector: position in one of<br>six sectors                                                               |  |  |  |  |  |  |  |
| Period                                                                                            | 16-bit unsigned integer    | Period: time of last revolution in TCR clocks.                                                          |  |  |  |  |  |  |  |
| PINSTATE_A<br>PINSTATE_B<br>PINSTATE_C                                                            | \$0000 or \$0001           | The actual state of the pin<br>is<br>\$0001 – high,<br>\$0000 – low                                     |  |  |  |  |  |  |  |
| EdgeT_LH_A<br>EdgeT_LH_B<br>EdgeT_LH_C                                                            | 16-bit unsigned integer    | TCR time of last low-high transition                                                                    |  |  |  |  |  |  |  |
| EdgeT_HL_A<br>EdgeT_HL_B<br>EdgeT_HL_C                                                            | 16-bit unsigned integer    | TCR time of last high-low transition                                                                    |  |  |  |  |  |  |  |
| * The parameter values are entered by TPU on Host Service Request 11 (Get LastEdgeT and ActualT). |                            |                                                                                                         |  |  |  |  |  |  |  |
| Other parameters are just for TPU function inner use.                                             |                            |                                                                                                         |  |  |  |  |  |  |  |

### Table 9. BLDC\_3HD parameter description





### Performance

### Table 10. BLDC\_3HD State Statistics

| State    | Max IMB Clock Cycles | RAM Accesses by TPU |
|----------|----------------------|---------------------|
| INIT     | 22                   | 5                   |
| GET_TIME | 8                    | 3                   |
| LH1      | 36                   | 14                  |
| HL1      | 36                   | 14                  |
| LH2      | 40                   | 15                  |
| HL2      | 40                   | 15                  |

**NOTE:** Execution times do not include the time slot transition time (TST = 10 or 14 IMB clocks)



Figure 4. BLDC\_3HD timing



AN2521/D Detailed Function Description



Figure 5. BLDC\_3HD state diagram

Noise Immunity The input signals can be disturbed by an impulse noise. The TPU hardware rejects short input pulses of less than a configurable number of IMB clocks. Longer pulses are processed by the TPU. Furthermore the function itself uses a pin history to reject short error pulses that are long enough to get through the hardware filter, but not long enough to last from the actual transition time to the time that the TPU services the channel. Even longer error pulses are counted on both edges, resulting in a short-time error of the Sector value.

BLDC Motor – Top (BLDC\_top) and BLDC Motor – Bottom (BLDC\_bottom)

The BLDC\_top and BLDC\_bottom TPU functions work together to generate a 6-channel, 3-phase PWM signal, with dead-time between the top and bottom channels. In order to charge the bootstrap transistors, the PWM signals start to run 1.6ms after their initialization (at 20MHz TCR1 clock). The functions generate signals corresponding to value of 0 for duty-cycle ratio *dc* until the first *dc* value is processed. This accures for at least one PWM period.

One of the phases is always switched off while the other two generate the PWM signal. Which phase is switched off, depends on which one of the six sectors the rotor is positioned in. The position is decoded from the Hall sensor signals.

The CPU controls the PWM output by setting the TPU parameters. The dutycycle ratio *dc* and PWM period *T* can be adjusted during run time. Conversely, dead-time (*DT*) and minimum pulse width (*MPW*) are not supposed to be changed during run time. The duty-cycle ratio *dc* can gain a value in the range (-1, 1). The sign controls the motion system direction, while the absolute value controls the amplitude of the applied voltage.



The following figures show the input *dc* value and corresponding output PWM signals (valid for sector 4, direction 0):





The following equations describe how the PWM signal transition times T1p, T2p, B1p, B2p, T1m, T2m, B1m, B2m are calculated, and how they are assigned to each channel transition time  $t_{LH}$  and  $t_{HL}$  based on BLDCm commutation rules:

| $Tdc_{\alpha} = T \cdot dc$ |                          |
|-----------------------------|--------------------------|
| $X = \frac{T + Tdc}{2}$     |                          |
| $Y = \frac{T - Tdc}{2}$     |                          |
| $A = \frac{X - DT}{2}$      | $C = \frac{Y - DT}{2}$   |
| $B = \frac{X + DT}{2}$      | $D = \frac{Y + DT}{2}$   |
| $Tlp = center\_time - A$    | $T2p = center\_time + A$ |
| $B1p = center\_time - B$    | $B2p = center\_time + B$ |
| $T1m = center\_time - C$    | $T2m = center\_time + C$ |
| $B1m = center\_time - D$    | $B2m = center\_time + D$ |

BLDC Motor version II TPU Function Set (BLDC)



| Channel |                                       |                                       | Se                                       | ctor                                  |                                          |                                       |  |  |
|---------|---------------------------------------|---------------------------------------|------------------------------------------|---------------------------------------|------------------------------------------|---------------------------------------|--|--|
| onanner | 4                                     | 6                                     | 2                                        | 3                                     | 1                                        | 5                                     |  |  |
| Q1      | $t_{\rm LH} = T1p$ $t_{\rm HL} = T2p$ | $t_{\rm LH} = T1p$ $t_{\rm HL} = T2p$ | OFF                                      | $t_{\rm LH} = T1m$ $t_{\rm HL} = T2m$ | $t_{\rm LH} = T1m$ $t_{\rm HL} = T2m$    | OFF                                   |  |  |
| Q2      | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | OFF                                      | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$    | OFF                                   |  |  |
| Q3      | $t_{\rm LH} = T1m$ $t_{\rm HL} = T2m$ | OFF                                   | $t_{\rm LH} = T1p$ $t_{\rm HL} = T2p$    | $t_{\rm LH} = T1p$ $t_{\rm HL} = T2p$ | OFF                                      | $t_{\rm LH} = T1m$ $t_{\rm HL} = T2m$ |  |  |
| Q4      | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | OFF                                   | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$    | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | OFF                                      | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ |  |  |
| Q5      | OFF                                   | $t_{\rm LH} = T1m$ $t_{\rm HL} = T2m$ | $t_{\rm LH} = T1m$<br>$t_{\rm HL} = T2m$ | OFF                                   | $t_{\rm LH} = T1p$<br>$t_{\rm HL} = T2p$ | $t_{\rm LH} = T1p$ $t_{\rm HL} = T2p$ |  |  |
| Q6      | OFF                                   | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$    | OFF                                   | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$    | $t_{\rm LH} = B2p$ $t_{\rm HL} = B1p$ |  |  |

# Table 11. Assignment of the calculated transition times to each channel transition times $t_{LH}$ and $t_{HL}$ based on the BLDC comutation rules

Host Interface





Written by both CPU and TPU

Not Used

### Table 12. BLDC\_top Control Bits

| Name                    | Options                       |  |  |  |  |  |  |
|-------------------------|-------------------------------|--|--|--|--|--|--|
| 3 2 1 0                 | BLDC_top function number      |  |  |  |  |  |  |
| Channel Function Select | (Assigned during assembly the |  |  |  |  |  |  |
|                         | DPTRAM code from library TPU  |  |  |  |  |  |  |
|                         | functions)                    |  |  |  |  |  |  |
| 1 0                     | 00 – Channel Disabled         |  |  |  |  |  |  |
| Channel Priority        | 01 – Low Priority             |  |  |  |  |  |  |
|                         | 10 – Middle Priority          |  |  |  |  |  |  |
|                         | 11 – High Priority            |  |  |  |  |  |  |
| 1 0                     | 00 – No Host Service Request  |  |  |  |  |  |  |
| Host Service Bits (HSR) | 01 – Not used                 |  |  |  |  |  |  |
|                         | 10 – Not used                 |  |  |  |  |  |  |
|                         | 11 – Not used                 |  |  |  |  |  |  |



### Table 12. BLDC\_top Control Bits



| Table 13 | BLDC | _bottom | Control | Bits |
|----------|------|---------|---------|------|
|----------|------|---------|---------|------|

| Name                               | Options                                                                                                    |
|------------------------------------|------------------------------------------------------------------------------------------------------------|
| 3 2 1 0<br>Channel Function Select | BLDC_bottom function number<br>(Assigned during assembly the<br>DPTRAM code from library TPU<br>functions) |
| 1 0<br>Channel Priority            | 00 – Channel Disabled<br>01 – Low Priority<br>10 – Middle Priority<br>11 – High Priority                   |
| Host Service Bits (HSR)            | 00 – No Host Service Request<br>01 – Not used<br>10 – Initialization<br>11 – Stop                          |
| 1 0<br>Host Sequence Bits (HSQ)    | xx – Not used                                                                                              |
| 0<br>Channel Interrupt Enable      | x – Not used                                                                                               |
| 0<br>Channel Interrupt Status      | x – Not used                                                                                               |



| Channel | Parameter | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |  |  |
|---------|-----------|---------------------------------------|--|--|--|--|--|--|
|         | 0         | pinst_addr_Q1                         |  |  |  |  |  |  |
|         | 1         | other_ch_Q1                           |  |  |  |  |  |  |
| _       | 2         | С                                     |  |  |  |  |  |  |
| ~       | 3         | T1p                                   |  |  |  |  |  |  |
| ð       | 4         | Т2р                                   |  |  |  |  |  |  |
|         | 5         | dc                                    |  |  |  |  |  |  |
|         | 6         |                                       |  |  |  |  |  |  |
|         | 7         | fault_pinstate                        |  |  |  |  |  |  |
|         | 0         | pinst_addr_Q2                         |  |  |  |  |  |  |
|         | 1         | other_ch_Q2                           |  |  |  |  |  |  |
|         | 2         | Tdc                                   |  |  |  |  |  |  |
| 6       | 3         | B1p                                   |  |  |  |  |  |  |
| Ø       | 4         | B2p                                   |  |  |  |  |  |  |
|         | 5         | DT                                    |  |  |  |  |  |  |
|         | 6         |                                       |  |  |  |  |  |  |
|         | 7         |                                       |  |  |  |  |  |  |
|         | 0         | pinst_addr_Q3                         |  |  |  |  |  |  |
|         | 1         | other_ch_Q3                           |  |  |  |  |  |  |
|         | 2         | D                                     |  |  |  |  |  |  |
| 03      | 3         | T1m                                   |  |  |  |  |  |  |
| Ø       | 4         | T2m                                   |  |  |  |  |  |  |
|         | 5         | Т                                     |  |  |  |  |  |  |
|         | 6         |                                       |  |  |  |  |  |  |
|         | 7         |                                       |  |  |  |  |  |  |
|         | 0         | pinst_addr_Q4                         |  |  |  |  |  |  |
|         | 1         | other_ch_Q4                           |  |  |  |  |  |  |
|         | 2         | Т_сору                                |  |  |  |  |  |  |
| Q4      | 3         | B1m                                   |  |  |  |  |  |  |
| 0       | 4         | B2m                                   |  |  |  |  |  |  |
|         | 5         | MPW                                   |  |  |  |  |  |  |
|         | 6         |                                       |  |  |  |  |  |  |
|         | 7         |                                       |  |  |  |  |  |  |
|         | 0         | pinst_addr_Q5                         |  |  |  |  |  |  |
|         | 1         | other_ch_Q5                           |  |  |  |  |  |  |
|         | 2         | center_time                           |  |  |  |  |  |  |
| Q5      | 3         |                                       |  |  |  |  |  |  |
| 0       | 4         |                                       |  |  |  |  |  |  |
|         | 5         | sync_presc_addr                       |  |  |  |  |  |  |
|         | 6         |                                       |  |  |  |  |  |  |
|         | 7         |                                       |  |  |  |  |  |  |

Table 14. BLDC\_top and BLDC\_bottom Parameter RAM



### Table 14. BLDC\_top and BLDC\_bottom Parameter RAM

| Channel | Parameter | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8    | 7   | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-----------|----|----|----|----|----|----|-----|------|-----|----|---|---|---|---|---|---|
|         | 0         |    |    |    |    |    |    |     | st_a |     |    | ; |   |   |   |   |   |
|         | 1         |    |    |    |    |    |    | oth | er_  | ch_ | Q6 |   |   |   |   |   |   |
|         | 2         |    | L  |    |    |    |    |     |      |     |    |   |   |   |   |   |   |
| 36      | 3         |    |    |    |    |    |    |     |      |     |    |   |   |   |   |   |   |
| a       | 4         |    |    |    |    |    |    |     |      |     |    |   |   |   |   |   |   |
|         | 5         |    |    |    |    |    |    |     |      |     |    |   |   |   |   |   |   |
|         | 6         |    |    |    |    |    |    |     |      |     |    |   |   |   |   |   |   |
|         | 7         |    |    |    |    |    |    |     |      |     |    |   |   |   |   |   |   |

#### Table 15. BLDC\_top and BLDC\_bottom parameter description

| Parameter                 | Format                                                | Description                                                                                                                                                                  |  |  |  |  |  |  |
|---------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Parameters written by CPU |                                                       |                                                                                                                                                                              |  |  |  |  |  |  |
| dc                        | 16-bit fractional                                     | duty-cycle ratio in the range <-1,1)                                                                                                                                         |  |  |  |  |  |  |
| Т                         | 16-bit unsigned integer                               | PWM period in number of TCR1<br>TPU cycles                                                                                                                                   |  |  |  |  |  |  |
| DT                        | 16-bit unsigned integer                               | Dead-time in number of TCR1<br>TPU cycles                                                                                                                                    |  |  |  |  |  |  |
| MPW                       | 16-bit unsigned integer                               | Minimum pulse width in number<br>of TCR1 TPU cycles. See<br><b>Performance</b> for details.                                                                                  |  |  |  |  |  |  |
| sync_presc_addr           | 8-bit unsigned integer                                | address of synchronization<br>channel <i>prescaler</i> parameter:<br>\$X4,<br>where X is synchronization<br>channel number.<br>\$0 if no synchronization channel<br>is used. |  |  |  |  |  |  |
|                           | Parameters written by                                 | y TPU                                                                                                                                                                        |  |  |  |  |  |  |
| fault_pinstate            | 0 or 1                                                | If fault channel is used, state of<br>fault pin:<br>0 low<br>1 high                                                                                                          |  |  |  |  |  |  |
| Other parameters a        | Other parameters are just for TPU function inner use. |                                                                                                                                                                              |  |  |  |  |  |  |



### Performance

### Table 16. BLDC\_top State Statistics

| State                | Max IMB Clock Cycles | RAM Accesses by TPU |
|----------------------|----------------------|---------------------|
| Т                    | 24                   | 5                   |
| TC2                  | 42                   | 18                  |
| ONOFF <sub>ON</sub>  | 14                   | 0                   |
| ONOFF <sub>OFF</sub> | 6                    | 0                   |

### Table 17. BLDC\_bottom State Statistics

| State                | Max IMB Clock Cycles | RAM Accesses by TPU |
|----------------------|----------------------|---------------------|
| INIT                 | 178                  | 47                  |
| STOP                 | 38                   | 0                   |
| Т                    | 24                   | 5                   |
| TC1                  | 82                   | 12                  |
| ONOFF <sub>ON</sub>  | 14                   | 0                   |
| ONOFF <sub>OFF</sub> | 6                    | 0                   |

**NOTE:** Execution times do not include the time slot transition time (TST = 10 or 14 IMB clocks)



AN2521/D



Figure 7. BLDC\_top and BLDC\_bottom timing





Figure 8. BLDC\_top and BLDC\_bottom state diagram

Minimum Pulse Width

The TPU cannot generate PWM signals with duty cycle ratios very close to 0% or 100%. It is the case when the dc value is close to 1 or -1. The minimum pulse width that the TPU can be guaranteed to correctly generate is determined by the TPU function itself and by the activity on the other channels. When the TPU function is requested to generate a narrower pulse a collision can occur. To prevent this, the parameter *MPW* (minimum pulse width) is introduced. The TPU function BLDCm limits the narrowest generated pulse widths to *MPW*. The CPU program should check the maximum absolute value of *dc* to avoid this limitation, or take account of the non-linear performance when *dc* moves towards the boundary values and the limitation is exhibited by the TPU. The maximum absolute value of *dc* should satisfy:

$$\left| dc \right| \le 1 - \frac{2(MPW + DT)}{T}$$



The *MPW* is written by the CPU. The *MPW* depends on the whole TPU unit configuration, especially the lengths of the longest states of other functions, and their priorities, running on the same TPU. The *MPW* has to be correctly calculated at the time the whole TPU unit is configured.



latency









When BLDC\_top and BLDC\_bottom are running alone on one TPU, the minimum pulse width can be calculated according to Figure 9 or Figure 10. These illustrate two possible worst cases of timing, when only compulsory BLDC functions are running on one TPU (BLDC\_top, BLDC\_bottom and BLDC\_3HD). The worst case happens when a transition on one of the Hall sensor signals is detected and processed during the shortest pulse on a PWM channel. The processing send links to four PWM channels to switch them on or off. Processing of the detected transition (state LH2), all the ON/OFF states and the transition states T, therefore has to be done within *MPW*. Each state is preceded by the Time Slot Transition (TST), which takes 10 or 14 IMB clock cycles.

According to the **Figure 9** the *MPW* is 246 IMB clock cycles – *DT*. According to **Figure 10** the *MPW* is 192 IMB clock cycles. In summary the MPW parameter value is equal to 246 IMB clock cycles – *DT*, and has a minimum value of 192 IMB clock cycles.

Note that the *MPW*, as well as the *DT*, are not entered into the parameter **RAM** in IMB clock cycles, but in TCR1 clock cycles. It is recommended for the BLDC function that the TCR1 clock is configured for its maximum speed, which is the IMB clock divided by 2. In this case the MPW = 123 - DT, with a minimum value of 96.



When other functions are running concurrently on the same TPU, the longest state of each function with its time-slot transition can increase the calculated *MPW* value. The BLDC\_fault function does not affect the *MPW*. The BLDC\_sync, if used, increase the *MPW* value by 22 (44 IMB clock cycles). The BLDC\_res, if used, increase the *MPW* value by 20 (40 IMB clock cycles).

If a lower value than the one calculated, is set for the *MPW* parameter, the motion system can run with a higher motor voltage amplitude, but with a risk, that the dead-time is not maintained.

It is also possible to use the Worst-Case Latency (WCL), which is automatically calculated by the MPC500\_Quick\_Start Graphical Configuration Tool. It can serve as a good approximation of *MPW*. The calculated WCL is always longer than the real-case is. Let the WCL be calculated after the configuration of TPU channels and then find the longest WCL value within all BLDC PWM channels. Convert the number, from IMB clock cycles to TCR1 clock cycles, to get the *MPW*.

### Synchronization signal for BLDC Motor (BLDC\_sync)

The BLDC\_sync TPU function uses information obtained from BLDC PWM functions, the actual PWM center times and the PWM periods. This allows a signal to be generated, which tracks the changes in the PWM period and is always synchronized with the PWM. The synchronization signal is a positive pulse generated repeatedly after the *prescaler* or *presc\_copy* PWM periods (see next paragraph). The low to high transition of the pulse can be adjusted by a parameter, either negative or positive, to go a number of TCR1 TPU cycles before or after the PWM period center time. The pulse width *pw* is another synchronization signal parameter.



Figure 11. Synchronization signal adjustment examples

BLDC Motor version II TPU Function Set (BLDC)



Semiconductor, Inc.

reescale

### Freescale Semiconductor, Inc.

Synchronized Change of PWM Prescaler And Synchronization Signal Prescaler The BLDC\_sync TPU function actually uses the *presc\_copy* parameter instead of the *prescaler* parameter. The *prescaler* parameter holds the prescaler value that is copied to the *presc\_copy* by the BLDC\_bottom function at the time the PWM parameters are reloaded. This ensures that new prescaler values for the PWM signals, as well as the synchronization signal, are applied at the same time. Write the synchronization signal *prescaler* parameter address to the *sync\_presc\_addr* parameter to enable this mechanism. Write 0 to disable it, and remember to set the synchronization signal *presc\_copy* parameter instead of the *prescaler* parameter in this case.



#### Table 18. BLDC\_sync Control Bits

| Name                               | Options                                                                                                  |
|------------------------------------|----------------------------------------------------------------------------------------------------------|
| 3 2 1 0<br>Channel Function Select | BLDC_sync function number<br>(Assigned during assembly the<br>DPTRAM code from library TPU<br>functions) |
| 1 0<br>Channel Priority            | 00 – Channel Disabled<br>01 – Low Priority<br>10 – Middle Priority<br>11 – High Priority                 |
| 1 0<br>Host Service Bits (HSR)     | 00 – No Host Service Request<br>01 – Not used<br>10 – Initialization<br>11 – Not used                    |
| 1 0<br>Host Sequence Bits (HSQ)    | xx – Not used                                                                                            |
| 0<br>Channel Interrupt Enable      | 0 – Channel Interrupt Disabled<br>1 – Channel Interrupt Enabled                                          |
| 0<br>Channel Interrupt Status      | 0 – Interrupt Not Asserted<br>1 – Interrupt Asserted                                                     |

TPU function BLDC\_sync generates an interrupt after each low to high transition.

Host Interface



| Parameter                                             | Format                    | Description                                                                                                     |  |  |  |  |  |
|-------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Parameters written by CPU                             |                           |                                                                                                                 |  |  |  |  |  |
| move                                                  | 16-bit signed integer     | The number of TCR1 TPU cycles<br>to forego (negative) or come after<br>(positive) the PWM period center<br>time |  |  |  |  |  |
| pw                                                    | 16-bit unsigned integer   | Synchronization pulse width in<br>number of TCR1 TPU cycles.                                                    |  |  |  |  |  |
| prescaler                                             | 16-bit unsigned integer   | The number of PWM periods per<br>synchronization pulse<br>– use in case of synchronized<br>prescalers change    |  |  |  |  |  |
| presc_copy                                            | 16-bit unsigned integer   | The number of PWM periods per<br>synchronization pulse<br>– use in case of asynchronized<br>prescalers change   |  |  |  |  |  |
|                                                       | Parameters written by TPU |                                                                                                                 |  |  |  |  |  |
| Other parameters are just for TPU function inner use. |                           |                                                                                                                 |  |  |  |  |  |

Performance

There is one limitation. The absolute value of parameter *move* has to be less than a quarter of the PWM period T.

$$move \left| < \frac{T}{4} \right|$$



Table 21. BLDC\_sync State Statistics

| State | Max IMB Clock Cycles | RAM Accesses by TPU |
|-------|----------------------|---------------------|
| INIT  | 12                   | 5                   |
| S1    | 12                   | 6                   |
| S2    | 8                    | 3                   |
| S3    | 16                   | 7                   |

**NOTE:** Execution times do not include the time slot transition time (TST = 10 or 14 IMB clocks)



Figure 12. BLDC\_sync timing



Figure 13. BLDC\_sync state diagram

### Resolver Reference Signal for BLDC Motor (BLDC\_res)

The BLDC\_res TPU function uses information read from the BLDC PWM functions, the actual PWM center times and the PWM periods. This allows a signal to be generated, which tracks the changes of the PWM period and is always synchronized with the PWM. The resolver reference signal is a 50% duty-cycle signal with a period equal to *prescaler* or synchronization channel



*presc\_copy* PWM periods (see next paragraph). The low to high transition of the pulse can be adjusted by a parameter, either negative or positive, to go a number of TCR1 TPU cycles before or after the PWM period center time.



Figure 14. Resolver reference signal adjustment examples

т

т

т

Synchronized Change of PWM Prescaler And Resolver Reference Signals Prescaler The BLDC\_res TPU function can inherit the Synchronization Signal prescaler that is synchronously changed with the PWM prescaler. Write the synchronization signals *presc\_copy* parameter address to the *presc\_addr* parameter to enable this mechanism. Write 0 to disable it, and in this case set the *prescaler* parameter to directly specify prescaler value.

Host Interface



#### Table 22. BLDC\_res Control Bits

| Name                    | Options                       |  |  |
|-------------------------|-------------------------------|--|--|
| 3 2 1 0                 | BLDC_res function number      |  |  |
| Channel Function Select | (Assigned during assembly the |  |  |
|                         | DPTRAM code from library TPU  |  |  |
|                         | functions)                    |  |  |
| 1 0                     | 00 – Channel Disabled         |  |  |
| Channel Driarity        | 01 – Low Priority             |  |  |
| Channel Priority        | 10 – Middle Priority          |  |  |
|                         | 11 – High Priority            |  |  |



| Name                            | Options                                                                               |
|---------------------------------|---------------------------------------------------------------------------------------|
| 1 0<br>Host Service Bits (HSR)  | 00 – No Host Service Request<br>01 – Not used<br>10 – Initialization<br>11 – Not used |
| 1 0<br>Host Sequence Bits (HSQ) | xx – Not used                                                                         |
| 0 Channel Interrupt Enable      | x – Not used                                                                          |
| 0<br>Channel Interrupt Status   | x – Not used                                                                          |

### Table 22. BLDC\_res Control Bits

### Table 23. BLDC\_res Parameter RAM

| Channel  | Parameter | 15        | 14         | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----------|-----------|------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|          | 0         |           | move       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|          | 1         |           |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 5        | 2         |           | presc_addr |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Sesolver | 3         | prescaler |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| esc      | 4         |           | time       |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 2        | 5         |           | dec        |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|          | 6         |           | Т_сору     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|          | 7         |           |            |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Table 24. BLDC\_res parameter description

| Parameter | Format                | Description                                                                                                     |
|-----------|-----------------------|-----------------------------------------------------------------------------------------------------------------|
|           | Parameters writter    | n by CPU                                                                                                        |
| move      | 16-bit signed integer | The number of TCR1 TPU cycles<br>to forego (negative) or come after<br>(positive) the PWM period center<br>time |



| Parameter                                             | Format                  | Description                                                                                                                                                                                                                           |  |  |  |  |
|-------------------------------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| presc_addr                                            | 16-bit unsigned integer | <ul> <li>\$00X6, where X is a number of<br/>Synchronization Signal channel,<br/>to inherit Sync. channel prescaler<br/>or</li> <li>\$0000 to enable direct specification<br/>of prescaler value in prescaler<br/>parameter</li> </ul> |  |  |  |  |
| prescaler 1, 2, 4, 6, 8, 10, 12, 14,                  |                         | The number of PWM periods per<br>synchronization pulse<br>– use when apresc_addr = 0                                                                                                                                                  |  |  |  |  |
| Parameters written by TPU                             |                         |                                                                                                                                                                                                                                       |  |  |  |  |
| Other parameters are just for TPU function inner use. |                         |                                                                                                                                                                                                                                       |  |  |  |  |

| Table 24. BLDC | _res | parameter | description |
|----------------|------|-----------|-------------|
|----------------|------|-----------|-------------|

Performance

There is one limitation. The absolute value of parameter *move* has to be less than a quarter of the PWM period T.

 $|move| < \frac{T}{4}$ 

#### Table 25. BLDC\_res State Statistics

| State | Max IMB Clock Cycles | RAM Accesses by TPU |
|-------|----------------------|---------------------|
| INIT  | 12                   | 5                   |
| S1    | 26                   | 9                   |
| S3    | 18                   | 7                   |

**NOTE:** Execution times do not include the time slot transition time (TST = 10 or 14 IMB clocks)



Figure 15. BLDC\_res timing

BLDC Motor version II TPU Function Set (BLDC)





Figure 16. BLDC\_res state diagram

**Fault Input for BLDC Motor (BLDC\_fault)** The BLDC\_fault is an input TPU function that monitors the pin, and if a high to low transition occurs, immediately sets all PWM channels low and cancels all further transitions on them. The PWM channels, as well as the synchronization and resolver reference signal channels (if used), have to be initialized again to start them running.

The function returns the actual pinstate as a value of 0 (low) or 1 (high) in the parameter *fault\_pinstate*. The parameter is placed on the Q1 PWM channel to keep the fault channel parameter space free.

#### Host Interface



### Table 26. BLDC\_fault Control Bits

| Name                    | Options                       |  |  |  |  |
|-------------------------|-------------------------------|--|--|--|--|
| 3 2 1 0                 | BLDC_fault function number    |  |  |  |  |
| Channel Function Select | (Assigned during assembly the |  |  |  |  |
|                         | DPTRAM code from library TPU  |  |  |  |  |
|                         | functions)                    |  |  |  |  |
| 1 0                     | 00 – Channel Disabled         |  |  |  |  |
| Channel Driarity        | 01 – Low Priority             |  |  |  |  |
| Channel Priority        | 10 – Middle Priority          |  |  |  |  |
|                         | 11 – High Priority            |  |  |  |  |



#### Name Options 00 – No Host Service Request 1 0 01 - Not used Host Service Bits (HSR) 10 – Initialization 11 - Not used 1 0 Host Sequence Bits (HSQ) xx - Not used 0 0 – Channel Interrupt Disabled **Channel Interrupt Enable** 1 – Channel Interrupt Enabled 0 0 - Interrupt Not Asserted **Channel Interrupt Status** 1 – Interrupt Asserted

### Table 26. BLDC\_fault Control Bits

TPU function BLDC\_fault generates an interrupt when a high to low transition appears.

### Table 27. BLDC\_fault Parameter RAM

| Channel | Parameter | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|-----------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|         | 0         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|         | 1         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Ĕ       | 2         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| input   | 3         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| ault    | 4         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Б       | 5         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|         | 6         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|         | 7         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### Table 28. BLDC\_fault parameter description

| Parameter                 | Format | Description                            |  |  |  |  |  |  |
|---------------------------|--------|----------------------------------------|--|--|--|--|--|--|
| Parameters written by TPU |        |                                        |  |  |  |  |  |  |
| fault_pinstate            | 0 or 1 | State of fault pin:<br>0 low<br>1 high |  |  |  |  |  |  |

BLDC Motor version II TPU Function Set (BLDC)



### Performance

 Table 29. BLDC\_fault State Statistics

| State    | Max IMB Clock Cycles | RAM Accesses by TPU |
|----------|----------------------|---------------------|
| INIT     | 8                    | 2                   |
| FAULT    | 44                   | 1                   |
| NO_FAULT | 4                    | 1                   |

**NOTE:** Execution times do not include the time slot transition time (TST = 10 or 14 IMB clocks)



Figure 18. BLDC\_fault state diagram



#### How to Reach Us:

Home Page: www.freescale.com

E-mail: support@freescale.com

#### USA/Europe or Locations Not Listed:

Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com

#### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

#### Asia/Pacific:

Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.



AN2521/D Rev.0 5/2003 For More Information On This Product, Go to: www.freescale.com