

## **Application Note**

AN2525/D Rev. 0, 5/2003

DC Motor – XOR version TPU Function Set (DCmXor)

By Milan Brejl, Ph.D.

## **Functional Overview**

The DC Motor – XOR version (DCmXor) TPU function is a version of the DC Motor (DCm) function that uses two TPU channels to generate one PWM output channel. The TPU channel outputs are connected to an XOR gate whos output is the required PWM signal. See **Figure 1**. An advantage of this solution is that the full range (0% to 100%) of PWM duty-cycle ratios is available. There is no *MPW* (minimum pulse width) parameter to limit the edge duty-cycle ratios in this version, unlike in the DCm. A disadvantage is that the number of assigned TPU channels is doubled.



Figure 1. Functionality of XOR version – illustration



The function set consists of 5 TPU functions:

- DC Motor XOR version C channels (DCmXor\_C)
- DC Motor XOR version T channels (DCmXor T)
- Synchronization Signal for DC Motor XOR version (DCmXor\_sync)
- Resolver Reference Signal for DC Motor XOR version (DCmXor\_res)
- Fault Input for DC Motor XOR version (DCmXor\_fault)

The DCm TPU function set drives a DC Motor, independently of the CPU. The CPU is required only to set a duty-cycle (*dc*) parameter in the range (–1,1). This determines both the speed and the direction. The function generates unipolar-switched center-aligned PWM signals.

The DCmXor\_C and DCmXor\_T TPU functions work together to generate 4 pairs of XOR gate inputs. The XOR gate outputs then produce a 4-channel 2-phase center-aligned PWM signal with dead-time between the top and bottom channels. The Synchronization Signal for the DCmXor function can be used to generate one or more adjustable signals for a wide range of uses. These are synchronized to the PWM, and track changes in the PWM period. The Resolver Reference Signal for the DCmXor 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 the DCmXor function is a TPU input function that sets all PWM outputs low when the input signal goes low.



AN2525/D Function Set Configuration

## **Function Set Configuration**

None of the TPU functions in the DC Motor – XOR version TPU function set can be used separately. The DCmXor\_C and DCmXor\_T functions have to be used together. The DCmXor\_C runs on pins SW1\_1 and SW3\_1 – see Figure 1. The DCmXor\_T runs on the other pins. One or more channels running Synchronization Signal for DCmXor as well as Resolver Reference Signals for DCmXor functions can be added. They can run with different settings on each channel. The function Fault Input for DCmXor 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. DCmXor TPU function set configuration options and restrictions

| TPU function | Optional/<br>Mandatory | How many channels | Assignable channels                     |
|--------------|------------------------|-------------------|-----------------------------------------|
| DCmXor_C     | mandatory              | 2                 | any 2 channels                          |
| DCmXor_T     | mandatory              | 6                 | any 6 channels                          |
| DCmXor_sync  | optional               | 1 or more         | any channels                            |
| DCmXor_res   | optional               | 1 or more         | any channels                            |
| DCmXor_fault | optional               | 1                 | any, recommended is 15 and DTPU bit set |

Table 2 shows an example of configuration.

Table 2. Example of configuration

| Channel | TPU function | Priority |
|---------|--------------|----------|
| 0       | DCmXor_C     | high     |
| 1       | DCmXor_T     | high     |
| 2       | DCmXor_T     | high     |
| 3       | DCmXor_T     | high     |
| 4       | DCmXor_C     | high     |
| 5       | DCmXor_T     | high     |
| 6       | DCmXor_T     | high     |
| 7       | DCmXor_T     | high     |
| 10      | DCmXor_sync  | low      |
| 11      | DCmXor_res   | low      |
| 15      | DCmXor_fault | high     |



Table 3 shows the TPU function code sizes.

Freescale Semiconductor, Inc.

Table 3. TPU function code sizes

| TPU function | Code size                                      |  |
|--------------|------------------------------------------------|--|
| DCmXor_C     | 134μ instructions + 8 entries = 142 long words |  |
| DCmXor_T     | 3 μ instructions + 8 entries = 11 long words   |  |
| DCmXor_sync  | 26 μ instructions + 8 entries = 34 long words  |  |
| DCmXor_res   | 38 μ instructions + 8 entries = 46 long words  |  |
| DCmXor_fault | 9 μ 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 *T*, *DT* and sync\_presc\_addr must be set before initialization. If a DCmXor\_sync channel or a DCmXor\_res channel is used, then its parameters must also be set before initialization.
- Issues an HSR (Host Service Request) type %10 to one of the DCmXor\_C channels to initialize all DCmXor\_C and DCmXor\_T channels. Issues an HSR type %10 to the DCmXor\_sync channels, DCmXor\_res channels and DCmXor\_fault channel, if used.
- 5. Enables servicing by assigning high, middle or low priority to the channel priority bits. All DCmXor\_C and DCmXor\_T channels must be assigned the same priority to ensure correct operation. The CPU must ensure that the DCmXor\_sync or DCmXor\_res function is initialized after the initialization of DCmXor:
  - assign a priority to the DCmXor\_C and DCmXor\_T 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 DCmXor\_C and DCmXor\_T channels has completed and
  - assign a priority to the DCmXor\_sync or DCmXor\_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.



AN2525/D
Detailed Function Description

## **Detailed Function Description**

DC Motor – XOR version – C channels (DCmXor\_C) and DC Motor – XOR version – T channels (DCmXor\_T) The DCmXor\_C and DCmXor\_T TPU functions work together to generate 4 pairs of XOR gate inputs. The XOR gate outputs then produce a 4-channel 2-phase center-aligned 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 a value 0 in duty-cycle ratio *dc* until the first *dc* value is processed, or for at least one PWM period.

The CPU controls the PWM output by setting the TPU parameters. The duty-cycle ratio dc and PWM period T can be adjusted during run time. Conversely, dead-time (DT) is 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 XOR gate outputs:



Figure 2. Unipolar switching

The following equations describe how the PWM signal transition times  $SW1\_1_T$ ,  $SW1\_2_T$ ,  $SW2\_1_T$ ,  $SW2\_2_T$ ,  $SW3\_1_T$ ,  $SW3\_2_T$ ,  $SW4\_1_T$  and  $SW4\_2_T$  are calculated:

$$Tdc = 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}$$

$$SW1\_1_T = center\_time - A$$

$$SW1_2_T = center\_time + A$$

$$SW2\_1_T = center\_time - B$$

$$SW2_2_T = center\_time + B$$

$$SW3\_1_T = center \_time - C$$

$$SW3_2_T = center_time + C$$

$$SW4\_1_T = center \_time - D$$

$$SW4\_2_T = center\_time + D$$



AN2525/D Detailed Function Description

Host Interface



Table 4. DCmXor\_C Control Bits

| Name                            | Options                                                                                        |
|---------------------------------|------------------------------------------------------------------------------------------------|
| 3 2 1 0 Channel Function Select | DCmXor_C function number (Assigned during assembly the DPTRAM code from library TPU functions) |
| 1 0 Channel Priority            | 00 – Channel Disabled<br>01 – Low Priority<br>10 – Middle Priority<br>11 – High Priority       |
| 1 0 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 Channel Interrupt Enable      | x – Not used                                                                                   |
| 0 Channel Interrupt Status      | x – Not used                                                                                   |

Table 5. DCmXor\_T Control Bits

| Name                         | Options                       |
|------------------------------|-------------------------------|
| 3 2 1 0                      | DCmXor_T function number      |
| Channel Function Select      | (Assigned during assembly the |
| Onamici i dilettori ocicet   | DPTRAM code from library TPU  |
|                              | functions)                    |
| 1 0                          | 00 - Channel Disabled         |
| Channel Priority             | 01 – Low Priority             |
| Charmer Fhority              | 10 – Middle Priority          |
|                              | 11 – High Priority            |
| 1 0                          | 00 – No Host Service Request  |
| Host Service Bits (HSR)      | 01 – Not used                 |
| Tiosi Service Bits (TISK)    | 10 – Not used                 |
|                              | 11 – Not used                 |
| 1 0 Host Sequence Bits (HSQ) | xx – Not used                 |



Table 5. DCmXor\_T Control Bits

| Name                       | Options      |
|----------------------------|--------------|
| 0 Channel Interrupt Enable | x – Not used |
| 0 Channel Interrupt Status | x – Not used |

Table 6. DCmXor\_C and DCmXor\_T Parameter RAM

| Channel | Parameter       |                 |  |  |  |
|---------|-----------------|-----------------|--|--|--|
|         | 0               | XY_X            |  |  |  |
|         | 1 SW13_2_ch_SW1 |                 |  |  |  |
| _       | 2               | SW24_1_ch_SW1   |  |  |  |
|         | 3               | SW24_2_ch_SW1   |  |  |  |
| SW1_1   | 4               | dc              |  |  |  |
| 0)      | 5               | Т               |  |  |  |
|         | 6               | other_ch_SW1    |  |  |  |
|         | 7               | fault_pinstate  |  |  |  |
|         | 0               | Ttime_SW1_2     |  |  |  |
|         | 1               | T_copy          |  |  |  |
| 01      | 2               | L               |  |  |  |
| SW1_2   | 3               | center_time     |  |  |  |
| )       | 4               | DT              |  |  |  |
|         | 5               | CPU14           |  |  |  |
|         | 6               |                 |  |  |  |
|         | 7               |                 |  |  |  |
|         | 0               | Ttime_SW2_1     |  |  |  |
|         | 1               |                 |  |  |  |
| _       | 2               |                 |  |  |  |
| SW2_1   | 3               |                 |  |  |  |
| )<br>No | 4               |                 |  |  |  |
| 0,      | 5               | sync_presc_addr |  |  |  |
|         | 6               |                 |  |  |  |
|         | 7               |                 |  |  |  |
|         | 0               | Ttime_SW2_2     |  |  |  |
|         | 1               |                 |  |  |  |
| 01      | 2               |                 |  |  |  |
| SW2_2   | 3               |                 |  |  |  |
|         | 4               |                 |  |  |  |
| 5       |                 |                 |  |  |  |
|         | 6               |                 |  |  |  |
|         | 7               |                 |  |  |  |



AN2525/D Detailed Function Description

Table 6. DCmXor\_C and DCmXor\_T Parameter RAM

| Channel       | Parameter | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |
|---------------|-----------|---------------------------------------|--|--|--|
|               | 0         | XY_Y                                  |  |  |  |
|               | 1         | SW13_2_ch_SW3                         |  |  |  |
| _             | 2         | SW24_1_ch_SW3                         |  |  |  |
| 3 SW2<br>4 5  |           | SW24_2_ch_SW3                         |  |  |  |
| No.           | 4         |                                       |  |  |  |
| 0)            | 5         |                                       |  |  |  |
|               | 6         | other_ch_SW3                          |  |  |  |
|               | 7         |                                       |  |  |  |
|               | 0         | Ttime_SW3_2                           |  |  |  |
|               | 1         |                                       |  |  |  |
| 01            | 2         |                                       |  |  |  |
| SW3_2         | 3         |                                       |  |  |  |
| No.           | 4         |                                       |  |  |  |
| 0)            | 5         |                                       |  |  |  |
|               | 6         |                                       |  |  |  |
|               | 7         |                                       |  |  |  |
|               | 0         | Ttime_SW4_1                           |  |  |  |
|               | 1         |                                       |  |  |  |
| _             | 2         |                                       |  |  |  |
| SW4_1         | 3         |                                       |  |  |  |
| )<br>No       | 4         |                                       |  |  |  |
| 0,            | 5         |                                       |  |  |  |
|               | 6         |                                       |  |  |  |
|               | 7         |                                       |  |  |  |
| 0 Ttime_SW4_2 |           | Ttime_SW4_2                           |  |  |  |
| 61            | 1         |                                       |  |  |  |
|               | 2         |                                       |  |  |  |
| SW4_2         | 3         |                                       |  |  |  |
| )             | 4         |                                       |  |  |  |
|               | 5         |                                       |  |  |  |
|               | 6         |                                       |  |  |  |
|               | 7         |                                       |  |  |  |



Table 7. DCmXor\_C and DCmXor\_T 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 TPU cycles                                                                                                                    |
| DT                                                    | 16-bit unsigned integer | Dead-time in number of TCR1 TPU cycles                                                                                                                     |
| CPU14                                                 | 16-bit unsigned integer | Time of 14 IMB clocks in TCR1 clocks.                                                                                                                      |
| sync_presc_addr                                       | 8-bit unsigned integer  | address of synchronization channel <i>prescaler</i> parameter: \$X4, where X is synchronization channel number. \$0 if no synchronization channel is used. |
| Parameters written by TPU                             |                         |                                                                                                                                                            |
| fault_pinstate                                        | 0 or 1                  | If fault channel is used, state of fault pin: 0 low 1 high                                                                                                 |
| Other parameters are just for TPU function inner use. |                         |                                                                                                                                                            |

Performance

Table 8. DCmXor\_T State Statistics

| State | Max IMB Clock Cycles | RAM Accesses by TPU |
|-------|----------------------|---------------------|
| ST    | 2                    | 1                   |
| SF    | 2                    | 0                   |

Table 9. DCmXor\_C State Statistics

| State | Max IMB Clock Cycles | RAM Accesses by TPU |
|-------|----------------------|---------------------|
| INIT  | 88                   | 16                  |
| STOP  | 100                  | 1                   |
| C1    | 76                   | 13                  |
| C2    | 28                   | 9                   |

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



Figure 3. DCmXor\_C and DCmXor\_T timing





Figure 4. DCmXor\_T state diagram and 3 cases of timing

**NOTE:** The timing of the link determines which case accurs.



Figure 5. DCmXor\_C state diagram

**Synchronization** signal for DC Motor XOR version (DCmXor sync)

The DCmXor sync TPU function uses information obtained from DCmXor C and DCmXor T functions, the actual PWM center times and the PWM periods. This allows a signal to be generated, that 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 before or after the PWM period center time of a number of TCR1 TPU cycles. The pulse width pw is another synchronization signal parameter.



Figure 6. Synchronization signal adjustment examples

Synchronized Change of PWM Prescaler And Synchronization Signal Prescaler

The DCmXor\_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 DCmXor\_bottom function at the time of the PWM parameters reload. 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 signals 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.



## AN2525/D

Host Interface



Table 10. DCmXor\_sync Control Bits

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

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

Table 11. DCmXor\_sync Parameter RAM

| Channel         | Parameter | 15         | 14        | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------|-----------|------------|-----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Je!             | 0         |            | move      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| channe          | 1         |            | pw        |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Š               | 2         |            | prescaler |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| o               | 3         | presc_copy |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| zati            | 4         | time       |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| ) ni            | 5         | dec        |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| ) rk            | 6         | Т_сору     |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Synchronization | 7         |            |           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |



Table 12. DCmXor\_sync parameter description

| Parameter                                             | Format                  | Description                                                                                            |  |  |  |  |  |
|-------------------------------------------------------|-------------------------|--------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                                       | Parameters writte       | n by CPU                                                                                               |  |  |  |  |  |
| move                                                  | 16-bit signed integer   | The number of TCR1 TPU cycles to forego (negative) or come after (positive) the PWM period center time |  |  |  |  |  |
| pw                                                    | 16-bit unsigned integer | Synchronization pulse width in number of TCR1 TPU cycles.                                              |  |  |  |  |  |
| prescaler                                             | 16-bit unsigned integer | The number of PWM periods per synchronization pulse  – use in case of synchronized prescalers change   |  |  |  |  |  |
| presc_copy                                            | 16-bit unsigned integer | The number of PWM periods per synchronization pulse  – use in case of asynchronized 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 then a quarter of the PWM period T.

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

Table 13. DCmXor\_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)



# S1 S2 S3 S1 S2 Center\_time Center\_time T T

Figure 7. DCmXor\_sync timing



Figure 8. DCmXor\_sync state diagram

Resolver Reference Signal for DC Motor – XOR version (DCmXor\_res) The DCmXor\_res TPU function uses information read from the DCmXor\_C and DCmXor\_T 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 before or after the PWM period center time of a number of TCR1 TPU cycles.



Figure 9. Resolver reference signal adjustment examples

Synchronized Change of PWM Prescaler And Resolver Reference Signals Prescaler The DCmXor\_res TPU function can inherit the Synchronization Signal prescaler that is synchronously changed with 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 *prescaler* parameter to directly specify prescaler value.



## AN2525/D

Host Interface



Table 14. DCmXor\_res Control Bits

| Name                            | Options                                                                                          |
|---------------------------------|--------------------------------------------------------------------------------------------------|
| 3 2 1 0 Channel Function Select | DCmXor_res function number (Assigned during assembly the DPTRAM code from library TPU functions) |
| 1 0 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 – Not used            |
| 1 0<br>Host Sequence Bits (HSQ) | xx – Not used                                                                                    |
| 0 Channel Interrupt Enable      | x – Not used                                                                                     |
| 0 Channel Interrupt Status      | x – Not used                                                                                     |

Table 15. DCmXor\_res Parameter RAM

| Channel  | Parameter | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |  |  |  |  |
|----------|-----------|---------------------------------------|--|--|--|--|
|          | 0         | move                                  |  |  |  |  |
|          | 1         |                                       |  |  |  |  |
| <u>.</u> | 2         | presc_addr                            |  |  |  |  |
| Resolver | 3         | prescaler                             |  |  |  |  |
| esc      | 4         | time                                  |  |  |  |  |
| ₩.       | 5         | dec                                   |  |  |  |  |
|          | 6         | T_copy                                |  |  |  |  |
|          | 7         |                                       |  |  |  |  |

Table 16. DCmXor\_res parameter description

er Format Description

Parameters written by CPII

| Parameter                                             | Format                     | Description                                                                                                                                                                                            |  |  |  |  |  |  |
|-------------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                                                       | Parameters writter         | n by CPU                                                                                                                                                                                               |  |  |  |  |  |  |
| move                                                  | 16-bit signed integer      | The number of TCR1 TPU cycles to forego (negative) or come after (positive) the PWM period center time                                                                                                 |  |  |  |  |  |  |
| presc_addr                                            | 16-bit unsigned integer    | \$00X6, where X is a number of<br>Synchronization Signal channel, to<br>inherit Sync. channel prescaler<br>or<br>\$0000 to enable direct specification<br>of prescaler value in prescaler<br>parameter |  |  |  |  |  |  |
| prescaler                                             | 1, 2, 4, 6, 8, 10, 12, 14, | The number of PWM periods per synchronization pulse – use when apresc_addr = 0                                                                                                                         |  |  |  |  |  |  |
|                                                       | 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| < \frac{T}{4}$$

Table 17. DCmXor\_res State Statistics

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

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





Figure 10. DCmXor\_res timing



Figure 11. DCmXor\_res state diagram

Fault Input for DC Motor – XOR version (DCmXor\_fault) The DCmXor\_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 SW1\_1 channel to keep the fault channel parameter space free.



AN2525/D Detailed Function Description

Host Interface

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

Table 18. DCmXor\_fault Control Bits

| Name                            | Options                                                                                            |
|---------------------------------|----------------------------------------------------------------------------------------------------|
| 3 2 1 0 Channel Function Select | DCmXor_fault function number (Assigned during assembly the DPTRAM code from library TPU functions) |
| 1 0 Channel Priority            | 00 – Channel Disabled<br>01 – Low Priority<br>10 – Middle Priority<br>11 – High Priority           |
| 1 0 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      | 0 – Channel Interrupt Disabled<br>1 – Channel Interrupt Enabled                                    |
| O Channel Interrupt Status      | 0 – Interrupt Not Asserted<br>1 – Interrupt Asserted                                               |

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



Table 19. DCmXor\_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         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Fa      | 5         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|         | 6         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|         | 7         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Table 20. DCmXor\_fault parameter description

| Parameter      | Format             | Description                      |
|----------------|--------------------|----------------------------------|
|                | Parameters writter | n by TPU                         |
| fault_pinstate | 0 or 1             | State of fault pin: 0 low 1 high |

Performance

Table 21. DCmXor\_fault State Statistics

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

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



AN2525/D
Detailed Function Description



Figure 12. DCmXor\_fault timing



Figure 13. DCmXor\_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.

