

# CorePWM v4.1

Handbook



#### Actel Corporation, Mountain View, CA 94043

© 2010 Actel Corporation. All rights reserved.

Printed in the United States of America

Part Number: 50200113-2

Release: February 2010

No part of this document may be copied or reproduced in any form or by any means without prior written consent of Actel.

Actel makes no warranties with respect to this documentation and disclaims any implied warranties of merchantability or fitness for a particular purpose. Information in this document is subject to change without notice. Actel assumes no responsibility for any errors that may appear in this document.

This document contains confidential proprietary information that is not to be disclosed to any unauthorized person without prior written consent of Actel Corporation.

#### Trademarks

Actel, IGLOO, Actel Fusion, ProASIC, Libero, Pigeon Point and the associated logos are trademarks or registered trademarks of Actel Corporation. All other trademarks and service marks are the property of their respective owners.



# **Table of Contents**

|   | Introduction                                          |
|---|-------------------------------------------------------|
|   | Core Overview                                         |
|   | Supported Families                                    |
|   | Core Version                                          |
|   | Supported Interfaces                                  |
|   | Utilization and Performance                           |
| 1 | Design Description                                    |
| T | Functional Blocks                                     |
|   | I/O Signals                                           |
|   | Register Map   15                                     |
|   | Configuration Example                                 |
|   | APB Interface Timing   24                             |
|   |                                                       |
| 2 | Tool Flows                                            |
|   | SmartDesign                                           |
|   | Importing into Libero IDE                             |
|   | Simulation Flows                                      |
|   | Synthesis in the Libero IDE                           |
|   | Place-and-Route in Libero IDE                         |
| 3 | Example Applications                                  |
| 5 | General Purpose PWM Application – Temperature Monitor |
|   | DAC                                                   |
|   | 2                                                     |
| 4 | Software Driver                                       |
| A | List of Document Changes                              |
| Π |                                                       |
| В | Product Support                                       |
|   | Customer Service                                      |
|   | Actel Customer Technical Support Center               |
|   | Actel Technical Support                               |
|   | Website                                               |
|   | Contacting the Customer Technical Support Center      |
|   | Index                                                 |
|   | IIIUCA                                                |



# Introduction

## **Core Overview**

#### **Intended Use**

CorePWM is a general purpose, multi-channel pulse width modulator (PWM) module for motor control, tone generation, battery charging, heating elements, and more.

In General Purpose PWM mode, duty cycle updates can be performed asynchronously or synchronously, based on parameter selection. In synchronous mode, all channels are updated at the beginning of the PWM period, which is useful for motor control and can be used to keep a constant dead band space between channel waveforms. Asynchronous mode is relevant to applications such as LED control, where synchronous updates are not required. Asynchronous mode lowers the area size, reducing shadow register requirements.

In addition to the general purpose PWM modes, there is a "Low Ripple DAC" mode that creates a minimum period pulse train whose High/Low average is that of the chosen duty cycle. When used with a low-pass filter (such as a simple RC circuit), a DAC can be created with far better bandwidth and ripple performance than a standard PWM algorithm can achieve. This type of DAC is ideally suited for fine tuning of power supply output levels.

CorePWM also provides support for tachometer monitoring of 3- and 4-wire fans. Incoming tachometer data is read by the firmware through the APB interface to calculate fan speed.

#### **Key Features**

- Configuration updates for all channels can be synchronized to the beginning of the PWM period, allowing precise updates and maintaining phase alignments between channels
- · Configurable resolution based on the APB bus width
- · Low-cost PWM solution with up to 16 separate PWM digital outputs, configurable via a register interface
- For DAC applications: Optional, per-channel Low Ripple DAC mode, allowing for greater resolution output of a given filter
- · Low-cost TACHOMETER solution with up to 16 separate TACH digital inputs, configurable via a register interface
- All PWM outputs are double-edge-controlled
- · Per-channel fixed register option for lower tile count
- · Edge control based on a configurable PWM period with prescaler value and 0% to 100% duty cycle capability
- · Set High, set Low, and Toggle Edge-Control modes
- · Can be programmed on-the-fly from a microcontroller, such as Core8051s, CoreABC
- Can be used to perform open or closed-loop margining of power supplies

## **Supported Families**

- IGLOO<sup>®</sup>/e
- ProASIC®3/E/L
- Fusion
- ProASIC<sup>PLUS®</sup>
- Axcelerator®
- RTAX-S
- RTAX-DSP

CorePWM v4.1

Introduction

## **Core Version**

This handbook supports CorePWM version 4.1.

## **Supported Interfaces**

CorePWM is available with an APB interface, which is described in the "APB Interface Timing" section on page 24.

## **Utilization and Performance**

CorePWM has been implemented in several of Actel's device families. A summary of various implementation data is listed in the following tables (using standard speed grades).

As shown in Table 1 through Table 8 on page 9, it is recommended to fix all registers that are not used, via parameters, to ensure optimal synthesis tile reduction.

Table 1 · CorePWM Device Utilization and Performance (one 8-bit DAC channel configuration)

| Family                   |            | Tiles         |       | Utilization |       | Performance |
|--------------------------|------------|---------------|-------|-------------|-------|-------------|
| I anniy                  | Sequential | Combinatorial | Total | Device      | Total | (MHz)       |
| IGLOO®/e                 | 20         | 96            | 116   | AGLE600     | 1.0%  | 72          |
| ProASIC®3/E              | 20         | 76            | 96    | A3P250      | 2.0%  | 96          |
| Fusion                   | 20         | 76            | 96    | AFS600      | 1.0%  | 101         |
| ProASIC <sup>PLUS®</sup> | 20         | 102           | 122   | APA300      | 1.0%  | 101         |
| Axcelerator®             | 20         | 31            | 51    | AX250       | 1.0%  | 252         |
| RTAX-S                   | 20         | 31            | 51    | RTAX250S    | 1.0%  | 223         |

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 1, APB\_DWIDTH = 8; DAC\_MODE1 = 1 (DAC mode), FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 0, FIXED\_PERIOD\_EN = 1, FIXED\_PERIOD = 1, SHADOW\_REG\_EN1 = 0.

| Table 2 · CorePWM Device Utilization and Performance |
|------------------------------------------------------|
| (one 16-bit DAC channel configuration)               |

| Family                  | Tiles      |               |       | Utilizatio | Performance |       |
|-------------------------|------------|---------------|-------|------------|-------------|-------|
| Family                  | Sequential | Combinatorial | Total | Device     | Total       | (MHz) |
| IGLOO/e                 | 54         | 147           | 201   | AGLE600V2  | 2.0%        | 59    |
| ProASIC3/E              | 54         | 111           | 165   | A3P250     | 3.0%        | 85    |
| Fusion                  | 54         | 111           | 165   | AFS600     | 1.0%        | 94    |
| ProASIC <sup>PLUS</sup> | 55         | 209           | 264   | APA200     | 3.0%        | 74    |

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 1, APB\_DWIDTH = 16; DAC\_MODE1 = 1 (DAC mode), FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 0, FIXED\_PERIOD\_EN = 1, FIXED\_PERIOD = 1, SHADOW\_REG\_EN1 = 1.

# Table 2 · CorePWM Device Utilization and Performance(one 16-bit DAC channel configuration) (continued)

| Axcelerator | 57 | 53 | 110 | AX250    | 2.0% | 210 |
|-------------|----|----|-----|----------|------|-----|
| RTAX-S      | 57 | 53 | 110 | RTAX250S | 1.0% | 176 |

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 1, APB\_DWIDTH = 16; DAC\_MODE1 = 1 (DAC mode), FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 0, FIXED\_PERIOD\_EN = 1, FIXED\_PERIOD = 1, SHADOW\_REG\_EN1 = 1.

Table 3 · CorePWM Device Utilization and Performance (one 8-bit general purpose PWM channel configuration)

| Family                  |            | Tiles         |       | Utilization |       | Performance |
|-------------------------|------------|---------------|-------|-------------|-------|-------------|
| Family                  | Sequential | Combinatorial | Total | Device      | Total | (MHz)       |
| IGLOO/e                 | 15         | 55            | 70    | AGLE600V2   | 1.0%  | 82          |
| ProASIC3/E              | 15         | 55            | 70    | A3P250      | 1.0%  | 130         |
| Fusion                  | 15         | 55            | 70    | AFS600      | 1.0%  | 144         |
| ProASIC <sup>PLUS</sup> | 15         | 58            | 73    | APA300      | 1.0%  | 141         |
| Axcelerator             | 16         | 40            | 56    | AX250       | 1.0%  | 181         |
| RTAX-S                  | 16         | 40            | 56    | RTAX250S    | 1.0%  | 187         |

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 1, APB\_DWIDTH = 8; DAC\_MODE1 = 0 (general purpose PWM mode), FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 0, FIXED\_PERIOD\_EN = 1, FIXED\_PERIOD = 8, FIXED\_PWM\_POS\_EN1 = 1, FIXED\_PWM\_POSEDGE1 = 0, FIXED\_PWM\_NEG\_EN1 = 0, FIXED\_PWM\_NEGEDGE1 = 0, SHADOW\_REG\_EN1 = 0

| Family                  |            | Tiles         |       | Utilizati | Performance |       |
|-------------------------|------------|---------------|-------|-----------|-------------|-------|
| ranny                   | Sequential | Combinatorial | Total | Device    | Total       | (MHz) |
| IGLOO/e                 | 91         | 272           | 363   | AGLE600V2 | 3.0%        | 46    |
| ProASIC3/E              | 91         | 275           | 366   | A3P250    | 6.0%        | 72    |
| Fusion                  | 91         | 275           | 366   | AFS600    | 3.0%        | 79    |
| ProASIC <sup>PLUS</sup> | 127        | 482           | 609   | APA300    | 6.0%        | 59    |
| Axcelerator             | 93         | 145           | 238   | AX250     | 6.0%        | 110   |
| RTAX-S                  | 93         | 145           | 238   | RTAX250S  | 6.0%        | 88    |

# Table 4 · CorePWM Device Utilization and Performance (one 16-bit general purpose PWM channel configuration)

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 1, APB\_DWIDTH = 16; DAC\_MODE1 = 0 (General Purpose PWM mode); SHADOW\_REG\_EN1 = 1, FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 64.



| Family                  |            | Tiles         |       | Utilization |       |                      |
|-------------------------|------------|---------------|-------|-------------|-------|----------------------|
|                         | Sequential | Combinatorial | Total | Device      | Total | Performance<br>(MHz) |
| IGLOO/e                 | 58         | 208           | 266   | AGLE600V2   | 2.0%  | 76                   |
| ProASIC3/E              | 58         | 150           | 208   | A3P250      | 3.0%  | 101                  |
| Fusion                  | 58         | 150           | 208   | AFS600      | 2.0%  | 109                  |
| ProASIC <sup>PLUS</sup> | 58         | 280           | 338   | APA300      | 4.0%  | 101                  |
| Axcelerator             | 58         | 66            | 124   | AX250       | 2.0%  | 250                  |
| RTAX-S                  | 58         | 66            | 124   | RTAX250S    | 2.0%  | 217                  |

Table 5 · CorePWM Device Utilization and Performance (8-bit multiple-output configuration example: 3DAC mode outputs without shadow update register)

*Note:* Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 3, APB\_DWIDTH = 8; DAC\_MODE1, DAC\_MODE2, and DAC\_MODE3 = 1 (DAC Mode) FIXED\_PERIOD\_EN = 1, FIXED\_PERIOD = 1, FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 0, SHADOW\_REG\_EN1 = 0, SHADOW\_REG\_EN2 = 0, SHADOW\_REG\_EN3 = 0.

Table 6 · CorePWM Device Utilization and Performance (12-bit multiple-output configuration example:3 DAC mode outputs, 3 general purpose PWM mode outputs)

| Family                  |            | Tiles         |       | Utilizati | Performance |       |
|-------------------------|------------|---------------|-------|-----------|-------------|-------|
| Family                  | Sequential | Combinatorial | Total | Device    | Total       | (MHz) |
| IGLOO/e                 | 212        | 723           | 935   | AGLE600V2 | 7.0%        | 45    |
| ProASIC3/E              | 212        | 694           | 906   | A3P250    | 15.0%       | 74    |
| Fusion                  | 212        | 694           | 906   | AFS600    | 7.0%        | 82    |
| ProASIC <sup>PLUS</sup> | 229        | 1054          | 1,283 | APA300    | 16.0%       | 67    |
| Axcelerator             | 216        | 307           | 523   | AX250     | 12.0%       | 103   |
| RTAX-S                  | 216        | 307           | 523   | RTAX250S  | 12.0%       | 87    |

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: PWM\_NUM = 6, APB\_DWIDTH = 16; DAC\_MODE1, DAC\_MODE2, and DAC\_MODE3 = 1 (DAC mode), DAC\_MODE4, DAC\_MODE5, and DAC\_MODE6 = 0 (general purpose PWM mode), FIXED\_PRESCALE\_EN = 1, FIXED\_PRESCALE = 8, SHADOW\_REG\_EN1 = 0, SHADOW\_REG\_EN2 = 0, SHADOW\_REG\_EN3 = 0, SHADOW\_REG\_EN3 = 0, SHADOW\_REG\_EN4 = 0, SHADOW\_REG\_EN5 = 0, SHADOW\_REG\_EN6 = 0,.

| Family                  |            | Tiles         |       | Utilizati | Performance |       |
|-------------------------|------------|---------------|-------|-----------|-------------|-------|
| ганну                   | Sequential | Combinatorial | Total | Device    | Total       | (MHz) |
| IGLOO/e                 | 314        | 768           | 082   | AGLE600V2 | 8.0%        | 47    |
| ProASIC3/E              | 314        | 768           | 082   | A3P250    | 18.0%       | 75    |
| Fusion                  | 314        | 768           | 1,082 | AF600     | 8.0%        | 83    |
| ProASIC <sup>PLUS</sup> | 328        | 1,043         | 1,371 | APA300    | 17.0%       | 70    |
| Axcelerator             | 319        | 483           | 802   | AX250     | 19.0%       | 103   |
| RTAX-S                  | 319        | 483           | 802   | RTAX250S  | 19.0%       | 87    |

# Table 7 · CorePWM Device Utilization and Performance (one 16-bit general purpose PWM channel and one TACH input configuration)

Note: Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: CONFIG\_MODE = 1, PWM\_NUM=3, TACH\_NUM=3,APB\_DWIDTH=16; DAC\_MODE1=0 (General Purpose PWM mode), FIXED\_PRESCALE\_EN=1, FIXED\_PRESCALE=8, FIXED\_PERIOD\_EN=0, FIXED\_PWM\_POS\_EN1=1, FIXED\_PWM\_POSEDGE1=0, FIXED\_PWM\_NEG\_EN1=0, FIXED\_PWM\_NEGEDGE1=0, SHADOW\_REG\_EN1=0, FIXED\_PWM\_POS\_EN2=1, FIXED\_PWM\_POSEDGE2=0, FIXED\_PWM\_NEG\_EN2=0, FIXED\_PWM\_NEGEDGE2=0, SHADOW\_REG\_EN2=0, FIXED\_PWM\_NEG\_ED3=1, FIXED\_PWM\_POSEDGE3=0, FIXED\_PWM\_NEG\_EN3=0, FIXED\_PWM\_NEGEDGE3=0, SHADOW\_REG\_EN3=0

# Table 8 · CorePWM Device Utilization and Performance (one TACH input cpnfiguration with 16-bit APBdata width)

| Family                  |            | Tiles         |       | Utilizati | Performance |       |
|-------------------------|------------|---------------|-------|-----------|-------------|-------|
| ranny                   | Sequential | Combinatorial | Total | Device    | Total       | (MHz) |
| IGLOO/e                 | 207        | 389           | 596   | AGLE600V2 | 4.0%        | 52    |
| ProASIC3/E              | 207        | 383           | 590   | A3P250    | 10.0%       | 89    |
| Fusion                  | 207        | 383           | 590   | AF600     | 4.0%        | 98    |
| ProASIC <sup>PLUS</sup> | 207        | 506           | 713   | APA300    | 9.0%        | 92    |
| Axcelerator             | 209        | 269           | 478   | AX250     | 5%          | 114   |
| RTAX-S                  | 209        | 269           | 478   | RTAX250S  | 11%         | 101   |

*Note:* Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics were set as follows: CONFIG\_MODE = 2, TACH\_NUM=3, APB\_DWIDTH=16.



# 1

# **Design Description**

## **Functional Blocks**

The CorePWM (pulse width modulation) macro generates up to 16 general purpose PWM signals, as shown in Figure 1-1. CorePWM includes a Register Interface block, Timebase Generation block, TACK INF block, and PWM Generation block.



Figure 1-1 · CorePWM Block Diagram

The **Register Interface** block connects to an APB bus for PWM register configuration and updating. Descriptions for all registers are given in Table 1-3 on page 15. A Shadow Register may be used so that PWM waveform updates occur only at the beginning of a PWM period. A shadow register holds all values and writes them when the SYNC\_UPDATE register is set to 1. In other words, for all channel synchronous updates, write a "1" to the SYNC\_UPDATE register after writting to all the channel registers.

The **Timebase Generation** block accepts PRESCALE and PERIOD register values and produces a PERIOD count. The number of system clocks between PERIOD counts is equal to the PRESCALE value.

The PWM Waveform Generation block has two modes:

General Purpose PWM mode takes input Period\_cnt counter values and compares them with the register values for all the PWM positive and negative edge locations. When a comparison is met, each respective output waveform is set to the correct high/low/toggle value. An example General Purpose PWM waveform configuration is demonstrated in Figure 1-3 on page 21. The example explains the relationship between the Prescale and Period register values, and how to configure the PWM waveforms with a given Prescale/Period timebase.

Low Ripple DAC mode is intended to drive a low-pass filter, typically a single-pole RC filter. Narrow pulses of constant width are spread evenly over time such that the average voltage is equal to the duty cycle. The output of the filter is then a DC voltage directly proportional to the duty cycle. This type of pulse train allows for much lower ripple at the output of the filter, and benefits from either higher bandwidth and/or smaller R and C values.

In the Tach interface module, the width of the decrementing counter is configured to 16 bits. The Tach interface module is used to measure the period of the TACHIN[x] signal by measuring between two successive positive or negative edges of TACHIN[x]. The measured value will be stored in the corresponding input's TACHPULSEDUR register. The measured value will be read by the firmware through the APB interface. The access to the control and status registers of the Tach interface module is through the APB interface. The stored value in TACHPULSEDUR will correspond to the count for half of a revolution of a four pole fan. When determining the speed for other than four pole fans, the algorithm



that converts the counter value to RPMs must be adjusted by the firmware. TACH INF supports 16- and 32-bit APB interface, but it does not support 8-bit interfaces.

To accurately measure the speed of 3-wire fans, you must turn on the fan periodically and long enough to get a complete tach measurement, often referred to as PWM pulse stretching. The PWM\_STRETCH register allows you to set the desired PWMx signals to the level specified by PWM\_STRETCH\_VALUE. The following algorithm can be used to measure the speed of 3-wire fans. This algorithm assumes that the TACHMODEy bit is set to '1' (one-shot mode):

- Software enables pulse stretching by writing a '1' to PWM\_STRETCHx, which forces PWMx to PWM\_STRETCH\_VALUEx. This requirement is not enforced by the hardware.
- Software can add a delay to ensure the fan tachometer circuitry is operational before enabling fan speed measurement.
- Software clears the TACHSTATUSy bit, enabling a one-time Tach measurement on the input signal TACHINy
  corresponding to one of the fans controlled by PWMx
- Software receives an interrupt and verifies that the Tach measurement for TACHINy has been completed (via TACHSTATUSy bit)
- Software disables pulse stretching by writing a '0' to PWM\_STRETCHx.

## I/O Signals

The port signals for the CorePWM macro are defined in Table 1-1 on page 13 and illustrated in Figure 1-2. All signals are either Input (input only) or Output (output only).



Figure 1-2 · CorePWM I/O Signal Diagram



| Name                    | Туре   | Description                                                                                                                                                                                                |  |  |
|-------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| System Signals          |        |                                                                                                                                                                                                            |  |  |
| PRESETN                 | Input  | Active low asynchronous reset                                                                                                                                                                              |  |  |
| PCLK                    | Input  | System clock – all operations and status shall be synchronous to the rising edge of this clock signal                                                                                                      |  |  |
| Microcontroller Signals |        |                                                                                                                                                                                                            |  |  |
| PSEL                    | Input  | Select line for CorePWM                                                                                                                                                                                    |  |  |
| PENABLE                 | Input  | Read output enable                                                                                                                                                                                         |  |  |
| PWRITE                  | Input  | Write enable                                                                                                                                                                                               |  |  |
| PADDR[7:0]              | Input  | Register address                                                                                                                                                                                           |  |  |
| PWDATA[APB_DWIDTH-1:0]  | Input  | Write address/data input                                                                                                                                                                                   |  |  |
| PREADY                  | Output | Ready signal, tied High                                                                                                                                                                                    |  |  |
| PSLVERR                 | Output | Transfer error signal, tied Low                                                                                                                                                                            |  |  |
| PRDATA[APB_DWIDTH-1:0]  | Output | Read data output                                                                                                                                                                                           |  |  |
| PWM Signals             |        |                                                                                                                                                                                                            |  |  |
| PWM[PWM_NUM:1]          | Output | Pulse width modulation output                                                                                                                                                                              |  |  |
| TACH Signals            |        |                                                                                                                                                                                                            |  |  |
| TACHIN[TACH_NUM -1:0]   | Input  | TACH input                                                                                                                                                                                                 |  |  |
| TACHINT                 | Output | Interrupt output for the tachometer. This signal indicates a<br>TACHSTATUS register bit has been set to one.<br>The polarity of this signal is controlled by the<br>TACHINT_ACT_LEVEL configurable option. |  |  |

### Table 1-1 · CorePWM I/O Signal Descriptions

Note: All signals active-High (logic 1) unless otherwise noted.



# Verilog/VHDL Parameters

CorePWM has parameters (Verilog) and generics (VHDL) for configuring the RTL code, described in Table 1-2. All parameters and generics are integer types.

| Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONFIG_MODE        | When 0, supports PWM only (legacy with dead banding support)<br>When 1, supports both PWM and TACH<br>When 2, supports TACH only                                                                                                                                                                                                                                                                                                                                                                                                         |
| PWM_NUM            | Number of PWM outputs from 1 to 16. This parameter is used only when CONFIG_MODE is set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| APB_DWIDTH         | PWM resolution and APB bus width from 8 to 32. This parameter must be set to either 16 or 32 when CONFIG_MODE is either 1 or 2.                                                                                                                                                                                                                                                                                                                                                                                                          |
| FIXED_PRESCALE_EN  | Fixed Prescale Enable. FIXED_PRESCALE_EN hardwires the register, disallowing APB write-access, and reducing tile count. This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                      |
| FIXED_PRESCALE     | Hardwired PRESCALE[APB_DWIDTH -1:0] register value. This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FIXED_PERIOD_EN    | Fixed Period Enable. FIXED_PERIOD_EN hardwires the register, disallowing APB write-access, and reducing tile count. This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                          |
| FIXED_PERIOD       | Hardwired PERIOD[APB_DWIDTH -1:0] register value. This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| SHADOW_REG_ENx     | Shadow Register Enable. Synchronizes all register modification changes to the beginning of the PWM cycle; that is, when PERIOD Count = 0. This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                    |
| DAC_MODE <i>x</i>  | DAC mode. 1 = Low ripple DAC mode; 0 = General purpose PWM mode.<br><i>Note:</i> x refers to each channel, from 1 to 16.<br>This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                  |
| FIXED_PWM_POS_ENx  | <ul> <li>Fixed per channel Positive Edge Enable.</li> <li>Note: x refers to each channel, from 1 to 16. FIXED_PWM_POS_ENx hardwires the register, disallowing APB write-access, and reducing tile count.</li> <li>In a typical PWM application, either the FIXED_PWM_POS_ENx or the FIXED_PWM_NEG_ENx could be set if one of those edges do not need to be software controlled with APB write-accesses. Fixing both edges would result in static output.</li> <li>This parameter is used only when CONFIG_MODE set to 0 or 1.</li> </ul> |
| FIXED_PWM_POSEDGEx | Hardwired POSEDGE[APB_DWIDTH -1:0] register value.         Note:       x refers to each channel, from 1 to 16.         This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                                                                                                       |

| Table 1-2 · CorePWM Parameters/Generics | Descriptions |
|-----------------------------------------|--------------|
|-----------------------------------------|--------------|

#### CorePWM v4.1



| Table 1-2 · CorePWM | Parameters/Generics         | Descriptions |
|---------------------|-----------------------------|--------------|
|                     | and the certain defines the | Descriptions |

|                                                   | Fixed per channel Negative Edge Enable.                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                   | Note: x refers to each channel, from 1 to 16. FIXED_PWM_NEG_ENx hardwires the register, disallowing APB write-access, and reducing tile count.                                                                                                                                                                                   |
| FIXED_PWM_NEG_EN <i>x</i><br>FIXED_DAC_OUT_ENx    | In a typical PWM application, either the FIXED_PWM_NEG_ENx or the FIXED_PWM_POS_ENx could be set if one of those edges do not need to be software-controlled with APB write-accesses. Fixing both edges would result in static output.                                                                                           |
|                                                   | For DAC applications, the FIXED_PWM_POS_ENx value is unconnected while the FIXED_DAC_OUT_ENx value would typically be disabled, as using it would result in static output.                                                                                                                                                       |
|                                                   | This parameter is used only when CONFIG_MODE set to 0 or 1.                                                                                                                                                                                                                                                                      |
| FIXED_PWM_NEGEDGE <i>x</i><br>FIXED_DAC_LEVELOUTx | Hardwired NEGEDGE[APB_DWIDTH -1:0] register value. When in DAC Mode, this parameter also fixes DACx_LEVELOUT, which is typically not fixed in DAC applications, as it would only create a static duty cycle output. Note: x refers to each channel, from 1 to 16.<br>This parameter is used only when CONFIG_MODE set to 0 or 1. |
|                                                   | Defines PWMx level when PWM_STRETCHx is set to 1.                                                                                                                                                                                                                                                                                |
| PWM_STRETCH_VALUEx                                | When 0, PWMx is set to 0 if PWM_STRETCHx is set to 1;                                                                                                                                                                                                                                                                            |
| r vvivi_51 KETCII_VALUEX                          | When 1, PWMx is set to 1 if PWM_STRETCHx is set to 1 (default).                                                                                                                                                                                                                                                                  |
|                                                   | This parameter is used only when CONFIG_MODE set to either 1 or 2.                                                                                                                                                                                                                                                               |
| TACH_NUM                                          | Number of Tachometer inputs from 1 to 16. This parameter is used only when CONFIG_MODE set to 1 or 2.                                                                                                                                                                                                                            |
| TACH_EDGEy                                        | Fixed per Tachometer input edge select. Selects the edge used to capture the counter value for the TACH[x] input signals. 0, capture counter value on falling edge of TACH[x] (default); 1, capture counter value on rising edge of TACH[x]. This parameter is used only when CONFIG_MODE set to 1 or 2.                         |
| TACHINT_ACT_LEVEL                                 | Selects active Low or active High TACHINT interrupt: 0, active Low interrupt (default); 1, active High interrupt. This parameter is used only when CONFIG_MODE set to 1 or 2.                                                                                                                                                    |

# **Register Map**

All registers are based on APB width parameter selection; default is 8 bits.

| Table 1-3 · CorePWM Register Definitions | Table 1-3 | · CorePWM | Reaister | Definitions |
|------------------------------------------|-----------|-----------|----------|-------------|
|------------------------------------------|-----------|-----------|----------|-------------|

| Register Name   | Paddr[7:0] | Description                                                                                                                                                                                                                                                    | Туре | Default |
|-----------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| PRESCALE        | 0x00       | PWM MODE: The system clock cycle is multiplied with the PRESCALE<br>value resulting in the minimum PERIOD count timebase.<br>DAC MODE: The Prescale and Period Registers could be used in<br>conjunction with the shadow register to synchronize DAC LEVELOUT. | R/W  | 0x08    |
| PERIOD          | 0x04       | PWM MODE: The PRESCALE value is multiplied with the PERIOD value yielding the PWM waveform cycle.                                                                                                                                                              | R/W  | 0x08    |
| PWM_ENABLE_0_7  | 0x08       | Bitwise channel enables for PWM/DAC channels 1 through 8.                                                                                                                                                                                                      | R/W  | 0x00    |
| PWM_ENABLE_8_15 | 0x0C       | Bitwise channel enables for PWM/DAC channels 9 through 16.                                                                                                                                                                                                     | R/W  | 0x00    |

#### Design Description



| Table 1-3 · CorePWM Register Definitions | (continued) |
|------------------------------------------|-------------|
|------------------------------------------|-------------|

| SYNC_UPDATE                   | 0xE4 | SYNC_UPDATE: When this bit is set to "1" and SHADOW_REG_EN<br>is selected, all POSEDGE and NEGEDGE registers are updated<br>synchronously. Synchronous updates to the PWM waveform occur only<br>when SHADOW_REG_EN is asserted and SYNC_UPDATE is set to<br>"1".<br>When this bit is set to "0", all the POSEDGE and NEGEDGE registers<br>are updated asynchronously. | R/W | 0x00 |
|-------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------|
| PWM1_POSEDGE                  | 0x10 | PWM MODE: Sets the positive edge of the output with respect to the<br>PERIOD resolution. When APB writes to this register, all the channels are<br>updated.                                                                                                                                                                                                            | R/W | 0x00 |
| PWM1_NEGEDGE<br>DAC1_LEVELOUT | 0x14 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM2_POSEDGE                  | 0x18 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                                                                                                                                                                                                                                                  | R/W | 0x00 |
| PWM2_NEGEDGE<br>DAC2_LEVELOUT | 0x1C | PWM MODE: Sets the negative edge of the output with respect to the PERIOD resolution. <i>DAC MODE</i> : Sets the desired output level, from 0-100%.                                                                                                                                                                                                                    | R/W | 0x00 |
| PWM3_POSEDGE                  | 0x20 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                                                                                                                                                                                                                                                  | R/W | 0x00 |
| PWM3_NEGEDGE<br>DAC3_LEVELOUT | 0x24 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM4_POSEDGE                  | 0x28 | PWM MODE: Sets the positive edge of the output with respect to the<br>PERIOD resolution.                                                                                                                                                                                                                                                                               | R/W | 0x00 |
| PWM4_NEGEDGE<br>DAC4_LEVELOUT | 0x2C | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM5_POSEDGE                  | 0x30 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                                                                                                                                                                                                                                                  | R/W | 0x00 |
| PWM5_NEGEDGE<br>DAC5_LEVELOUT | 0x34 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM6_POSEDGE                  | 0x38 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                                                                                                                                                                                                                                                  | R/W | 0x00 |
| PWM6_NEGEDGE<br>DAC6_LEVELOUT | 0x3C | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM7_POSEDGE                  | 0x40 | PWM MODE: Sets the positive edge of the output with respect to the<br>PERIOD resolution.                                                                                                                                                                                                                                                                               | R/W | 0x00 |
| PWM7_NEGEDGE<br>DAC7_LEVELOUT | 0x44 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.                                                                                                                                                                                                                              | R/W | 0x00 |
| PWM8_POSEDGE                  | 0x48 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                                                                                                                                                                                                                                                  | R/W | 0x00 |

#### CorePWM v4.1



### Table 1-3 · CorePWM Register Definitions (continued)

| PWM8_NEGEDGE<br>DAC8_LEVELOUT   | 0x4C | PWM MODE: Sets the negative edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
|---------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|------|
| DAC8_LEVELOUT                   |      | DAC MODE: Sets the desired output level, from 0-100%.                                                                                         |     |      |
| PWM9_POSEDGE                    | 0x50 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM9_NEGEDGE<br>DAC9_LEVELOUT   | 0x54 | PWM MODE: Sets the negative edge of the output with respect to the<br>PERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%. | R/W | 0x00 |
| PWM10_POSEDGE                   | 0x58 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM10_NEGEDGE<br>DAC10_LEVELOUT | 0x5C | PWM MODE: Sets the negative edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
|                                 |      | <i>DAC MODE</i> : Sets the desired output level, from 0-100%.                                                                                 |     |      |
| PWM11_POSEDGE                   | 0x60 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM11_NEGEDGE<br>DAC11_LEVELOUT | 0x64 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.     | R/W | 0x00 |
| PWM12_POSEDGE                   | 0x68 | PWM MODE: Sets the positive edge of the output with respect to the<br>PERIOD resolution.                                                      | R/W | 0x00 |
| PWM12_NEGEDGE<br>DAC12_LEVELOUT | 0x6C | PWM MODE: Sets the negative edge of the output with respect to the<br>PERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%. | R/W | 0x00 |
|                                 |      | PWM MODE: Sets the desired output level, non-100%.                                                                                            |     |      |
| PWM13_POSEDGE                   | 0x70 | PERIOD resolution.                                                                                                                            | R/W | 0x00 |
| PWM13_NEGEDGE<br>DAC13_LEVELOUT | 0x74 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.     | R/W | 0x00 |
| PWM14_POSEDGE                   | 0x78 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM14_NEGEDGE<br>DAC14_LEVELOUT | 0x7C | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.     | R/W | 0x00 |
| PWM15_POSEDGE                   | 0x80 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM15_NEGEDGE<br>DAC15_LEVELOUT | 0x84 | PWM MODE: Sets the negative edge of the output with respect to thePERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%.     | R/W | 0x00 |
| PWM16_POSEDGE                   | 0x88 | PWM MODE: Sets the positive edge of the output with respect to the PERIOD resolution.                                                         | R/W | 0x00 |
| PWM16_NEGEDGE<br>DAC16_LEVELOUT | 0x8C | PWM MODE: Sets the negative edge of the output with respect to the<br>PERIOD resolution.DAC MODE: Sets the desired output level, from 0-100%. | R/W | 0x00 |



Design Description

| Table 1-3 · CorePWM Register Definitions ( | (continued) |
|--------------------------------------------|-------------|
|--------------------------------------------|-------------|

| PWM_STRETCH    | 0x90 | When 0, the state of PWMx is determined by PWMx_POSEDGE/<br>NEGEDGE register settings.                                                                                                                                                                                                                                                                                                     | R/W       | 0x0000 |
|----------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------|
| TACHPRESCALE   | 0x94 | When 1, PWMx is set to PWM_STRETCH_VALUEx.Clock prescale setting. Determines effective clock rate for the counter<br>based on PCLK:0000 = divide by 1 (default)0001 = divide by 20010 = divide by 40011 = divide by 80100 = divide by 160101 = divide by 320110 = divide by 640111 = divide by 2561001 = divide by 5121010 = divide by 1,0241011 = divide by 2,048Others = divide by 2,048 | R/W       | 0x0    |
| TACHSTATUS     | 0x98 | TACH status register which contains one bit per TACH input, indicating whether the respective TACHPULSEDUR register has been updated at least once since the bit was cleared. The bits in this register gets cleared by writing "1", "0" does not have any effect.                                                                                                                         | R/<br>W1C | 0x0000 |
| TACHIRQMASK    | 0x9C | TACH interrupt mask register with one bit per tachometer signal,<br>indicating whether CorePWM needs to assert an interrupt if the respective<br>bit in TACHSTATUS register is asserted.                                                                                                                                                                                                   | R/W       | 0x0000 |
| TACHMODE       | 0xA0 | TACH Mode. Sets the measurement mode used for each TACH input.<br>When 0: TACH input is continuously measured and stored in the<br>respective TACHPULSEDUR register .<br>When 1: A one-time measurement is performed only if the respective bit<br>in TACHSTATUS register is cleared.                                                                                                      | R/W       | 0x0000 |
| TACHPULSEDUR_0 | 0xA4 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[0]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.                                                                                                                                     | R         | 0x0000 |
| TACHPULSEDUR_1 | 0xA8 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[1]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.                                                                                                                                     | R         | 0x0000 |
| TACHPULSEDUR_2 | 0xAC | Sstores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[2]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.                                                                                                                                    | R         | 0x0000 |

#### CorePWM v4.1



### Table 1-3 · CorePWM Register Definitions (continued)

| TACHPULSEDUR_3  | 0xB0 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[3]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
|-----------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|
| TACHPULSEDUR_4  | 0xB4 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[4]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_5  | 0xB8 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[5]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_6  | 0xBC | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[6]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_7  | 0xC0 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[7]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_8  | 0xC4 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[8]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_9  | 0xC8 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[9]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead.  | R | 0x0000 |
| TACHPULSEDUR_10 | 0xCC | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[10]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |
| TACHPULSEDUR_11 | 0xD0 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[11]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |
| TACHPULSEDUR_12 | 0xD4 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[12]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |
| TACHPULSEDUR_13 | 0xD8 | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[13]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |
| TACHPULSEDUR_14 | 0xDC | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[14]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |



#### Design Description

### Table 1-3 · CorePWM Register Definitions (continued)

| TACHPULSEDUR_15 |  | Stores the number of timer ticks between two successive positive (or negative) edges from the TACHIN[15]. The edge to be used is configurable. If the number of timer ticks exceeds the maximum register value, the value of 0 shall be stored instead. | R | 0x0000 |
|-----------------|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|
|-----------------|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|

*Note: Od* = *decimal*; *Ox* = *hexidecimal*; *Ob* = *binary*.

CorePWM v4.1

## **Configuration Example**

Figure 1-3 demonstrates how several register configurations affect General Purpose and Low Ripple DAC PWM output waveform generation.



Figure 1-3 · CorePWM Waveform Generation Example

Figure 1-4 to Figure 1-7 on page 23 demonstrate how to avoid overlapping of the dead banding issue using the register configurations of channel 1 and channel 2 as a pair. Both channel 1(PWM1) and channel 2(PWM2) are updated after writing a "1" to the SYNC\_UPDATE configuration register to avoid overlapping of dead band space.



Figure 1-4 · Dead Band Space Example



Figure 1-5 · Center-Aligned PWM Waveform Example









Figure 1-7 · Tach Measurement



Design Description

## **APB** Interface Timing

Figure 1-8 and Figure 1-9 depict typical write cycle and read cycle timing relationships relative to the system clock.

| PCLK _  |                     |
|---------|---------------------|
| PSEL    |                     |
| PWRITE  |                     |
| PENABLE |                     |
| PADDR   | Register Address    |
| PWDATA  | Register Write Data |





Figure 1-9 · Data Read Cycle



CorePWM is licensed in two ways. Depending on your license, tool flow functionality may be limited.

#### **Obfuscated**

Complete RTL code is provided for the core, allowing the core to be instantiated with SmartDesign. Simulation, Synthesis, and Layout can be performed within Libero IDE. The RTL code for the core is obfuscated<sup>1</sup> and some of the testbench source files are not provided. Instead, they are precompiled into the compiled simulation library.

### RTL

Complete RTL source code is provided for the core and testbenches.

## SmartDesign

The core can be configured using the configuration GUI within SmartDesign. An example of configuring one channel for PWM mode operation is shown in Figure 2-1 on page 26. Note the following in this example:

- Number of PWM Channels is 1.
- APB bit width and corresponding PWM resolution is 8 bits.
- The Prescale value (the number of clock ticks between Period ticks) is selected to be Fixed at 64, reducing the tile count, as no registers are used.
- The Period value is not Fixed and hence software-controlled.
- The Shadow Update Register is enabled, allowing for synchronized PWM updates at the beginning of the Period count.
- The Positive edge of the PWM is not Fixed and hence software-controlled.
- The Negative edge of the PWM waveform is Fixed at Period count 0.
- The User Testbench is selected to be generated.

<sup>1.</sup> Obfuscated means formatting and comments have been removed from the RTL source files, and all instance and net names have been replaced with random character sequences.

| -Global Configura | tion:                  |               |                          |   |  |
|-------------------|------------------------|---------------|--------------------------|---|--|
|                   | Configuration Mode:    |               | 0 - PWM Only Mode        | ~ |  |
|                   | Number of PWM C        | hannels:      | 1                        | ~ |  |
|                   | Hambor of FWH C        |               | •                        |   |  |
|                   | APB Data Bus Wid       | lth / Resolut | tion: 8                  | ~ |  |
| Global PWM Mod    | e Configuration:       |               |                          |   |  |
|                   | xed Prescale: 🔽        |               | Fixed Value: 64          |   |  |
|                   | xeu Prescale: 💌        |               | Fixed value: 04          |   |  |
| Fi                | xed Period: 📃          |               | Fixed Value: 1           |   |  |
| Channel 1 Config  | guration:              |               |                          |   |  |
| Low Ripple D      | AC mode:               |               | Shadow Update Register:  |   |  |
|                   |                        |               |                          |   |  |
| Fixed PWM F       | PosEdge:               |               | Fixed PWM PosEdge Value: | 0 |  |
| Fixed PWM (       | NegEdge / DAC LevelOut | . 🗹           | Fixed PWM NegEdge Value: | 0 |  |
|                   |                        |               |                          |   |  |

Figure 2-1 · CorePWM Configuration within SmartDesign – PWM Mode

An example of configuring one Channel for low ripple DAC operation is shown in Figure 2-2 on page 27. Note the following in this example:

- Number of PWM Channels is 1.
- APB bit width and corresponding PWM/DAC resolution is 8 bits.
- The Prescale and Period Values can be used in conjunction with the Shadow Update Register to update DAC1\_LEVELOUT values at a given period. For example, 3 DACs could be updated simultaneously based on the Prescale and Period values if the Shadow Update Register is enabled. In this example, the DAC1\_LEVELOUT value is updated whenever the APB bus updates the DAC1\_LEVELOUT register.
- The DAC LevelOut value is not Fixed and hence software-controlled. Note the DAC1\_LEVELOUT value is synonymous with a Duty Cycle value; i.e., an 8-bit DAC1\_LEVELOUT hex value of 7F is equal to an average duty cycle of 50% and will yield half of the full analog value after RC filtering.
- Note the "Fixed PWM PosEdge" value does not apply to DAC mode channel.
- The User Testbench is selected to be generated.

| Configuring c | orepwm_0                  |                   |                       |    |           |
|---------------|---------------------------|-------------------|-----------------------|----|-----------|
| Configuration |                           |                   |                       |    | <u>^</u>  |
| -Global Cont  | iguration:                |                   |                       |    | =         |
|               | Configuration Mode:       |                   | 0 - PWM Only Mode     | ~  |           |
|               | Number of PWM             | Channels:         | 1                     | ~  |           |
|               | APB Data Bus Wi           | dth / Resolution: | 8                     | ~  |           |
| Global PWN    | 1 Mode Configuration:     |                   |                       |    |           |
|               | Fixed Prescale: 📃         | F                 | Fixed Value: 0        |    |           |
|               | Fixed Period:             | F                 | ixed Value: 1         |    |           |
| Channel 1     | Configuration:            |                   |                       |    |           |
| Low Ri        | pple DAC mode:            | 🗹 Sh              | adow Update Register: |    |           |
| Fixed F       | PWM PosEdge:              | Fib               | ed PWM PosEdge Value: | 0  |           |
| Fixed F       | PWM NegEdge / DAC LevelOu |                   | ed PWM NegEdge Value: | 0  | ✓         |
| <             |                           |                   |                       |    | >         |
|               |                           |                   |                       | ОК | Cancel .: |

Figure 2-2 · CorePWM Configuration within SmartDesign – DAC Mode

## Importing into Libero IDE

CorePWM is available for download to the SmartDesign IP Catalog, via the Libero IDE web repository. For information on using SmartDesign to instantiate, configure, connect, and generate cores, refer to the Libero IDE online help.

## **Simulation Flows**

To run simulations, select the user testbench within the SmartDesign CorePWM configuration GUI, right-click, and select **Generate Design**. When SmartDesign generates the design files, it will install the appropriate testbench files. Set the design root to the CorePWM instantiation in the Libero IDE design hierarchy pane, and click the **Simulation** icon in the Libero IDE Design Flow window. This will invoke ModelSim® and automatically run simulation.

A simplified block diagram of the User Testbench is shown in Figure 2-3. The user testbench instantiates the CorePWM macro and provides a Register Write Stimulus process, Register Read process, and a PWM output duty cycle check process.



Figure 2-3 · CorePWM Verification Testbench

## Synthesis in the Libero IDE

Having set the design route appropriately, click the **Synthesis** icon in Libero IDE. The Synthesis window appears, displaying the Synplicity<sup>®</sup> project. Set Synplicity to use the Verilog 2001 standard if Verilog is being used. To run Synthesis, select the **Run** icon.

## Place-and-Route in Libero IDE

Having set the design route appropriately and run Synthesis, click on the Layout icon in Libero IDE to invoke Designer. CorePWM requires no special place-and-route settings.



# **Example Applications**

For General Purpose PWM applications, a duty cycle calculator is available online to assist in calculating the PWM POSEDGE and NEGEDGE register values, given a requested duty cycle. This is provided on the Actel website as a downloadable Excel spreadsheet:

http://www.actel.com/documents/duty\_cycle\_calc.zip

For DAC applications, a low ripple DAC calculator is also available online:

http://www.actel.com/documents/low\_ripple\_dac\_calc.zip

## **General Purpose PWM Application – Temperature Monitor**

A typical temperature monitor application using CorePWM is shown in Figure 3-1. In this example, fan speed is controlled by fluctuations in the NTC thermistor's resistive value. As shown, changes in the input voltage to the voltage monitor port will be converted to a digital value via the ADC and forwarded to an on-chip microcontroller (such as Core8051s). The microcontroller algorithm will periodically configure/reconfigure CorePWM registers based on the thermistor value and/or the fan's tachometer value.



Figure 3-1 · Temperature/Voltage Monitor Application Using CorePWM in a Fusion Device

DAC

A typical DAC application using CorePWM is shown in Figure 3-2 on page 30. In this example, PWM output is averaged to a varying DC voltage. At reset, the PWM duty cycle, or level out value, is 100% and the voltage increases to the rail of 12 volts. The PWM duty cycle / level out value changes to 75% and then 50%, and the output of the RC filter follows this by dropping to 8 volts and then 6 volts. The generated ripple voltage is a function of the RC circuit values, the APB system clock period, and the PWM duty cycle.



As shown, a field-effect transistor (FET) is used to increase and decouple the output voltage/current from the Fusion device. The load is monitored and changes to the PWM output are processed via a microcontroller (Core8051s, CoreABC, etc.).



In Low-Ripple DAC mode, pulse width is effectively reduced to 1 clock cycle period, significantly reducing the ripple at the output of a low pass filter.

Figure 3-2 · DAC Application Using CorePWM in Fusion Device



The FET, in this case, is used to illustrate the ability to extend the DAC's output to 12 V. For most applications, 3.3 V is sufficient. Higher clock speeds (and therefore lower ripple) can be achieved by driving the RC filter with a general purpose TTL output.

Using Low Ripple DAC mode has the added benefit of requiring a smaller time constant for the filter, which allows for smaller R and C components to be used. A Low Ripple DAC calculator is available to assist in determining the ideal values for R and C.



Drivers for CorePWM are available via the Firmware Catalog tool provided with Libero IDE. For more information on the Firmware Catalog, refer to www.actel.com/products/software/firmwarecat/default.aspx.



# **List of Document Changes**

The following table lists critical changes that were made in the current version of the document.

| Previous<br>Version | Changes in Current Version (5020113-1)                                                 | Page          |
|---------------------|----------------------------------------------------------------------------------------|---------------|
| 5020113-1           | Updated core version to v4.1.                                                          | N/A           |
| 5020113-0           | Updated "Utilization and Performance" tables.                                          | 6–9           |
|                     | Added low-cost TACHOMETER solution with up to 16 digital inputs.                       | N/A           |
|                     | Added center-aligned PWM support.                                                      | 22            |
|                     | Updated tool flow to support Libero IDE v8.5 and SmartDesign.                          | 25            |
|                     | Updated Figure 1-3, Figure 1-5, and Figure 1-6 in the "Configuration Example" section. | 21,<br>22, 23 |
|                     | Updated Figure 3-2.                                                                    | 30            |
|                     | Updated the "Software Driver" section.                                                 | 33            |

# **Product Support**

Actel

Actel backs its products with various support services including Customer Service, a Customer Technical Support Center, a web site, an FTP site, electronic mail, and worldwide sales offices. This appendix contains information about contacting Actel and using these support services.

## **Customer Service**

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

From Northeast and North Central U.S.A., call **650.318.4480** From Southeast and Southwest U.S.A., call **650.318.4480** From South Central U.S.A., call **650.318.4434** From Northwest U.S.A., call **650.318.4434** From Canada, call **650.318.4480** From Europe, call **650.318.4252** or +44 (0) 1276 401 500 From Japan, call **650.318.4743** From the rest of the world, call **650.318.4743** Fax, from anywhere in the world **650.318.8044** 

## Actel Customer Technical Support Center

Actel staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions. The Customer Technical Support Center spends a great deal of time creating application notes and answers to FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

## **Actel Technical Support**

Visit the Actel Customer Support website (www.actel.com/custsup/search.html) for more information and support. Many answers available on the searchable web resource include diagrams, illustrations, and links to other resources on the Actel web site.

## Website

You can browse a variety of technical and non-technical information on Actel's home page, at www.actel.com.

# **Contacting the Customer Technical Support Center**

Highly skilled engineers staff the Technical Support Center from 7:00 A.M. to 6:00 P.M., Pacific Time, Monday through Friday. Several ways of contacting the Center follow:

#### Email

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is tech@actel.com.

#### **Product Support**



#### Phone

Our Technical Support Center answers all calls. The center retrieves information, such as your name, company name, phone number and your question, and then issues a case number. The Center then forwards the information to a queue where the first available application engineer receives the data and returns your call. The phone hours are from 7:00 A.M. to 6:00 P.M., Pacific Time, Monday through Friday. The Technical Support numbers are:

#### 650.318.4460 800.262.1060

Customers needing assistance outside the US time zones can either contact technical support via email (tech@actel.com) or contact a local sales office. Sales office listings can be found at www.actel.com/contact/offices/index.html.

# POWER MATTERS

# Index

## Α

Actel electronic mail 37 telephone 38 web-based technical support 37 website 37 APB interface timing 24 applications 29

## С

configuration examples 21 contacting Actel customer service 37 electronic mail 37 telephone 38 web-based technical support 37 CorePWM key features 5 version 6 customer service 37

## D

DAC 29

## Ε

example 1 channel for low ripple DAC 26 DAC application 30 temperature monitor 29

## F

functional blocks 11

## I

importing into Libero IDE 27

#### Μ

modes General Purpose PWM 11 Low Ripple DAC 11

## 0

overview 5

### Ρ

parameters, Verilog and VHDL 14 place-and-route 28 port signals 12 product support 37–38 customer service 37 electronic mail 37 technical support 37 telephone 38 website 37

## R

register map 15

## S

simulation 27 simulation flows 27 SmartDesign 25 software driver 33 supported interfaces 6 synthesis 28

## Т

technical support 37 tool flows 25 importing into Libero IDE 27 simulation 27 SmartDesign 25

## U

utilization and performance 6

## W

web-based technical support 37



# Actel is the leader in low-power and mixed-signal FPGAs and offers the most comprehensive portfolio of system and power management solutions. Power Matters. Learn more at www.actel.com.

Actel Corporation • 2061 Stierlin Court • Mountain View, CA 94043 • USA Phone 650.318.4200 • Fax 650.318.4600 • Customer Service: 650.318.1010 • Customer Applications Center: 800.262.1060 Actel Europe Ltd. • River Court, Meadows Business Park • Station Approach, Blackwater • Camberley Surrey GU17 9AB • United Kingdom Phone +44 (0) 1276 609 300 • Fax +44 (0) 1276 607 540 Actel Japan • EXOS Ebisu Building 4F • 1-24-14 Ebisu Shibuya-ku • Tokyo 150 • Japan Phone +81.03.3445.7671 • Fax +81.03.3445.7668 • http://jp.actel.com Actel Hong Kong • Room 2107, China Resources Building • 26 Harbour Road • Wanchai • Hong Kong Phone +852 2185 6460 • Fax +852 2185 6488 • www.actel.com.cn

50200113-2/2.10