# Freescale Semiconductor Application Note Document Number: AN3511 Rev. 0, 09/2007 # Using the Pulse Width Modulation with the MCF521*x* ColdFire<sup>®</sup> Microcontroller by: Paolo Alcantára and Lech Olmedo RTAC Americas ## 1 Introduction This document is a quick reference to configure the pulse width modulation (PWM) module for the MCF521*x* microcontroller (MCU). Basic knowledge about the functional description and configuration options gives the user a better understanding on how the PWM module works. Some examples are included which are intended to be modified to suit the specific needs for any application. # 2 MCF521x Pulse Width Modulation Features The PWM module generates a synchronous series of pulses having a programmable period and duty cycle. With a suitable low-pass filter, the PWM can be used as a digital-to analog converter. ### **Contents** | 1 | Intro | oduction | |---|-------|-----------------------------------------| | 2 | MC | F521x Pulse Width Modulation Features 1 | | | 2.1 | Description | | 3 | Pul | se Width Modulation Explanation | | | 3.1 | Clock Source | | | 3.2 | Scaled Clock | | | 3.3 | Center-Aligned | | | 3.4 | Left-Aligned | | 4 | Cas | se Studies | | | 4.1 | Example: Case study for the PWM Module5 | | | 4.2 | Example: Configuring PWM Module 5 | | | 4.3 | Left-Aligned with Scaled Clock | | | 4.4 | Center-Aligned with Scaled Clock 8 | | 5 | Reg | gister Configuration8 | | | 5.1 | Port Assignment Register 8 | | | 5.2 | PWM Clock Select Register 9 | | | 5.3 | PWM Clock Select Register 9 | | | 5.4 | PWM Scale [A,B] Registers10 | | 6 | Cor | nfiguration Summary10 | | 7 | Cor | nfiguration Notes10 | | 8 | Cor | nclusion11 | | | 8.1 | Considerations and References | | | | | **Pulse Width Modulation Explanation** # 2.1 Description The main features of PWM module are: - Double-buffered period and duty cycle - Left-aligned or center-aligned outputs - Eight independent PWM channels using 8-bit period register or four PWM channels using 16-bit period register. - Byte-wide registers provide programmable duty cycle and period control - Four programmable clock sources # 3 Pulse Width Modulation Explanation The example code shows how the PWM works employing 8 different PWM signals through the M5213EVB board. Half of these signals are displayed on 4 LEDs and the others can be corroborated using an oscilloscope. This demonstrates how to configure the PWM module in an easy way and allows you to include it very quickly in your projects. A PWM signal has a frequency and a duty cycle. In most applications, the frequency is fixed while the duty cycle varies. Figure 1 illustrates a PWM signal. Figure 1. PWM Signal A general purpose timer (GPT) using output compare mode can also implement a PWM signal. However, the PWM module is more precise with frequency and duty cycle. A dedicated period and duty register exist for each channel and are double buffered. So if a change occurs in these registers, the change does not take effect until one of the following events occur: - The effective period ends - The counter resets to zero - The channel is disabled Additionally, the PWM module can generate four types of signals: Center-aligned with clock - Center-aligned with scaled clock - Left-aligned with clock - Left-aligned with scaled clock ### 3.1 Clock Source Each PWM channel can be associated with a clock generator: simple clock A, simple clock B, scaled clock A and scaled clock B. This distinction allows more flexibility in PWM module between channels. Table 1 shows clock source options per channels. **Table 1. Source Clock and Associated PWM Channel** | Source Clock | PWM channels | | | |---------------------------|--------------|--|--| | Clock A or Scaled Clock A | 0, 1, 4, 5 | | | | Clock B or Scaled Clock B | 2, 3, 6, 7 | | | ### 3.2 Scaled Clock The PWM channel with a scaled clock first receives the simple clock as its clock source. Then, the generated reference is prescaled with another register. A block diagram showing the difference between the simple clocks and scaled clocks is in Figure 2. Figure 2. Difference Between Simple Clock and Scaled Clock # 3.3 Center-Aligned This feature can be applied to any channel. A center-aligned signal is handled by a counter and its ability to go up and down. Signal can start each period at high or low digital value. Each period can be divided in four states explained in Figure 3. Using the Pulse Width Modulation with the MCF521x ColdFire<sup>®</sup> Microcontroller, Rev. 0 ### **Pulse Width Modulation Explanation** Figure 3. Center-Aligned Signal The steps 1–4 in Figure 3 are explained below: - 1. The counter operates as an up/down counter in center-aligned mode and is set to up-counter at the beginning. - 2. When the PWM counter matches the duty register, the output flip-flop changes state causing the PWM also to change state from low to high (or high to low depending on the PPOL bit). - 3. A match between the PWM counter and period register changes the counter direction from an up-count to a down-count. - 4. When the counter decrements and matches the duty register again, the PWM output channel changes state. - 1. When the PWM counter reaches 0x00, the counter changes from a down-count to an up-count and loads the double-buffered period and duty cycle values. # 3.4 Left-Aligned The feature is fully independent of the other channels. A left-aligned signal is handled by a counter and its capability to only count up depending on some registers. The signal can start each period at high or low digital value. Each period can be divided in two states as shown in Figure 4. Figure 4. Left-Aligned Signal The 8-bit counter is configured as an up-counter only. - 1. A match between PWM counter and period register resets the counter and a change in output PWM state. A load is performed from the double buffer period and duty register. - 2. When PWM counter matches the duty register, the output PWM changes state from low to high (or low to high depending on the PPOL bit). # 4 Case Studies # 4.1 Example: Case study for the PWM Module This example uses eight PWM channels in 8-bit mode. All channels share the same clock source (simple clock or scaled clock). There are two ways to calculate frequency for all channels: - Using equations from Table 2. - Using the spreadsheet showed in Figure 6 and Figure 5. With this approach, period (PWMPER*n*) and duty cycle (PWMDTY*n*) are the only differences between each PWM channel (without considering polarity and channel alignment). After configuring each PWM channel, the last step is to enable the desired channels. After this, the PWM are fully independent and do not need any more configuration. Although, the PWM frequency and duty cycle can be changed on the go and are reflected on the next PWM period. # 4.2 Example: Configuring PWM Module Table 2 shows all equation to be applied for each PWM signal type. ### **Case Studies** **Table 2. PWM Equations** | Equations | Description | |-----------------------------------------------------------------------------------------------------|-----------------------------------------| | $f_n = \frac{f_{SYS/2}}{2*PCK[A,B]*PWMSCLA*PWMPER_n}$ | Left-aligned with scaled clock [A,B] | | $f_n = \frac{f_{SYS/2}}{4*PCK[A,B]*PWMSCLA*PWMPER_n}$ | Center-aligned with scaled clock [A,B] | | $f_n = \frac{f_{SYS/2}}{PCK[A, B] * PWMPER_n}$ | Left-aligned with clock [A,B] | | $f_n = \frac{f_{SYS/2}}{2*PCK[A, B]*PWMPER_n}$ | Center-aligned with clock [A,B] | | $duty = \left 1 - PWMPOL[PPOL_n] - \frac{PWMDTY_n}{PWMPER_n} \right *100\%$ | Duty cycle for all PWM type signals. | | PCK[A,B] = 2n; n = [0,7]<br>fSYS = Core internal frequency<br>PWMSCLA = [0,255]<br>PWMPER = [0,255] | Some considerations about PWM equations | Additional to this equation, a spreadsheet (PWMparameterCalculator.xls), showed in Figure 6 and Figure 5, contains an easy way to generate a desired frequency using these parameters: - Desired frequency to be output through pin. - $f_{SYS/2}$ —Core internal frequency divided by two. - PERIOD—PWMPER*n* register. Recommended value is 200 to achieve good duty cycle resolution. (Refer to the duty cycle equation in Table 2.) The spreadsheet calculates the four possible PWM signal types and the obtained frequency with these parameters. Not all frequencies can be synthesized in all types of signals, so frequencies usually have to use a scaled clock instead of a simple clock. It is your responsibility to choose the results (as SCLA) that are below 256 because the register 8-bits wide. For example, in Figure 5 the following are used: - $f_{SYS/2} = 40,000,000 \text{ Hz}$ - Desired frequency = 30 Hz - Period = 200 (to have a more exact duty cycle) | Variable | Value | Unit | Comments | | |-------------------|----------|------|----------|--| | fsys/2 | 40000000 | Hz | Constant | | | desired frequency | 30 | Hz | Variable | | | PERIOD | 200 | N/A | Constant | | Figure 5. Parameters to Calculate PWM Signal Using the Pulse Width Modulation with the MCF521x ColdFire® Microcontroller, Rev. 0 7 After entering 40 MHz as the clock source, 30 Hz as the desired PWM, and 200 as PERIOD into the spreadsheet (PWMparameterCalculator.xls), it will show the different PWM frequencies with the provided information. | 11 1 150000 1 75000 12 2 75000 2 3750 13 4 37500 4 1875 14 8 18750 8 9375 15 16 9375 16 4687 16 32 4687.5 32 2343. 17 64 2343.75 64 1171.87 18 128 1171.875 128 585.93 19 Using Scaled Clock Using Scaled Clock Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 <th></th> | | | | | | | | | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--------------|--------------------|----------|--------------------|--|--------------------|------|-----------|--------------------| | 9 | 7 | Left Aligned | | | | | | Cent | er Aligne | ed | | PCKA Obtained frequency PCKA Obtained frequency 1 | 8 | | | | | | | | | | | 11 1 150000 1 7500 12 2 75000 2 3750 13 4 37500 4 1875 14 8 18750 8 937 15 16 9375 16 4687,5 16 32 4687,5 32 2343, 17 64 2343,75 64 1171,875 18 128 1171,875 128 585,93 19 128 1171,875 128 585,93 19 12 128 585,93 128 585,93 19 12 128 585,93 128 585,93 19 12 128 585,93 128 585,93 19 12 128 585,93 128 585,93 19 12 128 585,93 128 585,93 20 13 2500 14 2500 30 1250 1 | 9 | Using Clock | | | | | | Usi | ing Clock | | | 12 2 75000 2 37500 13 4 37500 4 1875 14 8 18750 8 9375 15 16 9375 16 4887 16 32 4687.5 32 2343. 17 64 2343.75 64 171.87 18 128 1171.875 128 585.93 19 19 128 1171.875 Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 4 | 10 | | | PCKA | obtained frequency | | | | PCKA | obtained frequency | | 13 | 11 | | | 1 | 150000 | | | | 1 | 75000 | | 14 8 18750 8 9375 15 16 9375 16 4687 16 32 4687.5 32 2343. 17 64 2343.75 64 1171.81 18 128 1171.875 128 585.93 19 Using Scaled Clock Using Scaled Clock Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 | 12 | | | 2 | 75000 | | | | 2 | 37500 | | 15 16 9375 16 4687.5 16 32 4687.5 32 2343. 17 64 2343.75 64 1171.8° 18 128 1171.875 128 585.33 19 Using Scaled Clock 20 Using Scaled Clock Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 32 39 30.0480 | 13 | | | 4 | 37500 | | | | 4 | 18750 | | 16 32 4687.5 32 2343. 17 64 2343.75 64 1171.87 18 128 1171.875 128 585.93 19 Using Scaled Clock Using Scaled Clock Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.95207668 1250 4 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 14 | | | 8 | 18750 | | | | 8 | 9375 | | 17 64 2343,75 64 1171.8 18 128 1171.875 128 585,93 19 20 Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29,9520 25 2500 8 313 29,95207668 1250 8 156 30,0480 26 2500 16 156 30,04807692 1250 16 78 30,0480 27 2500 32 78 30,04807692 1250 32 39 30,0480 | 15 | | | 16 | 9375 | | | | 16 | 4687.5 | | 18 128 171.875 128 585,93 19 Using Scaled Clock 20 Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29,9520 25 2500 8 313 29,95207668 1250 8 156 30,0480 26 2500 16 156 30,04807692 1250 16 78 30,0480 27 2500 32 78 30,04807692 1250 32 39 30,0480 | 16 | | | 32 | 4687.5 | | | | 32 | 2343.75 | | 19 20 Using Scaled Clock Using Scaled Clock | 17 | | | 64 | 2343.75 | | | | 64 | 1171.875 | | 20 Using Scaled Clock 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29,9520 25 2500 8 313 29,95207668 1250 8 156 30,0480 26 2500 16 156 30,04807692 1250 16 78 30,0480 27 2500 32 78 30,04807692 1250 32 39 30,0480 | 18 | | | 128 | 1171.875 | | | | 128 | 585.9375 | | 21 subproduct PCKA SCLA obtained frequency subproduct PCKA SCLA obtained frequency 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 19 | | | | | | | | | | | 22 2500 1 2500 30 1250 1 1250 30 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 20 | | <b>Using Scale</b> | ed Clock | | | Using Scaled Clock | | | | | 23 2500 2 1250 30 1250 2 625 30 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 21 | subproduct | PCKA | SCLA | obtained frequency | | subproduct | PCKA | SCLA | obtained frequency | | 24 2500 4 625 30 1250 4 313 29.9520 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 22 | 2500 | 1 | 2500 | 30 | | 1250 | 1 | 1250 | 30 | | 25 2500 8 313 29.95207668 1250 8 156 30.0480 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 23 | 2500 | 2 | 1250 | 30 | | 1250 | 2 | 625 | 30 | | 26 2500 16 156 30.04807692 1250 16 78 30.0480 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 24 | 2500 | 4 | 625 | 30 | | 1250 | 4 | 313 | 29.95207668 | | 27 2500 32 78 30.04807692 1250 32 39 30.0480 | 25 | 2500 | _ | 313 | 29.95207668 | | 1250 | - | 156 | 30.04807692 | | | 26 | 2500 | 16 | 156 | 30.04807692 | | 1250 | 16 | 78 | 30.04807692 | | 28 2500 64 39 30.04807692 1250 64 20 29.296 | 27 | 2500 | | 78 | 30.04807692 | | 1250 | 32 | 39 | 30.04807692 | | | | 2500 | 64 | 39 | 30.04807692 | | 1250 | 64 | 20 | 29.296875 | | 29 2500 128 20 29.296875 1250 128 10 29.296 | 29 | 2500 | 128 | 20 | 29.296875 | | 1250 | 128 | 10 | 29.296875 | Figure 6. Resulting Values in the Spreadsheet You now should select which PCKA and SCLA values can be used according to the following rules: - PCKA allowed values are: 1, 2, 4, 8, 16, 32, 64 and 128. These values are fixed on the spreadsheet. - SCLA must be less than 256. Therefore, in this example you can only choose between 156, 78, 39 or 20 for left-aligned and 156, 78, 39, 20 or 10 for center-aligned. - Within these SCLA values, you should select the obtained frequency row closest to the desired frequency. The final parameters that could be used with the same results are shown in Table 3 and Table 4. # 4.3 Left-Aligned with Scaled Clock Table 3. Left-Aligned with Scaled Clock | | PERIOD <sup>1</sup> | PCKA <sup>2</sup> | SCLA | Desired freq | Obtained Freq <sup>3</sup> | |----------|---------------------|-------------------|------|--------------|----------------------------| | Option 1 | 200 | 4 | 156 | 30 Hz | 30.04807 Hz | | Option 2 | 200 | 5 | 78 | 30 Hz | 30.04807 Hz | | Option 3 | 200 | 6 | 39 | 30 Hz | 30.04807 Hz | <sup>&</sup>lt;sup>1</sup> Using PCKA and SCLA, PWM channels affected are 0, 1, 4, 5, according to Table 1. It is your responsibility to use the appropriate PWMPER*n* (PWMPER1 for channel 1, for example). <sup>&</sup>lt;sup>2</sup> PCKA values that appear on the spreadsheet are modified by 2n. Therefore, PCKA only accepts n values. <sup>&</sup>lt;sup>3</sup> If the obtained frequency is not close enough to the desired frequency, you must change PERIOD by trial and error until the difference between obtained and desired frequency is adequate. 8 ### **Register Configuration** # 4.4 Center-Aligned with Scaled Clock Table 4. Center-Aligned with Scaled Clock | | PERIOD <sup>1</sup> | PCKA <sup>2</sup> | SCLA | Desired Freq | Obtained Freq <sup>3</sup> | |----------|---------------------|-------------------|------|--------------|----------------------------| | Option 1 | 200 | 3 | 156 | 30 Hz | 30.04807 Hz | | Option 2 | 200 | 4 | 78 | 30 Hz | 30.04807 Hz | | Option 3 | 200 | 5 | 39 | 30 Hz | 30.04807 Hz | Using PCKA and SCLA, PWM channels affected are 0, 1, 4, 5, according to Table 1. It is your responsibility to use the appropriate PWMPERn (PWMPER1 for channel 1, for example). The above example uses a period of 200. If the desired duty cycle is 50%, PWMDTYn must be 100 (n refers to channel number) and PWMPOL[PPOL] must be set, according to PWM equation from Table 2. With a period of 200, you can select a precise duty cycle (0.5% resolution). # 5 Register Configuration This section shows the register configuration that affect the entire PWM channels and the code lines used. This section is meant to merely illustrate how the registers are configured. # 5.1 Port Assignment Register The following code lines configure the PTCPAR (Figure 7) and PTDPAR (Figure 8), to assign the PWM function to the GPIO pins. Freescale Semiconductor Using the Pulse Width Modulation with the MCF521x ColdFire® Microcontroller, Rev. 0 <sup>&</sup>lt;sup>2</sup> PCKA values that appear on the spreadsheet are modified by 2*n*. Therefore, PCKA only accepts *n* values. <sup>&</sup>lt;sup>3</sup> If the obtained frequency is not close enough to the desired frequency, you must change PERIOD by trial and error until the difference between obtained and desired frequency is adequate. IPSBAR Offsets: 0x10\_0057 (PTCPAR) Access: User read/write Figure 7. Port TC Pin Assignment Register Configuration rigulo oli oli 12 i ili Alcolgililicili riogicici collingului # 5.2 PWM Clock Select Register The next code lines configure the PWMCLK. ``` /* Associate every channel with a source clock */ /* A, or B, SA or SB depending the channel */ MCF_PWM_PWMCLK = u8Clock; ``` Figure 9. PWM Clock Select Register # 5.3 PWM Clock Select Register The program uses this code to write the values to the PWMPRCLK: ``` /* change the prescaler of the clock source for every channel */ MCF_PWM_PWMPRCLK = 0 | MCF_PWM_PWMPRCLK_PCKA(BUSCLK_16) | MCF_PWM_PWMPRCLK_PCKB(BUSCLK_16); 7 6 5 4 3 2 1 0 R 0 PCKB PCKA Reset: 0 0 0 0 0 0 0 0 0 0 Figure 10. PWM Clock select register ``` Using the Pulse Width Modulation with the MCF521x ColdFire® Microcontroller, Rev. 0 **Configuration Summary** # 5.4 PWM Scale [A,B] Registers On the next code lines, the scaled clock register is configured according to Figure 11 and Figure 12. /\* set scaled value for scaled clock, if are activated \*/ MCF\_PWM\_PWMSCLA = u8ScaledValue; MCF\_PWM\_PWMSCLB = u8ScaledValue; Figure 11. PWM Scaled Register A Figure 12. PWM Scaled Register B # 6 Configuration Summary The following steps are needed to configure the pulse width modulator module: - 1. Configure PWM pins as their primary function in the pin assignment registers. - 2. Associate each PWM channel with a clock source in the PWMCLK register. - 3. Configure PWMPRCLK. If a scaled clock is selected, the PWMSCLA or PWMSCLB registers must be configured as well. - 4. For every PWM channel, these registers must be filled: PWMPER: set PWM period (see period equation above). PWMDTY: set duty cycle (see duty cycle equation above). PWMPOL: set channel polarity bit (start each period at high or low). PWMCAE: set channel alignment bit (left or center alignment). PWME: enable each channel using respective bit. # 7 Configuration Notes The following details must be considered when configuring the PWM: - PWMPRCLK[PCKA] and PWMPRCLK[PCKB] affect all PWM channels. - PWMSCLA and PWMSCLB affect only PWM channels linked to scaled clocks A or B. Using the Pulse Width Modulation with the MCF521x ColdFire® Microcontroller, Rev. 0 # 8 Conclusion The PWM module is a versatile module with eight channels in 8-bit mode or four channels in 16-bit mode. With a combination of clock source and prescaler, you can calculate precise PWM frequencies and duty cycles. After configuration, the module is fully independent and if a change in frequency or duty cycle is needed, a simple write in configuration registers is reflected at the next PWM period. ### 8.1 Considerations and References Find the latest software updates and configuration files for the MCF521x devices on the Freescale Semiconductor website: http://www.freescale.com This application note applies to: - MCF5211, MCF5212, and MCF5213 devices - M5213EVB Development Board employed with the PWM software demo For more information on the pulse width modulation module refer to the *MCF5213 ColdFire Integrated Microcontroller Reference Manual*. The PWMSoftwareDemo software was developed in CodeWarrior for Coldfire v6.3. Download the source files for PWMSoftwareDemo software (PWMSoftwareDemo.zip) from <a href="http://www.freescale.com">http://www.freescale.com</a>. Inside you'll find source code and a spreadsheet to easily calculate different PWM parameters. ### How to Reach Us: **Home Page:** www.freescale.com Web Support: http://www.freescale.com/support **USA/Europe or Locations Not Listed:** Freescale Semiconductor, Inc. Technical Information Center, EL516 2100 East Elliot Road Tempe, Arizona 85284 +1-800-521-6274 or +1-480-768-2130 www.freescale.com/support 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) www.freescale.com/support ### 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 Document Number: AN3511 Rev. 0 09/2007 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 that 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. RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics as their non-RoHS-compliant and/or non-Pb-free counterparts. For further information, see <a href="http://www.freescale.com">http://www.freescale.com</a> or contact your Freescale sales representative. For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp. Freescale<sup>™</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org © Freescale Semiconductor, Inc. 2007. All rights reserved.