Reference Manual Rev. 1, 10/2020

# Totem-Pole Bridgeless PFC Design Using MC56F8xxxx



Document identifier: DRM174

## **Contents**

| Chapter 1 Introduction                                 |    |
|--------------------------------------------------------|----|
| 1.1 Application outline                                |    |
| 1.2 Totem-Pole bridgeless PFC topology and features    |    |
| 1.3 MC56F8xxxx controller advantages and features      |    |
|                                                        |    |
| Chapter 2 System description                           |    |
| 2.1 Structure                                          |    |
| 2.2 Control logic                                      |    |
| 2.3 Working mode                                       |    |
| 2.4 Control loop introduction                          | 10 |
| Chapter 3 Hardware design                              | 16 |
| 3.1 Specification                                      |    |
| 3.2 PFC choke design                                   |    |
| 3.3 Power circuits and drives                          |    |
| 3.4 Analog signal sensing circuits and Auxiliary power | 20 |
| 3.5 Communication with backward LLC                    | 21 |
| 3.6 PCB layout considerations                          | 22 |
| Chapter 4 Software design                              | 25 |
| 4.1 Parameter normalization                            |    |
| 4.2 State machine                                      |    |
| 4.3 Control timing                                     |    |
| 4.4 Drive signal generation logic                      | 28 |
| 4.5 Fault protection                                   |    |
| 4.6 Peripherals settings                               |    |
| 4.7 Code runs in RAM                                   |    |
| Chapter 5 Getting started                              | 33 |
|                                                        |    |
| 5.1 System development environment                     |    |
| 5.2 Debugging TF-FFC board with FreewASTER             |    |
| Chapter 6 Testing                                      | 38 |
| 6.1 System efficiency                                  | 38 |
| 6.2 Startup performance                                |    |
| 6.3 Steady state performance                           |    |
| 6.4 Dynamic performance                                | 42 |
| Chapter 7 Revision history                             | 46 |
|                                                        |    |

## Chapter 1 Introduction

#### 1.1 Application outline

This reference design manual describes a Totem-Pole Bridgeless Power Factor Correction (PFC) design using MC56F8xxxx DSC.

This document focuses on the key parts design of Totem- Pole bridgeless PFC. System description part includes the system structure, different modulation mode, and control loop. Hardware design part includes PFC choke design, power circuits and drive circuits, sensing circuits and PCB layout consideration. Software design part mainly includes the system state machine, control timing, drive signal generation logic and fault protection.

#### 1.2 Totem-Pole bridgeless PFC topology and features

Power Factor Correction control scheme is widely adopted for power conversion of AC-DC application.



The earliest topology applied in AC-DC power conversion is Passive Power Factor Correction (PPFC) technique. The scheme put a filter inductor between the rectifier and bus capacitor. Figure 1 shows the topology.

In practical application, inductor is put between AC source and rectifier bridge. As shown in Figure 2, the improved PPFC topology will not have DC component in the inductor, which can prevent the inductor from saturation. The advantages of PPFC are that it is simple, reliable, without need of real- time control and low cost. In addition, this topology will limit the current total harmonic distortion under 30% by suppressing odd harmonics. In this application, inductor L is the **core** of design. When inductance is larger, Total Harmonic Distortion (THD) is smaller and current wave is more sinusoidal.

However, the phase difference will become bigger.

The disadvantages of the topology is that the passive component is often heavy with low power factor. This makes the power loss severe and produce a lot of heat. The noise of power frequency vibration is also a problem. The application is adopted under 300 W, especially applied in occasion that has no much limit for space, weight but sensitive with cost.

Reference Manual 3/47



The most common topology for AC-DC application is Active Power Factor Correction (APFC), it is the most effective way to improve power factor. Figure 3 shows the principle block diagram of APFC. The basic method is: rectify the alternating voltage to direct value, and then conduct DC-DC transformation by rectified voltage. There are voltage and current loops. Outer loop ensures that the bus voltage keep up with the set value. Inner loop ensures that the current wave can real-time track the input voltage wave.



APFC uses full-controlled semiconductor device. Figure 4 shows the topology of conventional PFC. The control scheme will help reduce the THD of the current below 5%, and make the PF value over 0.99 high. Besides, the input voltage can range from 85-265 V with high stability, low vibration and noise.

APFC techniques can effectively reduce harmonic content, improve power factor to satisfy current standard.

The disadvantages of the topology is the high cost and complexity of controlling circuits. Besides, with higher switch frequency, the switched loss becomes significant. Thus, it is applied in low power occasion.



Figure 5. Totem-pole bridgeless Power Factor Correction topology

In conventional PFC topology, there are two bridge diode voltage drops and one drop at the boost stage, which set a limit on system efficiency, especially for low voltage and large current occasion. In this case, bridgeless PFC converter was put forward by eliminating the diode bridge. Totem-Pole bridgeless is one of them. Figure 5 shows the topology of the basic totem-pole bridgeless PFC boost rectifier. It shows that two GaN HEMT are used as boost converters. And two low resistance silicon MOSFETs are placed to eliminate diode drop to improve the efficiency.

The significantly smaller reverse recovery charge of GaN HEMT compared with silicon MOSFETs makes the totem-pole bridgeless PFC practical. It meets the demand for increasing power density of switched-mode power supplies by adopting high switching frequency as well as not to increase switching losses at Pulse Width Modulated (PWM) converters. We choose the first generation GaN as the power device, whose reverse recovery charge is 20 times lower than S<sub>i</sub> counter part. It's suitable for hard-switched bridge.

The Totem-Pole bridgeless PFC focus on minimizing power loss in the conduction path. As shown in Figure 5, it consists of two fast GaN HEMT, Q1&Q2, operating at a pulse-width-modulation frequency (we use 80 kHz) and a pair of slow but low resistance MOSFETs, SD1&SD2, operating at power frequency (45-60 Hz). Thus the conduction path includes one fast switch and one slow switch without diode drop. The switch SD1&SD2 are the synchronized rectifier. During positive AC cycle, SD1 is on while SD2 is OFF and vice versa.

Table 1 shows the difference between conventional PFC and Totem-pole bridgeless PFC. Two switches of Totem-pole bridgeless PFC plays the same role with fast recovery diode as conventional PFC.

Table 1. Device comparison of conventional PFC and Totem-pole bridgeless PF

| _                            | Low speed diode | High speed diode | Switch device | Conduction path ON/(OFF)                                              |
|------------------------------|-----------------|------------------|---------------|-----------------------------------------------------------------------|
| Conventional PFC             | 4               | 1                | 1             | 2 low speed diode + 1 switch/(2 low speed diode + 1 high speed diode) |
| Totem-Pole<br>Bridgeless PFC | 2 (Si MOSFET)   | 0                | 2 (GaN)       | 1 S <sub>i</sub> MOSFET + 1 switch (GaN)                              |

#### 1.3 MC56F8xxxx controller advantages and features

The 56F8xxxx microcontroller is a member of the 32-bit 56800EX core-based Digital Signal Controllers (DSCs). Each device in the family combines, on a single chip, the processing power of a 32-bit DSP and the functionality of a microcontroller with a flexible set of peripherals. Due to its cost-effectiveness, configuration flexibility, and compact program code, 56F8xxxx is well-suited for many consumers and industrial applications.

The following list summarizes the superset of features across the entire 56F8xxxx family.

- 56800EX 32-bit DSC core
- Up to 100MIPS at 100 MHz core frequency
- Protects supervisor programs and resources from user programs
- One/Two 8-channel eFlexPWM module(s) with NanoEdge<sup>™</sup> placement and enhanced capture
- · Two separate 8-channel 12-bit cyclic ADC
- · One windowed watchdog timer, power Supervisor
- On-chip 8 MHz/400 kHz relaxation oscillator, 200 kHz Relaxation Oscillator and 4MHz to 16 MHz external Crystal Oscillator (XOSC)
- · Inter-Module Crossbar with AND-OR-INVERT function
- Programmable Interrupt Controller (INTC) with 4 level priority
- · One/Two Quad Timer(s), two Periodic Interval Timers
- · Two 12-bit DAC modules
- Four High Speed Comparators with integrated DAC references

The switched-mode power supply applications benefit greatly from the flexible eFlexPWM module, fast ADC module, on-chip analog comparator module, and inter-module crossbar with AOI function.

This Pulse Width Modulation (PWM) module can generate various switching patterns, including highly sophisticated waveforms. It can be used to control all known motor types and is ideal for controlling different Switched Mode Power Supplies (SMPS) topologies as well, it has the following features:

- 16 bits of resolution for center, edge aligned, and asymmetrical PWMs
- · Fractional delay for enhanced resolution of the PWM period and edge placement
- PWM outputs that can operate as complementary pairs or independent channels
- Support for synchronization to external hardware or other PWM, half cycle reload capability
- Multiple output trigger events can be generated per PWM cycle via hardware
- · Fault inputs can be assigned to control multiple PWM outputs, programmable filters for fault inputs
- · Independently programmable PWM output polarity, independent top and bottom dead time insertion
- · Each complementary pair can operate with its own PWM frequency and dead time values
- All outputs can be programmed to change simultaneously via a FORCE OUT event

The eFlexPWM offers flexibility in its configuration, enabling efficient control of any SMPS topology. The eFlexPWM module is capable of free control of rising and falling edges for each PWM output and includes automatic complementary signal generation and dead time insertion. Due to NanoEdge placement the eFlexPWM can generate duty cycles and frequencies with high a resolution of up to 312 ps.

The eFlexPWM module can also generate up to six synchronization events per sub-module to provide synchronization with other modules (ADC, Quad-timer).

This Totem-pole bridgeless PFC application uses the eFlexPWM module for generating two PWM signals for primary side power MOSFETs and two PWM signals for secondary side synchronous rectifier, and provide the trigger signal for ADC sample.

#### ADC features include:

- · Two independent 12-bit analog-to-digital converters (ADCs)
- Two 8-channel external inputs
- Built-in ×1, ×2, ×4 programmable gain pre-amplifier
- · Support of analog inputs for single-ended and differential, including unipolar differential, conversions
- · Sequential, parallel, and independent scan mode
- · All 16 samples have offset, limit and zero-crossing calculation supported
- ADC conversions can be synchronized by any module connected to the internal crossbar module, such as PWM, timer, GPIO, and comparator modules
- · Support for simultaneous triggering and software-triggering conversions
- · Support for a multi-triggering mode with a programmable number of conversions on each trigger
- Each ADC has ability to scan and store up to eight conversion results.

This Totem-pole PFC application uses the ADC module in triggered parallel mode, ADC samples are triggered at the center of PWM signal. ADCA sampled the input voltage and output bus voltage, ADCB sampled input current. The Inter-Module Crossbar and AND-OR-INVERT logic features:

- Provides generalized connections between and among on-chip peripherals: ADCs, 12-bit DAC, comparators, quad-timers, eFlexPWMs, EWM, and select I/O pins
- User-defined input/output pins for all modules connected to the crossbar
- · DMA request and interrupt generation from the crossbar
- · Write-once protection for all registers
- AND-OR-INVERT function provides a universal Boolean function generator that uses a four- term sum-of-products expression, with each product term containing true or complement values of the four selected inputs (A, B, C, D)

This Totem-pole bridgeless PFC converter application uses the Inter-Module Crossbar and AND-OR- INVERT logic to provide interconnection between the eFlexPWM module and ADC module, interconnection between fault signal and on-chip comparator, generate the synchronization rectifier PWM by multiple signals from eFlexPWM and on-chip comparator.

The application also uses other peripherals like on-chip comparator for hardware protection and two SCI module for communication with the primary side and remote control via PC and several GPIOs for LED indication.

Reference Manual 7 / 47

## Chapter 2 System description

#### 2.1 Structure

The application system incorporates power stage, control board and isolated Universal Asynchronous Receiver/Transmitter (UART) port to communicate with other devices, such as backward stage LLC resonant converter.

The control module involves voltage/current sensing circuitry, drivers, PM Bus communication and the DSC controller board.

The auxiliary power supply takes power directly from the DC Bus, then generates the desired voltages with Flyback converter.

The sensing circuitries are used for sensing input voltage, input current, DC bus voltage and accommodates them to the DSC acceptable voltage level.

The drivers are used for both amplification of DSC PWM signals and synchronous rectifier's MOSFET. The synchronous rectifiers are used to reduce the conduction losses in replace of conducting diodes.

DSC MC56F8xxxx controller is placed on the control daughter card and connected to power board via PCI slot. The control card is powered from power board side and it works as the master for the whole application.

The controller is also used to communicate with other equipment and the boards. One UART is applied to communicate with backward LLC stage, another UART to USB conversion is applied to communicate with host PC for FreeMASTER or firmware updating, one IIC reserved for PM Bus network.



Totem-Pole Bridgeless PFC Design Using MC56F8xxxx, Rev. 1, 10/2020

8 / 47

## 2.2 Control logic



The totem-pole bridgeless PFC consists of a pair of GaN HEMT switches(Q1&Q2) that operates at PWM frequency. They work as a pair of boost converters within a half cycle. In either cycle, one GaN HEMT will act as a master switch to increase the boost inductor L's current and the other transistor will act as a slave switch to force the current flow to the DC output meanwhile releasing energy. The roles of the pair interchange when AC polarity changes. And dead time is added to avoid the short of the bridge for GaN and Silicon MOSFET.

## 2.3 Working mode



The constant frequency controller is hard to ensure good input current shape in DCM at light load due to the nonlinear characteristics of the converter especially for GaN synchronous rectification. The poor input current shape in DCM will cause high current distortion and large RMS current drawn, which results in poor power factor. Besides, at light load, the load independent constant losses, which consists of gate charge loss, parasitic capacitance loss in MOSFET and core loss in inductor, become dominant and will cause very poor efficiency.

In this application, the control will ensure high efficiency by tuning on and off the PFC to regulate the output voltage within a hysteresis bandwidth.

The PFC is turned off when the load is very light. In this application, when the input current reference is equaled to 0.25 A for a certain time which is the low limit of current reference, PFC will enter the burst mode, as shown in Figure 8. PFC is turned off and output voltage decreases. When output voltage reaches <code>VDC\_BURSTOFF</code>, PFC is turned on again with constant reference current 0.25 A. If the output voltage drops quickly to a lower threshold, PFC will enter back to normal mode again.

## 2.4 Control loop introduction

Based on the MC56F8xxxx, a digital PFC rectifier is implemented as shown in .

Power Factor (PF) is defined as the ratio between AC input's real power and apparent power. Assuming input voltage is a perfect sine wave, PF can be defined as the product of current distortion and phase shift. The PFC control loop's tasks are:

- · Controls inductor current makes the current sinusoidal and maintains the same phase as the input voltage.
- · Controls output voltage makes the output voltage equaled to target value.

#### 2.4.1 Arithmetic of current reference



According to PFC theory, PFC arithmetic can be divided into three parts.

• Voltage outer loop insures the output voltage follows the reference-constant voltage output.

- Reference arithmetic insures that the current reference follows the sine reference.
- Current inner loop insures the input current follows the given current reference.

In analog arithmetic, the input voltage sample is introduced as the input current's reference so the ripple voltage is introduced to current control at the same time. In this application, we use:

$$i_{ref} = rac{V_{ac} \cdot V_c}{V_{rmc}^2}$$

#### Where:

- Vac is the input voltage involved to ensure the current wave follows the input voltage wave.
- V<sub>c</sub> is the output of voltage regulator.
- V<sub>rms</sub> is the RMS value of input voltage.

## 2.4.2 Voltage and Current Loop Design

PI loop control is widely used and classical in industry control. In this application, the voltage and current loops adopt PI regulator arithmetic. Figure 10 represents the small signal model block diagram of boost converter. The definition of variables will be represented blow.

#### Where:

- R<sub>m</sub> is the equivalent resistor of the equivalent multiplier/divider output current.
- g<sub>c</sub> is the gain between equivalent multiplier/divider output current and the output of voltage regulator.

The subscript **p** denotes the small-signal perturbations.



Reference Manual 11/47

#### 2.4.2.1 Current loop control design

Figure 11 represents the control block diagram of current loop.



#### Where:

- H<sub>i</sub>(s) is the current loop controller, which is designed to maintain the stability of current control loop.
- G<sub>id</sub>(s) is the duty-to-current transfer function.
- $F_m$  is the pulse-width ratio.

#### In this application:

- F<sub>m</sub>= 1/625.
- $\bullet$  R<sub>s</sub> is the equivalent sample resistor for unit current.
- H<sub>e</sub>(s) is a second-order filer for current sample.
- AD Gain =  $2^{15}/3.3$ .

The transfer function of open current loop excluding H<sub>i</sub>(s) is:

$$T_i(s) = F_m \times G_{id}(s) \times R_s \times H_e(s)$$

Figure 12 shows the bode plot of current loop excluding H<sub>i</sub>(s). From the bode plot, the bandwidth is only 34 Hz.



To have good current loop performance, the bandwidth needs to be within 3~10 kHz, and phase margin needs to be over 40 degrees. In this application, we set a zero in 3.5 kHz and set the gain to be 0.022.

$$H_i(s) = K_p + \frac{K_i}{s} = \frac{K_p(s + 2 \cdot \pi \cdot 3500)}{s}$$

Therefore, we have:

$$\begin{cases} Kp = 0.022 \\ Ki = 480 \end{cases}$$

The PI algorithm in the continuous time domain is expressed as:

$$y(t) = K_p \cdot e(t) + \int_0^t K_i e(t) dt = K_p \cdot e(t) + y_I(t)$$

The integral term above can be rewritten into discrete time domain by Backward Euler transformation:

$$y_I(n) = y_I(n-1) + K_i \cdot T_s \cdot e(n)$$

The discrete time domain representation of PI algorithms is:

$$y(n) = K_p \cdot e(n) + y_I(n-1) + K_i \cdot T_s \cdot e(n)$$

Totem-Pole Bridgeless PFC Design Using MC56F8xxxx, Rev. 1, 10/2020
Reference Manual

13 / 47

Therefore, we can get:

$$\begin{cases} K_{pz} = K_p = 0.022 \\ K_{iz} = K_i \cdot T_z = 0.006 \end{cases}$$

Figure 13 shows the bode plot of current loop including Hi(s). From the bode plot, the bandwidth is around 8 kHz. And the phase margin is over 55 degrees. Both of them meet our requirements.



## 2.4.2.2 Voltage loop control design

The control-to-output voltage transfer function is given as below:

$$\frac{v_{op}}{v_{cp}} = \frac{F_m g_c R_m H_i(s) G_{vd}}{1 + T_i}$$

Where:

-  $G_{vd}$  is the duty-to-output transfer function.

In this application,  $g_c$ = 1/ $V_{rms}$ .

For resistive load, the following approximations are valid:

$$\frac{v_{op}}{v_{cp}} = g_c \frac{R_m V_{rmc} \frac{R_2}{2}}{R_z V_o s C}$$

To have good voltage loop performance, the bandwidth needs to be within 2-10 Hz in order to reduce the effect of input voltage ripple towards inductor current regulation. In this application, we set a zero in 12 Hz. Then, the whole open loop can be defined as:

$$R_{v}(s) = g_{c} \frac{R_{m} V_{rmu} \frac{R}{2}}{R_{z} V_{o} s C} H_{v}(s)$$

#### Where:

• H<sub>v</sub>(s) is the voltage loop controller.

Figure 14 shows the bode plot of voltage loop. It can be seen that voltage loop bandwidth is about 9 Hz.



Reference Manual 15 / 47

## Chapter 3 Hardware design

This chapter describes the totem-pole bridgeless PFC hardware design and provides the layout consideration.

## 3.1 Specification

Table 2. Totem-pole bridgeless PFC specification

| Parameter           | Min. | 110 V <sub>ac</sub> input | 220 V <sub>ac</sub> input | Max.  |
|---------------------|------|---------------------------|---------------------------|-------|
| Input voltage (RMS) | 85 V | _                         | _                         | 265 V |
| Input current (RMS) | _    | 2.7 A                     | 2.7 A                     | _     |
| Output voltage      | _    | 380 V                     | 380 V                     | _     |
| Output current      | _    | 0.789 A                   | 1.579 A                   | _     |
| Output power        | _    | 300 W                     | 600 W                     | _     |
| iTHD                | _    | < 5%                      | < 5%                      | 5 %   |
| Power factor        | 0.95 | > 0.95                    | > 0.95                    | _     |
| Efficiency          | _    | 95%                       | 98%                       | _     |

## 3.2 PFC choke design

Calculate the PFC choke according to the choke current ripple, and we set  $\triangle$ Ilmax = 35%Ilpk, and below is the calculation process.

Set the Vinmin 85Vac with 350W load, and will calculate the choke inductance under this condition.

$$I_{Lrmz} = \frac{P_{in}}{V_{inrmz}} = \frac{P_{out}}{\eta V_{inrmz}} = 4.334A$$

$$I_{Lpk} = \sqrt{2} \times I_{Lrms} = 6.130A$$

The operation frequency is 80 kHz and  $t = 12.5 \mu s$ .

Sendust core: CS400060 core is selected to make the choke.

$$L_{\min} = \frac{V_{\text{out}}}{4 \times f_{\text{SW}} \times \Delta I_{L_{\max}}} = \frac{380}{4 \times 80k \times 6.130 \times 0.35} = 550uH$$

$$N = \sqrt{\frac{L_{\min}}{A_l}} = 80$$

The detailed information for the PFC choke is as follows:

1. Core:

Reference Manual 16 / 47

17 / 47

· Type: Toroid

• Size: 2 × 39.90OD × 24.10ID × 14.5H

· Material: 60

• Magnetics, Sendust core: CS400060

• KDM, KS157-060A

2. Construction: 80 Turns (reference), D1.02 mm × 2 Cu wire

3. Inductance: 600 uH ± 10% [100 kHz 0.3V]

4. Schematic: Rated Current: 10 A



### 3.3 Power circuits and drives

Figure 16 shows the power circuits for the EMI circuits, inrush limitation circuits, GaN MOSFET bridge and Si MOSEFT bridge. C31A, C31, C32 is used to absorb the voltage spike of GaN. And these ceramic capacitors should be placed as close as possible to GaN.



R20 and K1 are for the inrush limitation circuits. 27R power resistor is selected to prevent the high pulse current when the system is powered on.

**GaN MOSFET TPH3006PS** is chosen as main switch component. For the high recovery speed (30 ns) of body diode, it is suitable to act as the BOOST PFC free wheel diode, and brings high efficiency.

The common S<sub>i</sub> MOSFET IPP60R099C6 (Q1, Q2) is selected to realize the grid power frequency synchronization function, which will help to improve the system efficiency more, and will replace the low speed rectifier diode.



CASR 6-NP current transducer is for the choke current sensing, and we set the primary side power circuits in series connection mode to increase the gain between the primary to secondary, which will enhance the choke current signal's amplitude.

Reference Manual 18 / 47



Because of the critical driver requirements for the GaN MOSFETs, the isolated and individual driver IC SI8230 is selected to drive the GaN MOSFET and Si MOSFET. A small RC filter is placed between the DSC and driver IC to decrease the noise, otherwise the disturbance signal may cause the mistake pulse on the driver IC, and one diode is paralleled with the resistor to let the PWM change from high to low level in time. And the bridge high side and low side MOSFETs are driven with the individual GND, this will help to decrease the disturbance between them. The IC's drive current is 0.5 A, and this can meet the requirement.

Totem-Pole Bridgeless PFC Design Using MC56F8xxxx, Rev. 1, 10/2020

### 3.4 Analog signal sensing circuits and Auxiliary power



Figure 19 shows the Vac divider circuits and the  $V_{ac}$  polarity circuits. The  $V_{ac}$ L and  $V_{ac}$ N is connected to the DSC ADC pin, and this signal will be used to convert the  $V_{ac}$  amplitude, and will be used for the system control loop, such as the current reference, and  $V_{rms}$  calculation.

The comparator LT1719 is used for the  $V_{ac}$  polarity detection, and one RC filter is added for the noise decrease, and one transistor of Q4 is used to make the signal more clean. The Q4 should be placed closely to DSC.



We use the common resistor divider circuits to detect the high voltage signal  $V_{bus}$ . And as the DSC ADC input port is with high resistance, amplifier is not needed on this voltage circuits. However the R192, R193, R194 should be power resistors. Package can be 1206 or similar.

For the choke current analog circuits, one low pass filter is used to deal with the noise and ripple. The filter bandwidth is 13.5 kHz, and this will affect the system PF value and THDi, so when adjust the PFC control parameter, please pay attention to this filter's parameter too, and find the best performance.



One Flyback converter generates the auxiliary power, including the driver voltage 12 V, driver chip power 5 V, and the digital  $V_{cc}$  3.3 V. NXP TEA1721 chip is selected to control the converter, and this design can operation normally under 85  $V_{ac}$  to 265  $V_{ac}$ .

#### 3.5 Communication with backward LLC



Figure 22 shows the SCI connection for totem-pole PFC.

Reference Manual 21/47

- Pin 1 is the SCI RxD pin.
- Pin 2 is the SCI TxD pin.
- · Pin 3 connects to the ground.
- Pin 4 connects to 3.3 V.

## 3.6 PCB layout considerations

In totem-pole bridgeless PFC reference design, the input voltage and Vdc output are both high voltage, and system is working in high frequency mode 80 kHz with high dv/dt and di/dt. Thus the PCB layout need to be well considered, especially for following points:

- · The input and output current loop routing.
- Power ground copper pouring to avoid influence by high frequency and high current signal.
- · Heat dissipation for power components.
- · The absorb circuits placement.
- · Distance consideration for high voltage circuits.
- · Routing method for the Sensitive signals.

Figure 23 shows the placement for the totem-pole bridgeless PFC. The power loop should be as small as possible. Make sure the output current flow through the filter circuits first before it arrived at the output port. And the control circuits should be isolated from the power components, otherwise those signal will be disturbed by the high frequency switching power signal.



- 1: EMC filter circuits
- 2: Power circuits
- Signal and DSC control board circuits
- 4: Auxilary power circuits

Figure 23. Main board placement strategy

Except the placement, some other sensitive circuits should be taken into consideration.

1. GaN MOSFET driver circuit trace

Reference Manual 22 / 47

The driver chip should be placed as closely as possible to the GaN MOSFET, and the drive signal to G pin and the low side S pin loop should be as small as possible. Figure 24 shows the routing method.



2. High voltage ceramic capacitor absorb circuits for the high speed GaN MOSFET bridge. C30,C31, C32,C33 should be placed very closely to the high side GaN MOSFET U4, and the capacitor GND should be as close as possible to the U7 S pin.



3. Because this is the power system, the GND strategy is very important. We should separate the power GND, control GND and the analog AGND, the power GND and control GND should be connected together at the Vbus E-cap pin. Figure 26 shows the GND routing method.



Figure 26. Totem-pole bridgeless PFC GND routing strategy

## Chapter 4 Software design

This application core is the MC56F8xxxx digital signal controller. This low-cost DSC has enough peripherals and features suitable for implementation of full digital control of totem-pole bridgeless PFC.

The software is written in C language using Code Warrior, and calls the embedded software library (FSLESL) for time saving. For more information about how to use these libraries in the Code Warrior project, see *Inclusion of DSC Freescale Embedded Software Libraries in CodeWarrior 10.2* (document AN4586).

This section describes the design of the software blocks, including software structure, configuration of the DSC peripherals, control timing, implementation of codes run in ram and boot loader.

#### 4.1 Parameter normalization

In order to make full use of DSC resources, the application related physical quantities are all normalized to fixed-point decimal format, namely Q data format.

The relationship between actual value of the physical quantity and its normalized value is shown as follows.

$$Frac \ value = \frac{actual \ value}{quantization \ range}$$

#### Where:

- Frac value is the normalized value of the physical quantity.
- · Actual value is the actual value of the physical quantity expressed in unit.
- · Quantization range is the maximum measurable value of this physical quantity.

#### 4.2 State machine

This application uses the state machine to control the system flow, as shown in Figure 27. After reset the DSC configures all peripherals, the system enters a never ending loop including the application state machine. The application state machine includes four states:

- INIT: Variable initialization.
- STOP: The system is initialized and checking for the start conditions; PWM output is disabled.
- **RUN**: The system is running. The run sub-state is called. The PWM output is enabled or disabled according to the load and can be stopped by **Stop** command.
- FAULT: the system faces a fault condition and PWM output is disabled.

After the parameters initialization, the application state machine continues into the STOP state.

The software regularly checks the PFC\_run instruction to decide whether to start up. When the command PFC\_run is set, the input voltage RMS is detected to see whether it satisfies the requirements. If it is, after the output voltage reaching stable value with relay closed, the application state machine continues into the RUN state. In this state, the controller starts to take effect to achieve given output voltage and current according to load. Besides, the PFC\_run instruction is also regularly checked in RUN state. When the PFC\_run is cleared, the application state machine goes back to **STOP** state and waits for the PFC\_run command to be set again.

Under each state, if any fault is detected, the application state machine enters **FAULT** state. In this state, fault detection is still executed and whether to restart the application is optional. If allowed, when the fault condition is certainly cleared, the application state machine restarts from **INIT** state. If not, the software stays in a never ending loop and output of the converter is disabled. The system needs to power up again for restart.

Reference Manual 25 / 47



The **RUN** state is divided into three sub-state according to PFC application, as shown in Figure 27(b). When application state machine transits from **STOP** to **RUN**, the system first comes into the soft-start sub-state. The bus voltage reference will follow a ramp to make the bus voltage rise smoothly. After the output voltage or its reference reaches the target, system transfers into the **NORMAL** sub-state. Under the **NORMAL** sub-state, when the load is too light, system will come into the **LIGHTLOAD** sub-state. And vice versa, the system will come from **LIGHTLOAD** to **NORMAL** when the load increases and makes the output voltage lower than the burst low limit. The application main state machine is declared in <code>state\_machine.c</code> and <code>state\_machine.h</code>. It is declared as:

```
/* State machine control structure */
typedef struct
{
   __pmem SM_APP_STATE_FCN_T const* psState; /* State functions */
   __pmem SM_APP_TRANS_FCN_T const* psTrans; /* Transition functions */
SM_APP_CTRL uiCtrl; /* Control flags */
```

Reference Manual 26 / 47

```
SM_APP_STATE_T eState; /* State */
} SM_APP_CTRL_T;
```

It consists of four parts:

- psState: The pointer to the user state functions.
- psTrans: The pointer to the user transition functions. When the system transfers between different states, corresponding transition function is called.
- · uiCtrl: The system flow control flag.
- · estate: The actual state of the state machine.

The state machine is periodically called in the software by inline function which calls the user defined state function. The corresponding user end state functions and transition functions are defined in PFC statemachine.c.

```
/* pointer to function with a pointer to state machine control structure */ typedef void
(*PFCN_VOID_PSM) (SM_APP_CTRL_T *sAppCtrl);

/* State machine functions field (in pmem) */ __pmem const PFCN_VOID_PSM gSM_STATE_TABLE[4] =
{SM_StateFault, SM_StateInit, SM_StateStop, SM_StateRun};

/* State machine function */ extern inline void SM_StateMachine(SM_APP_CTRL_T *sAppCtrl)
{ gSM_STATE_TABLE[sAppCtrl -> eState](sAppCtrl); }
```

The sub-state functions and corresponding transition functions are defined in PFC\_statemachine.c and are called when the system is in the **RUN** state as the same way as the main state.

## 4.3 Control timing

The PFC software consists of two periodical interrupts and a background loop. The first periodical interrupt PWM0\_ISR() is driven by the VAL0 compare event from eFlexPWM SM0. This routine is configured for higher priority to execute the inner current loop calculation at 80 kHz and get the desired switching signal. The other periodical interrupt PWM1\_ISR() is driven by the VAL0 compare event from eFlexPWM SM1. This routine is used as a lower priority to execute outer voltage loop calculation at 10 kHz and the input voltage and current RMS are calculated here when a zero-cross is detected. The background loop runs in an endless loop. It includes the application state machine and communication with PC (FreeMASTER) and the backward LLC.

To summarize, PWMO ISR() is a time critical routine. The FSLESL is applied to minimize the total execution time.

In this PFC application, PWM output signal is re-routed onto the output trigger ports so that it can be sent to the chip routing logic through XBAR and AOI block to generate the final drive signal. Since the output trigger port is connected with PWM output signal, we need additional sub-module to trigger ADC A&B sample. MC56F8xxxx eFlexPWM module has four sub-modules SM0-4. SM0 is used to generate higher priority interrupt service request PWM0\_ISR() which updates PWM output duty and synchronize the ADC sample. SM1 is used to generate PWM1\_ISR() which executes voltage loop calculation. SM2 is used to provide output trigger to ADC A&B sample. The ADC trigger is a little bit ahead of the switch midpoint, so that center aligned PWMs ensures ADC sampling point at the center of PWM and not affected by the PWM switch operation and can get the middle value of inductor current when current rises. Besides, the timing of SM0 VAL0 event and ADC trigger makes register push, algorithm that doesn't need real time sample results and ADC sampling operate simultaneously which leaves more time for other algorithm calculation.

Reference Manual 27 / 47

28 / 47



When counter matches SM2 VAL0, <code>PWM\_OUT\_TRIGO</code> of SM2 is generated to trigger ADC A&B sample. The <code>PWM0\_ISR</code> started at nearly the same time (actually <code>PWM0\_ISR</code> is ahead a little), which leaves more time for algorithm calculation. Because the fast loop frequency is eight times of the slower loop, it means <code>PWM0\_ISR()</code> is executed eight times before <code>PWM1\_ISR()</code> is executed once. Figure 28 shows that between updating PWM value and the next ADC trigger, there is sufficient time for <code>PWM1\_ISR()</code> to run. And the center aligned PWM will ensure average current sample for the control scheme.

#### 4.4 Drive signal generation logic

Drive signals for GaN HEMTs are generated by eFlexPWM SM0. The generated PWMs can output directly or connect to internal-peripheral crossbar switch (XBAR).

Figure 29 shows the drive signal generation logic. The SW PWM output control is used to turn on/off the PWM outputs. PWM\_L&PWM\_H are GaN HEMT drive signals and synchronous rectification drive signal for MOSFETs are generated by GPIO output. All combinations are implemented by hardware, which ensures the timeliness of drive signal and simplifies the software design.

Reference Manual



#### 4.5 Fault protection

The hardware protection is over-current protection of inductor current, output voltage over-voltage protection. Over-current protection is generated by the build-in high speed comparator CMPB and CMPC for both positive and negative side. Over-voltage protection is generated by comparator D.

The software protection includes inductor over-current protection, output under-voltage and over- voltage protection, as well as input voltage under-voltage protection and over-voltage protection.

#### 4.6 Peripherals settings

#### 4.6.1 ADC converter

The ADC A&B converters are set to run simultaneously and triggered by VAL0 compare event of eFlexPWM sub-module 2. The trigger signals connection between eFlexPWM and ADC is provided by a cross bar switch module. The ADC A samples input voltage and output DC bus voltage, ADC B samples input current.

#### 4.6.2 Pulse width modulator eFlexPWM

The eFlexPWM sub-module 0 generates two complementary PWM signals with constant frequency 80 kHz and variable duty cycle. The generated PWM signals are routed to XBARB for the generation of GaN drive signals. VAL0 compare event is used to generate interrupt routine PWMO ISR() to handle inner current loop algorithm. In order to maximum the algorithm execution time, VAL0 is set to 35 bus cycles ahead of the switch midpoint.

The eFlexPWM sub-module 1&2 are used for timing control and no PWM signal is generated. Sub- module 1 is used to generated the 10kHz interrupt routine PWM1\_ISR() to handle outer voltage loop algorithm. Sub-module 2 is used to generate the trigger signal for ADC. In order to obtain the accurate input average current, ADC trigger signal is set to 20 bus cycles ahead of the switch midpoint. Because sub-module 2 is synchronized with sub-module 0 by master reload forcing initialization, the ADC trigger signal is almost synchronized with PWMO ISR() trigger.

#### 4.6.3 High speed comparator HSCMPD

The build-in high-speed comparator D is used to detect over voltage condition of the output voltage. One of the comparator's inputs is the measured output voltage, the other is the fault threshold set by VREF D.

#### 4.6.4 High speed comparator HSCMPB&C

The build-in high-speed comparator B&C are used to detect both side over current condition of the input current. One of the comparator's inputs is the single side measured output voltage, the other is the fault threshold set by VREF B&C.

#### 4.6.5 Inter-peripheral crossbar switch XBARA&B and AOI

Crossbar switch A provides the connection for trigger signals between eFlexPWM and ADC. It also works together with crossbar switch B and AOI module to generate the drive signals for GaN.

#### 4.6.6 Serial communication interface SCI0&SCI1

The serial communication interface SCI0 is used for communication with backward LLC, and it can exchange the information, accept the control instructions and execute.

The serial communication interface SCI1 is used for communication with the host PC for FreeMASTER or firmware updating. There is also a SCI -> USB converter on the board, so the communication with host PC finally goes via USB interface.

#### 4.7 Code runs in RAM

Due to the limitation of code execution speed in Flash, the time critical routine PWMO\_ISR() is configured to runs in RAM for time saving.

Because RAM is volatile, the relocated code is stored in flash and copied into RAM during microcontroller start-up. In order to realize this goal, take the following steps:

1. Disable the auto generated Linker Command File (LCF) by processor Export option if used, as shown in Figure 30.



2. Define code sections with pragma directive. Both the PWM0\_ISR() routine and the functions called in it are included in this section.

Reference Manual 30 / 47

3. Shrunken the .p\_Code memory segment length and assign a size fixed flash area for relocated code with LCF. Different device has different memory map, take MC56F82748 for example.

4. Reside the defined code section in corresponding section segment with LCF. And remember to reconfigure the address of each section segments to prevent overlap.

```
SECTIONS {
       .at_of_p_ramFuncSpace :
             WRITEW(0X2); # dummy insertion, prevent warning
              pROM data start = .;
            } > .p ramFuncCode
            .data in p flash ROM : AT( pROM data start)
            {
               ramFunc_code_start = pROM data start + data size;
        .codes onRAM : AT( ramFunc code start)
        . = . + data size; #prevent overlap with p falsh ROM data
             F RAMcode start addr = .;
             * (rtlib.text)
        \# - - relocate functions to section .codes onRAM - - - - - - \cdot
        * (ramFunc main.text)
             * (ramFunc pfc.text)
        # - - manually relocate called library into this section - - - -
                     GFLIB SDM.lib (.text)
                     PCLIB SDM.lib (.text)
                     . = ALIGN(2);
              F RAMcode end addr = .;
              __ramFunctions_size = F_RAMcode_end_addr - F_RAMcode_start_addr;
              ramFunctions LdAddr = ramFunc code start + data size;
              } >.p ramFuncSpace
```

Totem-Pole Bridgeless PFC Design Using MC56F8xxxx, Rev. 1, 10/2020

Reference Manual 31 / 47

5. Enable pROM-to-pRAM and pROM-to-xRAM copy utility and set the pass code sizes, resident address and runtime address in LCF.

```
F Livt size = ramFunction size;
F_Livt_RAM_addr = F_RAMcode_start_addr;
F_Livt_ROM_addr = ramFunctions_LdAddr;
F_xROM_to_xRAM = 0x0000;
F_pROM_to_xRAM = 0x0001;
F_pROM_to_pRAM = 0x0001;
```

For more details on how to relocate codes into RAM, refer to Relocate subroutines to PRAM for MC56F827xx DSC (document AN5143).

Reference Manual 32 / 47

## Chapter 5 Getting started

Figure 31 shows the TP-PFC main board. The control circuit is powered by auxiliary power. One isolated UART port is reserved for more usage.



## 5.1 System development environment

The TP-PFC supports debugging with CodeWarrior and FreeMASTER. Figure 32 shows the set-up of the debug connection.

To download program to the control chip, you need to connect a debugger (USB TAP or P&E- Multilink) to SWD port of the control board using a 14-pin cable. The control board can be powered from the main board or micro USB interface in the control board. In order to control and monitor the working status of the TP-PFC system, you must connect the micro interface on the control board to the PC through a micro USB cable.

Reference Manual 33 / 47



## 5.2 Debugging TP-PFC board with FreeMASTER



In order to connect the FreeMASTER to the target board, perform the following steps:

1. Select a symbol file for your project.

Select the symbol file in FreeMASTER by navigating to Project -> Options -> MAP Files, as shown in Figure 34.

36 / 47



2. Adjust the settings for using FreeMASTER.

Select **Direct RS232** in FreeMASTER by navigating to **Project -> Options -> Comm**, and set the speed as 19200, as shown in Figure 35.



Getting started

#### NOTE

The micro interface in the control board must be connected to PC for FreeMASTER control. Totem-pole bridgeless PFC **must not** start up with load to prevent from damage of start-up resistor.

## Chapter 6 Testing

This section provide the testing results of totem-pole bridgeless PFC.

## 6.1 System efficiency

Table 3 and Table 4 show the system efficiency at different voltage.

Table 3. System efficiency at  $V_{IN}$  = 110 V RM

| V <sub>in</sub> (V) | I <sub>in</sub> (A) | P <sub>in</sub> (W) | PF     | THDi  | V <sub>out</sub> (V) | I <sub>out</sub> (A) | P <sub>out</sub> (W) | Efficiency |
|---------------------|---------------------|---------------------|--------|-------|----------------------|----------------------|----------------------|------------|
| 109.55              | 1.7658              | 193.12              | 0.9983 | 3.25% | 381.6                | 0.484                | 184.6944             | 95.64%     |
| 109.08              | 3.5062              | 382.35              | 0.9997 | 1.98% | 381.8                | 0.961                | 366.9098             | 95.96%     |

Table 4. System efficiency at V<sub>IN</sub> = 220 V RMS

| V <sub>in</sub> (V) | I <sub>in</sub> (A) | P <sub>in</sub> (W) | PF     | THDi  | V <sub>out</sub> (V) | I <sub>out</sub> (A) | P <sub>out</sub> (W) | Efficiency |
|---------------------|---------------------|---------------------|--------|-------|----------------------|----------------------|----------------------|------------|
| 220.04              | 0.8775              | 190.23              | 0.9851 | 6.73% | 381.5                | 0.484                | 184.646              | 97.07%     |
| 219.77              | 1.7149              | 374.92              | 0.9947 | 4.98% | 381.6                | 0.961                | 366.7176             | 97.81%     |
| 219.51              | 2.5574              | 559.62              | 0.9968 | 2.76% | 381.8                | 1.436                | 548.2648             | 97.97%     |
| 219.37              | 2.9737              | 651.05              | 0.9979 | 2.50% | 381                  | 1.677                | 638.937              | 98.14%     |

Figure 36 shows the system efficiency power factor curve.



Figure 37 shows the total harmonic Distortion value curve.

Reference Manual 38 / 47



Figure 38 shows the efficiency curve.



## 6.2 Startup performance



41 / 47

## 6.3 Steady state performance



As shown in Figure 40:

- · CH1: Input AC voltage
- CH2: PWM gate for SD2
- CH3: Bus capacitor voltage
- · CH4: Inductor current

## 6.4 Dynamic performance



As shown in Figure 41:

· Ch3: Output voltage

· Ch4: Input current

Reference Manual 42 / 47



### As shown in Figure 42:

· Ch3: Output voltage

· Ch4: Input current

Reference Manual 43 / 47

44 / 47



### As shown in Figure 43:

- · Ch3: Output voltage
- Ch4: Inductor current



### As shown in Figure 44:

• Ch3: Output voltage

· Ch4: Input current

Reference Manual 45 / 47

# Chapter 7 Revision history

Table 5. Revision history

| Revision number | Date    | Substantive changes                                       |
|-----------------|---------|-----------------------------------------------------------|
| 0               | 11/2016 | Initial release                                           |
| 1               | 10/2020 | Replace MC56F82748 with MC56F8xxxx to cover more products |

Totem-Pole Bridgeless PFC Design Using MC56F8xxxx, Rev. 1, 10/2020

Reference Manual 46 / 47

How To Reach Us

Home Page:

nxp.com

Web Support:

nxp.com/support

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein.

NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp.com/SalesTermsandConditions.

While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREENCHIP, HITAG, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC. MIFARE DESFire, MIFARE PLUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, CodeWarrior, ColdFire, ColdFire+, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobileGT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platformin a Package, QUICC Engine, Tower, TurboLink, EdgeScale, EdgeLock, eIQ, and Immersive3D are trademarks of NXP B.V. All other product or service names are the property of their respective owners. AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamlQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile are trademarks or registered trademarks of Arm Limited (or its subsidiaries) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

© NXP B.V. 2016-2020.

All rights reserved.

For more information, please visit: http://www.nxp.com
For sales office addresses, please send an email to: salesaddresses@nxp.com

Date of release: 10/2020 Document identifier: DRM174

