section 30. power supply pwm - microchip...

56
' 2007 Microchip Technology Inc. DS70270B-page 30-1 Power Supply PWM 30 Section 30. Power Supply PWM HIGHLIGHTS This section of the manual contains the following major topics: 30.1 Introduction .................................................................................................................. 30-2 30.2 Features Overview....................................................................................................... 30-3 30.3 Module Description ...................................................................................................... 30-5 30.4 Control Registers ......................................................................................................... 30-6 30.5 Module Functionality .................................................................................................. 30-20 30.6 Clock Sources ............................................................................................................ 30-25 30.7 Primary PWM Time Base ........................................................................................... 30-26 30.8 Individual PWM Time Base(s) .................................................................................... 30-27 30.9 PWM Period ............................................................................................................... 30-28 30.10 PWM Frequency and Duty Cycle Resolution ............................................................. 30-28 30.11 PWM Duty Cycle Comparison Units .......................................................................... 30-29 30.12 Complementary PWM Outputs .................................................................................. 30-29 30.13 Independent PWM Outputs........................................................................................ 30-30 30.14 Duty Cycle Limits ....................................................................................................... 30-30 30.15 Dead-Time Generation............................................................................................... 30-30 30.16 Configuring a PWM Channel ..................................................................................... 30-33 30.17 Speed Limits of PWM Output Circuitry ...................................................................... 30-34 30.18 PWM Special Event Trigger ....................................................................................... 30-34 30.19 Individual PWM Triggers ............................................................................................ 30-35 30.20 PWM Interrupts .......................................................................................................... 30-35 30.21 PWM Time Base Interrupts ........................................................................................ 30-36 30.22 PWM Fault and Current-Limit Pins ............................................................................ 30-36 30.23 Leading Edge Blanking .............................................................................................. 30-36 30.24 PWM Fault Pins ......................................................................................................... 30-37 30.25 PWM Current-Limit Pins ............................................................................................ 30-40 30.26 Simultaneous PWM Faults and Current Limits .......................................................... 30-41 30.27 PWM Fault and Current-Limit Trigger Outputs to ADC .............................................. 30-41 30.28 PWM Output Override Priority ................................................................................... 30-41 30.29 Fault and Current-Limit Override Issues with Dead-Time Logic ................................ 30-42 30.30 Asserting Outputs via Current Limit ........................................................................... 30-42 30.31 PWM Immediate Update ............................................................................................ 30-42 30.32 PWM Output Override................................................................................................ 30-42 30.33 Functional Exceptions ................................................................................................ 30-43 30.34 Register Bit Alignment ............................................................................................... 30-43 30.35 Application Examples................................................................................................. 30-44 30.36 Methods to Reduce EMI ............................................................................................ 30-50 30.37 External Synchronization Features ............................................................................ 30-51 30.38 CPU Load Staggering ................................................................................................ 30-51 30.39 External Trigger Blanking........................................................................................... 30-52 30.40 Related Application Notes.......................................................................................... 30-55 30.41 Revision History ......................................................................................................... 30-56

Upload: others

Post on 16-Apr-2020

1 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWM

Power SupplyPW

M

30

HIGHLIGHTSThis section of the manual contains the following major topics:

30.1 Introduction .................................................................................................................. 30-230.2 Features Overview....................................................................................................... 30-330.3 Module Description ...................................................................................................... 30-530.4 Control Registers ......................................................................................................... 30-630.5 Module Functionality .................................................................................................. 30-2030.6 Clock Sources............................................................................................................ 30-2530.7 Primary PWM Time Base........................................................................................... 30-2630.8 Individual PWM Time Base(s).................................................................................... 30-2730.9 PWM Period............................................................................................................... 30-2830.10 PWM Frequency and Duty Cycle Resolution............................................................. 30-2830.11 PWM Duty Cycle Comparison Units .......................................................................... 30-2930.12 Complementary PWM Outputs .................................................................................. 30-2930.13 Independent PWM Outputs........................................................................................ 30-3030.14 Duty Cycle Limits ....................................................................................................... 30-3030.15 Dead-Time Generation............................................................................................... 30-3030.16 Configuring a PWM Channel ..................................................................................... 30-3330.17 Speed Limits of PWM Output Circuitry ...................................................................... 30-3430.18 PWM Special Event Trigger ....................................................................................... 30-3430.19 Individual PWM Triggers ............................................................................................ 30-3530.20 PWM Interrupts .......................................................................................................... 30-3530.21 PWM Time Base Interrupts ........................................................................................ 30-3630.22 PWM Fault and Current-Limit Pins ............................................................................ 30-3630.23 Leading Edge Blanking .............................................................................................. 30-3630.24 PWM Fault Pins ......................................................................................................... 30-3730.25 PWM Current-Limit Pins ............................................................................................ 30-4030.26 Simultaneous PWM Faults and Current Limits .......................................................... 30-4130.27 PWM Fault and Current-Limit Trigger Outputs to ADC.............................................. 30-4130.28 PWM Output Override Priority ................................................................................... 30-4130.29 Fault and Current-Limit Override Issues with Dead-Time Logic ................................ 30-4230.30 Asserting Outputs via Current Limit ........................................................................... 30-4230.31 PWM Immediate Update............................................................................................ 30-4230.32 PWM Output Override................................................................................................ 30-4230.33 Functional Exceptions................................................................................................ 30-4330.34 Register Bit Alignment ............................................................................................... 30-4330.35 Application Examples................................................................................................. 30-4430.36 Methods to Reduce EMI ............................................................................................ 30-5030.37 External Synchronization Features ............................................................................ 30-5130.38 CPU Load Staggering ................................................................................................ 30-5130.39 External Trigger Blanking........................................................................................... 30-5230.40 Related Application Notes.......................................................................................... 30-5530.41 Revision History ......................................................................................................... 30-56

© 2007 Microchip Technology Inc. DS70270B-page 30-1

Page 2: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.1 INTRODUCTIONThe Power Supply PWM module in the dsPIC30F Switch Mode Power Supply (SMPS) andDigital Power Conversion device family supports a wide variety of PWM modes and outputformats. The Power Supply PWM module is ideal for power conversion applications such as thefollowing:

� AC to DC Converters� DC to DC Converters� Power Factor Correction� Uninterruptible Power Supply (UPS)� Inverters� Battery Chargers� Digital Lighting

DS70270B-page 30-2 © 2007 Microchip Technology Inc.

Page 3: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.2 FEATURES OVERVIEWThe Power Supply PWM Module has the following features:

� 2 to 4 PWM generators with 4 to 8 I/O� 2 to 4 independent time bases� Duty Cycle resolution of 1.1 ns at 30 MIPS� Dead-Time resolution of 4.2 ns at 30 MIPS� Phase Shift resolution of 4.2 ns at 30 MIPS� Frequency resolution of 8.4 ns at 30 MIPS� Supported PWM modes:

- Standard Edge-Aligned PWM- Complementary PWM Output- Push-Pull PWM- Multi-Phase PWM- Variable Phase PWM- Constant Off-time PWM- Current Reset PWM- Current-Limit PWM- Independent Time Base PWM

� On-the-fly changes to:- PWM frequency- PWM duty cycle- PWM phase shift

� Output override control� Independent Current-Limit and Fault inputs� Special Event Comparator for scheduling other peripheral events� Comparator for each PWM generator for triggering ADC conversions

Figure 30-1 shows a simple block diagram representation of the PWM module. Figure 30-2illustrates how the module hardware is partitioned for each PWM output pair for theComplementary PWM Output mode. Each functional unit of the PWM module is discussed insubsequent sections.

The Power Supply PWM Module contains up to four PWM generators and has up to eight outputpins. For complementary outputs, the eight I/O pins are grouped into High/Low (H/L) pairs.

� PWM1H� PWM1L� PWM2H� PWM2L� PWM3H� PWM3L� PWM4H� PWM4L

© 2007 Microchip Technology Inc. DS70270B-page 30-3

Page 4: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Figure 30-1: Simplified Conceptual Block Diagram of the Power Supply PWM

MUX

Latch

Comparator

Timer

PDC2

Phase

MUX

Latch

Comparator

Timer

PDC3

Phase

MUX

Latch

Comparator

Timer

PDC4

Phase

MUX

Latch

Comparator

Timer

PDC1

PWMCONx

LEBCONx

Channel 1 Dead-time Generator

PTCON

SEVTCMP

Comparator Special Event

IOCONx

PWM enable and mode control

Channel 3 Dead-Time Generator

Channel 4 Dead-Time Generator

ALTDTRx, DTRx Dead-Time Control

Special EventPostscaler

SFLTX

PWM3LPWM3H

PWM2L

PWM2H

16-b

it D

ata

Bus

PWM1LPWM1H

FCLCONx

Pin and mode control

MDC

ADC Trigger Control

Master Duty Cycle Register

Fault mode and pin control

Pin override control

Special event

PTPER

Timer Period

PWM GEN #1

PWM GEN #2

PWM GEN #4

PTMR

Master Time Base

Phase

PWM GEN #3

Channel 2 Dead-Time Generator

PWM4LPWM4H

PWM

Use

r, C

urre

nt L

imit

and

Faul

t Ove

rrid

e an

d R

outin

g Lo

gic

Faul

t CLM

T O

verr

ide

Logi

c

Trigger

comparison value

IFLTX

Fault Control Logic

TRGCONx

Control for blanking external input signals

External Time Base Synchronization

SYNCOSYNCI

DS70270B-page 30-4 © 2007 Microchip Technology Inc.

Page 5: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Figure 30-2: Partitioned Output Pair, Complementary PWM Output Mode

30.3 MODULE DESCRIPTIONThe Power Supply PWM Module is designed for applications that require the following:� High duty cycle resolution at high PWM frequencies� The ability to drive standard Push-Pull or Half-Bridge converters� The ability to create multi-phase PWM outputs

Push-Pull and Half-Bridge converters are two common, medium-power topologies that requirethe PWM signal to be switched between alternate pins, as provided by the Push-Pull PWM mode.

Phase-Shifted PWM describes the situation where each PWM generator provides outputs, butthe phase relationship between the generator outputs is specifiable and changeable.

Multi-Phase PWM is often used to improve DC-DC converter load transient response and reducethe size of output filter capacitors and inductors. Multiple DC-DC converters are often operatedin parallel but phase shifted in time. A single PWM output operating at 250 kHz has a period of4 μs. But an array of four PWM channels, staggered by 1 μs each, yields an effective switchingfrequency of 1 MHz. Multi-phase PWM applications typically use a fixed-phase relationship.

Variable Phase PWM is useful in Zero Voltage Transition (ZVT) power converters. Here the PWMduty cycle is always 50 percent, and the power flow is controlled by varying the relative phaseshift between the two PWM generators.

PWM Duty Cycle Register

Duty Cycle Comparator

Fault Override Values

Channel override values

Fault Pin Assignment LogicFault Pin

PWMXH

PWMXL

TMR < PDC PWM

Override Logic

Dead-

Time

Logic

Fault Active

Phase Offset

MUX

MUX

Timer/Counter

Note: The phase-lock loop (PLL) must be enabled for the Power Supply PWM module tofunction. This is achieved by setting the FNOSC<1:0> bits in the FOSCSELconfiguration register.

© 2007 Microchip Technology Inc. DS70270B-page 30-5

Page 6: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.4 CONTROL REGISTERSThe following registers control the operation of the Power Supply PWM module:

� PTCON: PWM Time Base Control Register

This register is used to turn the PWM module on or off, to configure the Special Event Triggerand to specify synchronization settings.

� PTPER: Primary Time Base Register

The PWM time base value is written into this register, which determines the PWM operatingfrequency.

� SEVTCMP: PWM Special Event Compare Register

This register contains the compare value to which the Special Event Trigger is generated.

� MDC: PWM Master Duty Cycle Register

This register provides the duty-cycle value when a PWM generator is configured to use themaster duty cycle.

� PWMCONx: PWM Control Register

This register controls the fault and current-limit interrupts, and also the dead-time, duty cycleand time base modes.

� PDCx: PWM Generator Duty Cycle Register

The value in this register provides the duty cycle value for the PWMx outputs when the masterduty cycle is not selected.

� PHASEx: PWM Phase-Shift Register

The value in this register provides the phase shift for the PWMx outputs. When IndependentTime Base PWM mode is selected, the PWMx period value is provided.

� DTRx: PWM Dead-Time Register

The value in this register provides the dead time for the PWMxH output if positive dead time isselected and PWMxL output if negative dead time is selected.

� ALTDTRx: PWM Alternate Dead-Time Register

The value in this register provides the dead time for the PWMxL output if positive dead time isselected and PWMxH output if negative dead time is selected.

� TRGCONx: PWM Trigger Control Register

This register provides the PWMx trigger postscaler and also the number of PWM cycles to skipbefore generating the first trigger.

� IOCONx: PWM I/O Control Register

This register controls the PWM outputs, the PWM mode and PWM output override options.

� FCLCONx: PWM Fault Current-Limit Control Register

This register configures the fault and current-limit features.

� TRIGx: PWM Trigger Compare Value Register

This register contains the compare value for generating the PWMx trigger. This value iscompared with the selected PWMx time base.

� LEBCONx: Leading Edge Blanking Control Register

This register controls the leading edge blanking feature of the PWM module.

DS70270B-page 30-6 © 2007 Microchip Technology Inc.

Page 7: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-1: PTCON: PWM Time Base Control RegisterUpper Byte:

R/W-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0PTEN � PTSIDL SESTAT SEIEN EIPU SYNCPOL SYNCOEN

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

SYNCEN SYNCSRC<2:0> SEVTPS<3:0>bit 7 bit 0

bit 15 PTEN: PWM Module Enable bit1 = PWM module is enabled0 = PWM module is disabled

bit 14 Unimplemented: Read as �0� bit 13 PTSIDL: PWM Time Base Stop in Idle Mode bit

1 = PWM time base halts in CPU Idle mode0 = PWM time base runs in CPU Idle mode

bit 12 SESTAT: Special Event Interrupt Status bit1 = Special Event Interrupt is pending0 = Special Event Interrupt is not pending

bit 11 SEIEN: Special Event Interrupt Enable bit1 = Special Event Interrupt is enabled0 = Special Event Interrupt is disabled

bit 10 EIPU: Enable Immediate Period Updates bit1 = Active Period register is updated immediately0 = Active Period register updates occur on PWM cycle boundaries

bit 9 SYNCPOL: Synchronize Input Polarity bit1 = SYNCIN polarity is inverted (active-low)0 = SYNCIN is active-high

bit 8 SYNCOEN: Primary Time Base Sync Enable bit1 = SYNCO output is enabled0 = SYNCO output is disabled

bit 7 SYNCEN: External Time Base Synchronization Enable bit1 = External synchronization of primary time base is enabled0 = External synchronization of primary time base is disabled

bit 6-4 SYNCSRC<2:0>: Sync Source Selection bits000 = SYNCI001 = Reserved

���

111 = Reservedbit 3-0 SEVTPS<3:0>: PWM Special Event Trigger Output Postscale Select bits

0000 = 1:1 Postscale0001 = 1:2 Postscale

���

1111 = 1:16 Postscale

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-7

Page 8: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-2: PTPER: Primary Time Base Register

Register 30-3: SEVTCMP: PWM Special Event Compare Register

Upper Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

PTPER <15:8>bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0 U-0

PTPER <7:3> � � �bit 7 bit 0

bit 15-3 PTPER<15:3>: Primary Time Base (PTMR) Period Value bitsbit 2-0 Unimplemented: Read as �0�

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

Upper Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

SEVTCMP <15:8>bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0 U-0

SEVTCMP <7:3> � � �bit 7 bit 0

bit 15-3 SEVTCMP<15:3>: Special Event Compare Count Value bitsbit 2-0 Unimplemented: Read as �0�

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

DS70270B-page 30-8 © 2007 Microchip Technology Inc.

Page 9: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-4: MDC: PWM Master Duty Cycle RegisterUpper Byte:

R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0MDC<15:8>

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

MDC<7:0>bit 7 bit 0

bit 15-0 MDC<15:0>: Master PWM Duty Cycle Value bits(1)

Note 1: The minimum value for this register is 0x0008 and the maximum value is 0xFFEF.

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-9

Page 10: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-5: PWMCONx: PWM Control RegisterUpper Byte:HS/HC-0 HS/HC-0 HS/HC-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0FLTSTAT CLSTAT TRGSTAT FLTIEN CLIEN TRGIEN ITB MDCS

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 U-0 U-0 U-0 U-0 R/W-0 R/W-0

DTC<1:0> � � � � XPRES IUEbit 7 bit 0

bit 15 FLTSTAT: Fault Interrupt Status1 = Fault Interrupt is pending0 = No Fault Interrupt is pendingThis bit is cleared by setting FLTIEN = 0.

Note: Software must clear the interrupt status here, and clear the corresponding IFS bit in the InterruptController.

bit 14 CLSTAT: Current-Limit Interrupt Status bit1 = Current-limit interrupt is pending0 = No current-limit interrupt is pendingThis bit is cleared by setting CLIEN = 0.

Note: Software must clear the interrupt status here, and clear the corresponding IFS bit in the InterruptController.

bit 13 TRGSTAT: Trigger Interrupt Status bit1 = Trigger interrupt is pending0 = No trigger interrupt is pendingThis bit is cleared by setting TRGIEN = 0.

bit 12 FLTIEN: Fault Interrupt Enable bit1 = Fault interrupt enabled0 = Fault interrupt disabled and FLTSTAT bit is cleared

bit 11 CLIEN: Current-Limit Interrupt Enable bit1 = Current-limit interrupt enabled0 = Current-limit interrupt disabled and CLSTAT bit is cleared

bit 10 TRGIEN: Trigger Interrupt Enable bit1 = A trigger event generates an interrupt request0 = Trigger event interrupts are disabled and TRGSTAT bit is cleared

bit 9 ITB: Independent Time Base Mode bit1 = PHASEx register provides time base period for this PWM generator0 = Primary time base provides timing for this PWM generator

bit 8 MDCS: Master Duty Cycle Register Select bit1 = MDC register provides duty cycle information for this PWM generator0 = PDCx register provides duty cycle information for this PWM generator

bit 7-6 DTC<1:0>: Dead-Time Control bits00 = Positive dead time actively applied for all output modes01 = Negative dead time actively applied for all output modes10 = Dead-Time function is disabled11 = Reserved

bit 5-2 Unimplemented: Read as �0�

DS70270B-page 30-10 © 2007 Microchip Technology Inc.

Page 11: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

bit 1 XPRES: External PWM Reset Control bit1 = Current-limit source resets time base for this PWM generator if it is in independent time base mode0 = External pins do not affect PWM time base

bit 0 IUE: Immediate Update Enable bit1 = Updates to the active PDC registers are immediate0 = Updates to the active PDC registers are synchronized to the PWM time base

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-11

Page 12: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-6: PDCx: PWM Generator Duty Cycle Register

Register 30-7: PHASEx: PWM Phase-Shift Register

Upper Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

PDCx<15:8>bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

PDCx<7:0>bit 7 bit 0

bit 15-0 PDCx<15:0>: PWM Generator #x Duty Cycle Value bits(1)

Note 1: The minimum value for this register is 0x0008 and the maximum value is 0xFFEF.

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

Upper Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

PHASEx<15:8>bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0

PHASEx<7:2> � �bit 7 bit 0

bit 15-2 PHASEx<15:2>: PWM Phase-Shift Value or Independent Time Base Period for this PWM Generator bits If used as an independent time base, bits <3:2> are not used.

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

DS70270B-page 30-12 © 2007 Microchip Technology Inc.

Page 13: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-8: DTRx: PWM Dead-Time Register

Register 30-9: ALTDTRx: PWM Alternate Dead-Time Register

Upper Byte:U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0� � DTRx<13:8>

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0

DTRx<7:2> � �bit 7 bit 0

bit 15-14 Unimplemented: Read as �0�bit 13-2 DTRx<13:2>: Unsigned 12-bit Dead-Time Value bits for PWMx Dead-Time Unitbit 1-0 Unimplemented: Read as �0�

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

Upper Byte:U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0� � ALTDTRx<13:8>

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0

ALTDTRx<7:2> � �bit 7 bit 0

bit 15-14 Unimplemented: Read as �0�bit 13-2 ALTDTRx<13:2>: Unsigned 12-bit Dead-Time Value bits for PWMx Dead-Time Unitbit 1-0 Unimplemented: Read as �0�

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-13

Page 14: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-10: TRGCONx: PWM Trigger Control RegisterUpper Byte:

R/W-0 R/W-0 R/W-0 U-0 U-0 U-0 U-0 U-0TRGDIV<2:0> � � � � �

bit 15 bit 8

Lower Byte:U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0� � TRGSTRT<5:0>

bit 7 bit 0

bit 15-13 TRGDIV<2:0>: Trigger Output Divider000 = Trigger output for every trigger event001 = Trigger output for every 2nd trigger event010 = Trigger output for every 3rd trigger event011 = Trigger output for every 4th trigger event100 = Trigger output for every 5th trigger event101 = Trigger output for every 6th trigger event110 = Trigger output for every 7th trigger event111 = Trigger output for every 8th trigger event

bit 12-6 Unimplemented: Read as �0�bit 5-0 TRGSTRT<5:0>: Trigger Postscaler Start Enable Select bits

This value specifies the ROLL counter value needed for a match that will then enable the trigger postscalerlogic to begin counting trigger events.

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

DS70270B-page 30-14 © 2007 Microchip Technology Inc.

Page 15: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-11: IOCONx: PWM I/O Control RegisterUpper Byte:

R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0PENH PENL POLH POLL PMOD<1:0> OVRENH OVRENL

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 R/W-0

OVRDAT<1:0> FLTDAT<1:0> CLDAT<1:0> � OSYNCbit 7 bit 0

bit 15 PENH: PWMH Output Pin Ownership bit1 = PWM module controls PWMxH pin0 = GPIO module controls PWMxH pin

bit 14 PENL: PWML Output Pin Ownership bit1 = PWM module controls PWMxL pin0 = GPIO module controls PWMxL pin

bit 13 POLH: PWMH Output Pin Polarity bit1 = PWMxH pin is active-low0 = PWMxH pin is active-high

bit 12 POLL: PWML Output Pin Polarity bit1 = PWMxL pin is active-low0 = PWMxL pin is active-high

bit 11-10 PMOD<1:0>: PWM #x I/O Pin Mode bits00 = PWM I/O pin pair is in the Complementary PWM Output mode01 = PWM I/O pin pair is in the Independent Output mode10 = PWM I/O pin pair is in the Push-Pull Output mode11 = Reserved

bit 9 OVRENH: Override Enable for PWMxH Pin bit1 = OVRDAT<1> provides data for output on PWMxH pin0 = PWM generator provides data for PWMxH pin

bit 8 OVRENL: Override Enable for PWMxL Pin bit1 = OVRDAT<0> provides data for output on PWMxL pin0 = PWM generator provides data for PWMxL pin

bit 7-6 OVRDAT<1:0>: Data for PWMxH,L Pins if Override is Enabled bitsIf OVERENH = 1, then OVRDAT<1> provides data for PWMxHIf OVERENL = 1, then OVRDAT<0> provides data for PWMxL

bit 5-4 FLTDAT<1:0>: Data for PWMxH,L Pins if FLTMOD is Enabled bitsIf fault is active, then FLTDAT<1> provides data for PWMxHIf fault is active, then FLTDAT<0> provides data for PWMxL

bit 3-2 CLDAT<1:0>: Data for PWMxH,L Pins if CLMODE is Enabled bitsIf current limit is active, then CLDAT<1> provides data for PWMxHIf current limit is active, then CLDAT<0> provides data for PWMxL

bit 1 Unimplemented: Read as �0�bit 0 OSYNC: Output Override Synchronization bit

1 = Output overrides via the OVRDAT<1:0> bits are synchronized to the PWM time base0 = Output overrides via the OVRDAT<1:0> bits occur on next clock boundary

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-15

Page 16: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-12: FCLCONx: PWM Fault Current-Limit Control RegisterUpper Byte:

U-0 U-0 U-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0� � � CLSRC<3:0> CLPOL

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0

CLMODE FLTSRC<3:0> FLTPOL FLTMOD<1:0>bit 7 bit 0

bit 15-13 Unimplemented: Read as �0�bit 12-9 CLSRC<3:0>: Current-Limit Control Signal Source Select for PWM #x Generator bits

0000 = Analog Comparator #10001 = Analog Comparator #20010 = Analog Comparator #30011 = Analog Comparator #4

0100 = Reserved0101 = Reserved0110 = Reserved0111 = Reserved

1000 = Shared Fault #1 (SFLT1)1001 = Shared Fault #2 (SFLT2)1010 = Shared Fault #3 (SFLT3)1011 = Shared Fault #4 (SFLT4)

1100 = Reserved1101 = Independent Fault #2 (IFLT2)1110 = Reserved1111 = Independent Fault #4 (IFLT4)

bit 8 CLPOL: Current-Limit Polarity for PWM Generator #x bit1 = The selected current-limit source is active-low0 = The selected current-limit source is active-high

bit 7 CLMODE: Current-Limit Mode Enable for PWM Generator #x bit1 = Current-Limit mode is enabled0 = Current-Limit mode is disabled

DS70270B-page 30-16 © 2007 Microchip Technology Inc.

Page 17: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-12: FCLCONx: PWM Fault Current-Limit Control Register (Continued)

bit 6-3 FLTSRC<3:0>: Fault Control Signal Source Select for PWM Generator #x bits0000 = Analog Comparator #10001 = Analog Comparator #20010 = Analog Comparator #30011 = Analog Comparator #4

0100 = Reserved0101 = Reserved0110 = Reserved0111 = Reserved

1000 = Shared Fault #1 (SFLT1)1001 = Shared Fault #2 (SFLT2)1020 = Shared Fault #3 (SFLT3)1011 = Shared Fault #4 (SFLT4)

1100 = Reserved1101 = Independent Fault #2 (IFLT2)1110 = Reserved1111 = Independent Fault #4 (IFLT4)

bit 2 FLTPOL: Fault Polarity for PWM Generator #x bit1 = The selected Fault source is active-low0 = The selected Fault source is active-high

bit 1-0 FLTMOD<1:0>: Fault Mode for PWM Generator #x bits00 = The selected Fault source forces PWMxH, PWMxL pins to FLTDAT values (latched condition)01 = The selected Fault source forces PWMxH, PWMxL pins to FLTDAT values (cycle)10 = Reserved11 = Fault input is disabled

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-17

Page 18: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Register 30-13: TRIGx: PWM Trigger Compare Value RegisterUpper Byte:

R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0TRGCMP<15:8>

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0 U-0

TRGCMP<7:3> � � �bit 7 bit 0

bit 15-3 TRGCMP<15:3>: Trigger Control Value bits(1)

Register contains the compare value for the PWMx time base for generating a trigger to the ADC modulefor initiating a sample and conversion process or generating a trigger interrupt.

bit 2-0 Unimplemented: Read as �0�Note 1: The minimum usable value for this register is 0x0008. A value of 0x0000 does not produce a trigger. If the

TRIGx value is being calculated based on the duty cycle value, you must ensure that a minimum TRIGxvalue is written into the register at all times.

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

DS70270B-page 30-18 © 2007 Microchip Technology Inc.

Page 19: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Register 30-14: LEBCONx: Leading Edge Blanking Control RegisterUpper Byte:

R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 R/W-0PHR PHF PLR PLF FLTLEBEN CLLEBEN LEB<9:8>

bit 15 bit 8

Lower Byte:R/W-0 R/W-0 R/W-0 R/W-0 R/W-0 U-0 U-0 U-0

LEB<7:3> � � �bit 7 bit 0

bit 15 PHR: PWMH Rising Edge Trigger Enable bit1 = Rising edge of PWMH will trigger LEB counter0 = LEB ignores rising edge of PWMH

bit 14 PHF: PWMH Falling Edge Trigger Enable bit1 = Falling edge of PWMH will trigger LEB counter0 = LEB ignores falling edge of PWMH

bit 13 PLR: PWML Rising Edge Trigger Enable bit1 = Rising edge of PWML will trigger LEB counter0 = LEB ignores rising edge of PWML

bit 12 PLF: PWML Falling Edge Trigger Enable bit1 = Falling edge of PWML will trigger LEB counter0 = LEB ignores falling edge of PWML

bit 11 FLTLEBEN: Fault Input Leading Edge Blanking Enable bit1 = Leading Edge Blanking is applied to selected Fault Input0 = Leading Edge Blanking is not applied to selected Fault Input

bit 10 CLLEBEN: Current-Limit Leading Edge Blanking Enable bit1 = Leading Edge Blanking is applied to selected Current-Limit Input0 = Leading Edge Blanking is not applied to selected Current-Limit Input

bit 9-3 LEB: Leading Edge Blanking for Current-Limit and Fault Inputs bitsValue is 8 nsec increments

bit 2-0 Unimplemented: Read as �0�

Legend:R = Readable bit W = Writable bit U = Unimplemented bit, read as �0�-n = Value at POR �1� = Bit is set �0� = Bit is cleared x = Bit is unknown

© 2007 Microchip Technology Inc. DS70270B-page 30-19

Page 20: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.5 MODULE FUNCTIONALITYThe Power Supply PWM module is a very high-speed design that provides capabilities not foundin other PWM generators. The following PWM modes are supported by this module:

� Standard Edge-Aligned PWM mode� Complementary PWM Output mode� Push-Pull PWM mode� Multi-Phase PWM mode� Variable Phase PWM mode� Current-Limit PWM mode� Constant Off-time PWM mode� Current Reset PWM mode� Independent Time Base PWM mode

Some of these modes can be used in combination with other modes. For example, PWM1 canbe configured for Complementary PWM Output mode operation and Variable Phase modeoperation simultaneously. Similarly, the Standard Edge-Aligned mode can be used incombination with the Independent Time Base PWM mode.

While there exist additional combinations that would be feasible to implement, there are certaincombinations that are not possible to implement. As an example, it is not possible to use thesame PWM generator to produce both Standard Edge-Aligned mode and Complementary PWMOutput mode.

Following are brief descriptions of all modes of operation supported by the dsPIC30F SMPSdevice family.

30.5.1 Standard Edge-Aligned PWM ModeStandard Edge-Aligned PWM mode (Figure 30-3) is the basic PWM mode used by many powerconverter topologies, including Buck, Boost, and Forward. To create the edge-aligned PWM, atimer/counter circuit counts upward from zero to a specified maximum value for the period.Another register contains the value for the duty cycle, which is constantly compared to the timer(period) value. While the timer/counter value is less than or equal to the duty cycle value, thePWM output signal is asserted. When the timer value exceeds the duty cycle value, the PWMsignal is deasserted. When the timer is greater than the period value, the timer is reset and theprocess repeats.

Figure 30-3: Standard Edge-Aligned PWM Mode

Period

Duty Cycle

0

Period

TimerValue

Timer Resets

PWMH

Value

Duty Cycle Match

DS70270B-page 30-20 © 2007 Microchip Technology Inc.

Page 21: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.5.2 Complementary PWM Output ModeComplementary PWM Output mode is generated in a manner similar to Standard Edge-AlignedPWM mode. This mode provides a second PWM output signal on the PWML pin that is the com-plement of the primary PWM signal (PWMH). This mode is widely used in synchronous buckconverters and resonant converters.

In the dsPIC30F SMPS device family, this mode is enabled by setting PMOD = (00)b in theIOCONx register. The Complementary PWM Output mode is shown in Figure 30-4.

Figure 30-4: Complementary PWM Output Mode

30.5.3 Push-Pull PWM ModeThe Push-Pull PWM mode shown in Figure 30-5 is a version of the Standard Edge-Aligned PWMmode where the active PWM signal is alternately output on one of two PWM pins. Complemen-tary PWM output is not available. This mode is useful in transformer-based power converters.Transformer-based circuits must avoid any direct currents that will cause their cores to saturate.The Push-Pull mode ensures that the duty cycle of the two phases is identical, thus yielding anet DC bias of zero.

In the dsPIC30F SMPS device family, this mode is enabled by setting PMOD = (10)b in theIOCONx register.

Figure 30-5: Push-Pull PWM Mode

Period

Duty Cycle

0

Period

TimerValue

Timer Resets

PWMH

Value

PWML (Period)-(Duty Cycle)

Duty Cycle Match

Period

Duty Cycle

0

Period

TimerValue

Timer Resets

PWMH

Value

PWML Duty Cycle

Duty Cycle Match

© 2007 Microchip Technology Inc. DS70270B-page 30-21

Page 22: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.5.4 Multi-Phase PWM ModeMulti-Phase PWM, as shown in Figure 30-6, uses phase-shift values in the PHASEx registers toshift the PWM outputs relative to the primary time base. Because the phase-shift values areadded to the primary time base, the phase-shifted outputs occur earlier than in a PWM channelthat specifies zero phase shift. In Multi-Phase mode, the specified phase shift is fixed by theapplication�s design.

Figure 30-6: Multi-Phase PWM Mode

30.5.5 Variable Phase PWM ModeFigure 30-7 shows the waveforms for Variable Phase PWM mode. Power-converter circuits con-stantly change the phase shift among PWM channels to control the flow of power, in contrast tomost PWM circuits that vary the duty cycle of PWM signals to control power flow. Often in variablephase applications, the PWM duty cycle is maintained at 50 percent. The phase-shift valueshould be updated when the PWM signal is not asserted. Complementary PWM outputs areavailable in Variable Phase mode.

Figure 30-7: Variable Phase PWM Mode

The difference between Multi-Phase PWM mode and Variable Phase PWM mode is that in theformer there is a a phase difference between two separate PWM outputs. Conversely, in variablephase mode, the phase of a single PWM output is changed in every PWM cycle.

Duty CyclePWM2H

Duty CyclePWM4H

Duty CyclePWM3H

Duty CyclePWM1H

Period

Phase4

Phase2

Phase3

PTMR = 0

Duty CyclePWM1H

Period

Duty Cycle

Duty Cycle

Phase2 (old value)

Duty CyclePWM2H

Phase2 (new value)

DS70270B-page 30-22 © 2007 Microchip Technology Inc.

Page 23: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.5.6 Cycle-by-Cycle Current-Limit PWM ModeFigure 30-8 shows Cycle-by-Cycle Current-Limit mode. This mode truncates the asserted PWMsignal when the current-limit signal is asserted. The PWM output values are specified by the Cur-rent-Limit override bits (CLDAT<1:0>) in the IOCONx register. The override output remains ineffect until the beginning of the next PWM cycle. This mode is sometimes used in Power FactorCorrection (PFC) circuits where the inductor current controls the PWM on time. This is a constantfrequency PWM mode.

An analog comparator output, a shared fault pin (SFLTx) or an independent fault pin (IFLTx) canbe used as the current-limit signal by configuring the Current-Limit Control Signal Source SelectGenerator (CLSRC<3:0>) bits in the PWM Fault Current-Limit Control (FCLCONx<12:9>)register. The current-limit signal can also be configured to be active-high or active-low.

Figure 30-8: Cycle-by-Cycle Current-Limit PWM Mode

30.5.7 Constant Off-Time PWM ModeConstant Off-Time PWM mode is shown in Figure 30-9. This is a variable-frequency mode wherethe actual PWM period is less than or equal to the specified period value. The PWM time baseis externally reset after the PWM signal duty cycle value has been reached and the PWM signalhas been deasserted. This mode is implemented by enabling the Current Reset PWM mode andusing the complementary PWM output.

Figure 30-9: Constant Off-Time PWM Mode

Duty Cycle

0

Period

TimerValue

PWMH

Value

FLTx Negates PWM

Duty CycleProgrammed

Duty Cycle

Programmed

Duty CyclePWMH

Duty CycleActual Actual

FLTx Negates PWM

Duty Cycle

0

Period

TimerValue

Programmed Period

PWML

Value

External Timer Reset

Duty Cycle

Actual Period

External Timer Reset

Note: Duty Cycle represents off time

© 2007 Microchip Technology Inc. DS70270B-page 30-23

Page 24: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.5.8 Current Reset PWM ModeCurrent Reset PWM mode is shown in Figure 30-10. This is a variable-frequency mode wherethe actual PWM period is less than or equal to the specified period value. The PWM time baseis externally reset after the PWM signal duty cycle value has been reached and the PWM signalhas been deasserted. Current Reset PWM mode is a constant on time PWM mode.

Typically, in the converter application, an energy storage inductor is charged with current whilethe PWM signal is asserted, and the inductor current is discharged by the load when the PWMsignal is deasserted. In this application of Current Reset PWM mode, an external currentmeasurement circuit determines when the inductor is discharged, and then generates a signalthat the PWM module uses to reset the time base counter. In Current Reset PWM mode,complementary PWM outputs are available.

Figure 30-10: Current Reset PWM Mode

30.5.9 Independent Time Base PWM ModeIndependent Time Base PWM mode, as shown in Figure 30-11, is often used when thedsPIC30F SMPS device is controlling different power converter sub-circuits such as the PowerFactor Correction circuit, which can use 100 kHz PWM, and the full-bridge forward convertersection, which can use 250 kHz PWM.

Figure 30-11: Independent Time Base PWM Mode

Duty Cycle

0

Period

TimerValue

Programmed Period

PWMH

Value

External Timer Reset

Duty Cycle

Actual Period

External Timer Reset

Programmed Period

Duty CyclePWM2H

Duty CyclePWM4H

Duty CyclePWM3H

Duty Cycle

PWM1H

Period 4

Period 2

Period 3

Period 1

Note: With independent time bases, PWM signals are no longer phase related to each other.

DS70270B-page 30-24 © 2007 Microchip Technology Inc.

Page 25: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.6 CLOCK SOURCESThe Power Supply PWM module incorporates a number of clock frequencies for operation of thevarious functional blocks of the module. The PLL output frequency (FPWM) from the Oscillatormodule is used to generate the clock signals used in the PWM module. Therefore, to use thePWM module, the PLL must be enabled. Figure 30-12 shows the clock sources used in the PWMmodule and their relation with FPWM. Refer to Section 29. �Oscillator� for more information onhow FPWM is obtained.

Figure 30-12: Power Supply PWM Module Clock Sources

FPWM

PWM Primary Time Base (PTMR)

or Individual Time Base (ITMRx)

PWM Special Event Trigger

Clock

Trigger Clock

Leading Edge Blanking Clock

Dead-Time Control Clock

Phase Shift Control Clock

Duty Cycle Generation and Control Clock

÷ 8

÷ 4

PWM Individual

© 2007 Microchip Technology Inc. DS70270B-page 30-25

Page 26: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.7 PRIMARY PWM TIME BASEThere is a Primary Time Base (PTMR) counter for the entire PWM module. In addition, eachPWM generator has an individual time base counter. The PTMR determines when the individualtime base counters are to update their duty cycle and phase-shift registers. The master time baseis also responsible for generating the Special Event Triggers and timer-based interrupts.Figure 30-13 shows a block diagram of the primary time base logic.

The primary time base can be reset by an external signal specified via the Sync Source Selection(SYNCSRC<2:0>) bits in the PWM Time Base Control (PTCON<6:4>) register. The externalreset feature is enabled using the External Time Base Synchronization Enable (SYNCEN) bit inthe PTCON (PTCON<7>) register. The primary time base reset feature supports synchronizationof the primary time base with another dsPIC30F SMPS device or other circuitry in the user�sapplication. The primary time base logic also provides an output signal (SYNCO) when a periodmatch occurs.

Figure 30-13: PTMR Block Diagram

30.7.1 PTMR SynchronizationBecause absolute synchronization is not possible, the user application should program the timebase period of the secondary (slave) device to be slightly longer than the primary device timebase period to ensure that the two time bases will reset at the same time.

30.7.2 Primary PWM Time Base ROLL CounterThe primary time base has an additional 6-bit counter that counts the period matches of the pri-mary time base. This counter is referred to as the ROLL counter and is not accessible for reading.Each PWM generator has six Trigger Postscaler Start Enable Select (TRGSTRT<5:0>) bits in thePWM Trigger Control (TRGCONx<5:0>) register that specify how many counts of the ROLLcounter are allowed to pass before generating the first analog-to-digital conversion (ADC) trigger.The purpose of the ROLL counter and the TRGSTRT bits is to allow the user application tospread the system workload over a series of PWM cycles.

The TRGDIV<2:0> bits in the TRGCONx register act as a postscaler for the TRIGx register togenerate ADC triggers. These bits specify how frequently the ADC trigger is generated. Once theTRGDIV<2:0> postscaler is enabled, the ROLL bits and the TRGSTRT bits have no further effectuntil the PWM module is disabled and then re-enabled.

A typical application of the ROLL counter is a dsPIC controlled multi-channel DC-DC converter.In this application, each individual converter operating on a PWM channel triggers an ADC andexecutes the control loop, ensuring that no two PWM channels generate an ADC trigger at thesame time. This feature allows efficient utilization of the available CPU resources.

An additional use of the ROLL counter is to allow the internal FRC oscillator to be varied on aPWM cycle basis to reduce peak EMI emissions generated by switching transistors in the powerconversion application.

The ROLL counter is cleared when the PWM Module is disabled (PTEN = 0), and the TRIGxpostscalers (TRGDIV) are also disabled. A new match of the ROLL counter and the TRGSTRTbit value must then take place to begin counting again.

PTMR

PTPER

Equality Comparator

CLK

>

Reset

13

13

PR_MATCH

DS70270B-page 30-26 © 2007 Microchip Technology Inc.

Page 27: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.8 INDIVIDUAL PWM TIME BASE(S)Each PWM generator also has its own PWM time base. Figure 30-14 shows a block diagram forthe individual time base circuits. With a time base per PWM generator, the PWM module can gen-erate PWM outputs that are phase shifted relative to each other or totally independent of eachother. The individual PWM timers (ITMRx) provide the time base values that are compared to theduty cycle registers to create the PWM signals. These individual time base counters can be ini-tialized before or during an operation using the phase-shift registers. The primary (PTMR) andthe individual (ITMRx) timers are not readable by the user application.

Normally, the Primary PWM Time Base (PTMR) provides synchronization control to the individualtimers/counters so they count in lock-step unison.

If the PWM phase-shift feature is used, the PTMR provides the synchronization signal to eachindividual timer/counter that causes them to reinitialize with their individual phase-shift values.

If a PWM generator is operating in Independent Time Base mode, the individual timer/counterscount upward until their count values match the value stored in their phase registers, then theyreset and the cycle repeats.

The primary time base and the individual time bases are implemented as 13-bit counters. Thetimers/counters are clocked at 120 MHz at 30 MIPS, which provides a frequency resolution of8.4 ns.

All of the timers/counters are enabled or disabled by setting or clearing the PWM Module Enable(PTEN) bit in the PWM Time Base Control (PTCON<15>) register.

If an individual time base is not used, the Primary Time Base (PTPER) register sets the countingperiod for PTMR. The user application must write a 13-bit value to PTPER<15:3>. When thevalue in PTMR<15:3> matches the value in PTPER<15:3>, the primary time base is reset to �0�and the individual time base counters are reinitialized to their phase values (except inIndependent Time Base mode).

Figure 30-14: ITMRx Block Diagram

Note: The timers are cleared when the PTEN bit is cleared in software.

ITMRx

PTPER

Equality Comparator

CLK

>

Reset

13

13

MUX

PHASEx

ITBx0 1

15 3 15 3

15 3

© 2007 Microchip Technology Inc. DS70270B-page 30-27

Page 28: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.9 PWM PERIODThe Primary Time Base (PTPER) register holds the 13-bit value that specifies the counting periodfor the primary PWM time base. The timer period can be updated at any time by the userapplication. The PWM period can be determined from the formula shown in Equation 30-1.

Equation 30-1: PWM Period Formula

30.10 PWM FREQUENCY AND DUTY CYCLE RESOLUTIONThe PWM duty cycle resolution is 1.05 ns per LSB at 30 MIPS. The PWM period resolution is 8.4ns at 30 MIPS. Table 30-1 and Table 30-2 show the duty cycle resolution versus PWMfrequencies for 30 MIPS and 20 MIPS execution speed.

Table 30-1: Available PWM Frequencies and Resolutions @ 30 MIPS

Table 30-2: Available PWM Frequencies and Resolutions @ 20 MIPs

The reduction in available resolution for a given PWM frequency is due to the reduced clock rateand the fact that the LSB of duty cycle resolution is derived from a fixed-delay element. Atoperating frequencies below 30 MIPS, the contribution of the fixed-delay element to the outputresolution becomes less than 1 LSB. For frequency resonant mode power conversionapplications, it is desirable to know the available PWM frequency resolution. The availablefrequency resolution varies with the PWM frequency. The PWM time base clocks at 120 MHz at30 MIPS. Equation 30-2 provides the frequency resolution versus PWM period:

Equation 30-2: Frequency Resolution Versus PWM Period

Period Duration = (PTPER + 1) / 120 MHz @ 30 MIPS

MIPS PWM Duty Cycle Resolution PWM Frequency

30 16 bits 14.6 KHz30 15 bits 29.3 KHz30 14 bits 58.6 KHz30 13 bits 117.2 KHz30 12 bits 234.4 KHz30 11 bits 468.9 KHz30 10 bits 937.9 KHz30 9 bits 1.87 MHz30 8 bits 3.75 MHz

MIPS PWM Duty Cycle Resolution PWM Frequency

20 14 bits 39 KHz20 12 bits 156 KHz20 10 bits 624 KHz20 8 bits 2.5 MHz

Frequency Resolution = 120 MHz / (Period)

where, Period = PTPER<15:3>

DS70270B-page 30-28 © 2007 Microchip Technology Inc.

Page 29: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.11 PWM DUTY CYCLE COMPARISON UNITSThe PWM module has up to four PWM duty cycle generators. Up to five 16-bit special functionregisters are used to specify duty cycle values for the PWM module:

� Master Duty Cycle (MDC) register� PWM Generator Duty Cycle (PDC1, �, PDC4) registers

Each PWM generator has its own duty cycle register (PDCx), and there is a Master Duty Cycle(MDC) register. The MDC register can be used instead of individual duty cycle registers. TheMDC register enables multiple PWM generators to share a common duty cycle register to reducethe CPU overhead required in updating multiple duty cycle registers. Multi-phase powerconverters are an application where the use of the MDC feature saves valuable processor time.

The value in each duty cycle register determines the amount of time that the PWM output is inan active state. The PWM time base counters are 13 bits wide and increment twice per instructioncycle. The PWM output is asserted when the timer/counter is less than or equal to the MostSignificant 13 bits of the duty cycle register value. Each of the duty cycle registers allows a 16-bitduty cycle to be specified. The Least Significant 3 bits of the duty cycle registers are sent toadditional logic for further adjustment of the PWM signal edge.

Figure 30-15 is a block diagram of a duty cycle comparison unit; however, the additional circuitryfor resolving the Least Significant 3 bits is not shown.

Figure 30-15: Duty Cycle Comparison

The duty cycle values can be updated at any time. The updated duty cycle values can be helduntil the next rollover of the primary time base before becoming active. Optionally, by setting theImmediate Update Enable (IUE) bit in the PWM Control (PWMCONx<0>) register, the updatedduty cycle values can be used immediately.

30.12 COMPLEMENTARY PWM OUTPUTSComplementary PWM Output mode provides true and inverted PWM outputs on the pair of PWMoutput pins (PWMxH and PWMxL). The complementary PWM signal is generated by invertingthe active PWM signal. Complementary outputs are normally available with all PWM modesexcept Push-Pull PWM and Independent PWM Output modes.

PDCx Register

ITMRx or PTMR

Compare Logic PWMx signal

015

15

MUX

MDC Register

MDCx select0 1

Clk

15

0

0

<=

© 2007 Microchip Technology Inc. DS70270B-page 30-29

Page 30: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.13 INDEPENDENT PWM OUTPUTSIndependent PWM Output mode simply replicates the active PWM output signal on both outputpins (PWMxH and PWMxL) associated with a PWM generator.

30.14 DUTY CYCLE LIMITSThe duty cycle generators are limited to the range of allowable values. A value of 0x0008 is theminimum duty cycle value that will produce an output pulse. This value represents 8.4 ns at 30MIPS. This minimum range limitation is not a problem in a real world application because of theslew-rate limitation of the PWM output buffers, external FET drivers, and the power transistors.The application control loop requires larger duty cycle values to achieve minimum transistor ONtimes. The maximum duty cycle value is also limited to 0xFFEF.

30.15 DEAD-TIME GENERATIONDead time refers to a programmable period of time (specified by the Dead-Time Register (DTRx)or the Alternate Dead-Time (ALTDTRx) register) that prevents a PWM output from beingasserted until its complementary PWM signal has been deasserted for the specified time.Figure 30-16 shows the insertion of dead time in a complementary pair of PWM outputs.Figure 30-17 shows the four Dead-Time Control Units, which each have their own dead-timevalue. Dead-time generation can be provided when any of the PWM I/O pin pairs are operatingin any output mode.

Many power-converter circuits require dead time because the power transistors cannot switchinstantaneously. To prevent current shoot-through, some amount of time must be providedbetween the turn-off event of one PWM output and the turn-on event of the other PWM output ina complementary pair.

The PWM module can also provide negative dead time. Negative dead time is the forced overlapof the PWMH and PWML signals. Certain converter techniques require a limited amount ofcurrent shoot-through.

The dead-time feature can be disabled for each PWM generator. The dead-time functionality iscontrolled by the Dead-Time Control (DTC<1:0>) bits in the PWM Control (PWMCONx<7:6>)register.

Figure 30-16: Dead-Time Insertion for Complementary PWM

Note: Independent PWM Output mode is different from the Independent Time Base mode,in which each PWM generator has its own time base but can produce acomplementary or push-pull output.

Note: The user application is responsible for limiting the duty cycle values to the allowablerange of 0x0008 to 0xFFEF.

Note: If zero dead time is required, the dead-time feature must be explicitly disabled in theDTC<1:0> bits in the PWMCONx register.

PWM1H

PWM1L

tda tda

PWM Generator #1 Output

DS70270B-page 30-30 © 2007 Microchip Technology Inc.

Page 31: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Figure 30-17: Dead-Time Control Units Block Diagram

30.15.1 Dead-Time GeneratorsEach complementary output pair for the PWM module has 12-bit down counters to produce thedead-time insertion. Each dead-time unit has a rising and falling edge detector connected to theduty cycle comparison output.

Depending on whether the edge is rising or falling, one of the transitions on the complementaryoutputs is delayed until the associated timer counts down to zero. A timing diagram indicating thedead-time insertion for one pair of PWM outputs is shown in Figure 30-16.

30.15.2 Alternate Dead-Time SourceThe alternate dead time refers to the dead time specified by the ALTDTRx register that is appliedto the complementary PWM output. Figure 30-18 shows a dual dead-time insertion using theALTDTRx register.

Figure 30-18: Dual Dead-Time Waveforms

DTR1Dead-Time Unit

#1PWM1 in

PWM1H

PWM1L

ALTDTR1

DTR2Dead-Time Unit

#2PWM2 in

PWM2H

PWM2L

ALTDTR2

DTR3Dead-Time Unit

#3PWM3 in

PWM3H

PWM3L

ALTDTR3

DTR4Dead-Time Unit

#4PWM4 in

PWM4H

PWM4L

ALTDTR4

PWMH

PWML

PWML

PWML

PWMH

PWMH

No dead time

Positive dead time

Negative dead time

DTRx ALTDTRx

© 2007 Microchip Technology Inc. DS70270B-page 30-31

Page 32: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.15.3 Dead-Time RangesThe amount of dead time provided by each dead-time unit is selected by specifying a 12-bitunsigned value in the DTRx registers. The 12-bit dead-time counters clock at four times theinstruction execution rate. The Least Significant 1 bit of the dead-time value is processed by theFine Adjust PWM module.

Table 30-3 shows example dead-time ranges as a function of the device operating frequency.

Table 30-3: Example Dead-Time Ranges

30.15.4 Dead-Time Insertion TimingFigure 30-19 shows how the dead-time insertion for complementary signals is accomplished.

Figure 30-19: Dead-Time Insertion (PWM Output Signal Timing may be delayed)

30.15.5 Dead-Time DistortionFor small PWM duty cycles, the ratio of dead time to the active PWM time may become large. Inthis case, the inserted dead time introduces distortion into waveforms produced by the PWMmodule. The user application can ensure that dead-time distortion is minimized by keeping thePWM duty cycle at least three times larger than the dead time.

A similar effect occurs for duty cycles at or near 100 percent. The maximum duty cycle used inthe application should be chosen such that the minimum inactive time of the signal is at leastthree times larger than the dead time.

MIPS Resolution Dead-Time Range30 4.16 ns 0-17.03 µs20 6.25 ns 0-25.59 µs

9 0 1 2 3 4 5 6 7 8

CLOCK

PTMR

DUTY CYCLE REG4

RAW PWMH

RAW PWML

PWMH OUTPUT

PWML OUTPUT

DEAD-TIME VALUE1<10:4>

<15:4>

DS70270B-page 30-32 © 2007 Microchip Technology Inc.

Page 33: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.16 CONFIGURING A PWM CHANNELExample 30-1 shows a code example for configuring PWM channel 1 to operate in Complemen-tary PWM Output mode at 400 kHz with a dead-time value of approximately 64 ns. It is assumedthat the dsPIC30F SMPS device is operating on the Internal Fast RC Oscillator with the PLL inthe High Frequency Range (14.55 MHz input to the PLL).

Example 30-1: Code Example for Configuring PWM Channel 1.

mov #0x0400, w0 ; PWM Module is disabled, continue operation inmov w0, PTCON ; idle mode, special event interrupt disabled,

; immediate period updates enabled, no external; synchronization

; Set the PWM Periodmov #0x094D, w0 ; Select period to be approximately 2.5usecmov w0, PTPER ; PLL Frequency is ~480MHz. This equates to a

; clocke period of 2.1nsec. The PWM period and; duty cycle registers are triggered on both +ve; and -ve edges of the PLL clock. Therefore,; one count of the PTPER and PDCx registers; equals 1.05nsec.; So, to achieve a PWM period of 2.5usec, we; choose PTPER = 0x094D

mov #0x0000, w0 ; no phase shift for this PWM Channelmov w0, PHASE1 ; This register is used for generating variable

; phase PWM

; Select individual Duty Cycle Controlmov #0x0001, w0 ; Fault interrupt disabled, Current Limitmov w0, PWMCON1 ; interrupt disabled, trigger interrupt,

; disabled, Primary time base provides timing,; DC1 provides duty cycle information, positive; dead time applied, no external PWM reset,; Enable immediate duty cycle updates

; Code for PWM Current Limit and Fault Inputsmov #0x0003, w0mov w0, FCLCON1 ; Disable current limit and fault inputs

; Code for PWM Output Controlmov #0xC000, w0 ; PWM1H and PWM1L is controlled by PWM modulemov w0, IOCON1 ; Output polarities are active high, override

; disabled

; Duty Cycle Settingmov #0x04A6, w0 ; To achieve a duty cycle of 50%, we choosemov w0, PDC1 ; the PDC1 value = 0.5*(PWM Period)

; The ON time for the PWM = 1.25usec; The Duty Cycle Register will provide; positive duty cycle to the PWMxH outputs; when output polarities are active high; (see IOCON1 register)

; Dead-Time Settingmov #0x0040, w0 ; Dead time ~ 67nsecmov w0, DTR1 ; Hex(40) = decimal(64)

; So, Dead time = 64*1.05nsec = 67.2nsec; Note that the last 2 bits are unimplemented,; therefore the dead-time register can achieve a; a resolution of about 4nsec.

mov w0, ALTDTR1 ; Load the same value in ALTDTR1 register

bset PTCON, #15 ; turn ON PWM module

Note: This code example does not illustrate configuration of various fault modes for the PWM module.It is intended as a quick start guide for setting up the PWM Module.

© 2007 Microchip Technology Inc. DS70270B-page 30-33

Page 34: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.17 SPEED LIMITS OF PWM OUTPUT CIRCUITRYThe PWM output I/O buffers, and any attached circuits such as FET drivers and power FETs,have limited slew-rate capability. For very small PWM duty cycles, the PWM output signal islow-pass filtered; no pulse makes it through all of the circuitry.

A similar effect happens for duty cycle values near 100 percent. Before 100 percent duty cycleis reached, the output PWM signal appears to saturate at 100 percent.

Such behavior needs to be taken into account in user applications. In some power conversionapplications, duty cycle values near 0 or 100 percent are avoided, because, at these values, theuser application is operating in a discontinuous mode or a saturated mode where the control loopmay be non-functional.

30.18 PWM SPECIAL EVENT TRIGGERThe PWM module has a Special Event Trigger that allows analog-to-digital (A/D) conversions tobe synchronized to the PWM time base. The A/D sampling and conversion time can be pro-grammed to occur at any point within the PWM period. The Special Event Trigger allows the userapplication to minimize the delay between the time the A/D conversion results are acquired andthe time the duty cycle value is updated.

The Special Event Trigger is based on the primary PWM time base.

The PWM Special Event Trigger has one register (SEVTCMP) and four additional bits(SEVTPS<3:0> in PTCON) to control its operation. The PTMR value that causes a Special EventTrigger is loaded into the SEVTCMP register.

30.18.1 Special Event Trigger EnableThe PWM Module always produces Special Event Trigger pulses. This signal can optionally beused by the Analog-to-Digital Converter (ADC) module. If the Special Event Interrupt Enable(SEIEN) bit is set in the PTCON (PTCON<11>) register, a PWM Special Event interrupt requestis generated.

30.18.2 Special Event Trigger PostscalerThe PWM Special Event Trigger has a postscaler that allows a 1:1 to 1:16 postscale ratio. Thepostscaler is configured by writing the SEVTPS<3:0> control bits in the PTCON register.

The special event output postscaler is cleared on the following events:

� Any write to the SEVTCMP register� Any device Reset

DS70270B-page 30-34 © 2007 Microchip Technology Inc.

Page 35: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.19 INDIVIDUAL PWM TRIGGERSThe PWM module also features an additional ADC trigger output for each PWM generator. Thisfeature is very useful when the PWM generators are operating in Independent Time Base mode.

A block diagram of a trigger circuit is shown in Figure 30-20. The user application specifies amatch value in the TRIGx register. When the local time base counter value matches the TRIGxvalue, an ADC trigger signal is generated (if configured to do so).

Trigger signals are always generated regardless of the TRIGx value as long as the TRIGx valueis less than or equal to the PWM period value for the local time base. If the Trigger InterruptEnable (TRGIEN) bit is set in the PWM Control (PWMCONx <10>) register, an interrupt requestis generated.

The individual trigger outputs can be divided per the TRGDIV<2:0> bits in the TRGCONxregisters, which allows the trigger signals to the ADC to be generated once for every 1, 2, 3, �,8 trigger events.

The trigger divider allows the user application to tailor the ADC sample rates to the requirementsof the control loop.

Figure 30-20: PWM Trigger Block Diagram

30.20 PWM INTERRUPTSThe PWM module can generate interrupts based on internal timing or on external signals throughthe current-limit and fault inputs. The primary time base module can generate an interruptrequest when a specified event occurs. Each PWM generator module has its own interruptrequest signal to the interrupt controller. The interrupt for each PWM generator is an OR of thetrigger event interrupt request, the current-limit input event or the fault input event for thatmodule.

There are four interrupt request signals to the interrupt control, plus another interrupt requestfrom the primary time base on special events.

The four interrupt requests coming from each PWM generator are called Individual PWMinterrupts. The interrupt request (IRQ) for each one of these individual interrupts can come fromthe PWM Individual Trigger, PWM Fault logic, or PWM Current-Limit logic. When an interruptrequest is generated from any of the above sources, the PWM interrupt flag (in the IFS1 register)corresponding to the chosen PWM generator will be set.

If more than one IRQ source is enabled, then the interrupt source must be resolved in software.This can be done by checking the TRGSTAT, FLTSTAT and CLSTAT bits in the PWMCONxregister.

PTMR or ITMRx

Compare Logic

315

CLK

=

TRIGx Register

TRGDIV<2:0>

Pulse Divider PWMx Trigger

15 3TRIGx Write

© 2007 Microchip Technology Inc. DS70270B-page 30-35

Page 36: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.21 PWM TIME BASE INTERRUPTSThe PWM module can generate interrupts based on the primary time base and/or the individualtime bases in each PWM generator. The interrupt timing is specified by the Special EventComparison (SEVTCMP) register for the primary time base, and by the TRIGx registers for theindividual time bases in the PWM generator modules.

The primary time base special event interrupt is enabled using the Special Event Interrupt Enable(SEIEN) bit in the PTCON (PTCON<11>) register. The individual time base interrupts generatedby the trigger logic in each PWM generator are controlled by the Trigger Interrupt Enable(TRGIEN) bit in the PWM Control (PWMCONx<10>) registers.

30.22 PWM FAULT AND CURRENT-LIMIT PINSThe PWM module supports multiple fault pins for each PWM generator. These pins are labeledSFLTx (shared fault) or IFLTx (individual fault). The shared fault pins can be seen and used byany of the PWM generators. The individual fault pins can be used by specific PWM generators.

Each PWM generator can have one pin for use as a cycle-by-cycle current limit, and another pinfor use as a fault input. This fault input pin can be configured to reset the Fault state every PWMcycle, or have the Fault state remain latched until the Fault state has been reset in software.

30.23 LEADING EDGE BLANKINGEach PWM generator supports Leading Edge Blanking (LEB) of the current-limit and fault inputsthrough the LEB<9:3> bits and the PHR, PHF, PLR, PLF, FLTLEBEN and CLLEBEN bits in theLEBCONx registers. The purpose of leading edge blanking is to mask the transients that occuron the application printed circuit board when the power transistors are turned on and off.

The LEB bits support the blanking (ignoring) of the current-limit and fault inputs for a period of 0to 1024 ns in 8.4 ns increments following any specified rising or falling edge of the coarse PWMHand PWML signals. The coarse PWM signal (signal prior to the PWM fine tuning) has a resolutionof 8.4 ns (at 30 MIPS), which is the same time resolution as the LEB counters.

The PHR, PHF, PLR, and PLF bits select which edge of the PWMH and PWML signals will startthe blanking timer. If a new selected edge triggers the LEB timer while the timer is still active froma previously selected PWM edge, the timer reinitializes and continues counting.

The FLTLEBEN and CLLEBEN bits enable the application of the blanking period to the selectedfault and current-limit inputs.

The LEB duration at 30 MIPS = (LEB<9:3> + 1)/30 MHz * 4.

With a blanking period offset of 8.4 ns, a LEB<9:3> value of zero yields an effective blankingperiod of 8.4 ns. If a current-limit or fault input is active at the end of the previous PWM cycle, isstill active at the start of the new PWM cycle and the dead time is non-zero, the fault or currentlimit will be detected regardless of the LEB counter configuration.

Figure 30-21 illustrates the use of leading edge blanking in power conversion applications. Theleading-edge blanking signal enables the PWM fault and current-limit circuitry to ignore noisegenerated by high-power switching.

DS70270B-page 30-36 © 2007 Microchip Technology Inc.

Page 37: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Figure 30-21: Leading Edge Blanking

30.24 PWM FAULT PINSEach PWM generator can select its own fault input source from a selection of up to 10 fault orcurrent-limit sources. In the Fault Current-Limit Control (FCLCONx) registers, each PWM gener-ator has control (FLTSRC<3:0>) bits that specify the source for its fault input signal. Each PWMgenerator also has a Fault Interrupt Enable (FLTIEN) bit in the PWMCONx register that enablesthe generation of fault interrupt requests. Each PWM generator has an associated Fault Polarity(FLTPOL) bit in the FCLCONx register that selects the active level of the selected fault input.

The fault pins actually serve two purposes. First is generation of fault overrides for the PWM out-puts. The action of overriding the PWM outputs and generating an interrupt is performed asyn-chronously in hardware so that fault events are managed quickly. Second, the fault pin inputs canbe used to implement either Current-Limit PWM mode or Current Reset mode.

PWM Fault states are available on the Fault Interrupt Status (FLTSTAT) bit in the PWMCONx reg-isters. The FLTSTAT bit displays the fault IRQ latch if the FLTIEN bit is set. If fault interrupts arenot enabled, the FLTSTAT bit displays the status of the selected FLTx input in positive logic for-mat. When the fault input pins are not used in association with a PWM generator, these pinsbecome general purpose I/O or interrupt input pins.

The FLTx pins are normally active-high. The FLTPOL bit in the FCLCONx registers, if set to �1�,inverts the selected fault input signal so that it is an active-low.

The fault pins are also readable through the PORT I/O logic when the PWM module is enabled.This allows the user application to poll the state of the fault pins in software.

Figure 30-22 provides a PWM fault control logic diagram.

Switching Noise

Blanking time is determined by theLEB<9:3> bits in the LEBCONx registers

Fault and current-limitcircuitry ignores theswitching noise

PWM Output

High Power Signal

Blanking Signal

Power signal as seenby fault circuitry

© 2007 Microchip Technology Inc. DS70270B-page 30-37

Page 38: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Figure 30-22: PWM Fault Control Logic Diagram

30.24.1 Fault InterruptsThe FLTIENx bits in the PWMCONx registers determine if an interrupt will be generated whenthe FLTx input is asserted high. The Fault Mode for PWM Generator (FLTMOD) bits in theFCLCONx registers determine how the PWM generator and its outputs respond to the selectedfault input pin. The FLTDAT<1:0> bits in the IOCONx registers supply the data values to beassigned to the PWMxH and PWMxL pins in the case of a fault.

The fault pin logic can operate separately from the PWM logic as an external interrupt pin. If thefaults are disabled from affecting the PWM generators in the FCLCONx register, the fault pin canbe used as a general purpose interrupt pin.

30.24.2 Fault StatesThe IOCONx registers have two bits (FLTDAT<1:0>) that determine the state of each PWMx I/Opin when they are overridden by a fault input. When these bits are cleared, the PWM I/O pin isdriven to the inactive state. If the bit is set, the PWM I/O pin is driven to the active state. The activeand inactive states are referenced to the polarity defined for each PWM I/O pin (POLH and POLLpolarity control bits).

PWMx Generator

FLTDAT<1:0>

PWMxH,L Signals 2

Mux

Mux

Analog Comparator 1

Analog Comparator 2

Analog Comparator 3

Analog Comparator 4

FLTSRC<3:0>

CMP1x

CMP2x

CMP3x

CMP4x

SFLT1

SFLT2

SFLT3

SFLT4

IFLT2

IFLT4

PWMxH,L

2

2

Fault Mode

Selection Logic

Shared Fault # 1

Shared Fault # 2

Shared Fault # 3

Shared Fault # 4

Independent Fault # 2

Independent Fault # 4

FLTSTAT

FLTMOD<1:0>

PTMR

FLTMOD<1:0> = 00 � FLTSTAT signal is latched until reset in softwareFLTMOD<1:0> = 01 � FLTSTAT signal is reset by PTMR every PWM cycle FLTMOD<1:0> = 11 � FLTSTAT signal is disabled

Analog Comparator Module

0

1

�0000�

�0001�

�0010�

�1000�

�1001�

�1010�

�1011�

�1101�

�1111�

�0011�

DS70270B-page 30-38 © 2007 Microchip Technology Inc.

Page 39: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.24.3 Fault Input ModesThe fault input pin has two modes of operation:

� Latched mode: When the fault pin is asserted in Latched mode, the PWM outputs go to the states defined in the FLTDAT bits in the IOCONx registers. The PWM outputs remain in this state until the fault pin is deasserted AND the corresponding interrupt flag has been cleared in software. When both of these actions have occurred, the PWM outputs return to normal operation at the beginning of the next PWM cycle boundary. If the FLTSTAT bit is cleared before the Fault condition ends, the PWM module waits until the fault pin is no longer asserted to restore the outputs. Software can clear the FLTSTAT bit by writing a zero to the FLTIEN bit.

� Cycle-by-Cycle mode: When the fault input pin is asserted in Cycle-by-Cycle mode, the PWM outputs remain in the deasserted PWM state for as long as the fault pin is asserted. For Complementary PWM Output mode, PWMxH is low (deasserted) and PWMxL is high (asserted). After the fault pin is driven high, the PWM outputs return to normal operation at the beginning of the following PWM cycle.

The operating mode for each fault input pin is selected using the FLTMOD<1:0> control bits inthe FCLCONx register.

30.24.4 Fault EntryThe response of the PWM pins to the fault input pins is always asynchronous with respect to thedevice clock signals. That is, the PWM outputs should immediately go to the states defined in theFLTDAT register bits without any interaction from the dsPIC30F SMPS device or software. Referto Section 30.29 �Fault and Current-Limit Override Issues with Dead-Time Logic� forinformation regarding data sensitivity and behavior in response to current-limit or Fault events.

30.24.5 Fault ExitThe restoration of the PWM signals after a Fault condition has ended must occur at a PWM cycleboundary to ensure proper synchronization of PWM signal edges and manual signal overrides.The next PWM cycle begins when the PTMR value is zero.

30.24.6 Fault Exit with PTMR DisabledThere is a special case for exiting a Fault condition when the PWM time base is disabled(PTEN = 0). When a fault input is programmed for Cycle-by-Cycle mode, the PWM outputs areimmediately restored to normal operation when the fault input pin is deasserted. The PWM out-puts should return to their default programmed values. (With the time base disabled, there is noreason to wait for the beginning of the next PWM cycle.) When a fault input is programmed forLatched mode, the PWM outputs are restored immediately when the fault input pin is deassertedand the FLTSTAT bit has been cleared in software.

30.24.7 Fault Pin Software ControlThe fault pin can be controlled manually in software. Since the fault input is shared with a PORTI/O pin, the PORT pin can be configured as an output by clearing the corresponding TRIS bit.When the PORT bit for the pin is cleared, the fault input will be activated.

Note: Use caution when controlling the fault inputs in software. If the TRIS bit for the faultpin is cleared and the PORT bit is set high, the fault input cannot be drivenexternally.

© 2007 Microchip Technology Inc. DS70270B-page 30-39

Page 40: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.25 PWM CURRENT-LIMIT PINSEach PWM generator can select its own current-limit input source from up to 10 current-limit/faultsources. In the FCLCONx registers, each PWM generator has control bits (CLSRC<3:0>) thatspecify the source for its current-limit input signal. Additionally, each PWM generator has aCurrent-Limit Interrupt Enable (CLIEN) bit in the PWM Control (PWMCONx<11>) register thatenables the generation of current-limit interrupt requests. Each PWM generator has anassociated Current-Limit Polarity for PWM Generator bit (CLPOL) in the PWM FaultCurrent-Limit Control (FCLCONx<8>) register.

The current-limit pins serve two different purposes. They can be used to implement eitherCurrent-Limit PWM mode or Current Reset PWM mode.

When the CLIEN bit is set in the PWMCONx registers, the PWMxH and PWMxL outputs areforced to the values specified by the CLDAT<1:0> bits in the IOCONx register if the selectedcurrent-limit input signal is asserted. This is called Current-Limit mode.

When the Current-Limit Mode Enable for PWM Generator (CLMODE) bit is zero, the ExternalPWM Reset Control (XPRES) bit in the PWMCONx register is �1�, and the PWM generator is inIndependent Time Base mode (ITB = 1), then a current-limit signal resets the time base for theaffected PWM generator. This behavior is called Current Reset mode, which is used in somePower Factor Correction (PFC) applications.

30.25.1 Current-Limit InterruptsThe state of the PWM current-limit conditions is available on the Current-Limit Interrupt Status(CLSTAT) bits in the PWM Control (PWMCONx<14>) registers. The CLSTAT bits display the cur-rent-limit IRQ flag if the CLIEN bit is set. If current-limit interrupts are not enabled, the CLSTATbits display the status of the selected current-limit inputs in positive logic format. When the cur-rent-limit input pin associated with a PWM generator is not used, these pins become generalpurpose I/O or interrupt input pins.

The current-limit pins are normally active-high. If set to �1�, the CLPOL bit in the FCLCONxregisters inverts the selected current-limit input signal to active-low.

The interrupts generated by the selected current-limit signals are combined to create a singleinterrupt request signal to the interrupt controller, which has its own interrupt vector, interrupt flagbit, interrupt enable bit, and interrupt priority bits associated with it.

The fault pins are also readable through the PORT I/O logic when the PWM module is enabled.This capability allows the user application to poll the state of the fault pins in software.

Figure 30-23 provides a PWM current-limit control logic diagram.

DS70270B-page 30-40 © 2007 Microchip Technology Inc.

Page 41: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

Figure 30-23: PWM Current-Limit Control Logic Diagram

30.26 SIMULTANEOUS PWM FAULTS AND CURRENT LIMITSThe current-limit override function, if enabled and active, forces the PWMxH and PWMxL pins tothe values specified by the CLDAT<1:0> bits in the IOCONx registers, unless the Fault functionis enabled and active. If the selected fault input is active, the PWMxH and PWMxL outputsassume the values specified by the FLTDAT<1:0> bits in the IOCONx registers.

30.27 PWM FAULT AND CURRENT-LIMIT TRIGGER OUTPUTS TO ADCThe fault and current-limit source selection fields in the FCLCONx registers (FLTSRC<3:0> andCLSRC<3:0>) control multiplexers in each PWM generator module. The control multiplexersselect the desired fault and current-limit signals for their respective modules. The selected faultand current-limit signals are also available to the ADC module as trigger signals that initiate ADCsampling and conversion operations.

30.28 PWM OUTPUT OVERRIDE PRIORITYIf the PWM module is enabled, the priority of PWMx pin ownership is as follows:

1. PWM Generator (lowest priority)2. Output Override3. Current-Limit Override4. Fault Override5. PENx (GPIO/PWM) ownership (highest priority)

If the PWM module is disabled, the GPIO module controls the PWMx pins.

PWMx Generator

CLDAT<1:0>

Signals 2

MUX

Mux

Analog Comparator 1Analog Comparator 2

Analog Comparator 3Analog Comparator 4

CLSRC<3:0>

CMP1xCMP2xCMP3xCMP4x

SFLT1SFLT2SFLT3SFLT4IFLT2IFLT4

PWMxH,L

2

2

Shared Fault # 1Shared Fault # 2Shared Fault # 3Shared Fault # 4

Independent Fault # 2Independent Fault # 4

CLSTATXPRES

PWM Period Reset

EN

EN

Analog Comparator Module

�0000��0001��0010�

�1000��1001��1010��1011��1101��1111�

�0011�

0

1CLMOD

PWMxH,L

© 2007 Microchip Technology Inc. DS70270B-page 30-41

Page 42: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.29 FAULT AND CURRENT-LIMIT OVERRIDE ISSUES WITH DEAD-TIME LOGICIn the event of a Fault of Current-Limit condition, the data in the FLTDAT<1:0> bits orCLDAT<1:0> bits determine the state of the PWM I/O pins.

If any of the FLTDAT<1:0> or CLDAT<1:0> bits are �0�, then PWMxH and/or PWMxL outputs areimmediately driven low (deasserted), bypassing the dead-time logic. This behavior enables thePWM outputs to turn off immediately without any additional delays, as many power conversionapplications require a fast response to fault shutdown signals for accurate control and/or to limitcircuitry damage.

If any of the FLTDAT<1:0> or CLDAT<1:0> bits are �1�, then PWMxH and/or PWMxL outputs passthrough the dead-time logic and, therefore, will be delayed by the specified dead-time value. So,in this case, dead time will be inserted even if a Fault or Current-Limit condition occurs.

30.30 ASSERTING OUTPUTS VIA CURRENT LIMITIt is possible to use the CLDAT bits to assert the PWMxH and PWMxL outputs in response to aCurrent-Limit event. Such behavior could be used as a current �force� feature in response to anexternal current or voltage measurement that indicates a sudden sharp increase in the load onthe power-converter output. Forcing the PWM to an ON state can be considered a�Feed-Forward� action that allows quick system response to unexpected load increases withoutwaiting for the digital control loop to respond.

30.31 PWM IMMEDIATE UPDATEFor high-performance PWM control-loop applications, it may be desirable to force the duty cycleupdates to occur immediately. Setting the IUE bit in the PWMCONx registers enables thisfeature.

In a closed-loop control application, any delay between the sensing of a system�s state and thesubsequent output of PWM control signals that drive the application reduces the loop stability.Setting the IUE bit minimizes the delay between writing the duty cycle registers and the responseof the PWM generators to that change.

30.32 PWM OUTPUT OVERRIDEAll control bits associated with the PWM output override function are contained in the IOCONxregister. If the PENH, PENL bits are set, the PWM module controls the PWMx output pins.

The PWM output override bits allow the user to manually drive the PWM I/O pins to specifiedlogic states independent of the duty cycle comparison units.

The OVRDAT<1:0> bits in the IOCONx registers determine the state of the PWM I/O pins whena particular output is overridden by the OVRENH and OVRENL bits.

The OVRENH and OVRENL bits are active-high control bits. When these bits are set, thecorresponding OVRDAT bit overrides the PWM output from the PWM generator.

30.32.1 Complementary PWM Output ModeWhen the PWM is in Complementary PWM Output mode, the dead-time generator is still activewith overrides. The output overrides and fault overrides generate control signals used by thedead-time unit to set the outputs as requested, including dead time.

Dead-time insertion can be performed when the PWM channels are overridden manually.

30.32.2 Override SynchronizationIf the OSYNC bit in the IOCONx register is set, the output overrides performed by the OVRENH,OVRENL and OVRDAT<1:0> bits are synchronized to the PWM time base. Synchronous outputoverrides occur when the time base is zero.

If PTEN = 0, meaning the PWM timer is not running, writes to IOCONx take effect on the nextTCY boundary.

DS70270B-page 30-42 © 2007 Microchip Technology Inc.

Page 43: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.33 FUNCTIONAL EXCEPTIONS

30.33.1 Power-on Reset ConditionsUpon a Power-on Reset, all registers associated with the PWM module are reset to the statesgiven in Table 30-4. On a device Reset, the PWM output pins are tri-stated.

30.33.2 Sleep ModeThe selected fault input pin has the ability to wake the CPU from Sleep mode. The PWM moduleshould generate an asynchronous interrupt if any of the selected fault pins is driven low while inSleep mode.

It is recommended that the user application disable the PWM outputs prior to entering Sleepmode. If the PWM module is controlling a power conversion application, the action of putting thedevice into Sleep mode causes any control loops to be disabled, and most applications will likelyexperience issues unless they are explicitly designed to operate in an Open-Loop mode.

30.33.3 CPU Idle ModeThe PWM module has a PTSIDL control bit in the PTCON register. This bit determines if thePWM module continues to operate or stops when the device enters Idle mode. Stopped Idlemode functions like Sleep mode, and fault pins are asynchronously active.

� PTSIDL = 1 (Stop module when in Idle mode)� PTSIDL = 0 (Do not stop module when in Idle mode)

It is recommended that the user application disable the PWM outputs prior to entering Idle mode.If the PWM module is controlling a power-conversion application, the action of putting the deviceinto Idle mode causes any control loops to be disabled, and most applications will likelyexperience issues unless they are explicitly designed to operate in an Open-Loop mode.

30.34 REGISTER BIT ALIGNMENTTable 30-4 shows the registers for the Power Supply PWM module. All time-based data for themodule is always bit-aligned with respect to time. For example, bit 3 in the period register, theduty cycle registers, the dead-time registers, the trigger registers and the phase registers alwaysrepresents a value of 8.4 ns, assuming 30 MIPS operation. Unused portions of registers alwaysread as zero.

The use of data alignment makes it easier to write software because it eliminates the need toshift time values to fit into registers. It also eases the computation and understanding of timeallotment within a PWM cycle.

© 2007 Microchip Technology Inc. DS70270B-page 30-43

Page 44: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.35 APPLICATION EXAMPLESThe following sections describe application examples for each of the available PWM modes.

30.35.1 Standard Edge-Aligned PWM ModeIn Standard Edge-Aligned PWM mode, the PWM output is typically connected to a single tran-sistor, which charges an inductor, as shown in Figure 30-24. Buck and Boost converters typicallyuse Standard Edge-Aligned PWM mode.

Figure 30-24: Applications of Standard Edge-Aligned PWM Mode

Buck Converter

+VINL1

PWM1H

+

VOUT

Boost Converter

+VIN

PWM1H

L1 VOUT

+

Period

PWM1H

TON TOFF

Inductor charges during TONTON versus Period controls power flow

DS70270B-page 30-44 © 2007 Microchip Technology Inc.

Page 45: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.35.2 Complementary PWM Output ModeComplementary PWM Output mode is often used in circuits that use two transistors in a bridgeconfiguration where transformers are not used, as shown in Figure 30-25. If transformers areused, then some means must be provided to ensure that no net DC currents flow through thetransformer (which would cause core saturation).

Figure 30-25: Applications of Complementary PWM Output Mode

VOUTL1+VIN

PWM1H

PWM1L

Synchronous Buck Converter

+

+

+VIN

PWM1H

PWM1L

CR T1

Series Resonant Half Bridge Converter

LR VOUT

PWM1L

PWM1H

Dead Time Dead Time Dead Time

Period

© 2007 Microchip Technology Inc. DS70270B-page 30-45

Page 46: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.35.3 Push-Pull PWM ModePush-Pull PWM mode is typically used in transformer coupled circuits to ensure that no net DCcurrents flow through the transformer. Push-Pull mode ensures that the same duty cycle PWMpulse is applied to the transformer windings in alternate directions, as shown in Figure 30-26.

Figure 30-26: Applications of Push-Pull PWM Mode

+

T1 VOUT

Half Bridge Converter+VIN

PWM1H

PWM1L

+

+

L1

PWM1H

PWM1L

TON TOFF

TON

TOFF

Period Period

Dead Time Dead Time Dead Time

T1

++VIN

PWM1H

PWM1L

Push-Pull Buck ConverterL1 VOUT

PWH1H

PWH1L

PWH1L

PWH1H

+VIN

T1 L1 VOUT

Full Bridge Converter

+

DS70270B-page 30-46 © 2007 Microchip Technology Inc.

Page 47: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.35.4 Multi-Phase PWM ModeMulti-Phase PWM mode is often used in DC/DC converters that must handle very fast load cur-rent transients and fit into tight spaces. A multi-phase converter is essentially a parallel array ofbuck converters that are operated slightly out of phase of each other, as shown in Figure 30-27.The multiple phases create an effective switching speed equal to the sum of the individual con-verters. If a single phase is operating with a 333 kHz PWM frequency, the effective switching fre-quency for the circuit is 1 MHz. This high switching frequency greatly reduces output capacitorsize requirements and improves load transient response.

Figure 30-27: Applications of Multi-Phase PWM Mode

+

+VIN

PWM1H PWM2H PWM3H

L1L2

L3

PWM1L PWM1L PWM1L

VOUT

ConverterMulti-Phase DC/DC

PWM1H

PWM1L

PWM2H

PWM2L

PWM3H

PWM3L

© 2007 Microchip Technology Inc. DS70270B-page 30-47

Page 48: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.35.5 Variable Phase PWM ModeVariable Phase PWM mode is used in newer power conversion topologies that are designed toreduce switching losses. In standard PWM methods, any time a transistor switches between theconducting state and the non-conducting state (and vice versa), the transistor is exposed to thefull current and voltage condition for the period of time it takes the transistor to turn on or off. Thepower loss (V * I * Tsw * FPWM) becomes appreciable at high frequencies. The Zero VoltageSwitching (ZVS) and Zero Current Switching (ZVC) circuit topologies attempt to usequasi-resonant techniques to shift either the voltage or current waveforms relative to each other.This action makes either the voltage or the current zero at the time the transistor turns on or off.If either the current or the voltage is zero, no switching loss is generated.

In Variable Phase PWM modes, the duty cycle is fixed at 50 percent, and the power flow iscontrolled by varying the phase relationship between the PWM channels, as shown inFigure 30-28.

Figure 30-28: Application of Variable Phase PWM Mode

PWM1H

PWM1L

PWM2H

PWM2L

Variable Phase Shift

+

Full Bridge ZVT Converter

T1 VOUT

+VIN

PWM1H

PWM1H

PWM1H

DS70270B-page 30-48 © 2007 Microchip Technology Inc.

Page 49: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.35.6 Current Reset PWM ModeIn Current Reset PWM mode, the PWM frequency varies with the load current. This mode differsfrom most PWM modes because the user application sets the maximum PWM period, but anexternal circuit measures the inductor current. When the inductor current falls below a specifiedvalue, the external current comparator circuit generates a signal that resets the PWM time basecounter. The user application specifies a PWM �ON� time, and then, some time after the PWMsignal becomes inactive, the inductor current falls below a specified value and the PWM counteris reset � earlier than the programmed PWM period. This mode is sometimes called ConstantOn-Time mode. This mode should not be confused with Cycle-by-Cycle Current-Limit PWMmode, where the PWM is asserted, an external circuit generates a current fault and the PWMsignal is turned off before its programmed duty cycle would normally turn it off. In this mode,shown in Figure 30-29, the PWM frequency is fixed per the time base period.

Figure 30-29: Application of Current Reset PWM Mode

+ +ACIN CIN

L

IL

PWM1H

D VOUT

COUT

External current comparator resets PWM counterPWM cycle restarts early

This is a variable frequency PWM mode

PWM1H

PWM1H

IL

TON

TOFF

Actual Period

Programmed Period

© 2007 Microchip Technology Inc. DS70270B-page 30-49

Page 50: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.36 METHODS TO REDUCE EMIThe goal in reducing EMI is to move the PWM edges around in time to spread the EMI energyover a range of frequencies. This reduces the peak energy at any given frequency during the EMImeasurement process, which measures long-term averages.

The EMI measurement process integrates the EMI energy into 9-kHz-wide frequency bins.Assuming that the carrier (PWM) frequency is 150 kHz, a 6 percent dither will yield a 9-kHz-widedither.

30.36.1 Method 1: Programmable FRC DitherThis method dithers all of the PWM outputs and the system clock. The advantage of this methodis that no CPU resources are required. It is automatic once it is set up. The user application canperiodically update these values to simulate a more random frequency pattern.

Refer to Section 29.6.2 �FRC Tuning and Dithering� for additional information.

30.36.2 Method 2: Software Controlled DitherThis method uses software to dither individual PWM channels by scaling the duty cycle andperiod. This method consumes CPU resources as follows:

Assume:

4 PWM channels updated @ 150 kHz rate:

600 kHz x (5 clocks (2 mul, 1 tblrdl, 1 mov)) = 3 MIPS additional workload

30.36.3 Method 3: Software Scaling of Time Base PeriodThis method uses software to scale just the time base period. Assuming that the dither rate isrelatively slow (about 250 Hz), the application control loop should be able to compensate for thechanges in PWM period and adjust the duty cycle accordingly.

30.36.4 Method 4: Frequency ModulationThis method varies the frequency at which the PWM cycle is varied (dithered). The frequencymodulation process is similar (mathematically speaking) to phase modulation when analyzedover a small time window.

The PWM module can phase modulate the PWM signals using the phase offset registers. Phasemodulation has the advantage that the software is simpler and faster because multiple multiplyoperations (used for dithering frequency by scaling period and duty cycles) are replaced withfewer additions or simple updates of phase offset values into the phase registers.

This method also has the following advantages:

� Multi-phase and variable phase PWM modes can still be created.� The PWM generators can still use the common time base, which simplifies determining

when a �quiet time� is available for measuring current.

This method has one disadvantage: the phase modulation must be at a relatively high updaterate to achieve usable frequency spreading.

30.36.5 Independent PWM Channel Dithering IssuesMulti-phase or variable phase designs using independent output dithering must consider thefollowing issues:

� The phases are no longer phase aligned.� Control of current sharing among phases is more difficult.

DS70270B-page 30-50 © 2007 Microchip Technology Inc.

Page 51: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.37 EXTERNAL SYNCHRONIZATION FEATURESIn large power conversion systems, it is often desirable to synchronize multiple power controllersto ensure that �beat frequencies� are not generated within the system, or as a means to ensure�quiet� periods during which time current and voltage measurements can be made.

dsPIC30F SMPS devices have input and/or output pins that provide the capability to either syn-chronize the dsPIC30F SMPS device with an external device or have external devices synchro-nized to the dsPIC30F SMPS device. These synchronizing features are enabled via theSYNCEN and SYNCOEN bits in the PTCON control register in the PWM module.

The SYNCPOL bit in the PTCON register selects whether the rising edge or the falling edge ofthe SYNCI signal is the active edge. The SYNCPOL bit in the PTCON register also selectswhether the SYNCO output pulse is active-low or active-high.

The SYNCSRC<2:0> bits in the PTCON register specify the source for the SYNCI signal.

If the SYNCI feature is enabled, the primary time base counter is reset when an active SYNCIedge is detected. If the SYNCO feature is enabled, an output pulse is generated when theprimary time base counter rolls over at the end of a PWM cycle.

The recommended SYNCI pulse width should be more than 100 ns. The expected SYNCOoutput pulse width will be approximately 100 ns.

When using the SYNCI feature, it is recommended that the user application program the periodregister with a period value that is slightly longer than the expected period of the external syn-chronization input signal. This provides protection in case the SYNCI signal is not received dueto noise or external component failure. With a reasonable period value programmed into thePTPER register, the local power conversion process should remain operational even if the globalsynchronization signal is not received.

30.38 CPU LOAD STAGGERINGThe dsPIC30F SMPS device has the ability to stagger the individual trigger comparison opera-tions. This feature helps to level the processor�s workload to minimize situations where theprocessor is overloaded.

Assume a situation where four PWM channels are controlling four independent voltage outputs.Assume further that each PWM generator is operating at 500 kHz (2 μs period) and each controlloop is operating at 125 kHz (8 μs).

The TRGDIV<2:0> bits in each TRGCONx register will be set to �011�, which specifies that everyfourth trigger comparison match will generate a trigger signal to the ADC to capture data andbegin a conversion process.

If the stagger-in-time feature did not exist, all of the requests from all of the PWM trigger registersmight occur at the same time. If this �pile-up� were to happen, some data samples might becomestale (outdated) by the time the data for all four channels can be processed.

With the stagger-in-time feature, the trigger signals are spaced out over time (during succeedingPWM periods) so that all of the data is processed in an orderly manner.

The ROLL counter is a counter connected to the primary time base counter and is incrementedeach time the primary time base counter reaches terminal count (period rollover).

The stagger-in-time feature is controlled by the TRGSTRT<5:0> bits in the TRGCONx registers.The TRGSTRT<5:0> bits specify the count value of the ROLL counter that must be matchedbefore an individual trigger comparison module in each of the PWM generators can begin tocount the trigger comparison events as specified by the TRGDIV<2:0> bits in the TRGCONxregisters.

In the preceding example with the four PWM generators, the first PWM�s TRGSTRT<5:0> bitswould be �000�, the second PWM�s TRGSTRT bits would be set to �001�, the third PWM�sTRGSTRT bits would be set to �010�, and the fourth PWM�s TRGSTRT bits would be set to �011�.Therefore, over a total of four PWM cycles, the four separate control loops could be run, eachwith their own 2 μs time period.

Figure 30-30 illustrates the preceding example of CPU load staggering using the individual PWMtriggers.

© 2007 Microchip Technology Inc. DS70270B-page 30-51

Page 52: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

Figure 30-30: CPU Load Staggering Using Individual PWM Triggers

30.39 EXTERNAL TRIGGER BLANKINGUsing the LEB<9:3> bits in the LEBCONx registers, the PWM module has the capability to blank (ignore) the external current and fault inputs for a period of 0 to 1024 ns. This feature is useful if power transistor turn-on induced transients make current sensing difficult at the start of a PWM cycle.

PWM1H

PWM2H

PWM3H

PWM4H

PTEN = 1

PWM PWM PWM PWM

TRGSTRT = 0TRGDIV = 3

TRGSTRT = 1TRGDIV = 3

TRGSTRT = 2TRGDIV = 3

TRGSTRT = 3TRGDIV = 3

TRIG1<15:3>

TRIG2<15:3>

TRIG3<15:3>

TRIG4<15:3>

PWM PWM PWM PWM

TRIG1<15:3>

TRIG2<15:3>

TRIG3<15:3>

TRIG4<15:3>

The TRGSTRT bits in the TRGCONx registerspecify how many PWM cycles are allowed topass before generating the first trigger. In thecase of PWM4, the first trigger is generatedafter 3 PWM cycles have passed.

The TRGDIV bits provide a postscaler for generating PWMtriggers. In this case, a trigger is produced once every 4 PWMcycles.

Cycle 1 Cycle 2 Cycle 3 Cycle 4 Cycle 5 Cycle 6 Cycle 7 Cycle 8

Note: The �x� shown in the PWM cycle denotes the instance of the trigger.

DS70270B-page 30-52 © 2007 Microchip Technology Inc.

Page 53: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

© 2007 M

icrochip Technology Inc.D

S70270B

-page 30-53

Section 30. Power Supply PW

My

TaFi Bit 3 Bit 2 Bit 1 Bit 0 All

ResetsPT SEVTPS<3:0> 0000

PT � � � FFF0

M 0000

SE � � � 0000

PW � � XPRES IUE 0000

IO CLDAT<1:0> � OSYNC 0000

FC FLTPOL FLTMOD<1:0> 0000

PD 0000

PH � � 0000

DT � � 0000

AL � � 0000

TR � � � 0000

TR TRGSTRT<5:0> 0000

LE � � � 0000

PW � � XPRES IUE 0000

IO CLDAT<1:0> � OSYNC 0000

FC FLTPOL FLTMOD<1:0> 0000

PD 0000

PH � � 0000

DT � � 0000

AL � � 0000

TR � � � 0000

TR TRGSTRT<5:0> 0000

LE � � � 0000

PW � � XPRES IUE 0000

IO CLDAT<1:0> � OSYNC 0000

FC FLTPOL FLTMOD<1:0> 0000

PD 0000

PH � � 0000

DT � � 0000

AL � � 0000

TR � � � 0000

TR TRGSTRT<5:0> 0000

LE � � � 0000

PW � � XPRES IUE 0000

IO CLDAT<1:0> � OSYNC 0000

Power SupplPWM 30

ble 30-4: Power Supply PWM Register Maple Name ADR Bit 15 Bit 14 Bit 13 Bit 12 Bit 11 Bit 10 Bit 9 Bit 8 Bit 7 Bit 6 Bit 5 Bit 4

CON 0400 PTEN � PTSIDL SESTAT SEIEN EIPU SYNCPOL SYNCOEN SYNCEN SYNCSRC<2:0>

PER 0402 PTPER<15:3>

DC 0404 MDC<15:0>

VTCMP 0406 SEVTCMP<15:3>

MCON1 0408 FLTSTAT CLSTAT TRGSTAT FLTIEN CLIEN TRGIEN ITB MDCS DTC<1:0> � �

CON1 040A PENH PENL POLH POLL PMOD<1:0> OVRENH OVRENL OVRDAT<1:0> FLTDAT<1:0>

LCON1 040C � � � CLSRC<3:0> CLPOL CLMODE FLTSRC<3:0>

C1 040E PDC1<15:0>

ASE1 0410 PHASE1<15:2>

R1 0412 � � DTR1<13:2>

TDTR1 0414 � � ALTDTR1<13:2>

IG1 0416 TRIG<15:3>

GCON1 0418 TRGDIV<2:0> �- �- �- �- �- �- �-

BCON1 041A PHR PHF PLR PLF FLTLEBEN CLLEBEN LEB<9:3>

MCON2 041C FLTSTAT CLSTAT TRGSTAT FLTIEN CLIEN TRGIEN ITB MDCS DTC<1:0> � �

CON2 041E PENH PENL POLH POLL PMOD<1:0> OVRENH OVRENL OVRDAT<1:0> FLTDAT<1:0>

LCON2 0420 � � � CLSRC<3:0> CLPOL CLMODE FLTSRC<3:0>

C2 0422 PDC2<15:0>

ASE2 0424 PHASE2<15:2>

R2 0426 � � DTR2<13:2>

TDTR2 0428 � � ALTDTR2<13:2>

IG2 042A TRIG<15:3>

GCON2 042C TRGDIV<2:0> �- �- �- �- �- �- �-

BCON2 042E PHR PHF PLR PLF FLTLEBEN CLLEBEN LEB<9:3>

MCON3 0430 FLTSTAT CLSTAT TRGSTAT FLTIEN CLIEN TRGIEN ITB MDCS DTC<1:0> � �

CON3 0432 PENH PENL POLH POLL PMOD<1:0> OVRENH OVRENL OVRDAT<1:0> FLTDAT<1:0>

LCON3 0434 � � � CLSRC<3:0> CLPOL CLMODE FLTSRC<3:0>

C3 0436 PDC3<15:0>

ASE3 0438 PHASE3<15:2>

R3 043A � � DTR3<13:2>

TDTR3 043C � � ALTDTR3<13:2>

IG3 043E TRIG<15:3>

GCON3 0440 TRGDIV<2:0> �- �- �- �- �- �- �-

BCON3 0442 PHR PHF PLR PLF FLTLEBEN CLLEBEN LEB<9:3>

MCON4 0444 FLTSTAT CLSTAT TRGSTAT FLTIEN CLIEN TRGIEN ITB MDCS DTC<1:0> � �

CON4 0446 PENH PENL POLH POLL PMOD<1:0> OVRENH OVRENL OVRDAT<1:0> FLTDAT<1:0>

Page 54: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Fam

ily Reference M

anual

DS

70270B-page 30-54

© 2007 M

icrochip Technology Inc.

3:0> FLTPOL FLTMOD<1:0> 0000

0000

� � 0000

� � 0000

� � 0000

� � � 0000

TRGSTRT<5:0> 0000

� � � 0000

� � � � 0000

it 4 Bit 3 Bit 2 Bit 1 Bit 0 All Resets

FCLCON4 0448 � � � CLSRC<3:0> CLPOL CLMODE FLTSRC<

PDC4 044A PDC4<15:0>

PHASE4 044C PHASE4<15:2>

DTR4 044E � � DTR4<13:2>

ALTDTR4 0450 � � ALTDTR4<13:2>

TRIG4 0452 TRIG<15:3>

TRGCON4 0454 TRGDIV<2:0> �- �- �- �- �- �- �-

LEBCON4 0456 PHR PHF PLR PLF FLTLEBEN CLLEBEN LEB<9:3>

Reserved 0458-47F

� � � � � � � � � � � �

Table 30-4: Power Supply PWM Register Map (Continued)File Name ADR Bit 15 Bit 14 Bit 13 Bit 12 Bit 11 Bit 10 Bit 9 Bit 8 Bit 7 Bit 6 Bit 5 B

Page 55: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

Section 30. Power Supply PWMPow

er SupplyPW

M

30

30.40 RELATED APPLICATION NOTESThis section lists application notes that are related to this section of the manual. These applica-tion notes may not be written specifically for the dsPIC30F SMPS device Product Family, but theconcepts are pertinent and could be used with modification and possible limitations. The currentapplication notes related to the Power Supply PWM module include the following:

Title Application Note #No related application notes at this time.

Note: Please visit the Microchip web site (www.microchip.com) for additional ApplicationNotes and code examples for the dsPIC30F SMPS device family.

© 2007 Microchip Technology Inc. DS70270B-page 30-55

Page 56: Section 30. Power Supply PWM - Microchip Technologyww1.microchip.com/downloads/en/DeviceDoc/70270B.pdf · 2007-02-14 · dsPIC30F Family Reference Manual DS70270B-page 30-2 ' 2007

dsPIC30F Family Reference Manual

30.41 REVISION HISTORY

Revision A (February 2007)This is the initial released revision of this document.

Revision B (February 2007)Minor edits throughout document.

DS70270B-page 30-56 © 2007 Microchip Technology Inc.