

# **Table of Contents**

| Introduction                                        |  |
|-----------------------------------------------------|--|
| Power Management Overview                           |  |
| MPM Design Description                              |  |
| Adding the New APOL Channel to MPM Reference Design |  |
| Adding a New DPOL Channel to MPM Reference Design   |  |
| Appendix A                                          |  |
| References                                          |  |

# Introduction

The SmartFusion<sup>®</sup> customizable system-on-chip (cSoC) FPGA devices integrate the FPGA technology with hardened ARM<sup>®</sup> Cortex<sup>™</sup>-M3 processor-based microcontroller subsystem (MSS) and programmable high-performance analog blocks built on a low power flash semiconductor process. The MSS consists of hardened blocks, such as a 100 MHz ARM Cortex-M3 processor, peripheral DMA (PDMA), embedded nonvolatile memory (eNVM), embedded SRAM (eSRAM), embedded FlashROM (eFROM), external memory controller (EMC), watchdog timer, system registers, Phillips Inter-Integrated circuit (I2C), SPI, 10/100 Ethernet controller, real-time counter (RTC), general purpose input output (GPIO) block, fabric interface controller (FIC), and in-application programming (IAP). The programmable analog block contains the analog compute engine (ACE) and analog front-end (AFE) consisting of ADCs, DACs, active bipolar prescalers (ABPS), comparators, current monitors, and temperature monitor circuitry.

These unique features make the SmartFusion cSoC an ideal choice for Power management solutions.

Power management of boards or of a complete system is one of the main challenges in designing a high availability system. To create a reliable system, you need to use complex devices, often mixing FPGAs, microprocessors, ASICs and ASSPs on the same board. Many of these devices require different power supplies to achieve their full functionality.

Power management mainly deals with:

- The power-up/power-down sequence of different devices on the board or complete system
- · Power supplies output voltage monitoring and gives an indicator of a fault
- Maintains constant supply voltages by trimming output of the voltage regulators as per device power requirements

This application note describes a power management solution called Mixed Signal Power Manager (MPM) reference design using the SmartFusion cSoC. The MPM reference design has been enhanced as per the user requirements for adding ACE services to monitor additional power supply rails. The MPM reference design supports both analog point of loads (APOL) and digital point of loads (DPOL).



# **Power Management Overview**

Power Management helps control the power system of a board or a complete system. To create a reliable system, you will need to use complex devices, often mixing FPGAs, microprocessors, ASICs, and ASSPs on the same board. Many of such devices require different power supplies to achieve their full functionality. Often these supplies must be applied in a predetermined and consistent order known as power sequencing. Proper sequencing will also limit any inrush current effects that can put strain on the system power supplies.

Figure 1 on page 4 gives the detailed description about how power management is done in an example system which runs with multiple applications.



#### Figure 1 • Block Diagram of a System Showing Power Management

Consider an example system that requires different voltages to drive different functional blocks and hence it is not always possible to hook up the main source directly to power functional blocks. Power management here plays a major role in driving all the blocks with the required voltage without any fluctuations. Hence, the voltage of different voltage rails is monitored very closely all the time to avoid any damage to the system due to voltage ramp ups. Voltage regulators do the job of maintaining the voltage levels to the required value without any fluctuations.



# Voltage Regulator

The voltage regulator in a typical system is used to accomplish different goals like step-down the voltage among different sub-circuits that require low supply voltage, or to step-up the voltage for sub-circuits that need higher voltage.

As shown in Figure 2, a regulator consists of four signals:

- Input Voltage (V<sub>in</sub>)
- Enable (E<sub>n</sub>)
- Output Voltage (Vout)
- Feedback/Adjust/Trimming signal

The enable and the trimming signals come from the controller/PLD device. The enable signal enables the voltage regulator and trimming performs small adjustments on the output voltage of a regulator or power supply (less than 10% of the output) by driving the trim, adjust, or feedback pin of the regulator to maintain constant voltage.



#### Figure 2 • Voltage Regulator

The trimming signal is set in two ways:

- Open loop trimming
- Closed loop trimming



# **Open Loop Trimming**

As mentioned above, the Trim pin is used to adjust the output voltage of the regulator. In open loop trimming there are mainly three ways to set the Trim signal.

### By using Discrete Components on the Board

In this method, the output of the regulator is set to particular value and it is not possible to adjust the output unless you change the discrete components.





#### By using Potentiometer

In this method the output of the regulator can be adjusted by changing the potentiometer manually.



Figure 4 • Trim Value Set By the Potentiometer



### By Setting the Trim Signal using the Controller at the Initialization Time

As shown in Figure 5, the trim input is set by the controller that puts out a pulse-width modulated (PWM) signal that acts as a DAC when fed through a low pass filter such as an RC network. The feedback pin value is never adjusted and it is set once at the time of system initialization to a fixed value until a reset or power cycle occurs in a system.



Figure 5 • Trim Value Set By the Controller

## **Closed Loop Trimming**

In closed loop trimming, the trim input of the power supply is dependent upon the output voltage of the voltage regulator. In closed-loop trimming, the controller constantly scans (once per loop) the output voltage of the regulator, and actively adjusts the regulator feedback voltage to drive the regulator to some target output voltage.

Closed-loop trimming is Active mode; it is continually operating. The algorithm for trimming is linear. The main function of the algorithm is determining the trimming voltage ( $V_{trim}$ ) depending upon the output voltage of regulator and target voltage.

Here, trimming voltage ( $V_{trim}$ ) is the signal which is fed to the regulator feedback pin and target voltage is the voltage level that user wants at the regulator output.



#### Figure 6 • Block Diagram of Closed Loop Trimming

The input  $V_{in}$  and the trimming signal should be analog signal. There are several techniques used to generate trimming signals, two of them are:

- Digital to analog converter (DAC)
- Pulse width modulator (PWM)



### DAC

The DAC is a device that converts a digital signal to analog signal. Digital-to-analog conversion can degrade a signal, hence, the conversion details are normally chosen in a manner that the errors are negligible. Sigma-Delta DAC is one type of DAC which is driven by pulse density modulated signal, created with a low-pass filter, step, and negative feedback loop. The analog low-pass filter at the output attenuates the noise at higher frequencies.

The 8-bit, 16-bit, or 24-bit unsigned binary digital input word to be converted is fed to an all-digital firstorder sigma-delta modulator. Sigma-delta modulation is a subset of the class of duty factor modulation methods, as is PWM. In all of these, the output duty factor approximates the input to the modulator over some time period. Typically, the input signal changes slowly, and the output of the modulator is clocked at a higher sample rate, but with a lower output resolution. In the limiting (and commonly used) case, the output only has one-bit of resolution.

### **PWM**

The PWM is a general purpose, multi-channel module for motor control, tone generation, battery charging, heating elements, fine tuning of power supply output levels, etc. It is the simplest DAC type. A stable current or voltage is switched into an analog low-pass filter with a duration determined by the digital input code.

In General Purpose PWM mode, duty cycle updates can be performed asynchronously or synchronously, based on parameter selection.

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

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

The PWM holds the frequency constant and varies the pulse width  $(t_{ON})$  to adjust the output voltage. The average power delivered is proportional to the duty cycle, D, making this an efficient way to provide power to a load.

$$D = \frac{t_{ON}}{t_{ON} + t_{OFF}}$$



Figure 7 gives the information about how the PWM output is averaged to a varying DC voltage. In the following diagram, assume that the Main Power Supply is of 12 V. At reset, the PWM duty cycle, or level out value, is 100% and the voltage increases to the rail of 12 volts. The PWM duty cycle/level out value changes to 75% and then 50%, and the output of the RC filter follows this by dropping to 8 volts and then 6 volts. The generated ripple voltage is a function of the RC circuit values, the system clock period, and the PWM duty cycle. In Low Ripple DAC mode, the pulse width is effectively reduced to a 1 clock cycle period, significantly reducing the ripple at the output of a low-pass filter. Using Low Ripple DAC mode has the added benefit of requiring a smaller time constant for the filter, which allows for smaller R and C components to be used.



#### Figure 7 • Averaging of PWM Output

The purpose of trimming is to perform small adjustments on the output voltage of a regulator or power supply (less than 10% of the output) by driving the trim, adjust, or feedback pin of the regulator.



Figure 8 • Voltage Waveform Of Voltage Across Load



Trimming is known to provide a voltage regulator with a trim input to which a control signal can be supplied to trim the output voltage of the voltage regulator. Such trimming can be used to adjust the output voltage to a desired value. This compensates for changes of the power supply characteristics due to temperature changes or aging, in which, the output voltage of the power supply is raised or lowered from the set point. This is referred to as an active trim or an active DC output control of the voltage regulator.

The main function of the power management solution (MPM) using the SmartFusion are power sequencing, power monitoring, and power supply margining.

# **MPM Design Description**

Figure 9 shows the block diagram of the MPM reference design using the SmartFusion cSoC.



#### Figure 9 • Block Diagram of the MPM Reference Design

The MPM reference design delivers superior power monitoring, power sequencing, closed-loop trimming, and power-up and power-down control of external power supplies (external regulators).

### **Hardware Implementation Details**

The FPGA fabric is used to implement the CorePWM and CoreGPIOs(2). The CorePWM is configured in the low-ripple DAC mode that generates the trim/adjust signals to voltage regulators. CorePWM supports 32 individual outputs. CoreGPIOs are used to implement the status signals like over voltage, under voltage, and enable signals to different voltage regulators.



Figure 10 depicts the flow of the Hardware implementation. The two CoreGPIOs and the CorePWM are connected to the Cortex-M3 processor through the APB Interface. The CorePWM continuously generates the duty cycle and performs trimming. The CoreGPIOs are used for enabling the regulators and the LEDs.



Figure 10 • Block Diagram Representing Hardware Flow

### **Analog Computing Engine (ACE)**

The SmartFusion inbuilt ACE is used to generate the trim/adjust signals to different voltage regulators using the DAC. ACE is used to monitor the output of voltage regulators using the ADC.



### Software Implementation Details

The software design performs the following operations:

- · Initializes and configures the SmartFusion ACE to monitor the voltage levels of MPM channels
- Sets the MPM configuration registers through I2C
- · Logs the MPM status of multiple channels to the eNVM
- · Controls the CorePWM or on chip DAC to trim output voltage of different regulators
- Controls CoreGPIOs to enable regulators and to generate status signal
- · Checks the MPM status and shuts down the system if the either of OFF, OV2 or UV2 is observed
- · At regular intervals, each MPM channel information is displayed on OLED

The MPM solution block diagram is shown in Figure 11. As depicted, the Voltage regulator is connected through a three pin jumper. This jumper is used to select the trim type, either SDD or PWM. When the jumper is connected to the ACE pin and the output pin then it will result in SDD trimming type and the other way results in PWM trimming type. In the similar manner the other three regulators are also connected.



Figure 11 • Block Diagram Of Complete Set Up Of MPM



Trimming value is increased if the voltage is more than the nominal and it is decreased if the voltage is less than the nominal. This can be implemented using any of the following:

- Linear function or
- PI controller function or
- Using the equation:

Y=mX+c

#### where:

'Y' is the output duty cycle,

'X' is the step size that varies with the state of the channel,

'm' is the slope, and

'c' is constant

In the current design, the power ramp has been implemented using the above equation. Figure 12 and Figure 13 on page 12 are the graphs that are obtained with the implementation of above equation.

The name Channel<n>\_M\_C<q> gives the following details:

- 'n' represents the channel number,
- 'p' gives the slope value, and
- 'q' gives the constant value



Figure 12 • Graphical Representation Of Power Ramp Of Channel 1

EQ 1





#### Figure 13 • Graphical Representation Of Power Ramp Of Channel 2

The MPM solution has the following components:

- Design files: The Hardware design files contain configuration of hardware components like PWM channels, ACE, GPIOs etc. The Software design files contain C implementation for the initialization of PWM, enumeration of all ACE channels, and power management algorithm, shutting down the system when any fault condition is observed.
- GUI: The GUI enables you to configure power management and drive output signals as the monitored voltages meet or deviate from the user-programmed operating limits. MPM design is programmed into the device through an easy-to-use standalone GUI tool.
- MPM power management demo daughter card (MPM-DC).





The complete flow of the MPM reference design is explained in the Figure 14.

Figure 14 • Flowchart For Complete MPM Data Flow



# Adding a New APOL Channel to MPM Reference Design

You can enhance the MPM reference design to add more channels as per the application requirements. The steps listed below explain the procedure on adding a new channel for the MPM reference design using the Libero Flow. Adding new channels can be implemented only with the ripple DAC implementation of CorePWM, and it is not possible to add new channel using on chip DAC, as all the available DAC channels are used in the existing MPM reference design. Adding a new channel to the existing MPM reference involves below steps:

- 1. Adding a monitoring channel to ADC to sample the regulator output
- 2. Adding extra channel to CoreGPIO to generate enable signal
- 3. Adding extra channel to CorePWM to generate ripple DAC

# Adding a Monitoring Channel to ADC to Sample the Regulator Output

Adding a new channel to ADC to sample the regulator output is required for closed loop control of the MPM. The number of channels or regulators that can be controlled in closed loop is based on the number of ADC channels available on the device. The Table1 below gives the available Analog input channels for SmartFusion cSoC Device for closed loop control of MPM.

|                  | A2F500(FG484) | A2F200 | A2F060 |
|------------------|---------------|--------|--------|
| ABPS             | 10            | 8      | 2      |
| Direct ADC i/ps  | 12            | 8      | 11     |
| CM0              | 5             | 4      | 1      |
| TM0              | 5             | 4      | 1      |
| Total Analog i/p | 32            | 24     | 15     |
| DACs             | 3             | 2      | 1      |

#### Table 1 • Analog Input Channels For SmartFusion cSoC Device

Use the following steps to add a monitoring channel. For design files of this application note, refer to "Appendix A" on page 38, in the Libero HW project.

1. Open the SmartDesign MSS configurator from the Libero-Project Flow.



2. Double-click the ACE block to configure. It looks similar to Figure 15.

| Configure ACE                                     | Controller                   | Flags                          |                     |             |         |
|---------------------------------------------------|------------------------------|--------------------------------|---------------------|-------------|---------|
| ADC Configuration                                 |                              |                                |                     |             |         |
| ACLK: 80 MHz                                      | ADC Clock: 10 MHz            | Resolution: 12 - bits          |                     | Advanced Op | tions   |
| Add service:                                      |                              |                                |                     |             |         |
| Active Bipolar Prescaler Inpu<br>ADC Direct Input | Service                      | Signal                         | Sample<br>time (us) |             | SCB     |
| Current Input                                     |                              | MPM_Channel_1_DMPM_DB_APOL1_3P |                     | W9 (ABPS2)  | 1(5)    |
| Differential Input<br>Temperature Input           | Active Bipolar Prescaler Inp | MPM_Channel_2_DMPM_DB_APOL2_1P |                     | W12 (ABPS6) | 3(5)    |
| LVTTL Input                                       | ADC Direct Input             | MPM_Channel_6_A2F_BOARD_RV1_PO |                     | Y7 (CM0)    | 0(3)    |
| Analog Comparator                                 | Sigma Delta DAC              | SDD0                           |                     | V7(SDD0)    | N/A(15) |
| Sigma Delta DAC                                   | Sigma Delta DAC              | SDD1                           | 10.000              | Y17(SDD1)   | N/A(15) |
| Add >>                                            |                              |                                |                     |             |         |
| Add >>                                            | ADC Block 0                  |                                |                     |             |         |

#### Figure 15 • ACE Configurator Before Adding a Service

3. Select Active Bipolar Prescaler Input or ADC Direct Input from the Add service list, and click Add. If the analog input value is less than the ADC voltage reference, choose the ADC Direct Input service for a higher accuracy for the application. An analog service configurator window opens as shown in below Figure 16, allowing you to customize the service.

| ABPS0                                                     | Signal nar  |                   | +               | Prescaler<br>/- 15.36                      | • v -          |           |   |
|-----------------------------------------------------------|-------------|-------------------|-----------------|--------------------------------------------|----------------|-----------|---|
|                                                           | 10.0        | 00                |                 | Send raw                                   | ADC result to  | DMA       |   |
| Digital filtering –<br>Filtering factor<br>Initial value: |             | •                 |                 | Linear transfo<br>Scale factor:<br>Offset: | rmation        |           |   |
| Send filtere                                              | d result to |                   |                 |                                            | isformed resul | It to DMA |   |
|                                                           |             |                   | eshold Detectio |                                            | Assert         | De-assert | × |
| Flag                                                      | Name        | Flag Type         | (V)             | Hysteresis<br>(mV)                         | Samples        | Samples   | Â |
|                                                           |             |                   |                 |                                            |                |           |   |
| Accort flog wit                                           | en nost pro | ocessing complete | d               |                                            |                |           | Ŧ |

#### Figure 16 • Active Bipolar Prescaler Configurator

4. Enter the Signal name prefixed with 'MPM\_Channel\_<n>...', where '...' represents any other text needed to name the ACE channel signal and <n> is a unique MPM channel number between 1 and MPM\_MAX\_NUMBER\_OF\_CHANNELS under Signal Name option. For Example if you are adding 7th channel to the reference design, Signal name can be MPM\_Channel\_7\_DMPM\_DB\_APOL3\_1P5V. Assign flags UP and DOWN of flag types Over and



Under as required for application. The initial voltage values for these thresholds are not important and can be configured to any valid value.

The MPM driver dynamically reprograms these on the fly when managing the channels. For hysteresis-based thresholds, the MPM GUI specified hysteresis value is used. State filtered (assert/deassert samples) based thresholds are used as is in the ACE configuration. Channels meeting these criteria that are not given 'out of range' threshold ± hysteresis configurations via the MPM GUI are recognized and managed by the MPM firmware. After filling up all fields, Active Bipolar Prescaler Input Dialog Box looks like Figure 17.

| ABPS0             | Signal na    | ame:<br>nannel_7_DMPM_[ | +,               | Prescaler<br>/- 15.36 | • v               |                      |   |
|-------------------|--------------|-------------------------|------------------|-----------------------|-------------------|----------------------|---|
|                   |              |                         |                  | Send raw              | ADC result to     | DMA                  |   |
| cquisition time:  | 10.          | 000 us                  |                  |                       |                   |                      |   |
| Digital filtering |              |                         |                  | Linear transfo        | rmation           |                      |   |
| Filtering factor  | : 128        | -                       |                  | Scale factor:         |                   |                      |   |
| Initial value:    | 0.0          | 00 V                    |                  | Offset:               |                   |                      |   |
| _                 |              |                         |                  | Onseta                |                   |                      |   |
| Send filtere      | ed result to | DMA                     |                  | Send tran             | nsformed resu     | lt to DMA            |   |
|                   |              | Thr                     | eshold Detectio  | n                     |                   | ۲                    |   |
| Rag               | Name         | Hag Type                | Threshold<br>(V) | Hysteresis<br>(mV)    | Assert<br>Samples | De-assert<br>Samples | ^ |
| UP                |              | OVER                    | 1.5              | 10                    |                   |                      | - |
| DOWN              |              | UNDER                   | 0.5              | 10                    |                   |                      |   |
|                   |              |                         |                  |                       |                   |                      | - |
| _                 |              | rocessing completed     |                  | II                    |                   |                      |   |



5. Click **OK**. The ACE configurator looks like Figure 18. Assign the Package Pin value.

| Configure ACE                                     | Controller                   | Flags                          |                     |             |         |
|---------------------------------------------------|------------------------------|--------------------------------|---------------------|-------------|---------|
| ADC Configuration                                 |                              |                                |                     |             |         |
| Abe comga daon                                    |                              |                                |                     |             |         |
| ACLK: 80 MHz                                      | ADC Clock: 10 MHz            | Resolution: 12 v bits          |                     | Advanced Op | otions  |
| Add service:                                      |                              |                                |                     |             |         |
| Active Bipolar Prescaler Inpu<br>ADC Direct Input | Service                      | Signal                         | Sample<br>time (us) | Package Pin | SCB     |
| Current Input                                     |                              | MPM_Channel_1_DMPM_DB_APOL1_3P | 10.000 W9           |             | 1(5)    |
| Differential Input<br>Temperature Input           |                              |                                | 10.000 W1           |             | 3(5)    |
| LVTTL Input                                       | ADC Direct Input             | MPM_Channel_6_A2F_BOARD_RV1_PO | 10.000 Y7 (         |             | 0(3)    |
| Analog Comparator                                 | Sigma Delta DAC              | SDD0                           | 10.000 V7 (         | (SDD0)      | N/A(15) |
| Sigma Delta DAC                                   | Sigma Delta DAC              | SDD1                           | 10.000 Y17          |             | N/A(15) |
|                                                   | Active Bipolar Prescaler Inp | MPM_Channel_7_DMPM_DB_APOL3_1P | 10.000 Una          | issigned    | 0(1)    |
|                                                   |                              |                                |                     |             |         |
|                                                   | ADC Block 0                  |                                |                     |             |         |

Figure 18 • ACE Configurator After Adding a Service



6. Typically, you will know with which analog pad the service needs to be assigned to based on your board design. The package pin assignment also determines which ABPS is selected. The Active Bipolar Prescaler Input (ABPS) service senses the voltage on an input pad and scales it to fit the range of the ADC (nominally 0 V to 2.56 V, if the internal voltage reference, Varef, is used). Currently, assign the value to Y11(ABPS7). The ACE configurator looks like in Figure 19.

| Configure ACE                                     | Controller                   | Flags                           |                     |             |          |
|---------------------------------------------------|------------------------------|---------------------------------|---------------------|-------------|----------|
| ADC Configuration                                 |                              |                                 |                     |             |          |
| ACLK: 80 MHz                                      | ADC Clock: 10 MHz            | Resolution: $12 	extsf{w}$ bits |                     | Advanced Op | otions   |
| Add service:                                      |                              |                                 |                     |             | <b>_</b> |
| Active Bipolar Prescaler Inpu<br>ADC Direct Input | Service                      | Signal                          | Sample<br>time (us) | Package Pin | SCB      |
| Current Input                                     | Active Bipolar Prescaler Inp | MPM_Channel_1_DMPM_DB_APOL1_3P  | 10.000              | W9(ABPS2)   | 1(5)     |
| Differential Input                                |                              | MPM_Channel_2_DMPM_DB_APOL2_1P  |                     | W12 (ABPS6) | 3(5)     |
| Temperature Input                                 | ADC Direct Input             | MPM_Channel_6_A2F_BOARD_RV1_PO  |                     | Y7(CM0)     | 0(3)     |
| Analog Comparator                                 | Sigma Delta DAC              | SDD0                            |                     | V7(SDD0)    | N/A(15)  |
| Sigma Delta DAC                                   | Sigma Delta DAC              | SDD1                            |                     | Y17(SDD1)   | N/A(15)  |
|                                                   | Active Bipolar Prescaler Inp | MPM_Channel_7_DMPM_DB_APOL3_1P  | 10.000              | Y11(ABPS7)  |          |
|                                                   |                              |                                 |                     |             |          |
|                                                   | ADC Block 0                  |                                 |                     |             |          |

Figure 19 • ACE Configurator After Adding a Service With Package Pin

 After assigning the pin value, click the Controller tab. Then click ADC1\_MAIN in the Procedures box. As shown in Figure 20 on page 18, open the Controller tab in ACE configurator to configure Sample sequencing. The Sampling Sequence determines the order in which analog channels are sampled for a particular ADC.



The **Operating sequence entry** can be specified as **Auto** or **Manual**. Select **Auto**. As shown in Figure 20, the **Available signals** list shows the signals that are assigned to a specific ADC. You can use this list of signals to indicate which one you want to sample in Auto mode by moving these signals to and from the **Sampling rate**. Click on the ADC<n>\_MAIN in which the newly added signal is and move it from the **Available signals** list to **Sampling rate** table. Click **Calculate Sequence and Actual Rate**. This creates a basic round robin sequence of your selected signals. Click **OK**.

| Configure ACE                                      | Controller Flags                                               |                                                             |  |
|----------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------|--|
| Procedures                                         | ·= 📝 🕻                                                         | K                                                           |  |
| ADC0 MAIN<br>ADC1_MAIN<br>ADC2_MAIN                | Name                                                           | ADC Block 0<br>ADC Block 1<br>ADC Block 2                   |  |
| Operating sequence entry:<br>Details of procedure: | Auto     Manual  ADC1_MAIN                                     |                                                             |  |
| Available signals:<br>MPM_Channel_7_DMPI<br>SDD1   | Sampling rate Signal MI Signal MPM_Channel_2_DMPM_D Commons.   | Actual Rate<br>(ksps)           B_APOL2_1P5V         84.200 |  |
|                                                    | culate Sequence and Actual Rate                                | al sampling rate: 84.200 ksps                               |  |
| Operating sequence                                 | Instruction                                                    | SSE Execution<br>Time (us)                                  |  |
|                                                    | annel_2_DMPM_DB_APOL2_1P5V<br>ution sequence for this timeslot | 11.725<br>0.100                                             |  |
|                                                    |                                                                |                                                             |  |
|                                                    |                                                                |                                                             |  |

Figure 20 • Controller Tab of ACE Configurator

8. The MSS configurator appears as shown in Figure 21. You can observe the added signal MPM\_Channel\_7\_DMPM\_DB\_APOL3\_1P5V.



Figure 21 • MSS Configurator With Added Signal

# Adding a Channel to CoreGPIO to Generate Enable Signal

Use the following steps to add a channel to CoreGPIO to generate enable signal in the Libero HW project:

- 1. Open the SmartDesign MSS configurator from Libero-Project Flow.
- 2. Double click MSS I/O block to configure, it is similar to Figure 22.

| K Configuring MSS_FIO_0 (MSS_FIO - 1.0.203)                        | - C - X |
|--------------------------------------------------------------------|---------|
| Configuration                                                      |         |
| Multiplexed With MAC Peripheral RMII Management Interface MSS I/Os |         |
| IO_24 (MDC) Not Used  AA3 IO_23 (MDIO) Not Used                    | V4      |
| Multiplexed With MAC Peripheral RMII Data Interface MSS I/Os       |         |
| IO_22 (RXER) Not Used V AA4 IO_21 (CRSDV) Not Used V               | W4      |
| IO_20 (TXEN) Not Used  Y4 IO_19 (RXD[0]) Not Used                  | U5      |
| IO_18 (RXD[0]) Not Used  V5 IO_17 (TXD[1]) Not Used                | W5      |
| IO_16 (TXD[0]) Not Used  AA5                                       |         |
| Multiplexed With GPIO[15:0] Peripheral MSS I/Os                    |         |
| IO_15 (GPIO[15]) Not Used v (14 (GPIO[14]) Not Used v              | • • AB3 |
| IO_13 (GPIO[13]) Not Used V AB2 IO_12 (GPIO[12]) TRIBUFF V         | AA2     |
| IO_11 (GPIO[11]) TRIBUFF T T4 IO_10 (GPIO[10]) TRIBUFF             | • U3    |
| IO_9 (GPIO[9]) TRIBUFF V 3 IO_8 (GPIO[8]) TRIBUFF V                | • тз    |
| IO_7 (GPIO[7]) OUTBUF V W2 IO_6 (GPIO[6]) OUTBUF V                 | • V2    |
| IO_5 (GPIO[5]) OUTBUF • U2 IO_4 (GPIO[4]) OUTBUF •                 | AA1     |
| IO_3 (GPIO[3]) OUTBUF • Y1 IO_2 (GPIO[2]) OUTBUF •                 | • W1    |
| IO_1 (GPIO[1]) OUTBUF  R3 IO_0 (GPIO[0]) OUTBUF                    | • V1    |
| Help                                                               | Cancel  |



3. Select TRIBUFF for IO\_16 as shown in Figure 23.

| 🕵 Cor  | figuring MSS_FIO_0 (MSS_FIO - 1.0.)  | 203)        |                      |            |       | x  |
|--------|--------------------------------------|-------------|----------------------|------------|-------|----|
| Config | juration                             |             |                      |            |       |    |
|        | Multiplexed With MAC Peripheral RMII | Manageme    | nt Interface MSS I/O | Ds         |       |    |
|        | IO_24 (MDC) Not Used 💌               | AA3         | IO_23 (MDIO)         | ot Used 💌  | V4    |    |
|        | Multiplexed With MAC Peripheral RMII | Data Interf | ace MSS I/Os         |            |       |    |
|        | IO_22 (RXER) Not Used 🔻              | AA4         | IO_21 (CRSDV)        | Not Used 🔻 | W4    |    |
|        | IO_20 (TXEN) Not Used 🔻              | ¥4          | IO_19 (RXD[0])       | Not Used 🔻 | U5    |    |
|        | IO_18 (RXD[0]) Not Used 🔻            | V5          | IO_17 (TXD[1])       | Not Used 🔻 | W5    |    |
|        | IO_16 (TXD[0]) Not Used  Not Used    | AA5         |                      |            |       |    |
|        | - Multiplexed With GPIC              | al MSS I/Os |                      |            |       |    |
|        | IO_15 (GPIO[15] BIBUF                | 🔒 Үз        | IO_14 (GPIO[14])     | Not Used 🔻 | AB3   |    |
|        | IO_13 (GPIO[13]) Not Used 🔻          | 🔒 AB2       | IO_12 (GPIO[12])     | TRIBUFF 🔻  | AA2   |    |
|        | IO_11 (GPIO[11]) TRIBUFF •           | ) T4        | IO_10 (GPIO[10])     | TRIBUFF -  | U3    |    |
|        | IO_9 (GPIO[9]) TRIBUFF •             | ) v3        | IO_8 (GPIO[8])       | TRIBUFF -  | Т3    |    |
|        | IO_7 (GPIO[7]) OUTBUF -              | ) w2        | IO_6 (GPIO[6])       |            | V2    |    |
|        | IO_5 (GPIO[5]) OUTBUF -              | ) U2        | IO_4 (GPIO[4])       |            | AA1   |    |
|        | IO_3 (GPIO[3]) OUTBUF •              | ) <b>Y1</b> | IO_2 (GPIO[2])       |            | W1    |    |
|        | IO_1 (GPIO[1]) OUTBUF •              | ) R3        | IO_0 (GPIO[0])       |            | V1    |    |
| н      | elp 🔻                                |             |                      | ОК         | Cance | el |

Figure 23 • Selecting TRIBUFF for I/O\_16



4. Now MSS I/O Block in MSS configurator is visible as shown in Figure 24.



#### Figure 24 • MSS I/O Block After Adding Extra I/O Port

- 5. Save the changes and click Generate. Refer Changes in Softconsole section to update eNVM firmware client.
- In Libero, right click SF\_MPM\_RefDesign\_MSS block, select Update Instance(s) with Latest Component as shown in Figure 25.



Figure 25 • Updating MPM\_MSS\_0

- Image: State of the state o
- 7. Right-click IO\_16\_D port of SF\_MPM\_RefDesign\_MSS and select **Tie Low** as shown in Figure 26.

#### Figure 26 • Selecting Tie Low for I/O Port

8. Right-click IO\_16\_E port of SF\_MPM\_RefDesign\_MSS and select Invert as shown in Figure 27.



Figure 27 • Selecting Invert for I/O Port



9. Right-click the IO\_16\_PADTRI pin of SF\_MPM\_RefDesign\_MSS and select Modify Port as shown in Figure 28.



#### Figure 28 • Selecting Modify Port

10. Enter the name of the pin as DMPM\_DB\_APOL3\_EN as shown in Figure 29 and click **OK**.

| Name: | DMPM_DB_APOL3_EN       |
|-------|------------------------|
| Direc | tion:                  |
|       | Input                  |
| ۲     | Output                 |
|       | Bi-directional (inout) |

Figure 29 • Modify Port Dialog Box



11. Now right-click GPIO\_OUT[31:0] of MPM\_GPIO\_Regulator\_Enables and select Edit Slice as shown in Figure 30.



#### Figure 30 • Selecting Edit Slice

12. Click Add slice entry in the Edit Slices dialog box to add GPIO\_OUT[5] and change the configuration as shown in Figure 31. Click OK.



Figure 31 • Edit Slices Dialog Box



13. Connect GPIO\_OUT[5] port of MPM\_GPIO\_Regulator\_Enables to IO\_16\_E port of SF\_MPM\_RefDesign\_MSS by using Connection Mode button as shown in Figure 32.





14. Right-click GPIO\_OUT[31:6] of MPM\_GPIO\_Regulator\_Enables and select Mark Unused as shown in Figure 33.



Figure 33 • Selecting Mark Unused for GPIO\_OUT[31:6]

# Adding a Channel to CorePWM to Generate Ripple DAC

Use the following steps to add a channel to CorePWM to generate ripple DAC:

 Configure the connections of CorePWM (MPM\_PWM\_Trimming\_Outputs). Double click CorePWM block of MPM\_top and increment the Number of PWM Channels by 1 as shown in Figure 34.

| nfiguration<br>Global Configuration: |                                  |                     | _ |
|--------------------------------------|----------------------------------|---------------------|---|
|                                      | Configuration Mode:              | 0 - PWM Only Mode 🔹 |   |
|                                      | Number of PWM Channels:          | 3 🔹                 |   |
|                                      | APB Data Bus Width / Resolution: | 1<br>2<br>3         |   |
| Global PWM Mode Configuration        | on:                              | 4<br>5<br>6         |   |
| Fixed F                              | rescale:                         | 7 8 9               |   |
| Fixed F                              | eriod:                           | 10                  |   |
| Channel 1 Configuration:             |                                  |                     | + |
|                                      | III                              |                     | • |

#### Figure 34 • Configuring CorePWM

2. Current design has 3 PWM channels. After adding the new PWM channel, select Low Ripple DAC mode for channel 3 as shown in Figure 35.

| Channel 3 Configuration:           |               |                            |   |
|------------------------------------|---------------|----------------------------|---|
| Low Ripple DAC mode:               |               | Shadow Update Register:    |   |
| Fixed PWM PosEdge:                 |               | Fixed PWM PosEdge Value: 0 |   |
| Fixed PWM NegEdge / DAC LevelOut   |               | Fixed PWM NegEdge Value: 0 |   |
| Channel3 PWM stretch level (HIGH w | hen selected) |                            |   |
| Channel 4 Configuration:           |               |                            |   |
| Low Ripple DAC mode:               |               | Shadow Update Register:    |   |
| Fixed PWM PosEdge:                 |               | Fixed PWM PosEdge Value: 0 |   |
| Fixed PWM NenEdne / DAC LevelOut   | :             | Fixed PWM NeoEdoe Value:   | • |

Figure 35 • Selecting Low Ripple DAC Mode



3. The CorePWM (MPM\_PWM\_Trimming\_Outputs) block looks like Figure 36. Right-click the PWM[4:1] as shown in Figure 37 and select Edit Slice.



Figure 36 • CorePWM Block After Adding PWM Channel



Figure 37 • PWM Edit Slice



|   | Edit Slice<br>Create | s - PV   | - | 1]<br>slices of wid | th 1 🔻 | Add Slices |
|---|----------------------|----------|---|---------------------|--------|------------|
|   | PWM[4:1]             | <b>a</b> |   | Left                | Right  | × 🗣        |
|   |                      |          | 1 | 1                   | 1      |            |
|   |                      |          | 2 | 2                   | 2      |            |
|   |                      |          | 3 | 3                   | 3      | -          |
|   |                      |          | 4 | 4                   | 4      |            |
|   |                      |          |   |                     |        |            |
| 1 |                      |          |   |                     |        |            |
|   |                      |          |   |                     |        |            |
|   |                      |          |   |                     |        |            |
|   | Help                 |          |   |                     | Ok     | Cancel     |

4. Click Add Slices to add an extra PWM port as shown in Figure 38. Click OK.

#### Figure 38 • Edit Slices of CorePWM

5. Right-click PWM[3] to clear the attribute as shown in Figure 39 and right click PWM[3] again to Promote to Top Level as shown in Figure 40 on page 27.



Figure 39 • PWM[3] Clear Attribute



Figure 40 • PWM[3] Promote to Top Level



6. Modify the PWM[3] port as shown in below Figure 41. Enter the name of the port as MPM\_Channel\_7\_DMPM\_DB\_APOL3\_PWM\_TRIM as shown in Figure 42.



Figure 41 • PWM[3] Select Modify Port

Figure 42 • Modify Port Dialog Box

7. Select Mark Unused for PWM[4] as shown in Figure 43.



#### Figure 43 • PWM[4] Mark Unused

8. Save the design, right-click the SmartDesign canvas, and generate the component as shown in Figure 44.



Figure 44 • Selecting Generate Component



 In Libero project flow, after compiling, in I/O attribute editor, select corresponding pin number for the port MPM\_Channel\_7\_DMPM\_DB\_APOL3\_PWM\_TRIM as shown in Figure 45. Select Commit and Check from the File menu and close the window.

| dit View Logic For                 | rmat Too | ls Window Help                        |       |             |                 |          |                |                 |                      |         |          |                    |      |                     |                |          |
|------------------------------------|----------|---------------------------------------|-------|-------------|-----------------|----------|----------------|-----------------|----------------------|---------|----------|--------------------|------|---------------------|----------------|----------|
| ⊇ C   M   ?                        | p p )    | > ☆ ♥ ♥ ♥ ₿ 8 10 10 2 0               | # 🔁 🏲 | 8 📲 🐄       | <b>≌i 1</b> 1 t | n        |                |                 |                      |         |          |                    |      |                     |                |          |
| ical ×                             |          | Port Name                             | Group | Macro Cell  | Pin<br>Number   | Locked   | Bank           | I/O<br>Standard | Output<br>Drive (mA) | Slew    | Resistor | Schmitt<br>Trigger | Skew | Output<br>Load (pF) | Use I/O<br>Reg | Hot      |
| \\SF_MPM_RefDe                     |          |                                       |       |             |                 |          |                |                 |                      |         |          | ingger             |      |                     | neg            |          |
| : \\SF_MPM_RefDe                   | 7        | DMPM_DB_APOL1_EN                      |       | ADLIB:TRIB  | T3              |          | Bank4          | LVTTL           | 8                    | High    | None     | -                  |      | 35                  |                |          |
| : \\SF_MPM_RefDe<br>\\SF_MPM_RefDe | 8        | DMPM_DB_APOL2_EN                      |       | ADLIB:TRIB  | V3              |          | Bank4          | LVTTL           | 8                    | High    | None     | -                  |      | 35                  |                |          |
| SF MPM RefDe                       | 9        | DMPM_DB_APOL3_EN                      |       | ADLIB:TRIB  | AA5             |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| : \\SF_MPM_RefDe                   | 10       | DMPM_DB_DPOL1_EN                      |       | ADLIB:TRIB  | U3              |          | Bank4          | LVTTL           | 8                    | High    | None     | -                  |      | 35                  |                |          |
| : \\SF_MPM_RefDe                   | 11       | DMPM_DB_DPOL2_EN                      |       | ADLIB:TRIB  | T4              |          | Bank4          | LVTTL           | 8                    | High    | None     | -                  |      | 35                  |                |          |
| : \\SF_MPM_RefDe                   | 12       | DMPM_DB_DPOL3_EN                      |       | ADLIB:TRIB  | AA2             |          | Bank4          | LVTTL           | 8                    | High    | None     | -                  |      | 35                  |                |          |
| NSF_MPM_RefDe                      | 13       | DMPM_DB_LED_D0_N                      |       | ADLIB:OUTB  | V1              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| VSF_MPM_RefDe                      | 14       | DMPM DB LED D1 N                      |       | ADLIB:OUTB  | R3              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| NSF MPM RefDe                      | 15       | DMPM DB LED D2 N                      | -     | ADLIB:OUTB  | W1              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| : \\SF_MPM_RefDe                   | 16       | DMPM DB LED D3 N                      |       | ADLIB:OUTB  | Y1              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| \\SF_MPM_RefDe                     | 17       | DMPM DB LED D4 N                      |       | ADLIBOUTB   | AA1             |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| SF_MPM_RefDe                       | 18       | DMPM_DB_LED_D5_N                      |       | ADLIBOUTB   | 112             |          | Bank4          | IVTTI           | 8                    | High    | None     |                    |      | 35                  |                |          |
| \SF MPM RefDe ≡                    | 19       | DMPM_DB_LED_D6_N                      | _     | ADLIB:OUTB  | V2              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| F MPM RefDe                        | 20       | DMPM DB LED D7 N                      | _     | ADLIB:OUTB  | W2              |          | Bank4          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| MPM_RefDe                          | 20       | 12C 0 SCL                             | I2C 0 | ADLIB:BIBU  | U21             |          | Bank4<br>Bank2 | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| MPM_RefDe                          |          | 12C_0_SCL<br>12C_0_SDA                | 12C_0 | ADLIB:BIBU  | V21             |          | Bank2          | LVTTL           | 8                    | High    | None     |                    |      |                     |                |          |
| PM_RefDe<br>PM_RefDe               | 22       |                                       |       | ADLIB:BIBU  | U20             |          | Bank2          | LVTTL           | 8                    |         |          |                    |      | 35                  |                | <b>V</b> |
| M_RefDe                            | 23       | 12C_1_SCL                             | I2C_1 |             |                 |          |                |                 |                      | High    | None     |                    |      | 35                  |                | <b>V</b> |
| PM RefDe                           | 24       | 12C_1_SDA                             | I2C_1 | ADLIB:BIBU  | V22             |          | Bank2          | LVTTL           | 8                    | High    | None     |                    |      | 35                  |                |          |
| M_RefDe                            | 25       | MPM_Channel_1_DMPM_DB_APOL1_3P3V      |       | ADLIB:IOPA  | W9              |          | Bank3          | LVTTL           | -                    | Low     | -        | -                  | -    | -                   |                |          |
| IPM_RefDe                          | 26       | MPM_Channel_1_DMPM_DB_APOL1_PWM_TRIM  |       | ADLIB:OUTB  | C22             |          | Bank1          | LVTTL           | 12                   | High    | None     |                    |      | 35                  |                |          |
| PM_RefDe                           | 27       | MPM_Channel_1_DMPM_DB_APOL1_SDD_TRIM  |       | ADLIB:IOPA  | V7              |          | Bank3          | LVTTL           | -                    | -       | -        |                    | -    | -                   |                |          |
| MPM_RefDe<br>MPM_RefDe             | 28       | MPM_Channel_2_DMPM_DB_APOL2_1P5V      |       | ADLIB:IOPA  | W12             |          | Bank3          | LVTTL           | -                    | Low     | -        | -                  | -    | -                   |                |          |
| MPM_RefDe                          | 29       | MPM_Channel_2_DMPM_DB_APOL2_PWM_TRIM  |       | ADLIB:OUTB  | P2              |          | Bank5          | LVTTL           | 12                   | High    | None     | -                  |      | 35                  |                |          |
| MPM RefDe                          | 30       | MPM_Channel_2_DMPM_DB_APOL2_SDD_TRIM  |       | ADLIB:IOPA  | Y17             |          | Bank3          | LVTTL           | -                    |         | -        | -                  | -    | -                   |                |          |
| MPM_RefDe                          | 31       | MPM_Channel_3_DMPM_DB_DPOL1_PG        |       | ADLIB:INBU  | AB2             |          | Bank4          | LVTTL           | -                    | -       | Up       |                    | -    |                     |                |          |
| MPM_RefDe                          | 32       | MPM_Channel_4_DMPM_DB_DPOL2_PG        |       | ADLIB:INBU  | AB3             |          | Bank4          | LVTTL           | -                    | -       | Up       |                    |      | -                   |                |          |
| OARD_LED                           | 33       | MPM_Channel_5_DMPM_DB_DPOL3_PG        |       | ADLIB:INBU  | Y3              |          | Bank4          | LVTTL           | -                    | -       | Up       |                    | -    |                     |                |          |
| BOARD_LEE                          | 34       | MPM_Channel_6_A2F_BOARD_RV1_POT_2P56V |       | ADLIB:IOPA  | ¥7              |          | Bank3          | LVTTL           | -                    | Low     | -        | -                  | -    | -                   |                |          |
| BOARD_LED                          | 35       | MPM_Channel_7_DMPM_DB_APOL3_1P5V      |       | ADLIB:IOPA  | Y13             |          | Bank3          | LVTTL           | -                    | Low     | -        | -                  | -    | -                   |                |          |
| BOARD_SW                           | 36       | MPM Channel 7 DMPM DB APOL3 PWM TRIM  |       | ADLIB:OUTB  | P1 -            |          | Bank5          | LVITL           | 12                   | High    | None     |                    |      | 35                  |                |          |
| BOARD_SW                           | 37       | MPM PMBus SCL                         |       | ADLIB:BIBUE | F3              |          | Bank5          | LVTTL           | 12                   | High    | None     |                    |      | 35                  |                |          |
| 13_0                               | 38       | MPM PMBus SDA                         |       | ADLIB:BIBUF | E3              |          | Bank5          | LVTTL           | 12                   | High    | None     |                    |      | 35                  |                |          |
|                                    | 38       | MPM PMBus SMBALERT                    |       | ADLIB:BIBUF | G4              | <b>v</b> | Bank5          | LVTTL           | 12                   | High    | None     |                    |      | 30                  |                |          |
|                                    | 40       | MSS RESET N                           |       | ADLIB:BIBUF | 04<br>R1        |          | Bank3          | LVTTL           | - 12                 | ngn<br> | None     |                    |      | 35                  |                |          |
| -                                  | 40       | VAREFO                                |       | ADLIB:INBU  | U10             |          | Bank4<br>Bank3 | LVTTL           | -                    | Low     | ivone    |                    | -    | -                   |                | <b>V</b> |

Figure 45 • Selecting Pin Numbers in the I/O Attribute Editor

10. Perform the place and route and program the FPGA.

# Adding a New DPOL Channel to MPM Reference Design

The DPOL for the channel must be connected to the MPM PMBus and each DPOL on the MPM PMBus must obviously have a unique I2C/PMBus slave address. MPM GUI uses I2C/PMBus slave address to get the details of the DPOL. Follow the below steps to add the new DPOL channel. Assuming you are adding new channel of DPOL as 8th channel.

1. Open the SmartDesign MSS configurator from Libero-Project Flow and double click GPIO block to configure and select Input for GPIO\_16 for the **Power Good (PG) DPOL output signal** as shown in Figure 46.

| 100 | Config | uring MSS_GPIC  | D_0 (MSS_GPIO - 1.0.)   | 101)       |     |                      |                            |        |
|-----|--------|-----------------|-------------------------|------------|-----|----------------------|----------------------------|--------|
|     |        | Multiplexed Wit | h SPI0 Peripheral Dedic | ated I/Os  |     |                      |                            | *      |
|     |        | GPIO_19:        | Use as MSS I/O Pad      | Not Used 🔻 | Y20 | or connect to Fabric | Not Used 🔹                 |        |
|     |        | GPIO_18:        | Use as MSS I/O Pad      | Not Used 🔻 | W19 | or connect to Fabric | Not Used 🔹                 |        |
|     |        | GPIO_17:        | Use as MSS I/O Pad      | Not Used 🔻 | V18 | or connect to Fabric | Not Used 🔹                 |        |
|     |        | GPIO_16:        | Use as MSS I/O Pad      | Not Used 🔹 | U17 | or connect to Fabric | Input   Not Used           | -      |
|     |        | Multiplexed Wit | h MSS User I/Os         |            |     |                      | Input<br>Output            | =      |
|     |        | GPIO_15:        | Use as MSS I/O Pad      | Input 💌    | ¥3  | or connect to Fabric | Input/Output<br>Not Used 🔻 |        |
|     |        | GPIO_14:        | Use as MSS I/O Pad      | Input 🔹    | AB3 | or connect to Fabric | Not Used 💌                 |        |
|     |        | GPIO_13:        | Use as MSS I/O Pad      | Input 🔹    | AB2 | or connect to Fabric | Not Used 🔹                 | *      |
|     | Help   | •               |                         |            |     |                      | ОК                         | Cancel |

Figure 46 • Configuring MSS GPIO

2. Ensure that resistor pull up for GPIO\_13, GPIO\_14, and GPIO\_15 ports in I/O Editor of MSS configurator as shown in Figure 47.

|     |               | 1         | 1          | 1         |              |                   |      | 1             |             |         |                  | 1           |
|-----|---------------|-----------|------------|-----------|--------------|-------------------|------|---------------|-------------|---------|------------------|-------------|
|     | Port Name     | Direction | Pin Number | Bank Name | I/O Standard | Output Drive (mA) | Slew | Resistor Pull | nmitt Trigg | Skew    | Output Load (pF) | Hot Swappal |
| 124 | MSSPWDATA[16] | Output    |            | -         |              |                   |      | -             |             |         |                  |             |
| 125 | MSSPWDATA[17] | Output    |            |           |              |                   |      | -             |             |         |                  |             |
| 126 | MSSPWDATA[18] | Output    |            | -         |              | -                 |      |               |             |         |                  |             |
| 127 | MSSPWDATA[19] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 128 | MSSPWDATA[20] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 129 | MSSPWDATA[21] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 130 | MSSPWDATA[22] | Output    |            | -         |              |                   |      | -             |             |         |                  |             |
| 131 | MSSPWDATA[23] | Output    |            | -         |              | -                 |      |               |             |         |                  |             |
| 132 | MSSPWDATA[24] | Output    |            |           |              |                   |      | -             |             |         |                  |             |
| 133 | MSSPWDATA[25] | Output    |            | -         |              |                   |      | -             |             |         |                  |             |
| 134 | MSSPWDATA[26] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 135 | MSSPWDATA[27] | Output    |            | -         |              |                   |      | -             |             |         |                  |             |
| 136 | MSSPWDATA[28] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 137 | MSSPWDATA[29] | Output    |            | -         |              |                   | -    |               |             |         |                  |             |
| 138 | MSSPWDATA[30] | Output    |            |           |              |                   |      |               |             |         |                  |             |
| 139 | MSSPWDATA[31] | Output    |            |           |              |                   |      | -             |             |         |                  |             |
| 140 | MSSPWRITE     | Output    |            | -         |              |                   |      | -             |             |         |                  |             |
| 141 | SDD0          | Output    | ٧7         | Bank3     | LVTTL        |                   |      | -             | <b></b>     |         |                  | <b></b>     |
| 142 | SDD 1         | Output    | ¥17        | Bank3     | LVTTL        |                   |      | -             |             |         |                  |             |
| 143 | VAREF0        | Input     | U10        | Bank3     | LVTTL        |                   | Low  |               |             |         |                  |             |
| 144 | VAREF1        | Input     | AB11       | Bank3     | LVTTL        |                   | Low  | -             |             |         |                  |             |
| 145 | VAREF2        | Input     | T14        | Bank3     | LVTTL        |                   | Low  |               |             |         |                  |             |
| 146 | F2M_GPI_16    | Input     |            | -         |              |                   | -    | -             |             |         |                  |             |
| 147 | GPIO_15_IN    | Input     | Y3         | Bank4     | LVTTL 👻      |                   |      | Up 👻          |             |         |                  | <b>V</b>    |
| 148 | GPIO_14_IN    | Input     | AB3        | Bank4     | LVTTL -      |                   |      | Up -          |             | <b></b> |                  | <b>V</b>    |
| 149 | GPIO_13_IN    | Input     | AB2        | Bank4     | um. 👻        |                   | -    | Up 👻          |             |         |                  | V           |

Figure 47 • I/O Editor



- Follow the section Adding a Channel to CoreGPIO to Generate Enable Signal to generate the enable signal for the new channel of DPOL. While adding new channel to CoreGPIO, you have to perform the following steps.
  - Select TRIBUFF for IO\_17 of MSS I/O block.
  - Refer "Changes in Softconsole" on page 36 to update eNVM firmware client.
  - Select Tie Low for IO\_17\_D port of SF\_MPM\_RefDesign\_MSS
  - Select Invert for IO\_17\_E port of SF\_MPM\_RefDesign\_MSS.
  - Modify the IO\_17\_PADTRI pin of SF\_MPM\_RefDesign\_MSS and enter the name as DMPM\_DB\_DPOL4\_EN.
  - To add GPIO\_OUT[6] to MPM\_GPIO\_Regulator\_Enables, configure GPIO\_OUT[31:0] as shown in Figure 48.

| Edit Slices - GPIO_OU | JT[31:0  | ]         |       | ? X       |
|-----------------------|----------|-----------|-------|-----------|
| Create 32 🔻           | slices o | f width 1 | ▼ A   | dd Slices |
| GPIO_OUT[31:0]        |          | Left      | Right |           |
|                       | 1        | 0         | 0     |           |
|                       | 2        | 1         | 1     |           |
|                       | 3        | 2         | 2     |           |
|                       | 4        | 31        | 7     |           |
|                       | 5        | 3         | 3     |           |
|                       | 6        | 4         | 4     |           |
|                       | 7        | 5         | 5     |           |
|                       | 8        | 6         | 6     |           |
| Help                  |          |           | ОК    | Cancel    |

Figure 48 • Configuring GPIO\_OUT[31:0]



 Connect GPIO\_OUT[6] port of MPM\_GPIO\_Regulator\_Enables to IO\_17\_E port of SF\_MPM\_RefDesign\_MSS. Now the CoreGPIO (MPM\_GPIO\_Regulator\_Enables) block is similar to Figure 49.



#### Figure 49 • CoreGPIO Block After Configuration

4. Right-click the F2M\_GPI\_16 pin of SF\_MPM\_RefDesign\_MSS and select Promote to Top Level as shown in Figure 50.



Figure 50 • Promote to Top Level



5. Right-click the F2M\_GPI\_16 pin of SF\_MPM\_RefDesign\_MSS and select Modify port as shown in Figure 51. Enter port name as shown in Figure 52 on page 34.



Figure 51 • Selecting Modify Port

| Name: | MPM_Channel_8_DMPM_DB_DPOL4_PG |
|-------|--------------------------------|
| Direc | tion:                          |
| ۲     | Input                          |
|       | Output                         |
|       | Bi-directional (inout)         |

Figure 52 • Modify Port Dialog Box

6. Save the design, right-click the SmartDesign canvas, and generate the component as shown in Figure 44 on page 29.

 In Libero project flow, after compiling, in I/O attribute editor, select corresponding pin number for the port MPM\_Channel\_8\_DMPM\_DB\_DPOL4\_PG and select Up for Resistor Pull as shown in Figure 53. Select Commit and Check from the File menu and close the window.

| ic Format T        | ools Window Help               |       |             |               |          |                |                 |                      |      |                  |                    |         |                     |                |               |
|--------------------|--------------------------------|-------|-------------|---------------|----------|----------------|-----------------|----------------------|------|------------------|--------------------|---------|---------------------|----------------|---------------|
| 8                  | 6 B B B B B B                  | 10    | 🔁 🖨 🗎 🐿     | . *::         |          | 10             | #               |                      |      | 🔁 in 🖾 -         | 1월 🖘 🖣             | i th th |                     |                |               |
| efDe               | Port Name                      | Group | Macro Cell  | Pin<br>Number | Locked   | Bank<br>Name   | I/O<br>Standard | Output<br>Drive (mA) | Slew | Resistor<br>Pull | Schmitt<br>Trigger | Skew    | Output<br>Load (pF) | Use I/O<br>Reg | Hot<br>Swappa |
| efDe 8             | DMPM_DB_APOL2_EN               |       | ADLIB:TRIB  | V3            |          | Bank4          | LVTTL           | 8                    | High | None             |                    |         | 35                  |                |               |
| efDe 9             | DMPM_DB_APOL3_EN               |       | ADLIB:TRIB  | AA5           |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| efDe 10            | DMPM DB DPOL1 EN               |       | ADLIB:TRIB  | U3            |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| efDe 10<br>efDe 11 | DMPM DB DPOL2 EN               |       | ADLIB:TRIB  | T4            |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| fDe 12             | DMPM_DB_DPOL3_EN               |       | ADLIB:TRIB  | AA2           |          | Bank4          | IVTTI           | 8                    | High | None             | -                  |         | 35                  |                |               |
| 13                 | DMPM DB DPOL4 EN               |       | ADLIB       | W5            |          | Bank4          | LVTTL           | - 8                  | High | None             | -                  |         | 35                  |                |               |
| 14                 | DMPM DB LED D0 N               |       | ADLIB:OUTB  | V1            |          | Bank4          | IVTTI           | - 8                  | High | None             |                    |         | 35                  |                |               |
| 15                 | DMPM DB LED D1 N               |       | ADLIB:OUTB  | R3            |          | Bank4          | LVTTL           | 8                    | High | None             |                    |         | 35                  |                |               |
| 15                 | DMPM DB LED D2 N               | -     | ADLIB:OUTB  | W1            |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| 17                 | DMPM DB LED D3 N               | -     | ADLIB:OUTB  | Y1            |          | Bank4          | IVTTI           | 8                    | High | None             |                    |         | 35                  |                |               |
| 18                 | DMPM DB LED D4 N               | -     | ADLIB:OUTB  | AA1           |          | Bank4          | LVTTL           | 8                    | High | None             |                    |         | 35                  |                |               |
| 19                 | DMPM DB LED D5 N               |       | ADLIB:OUTB  | U2            |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| 20                 | DMPM DB LED D6 N               |       | ADLIB:OUTB  | V2            |          | Bank4          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
|                    | DMPM_DB_LED_D7_N               |       | ADLIB:OUTB  | W2            |          | Bank4          | LVTTL           | 8                    | High | None             |                    |         |                     |                |               |
| 21                 | 12C 0 SCL                      | I2C_0 | ADLIB:BIBU  | U21           |          | Bank2          | LVTTL           | 8                    | High | None             | -                  |         | 35                  |                |               |
| 22                 | 12C_0_SDA                      | 12C_0 | ADLIB:BIBU  | V21           |          | Bank2          | IVIT            | 8                    | High | None             |                    |         | 35                  |                |               |
| 23                 |                                |       | ADLIB:BIBU  | U20           |          | Bank2<br>Bank2 | LVTTL           | 8                    | ~    |                  |                    |         | 35                  |                |               |
| 24                 | 12C_1_SCL                      | I2C_1 |             |               |          |                |                 |                      | High | None             |                    |         | 35                  |                |               |
| 25                 | I2C_1_SDA                      | I2C_1 | ADLIB:BIBU  | V22           |          | Bank2          | LVTTL           | 8                    | High | None             |                    |         | 35                  |                |               |
| 26                 | MPM_Channel_1_DMPM_DB_APOL1_3P |       | ADLIB:IOPA  | W9            |          | Bank3          | LVTTL           | -                    | Low  | -                | -                  | -       | -                   |                |               |
| 27                 | MPM_Channel_1_DMPM_DB_APOL1_P  |       | ADLIB:OUTB  | C22           | V        | Bank1          | LVTTL           | 12                   | High | None             | -                  |         | 35                  |                |               |
| 28                 | MPM_Channel_1_DMPM_DB_APOL1_S  |       | ADLIB:IOPA  | V7            |          | Bank3          | LVTTL           | -                    | -    | -                | -                  | -       | -                   |                |               |
| 29                 | MPM_Channel_2_DMPM_DB_APOL2_1P |       | ADLIB:IOPA  | W12           |          | Bank3          | LVTTL           | -                    | Low  | -                | -                  | -       | -                   |                |               |
| 30                 | MPM_Channel_2_DMPM_DB_APOL2_P  |       | ADLIB:OUTB  | F1            | <b>V</b> | Bank5          | LVTTL           | 12                   | High | None             | -                  |         | 35                  |                |               |
| 31                 | MPM_Channel_2_DMPM_DB_APOL2_S  |       | ADLIB:IOPA  | Y17           |          | Bank3          | LVTTL           | -                    | -    | -                | -                  | -       | -                   |                |               |
| 32                 | MPM_Channel_3_DMPM_DB_DPOL1_PG |       | ADLIB:INBU  | AB2           |          | Bank4          | LVTTL           | -                    | -    | Up               |                    | -       | -                   |                |               |
| 33                 | MPM_Channel_4_DMPM_DB_DPOL2_PG |       | ADLIB:INBU  | AB3           | <b>V</b> | Bank4          | LVTTL           | -                    | -    | Up               |                    | -       | -                   |                |               |
| 34                 | MPM_Channel_5_DMPM_DB_DPOL3_PG |       | ADLIB:INBU  | Y3            |          | Bank4          | LVTTL           | -                    | -    | Up               |                    | -       | -                   |                |               |
| 35                 | MPM_Channel_6_A2F_BOARD_RV1_PO |       | ADLIB:IOPA  | Y7            | <b>V</b> | Bank3          | LVTTL           | -                    | Low  |                  | -                  | -       | -                   |                |               |
| 36                 | MPM_Channel_7_DMPM_DB_APOL3_1P |       | ADLIB:IOPA  | Y13           | <b>V</b> | Bank3          | LVTTL           | -                    | Low  |                  | -                  | -       | -                   |                |               |
| 37                 | MPM_Channel_7_DMPM_DB_APOL3_P  |       | ADLIB:OUTB  | P1            | <b>V</b> | Bank5          | LVTTL           | 12                   | High | None             | -                  |         | 35                  |                |               |
| 38                 | MPM_Channel_8_DMPM_DB_DPOL4_PG |       | ADLIB:INBUF | M6 🚽          |          | Bank5          | LVTTL           |                      | -    | Up               |                    | -       | -                   |                |               |
| 39                 | MPM_PMBus_SCL                  |       | ADLIB:BIBUF | F3            | 7        | Bank5          | LVTTL           | 12                   | High | None             |                    |         | 35                  |                |               |
| 40                 | MPM_PMBus_SDA                  |       | ADLIB:BIBUF | E3            | <b>V</b> | Bank5          | LVTTL           | 12                   | High | None             |                    |         | 35                  |                |               |
| 41                 | MPM_PMBus_SMBALERT             |       | ADLIB:BIBUF | G4            | <b>V</b> | Bank5          | LVTTL           | 12                   | High | None             |                    |         | 35                  |                |               |
| - 42               | MSS RESET N                    |       | ADLIB:INBU  | B1            |          | Bank4          | LVTTL           |                      | -    | None             |                    |         |                     |                |               |

Figure 53 • Selecting Pin Numbers in I/O Attribute Editor

8. Perform the place and route and program the FPGA.



### **Changes in Softconsole**

If you are adding the new channel of APOL, delete mss\_ace folder under drivers\_config folder and add the same from firmware folder (C:\Microsemi\SF\_MPM\_RefDesign\_v4.0\design\_files\Libero\_project\SF\_MPM\_RefDesign\firmware\drivers\_config).



#### Figure 54 • SoftConsole Project Explorer

If you are adding the new channel of DPOL, do the following changes to mpm.c file.

1. To configure the port MPM\_Channel\_8\_DMPM\_DB\_DPOL4\_PG, add the configuration code to the function mpm\_init\_engine() as shown in Figure 55.



#### Figure 55 • Configuring MSS\_GPIO\_16

2. Add the following IRQHandler to mpm.c file



Now build the softconsole project in release mode. Use the \*.HEX file from release folder (C:\Microsemi\SF\_MPM\_RefDesign\_v4.0\design\_files\SoftConsole\_workspace\SF\_MPM\_RefDesign\m pm\_reference\_design\Release) in MSS eNVM client under MPM\_Firmware as shown in Figure 56.

|                                                                                                       |                                                       |                                                                                                                                      | Useru                    | lients in eNV     | м                   |        |                |            | _ |
|-------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------|---------------------|--------|----------------|------------|---|
| Initialization<br>Data Storage                                                                        | Client Type                                           | Client Name                                                                                                                          | Depth<br>X               | Start<br>Address  | Pa                  | ige    | Initialization | Lock Start |   |
|                                                                                                       | Client Type                                           |                                                                                                                                      | Width                    | (hex)             | Start               | End    | Order          | Address    |   |
| 1                                                                                                     | Data Storage                                          | MPM_Configurati                                                                                                                      | 832 x 32                 | 3E000             | 1984                | 2009   | N/A            | <b>V</b>   |   |
| Add to System 2                                                                                       | Data Storage                                          | MPM_Firmware                                                                                                                         | 39428 x 8                | 0                 | 0                   | 308    | N/A            |            |   |
| 3                                                                                                     | Data Storage                                          | MPM_Event_Log                                                                                                                        | 16384 x 8                | 3A000             | 1856                | 1983   | N/A            |            |   |
| Jsage Statistics                                                                                      | Modify Data St                                        | orage Client                                                                                                                         |                          |                   |                     | ×      |                |            |   |
| Available Pages: 4087                                                                                 |                                                       |                                                                                                                                      |                          | _                 |                     |        |                |            |   |
| Jsed Pages: 463                                                                                       | Client name:                                          | MPN                                                                                                                                  | <pre>1_Firmware</pre>    |                   |                     |        |                |            |   |
| Free Pages: 3624                                                                                      | eNVM                                                  |                                                                                                                                      |                          | <u> </u>          |                     |        |                |            |   |
|                                                                                                       |                                                       |                                                                                                                                      |                          |                   |                     |        |                |            |   |
| Reserved Region                                                                                       | Content:                                              |                                                                                                                                      |                          |                   |                     |        |                |            |   |
|                                                                                                       |                                                       |                                                                                                                                      |                          |                   |                     |        |                |            |   |
| 0x6007FB80 -                                                                                          | M                                                     | emory file: C:\\                                                                                                                     | licrosemi\SF_I           | MPM_RefDe         | sign_v4.0\c         | esign_ |                |            |   |
| 0x6007FB80 -<br>0x6007FFFF                                                                            | @ M                                                   |                                                                                                                                      |                          | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFFF                                                                                            | @ M                                                   |                                                                                                                                      | licrosemi\SF_t<br>·Hex ▼ | MPM_RefDe         | sign_v4.0\c<br>Brow |        |                |            |   |
| 0x6007FFF                                                                                             |                                                       |                                                                                                                                      | Hex 🔻                    | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFFF                                                                                            |                                                       | Format: Intel                                                                                                                        | Hex 🔻                    | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFF                                                                                             | © N                                                   | Format: Inte<br>o content (client is a pl                                                                                            | -Hex 🔹                   | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFFF<br>eNVM Blocks<br>Client in block 0<br>Client in both 0 and 1                              | © N                                                   | Format: Intel                                                                                                                        | Hex                      | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFFF<br>eNVM Blocks<br>Client in block 0                                                        | © N                                                   | Format: Intel                                                                                                                        | -Hex 🔹                   | MPM_RefDe         |                     |        |                |            |   |
| 0x6007FFFF<br>NVM Blocks<br>Client in block 0<br>Client in block 0<br>Client in block 1               | © N<br>● ♥ U<br>Start addre                           | Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>sss: 0x 0                                                    | Hex                      |                   |                     |        |                | Cancel     |   |
| 0x6007FFFF<br>NVM Blocks<br>Client in block 0<br>Client in block 0<br>Client in block 1               | © N.<br>€ ⊻ U.                                        | Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>ess: 0x 0                                                    | Hex                      | MPM_RefDe<br>bits |                     |        | Ok             | Cancel     |   |
| 0x6007FFF<br>Client in block 0<br>Client in block 0<br>Client in block 1<br>Client in block 1<br>Help | © N<br>● ♥ U<br>Start addre                           | Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>ess: 0x 0<br>rd: 8                                           | Hex                      |                   | Brows               |        | Ok             | Cancel     |   |
| 0x6007FFFF<br>NVM Blocks<br>Client in block 0<br>Client in block 0<br>Client in block 1               | N                                                     | Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>ess: 0x 0<br>rd: 8                                           | Hex                      | bits              | Brows               |        | Ok             | Cancel     |   |
| 0x6007FFF<br>Client in block 0<br>Client in block 0<br>Client in block 1<br>Client in block 1<br>Help | ● N<br>● ♥ U<br>Start addr<br>Size of wo<br>Number of | Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>sss: 0x 0<br>rd: 8<br>words: 3943                            | Hex                      | bits              | Brows               |        | Ok             | Cancel     |   |
| 0x6007FFF<br>Client in block 0<br>Client in block 0<br>Client in block 1<br>Client in block 1<br>Help | N                                                     | Format: Intel<br>Format: Intel<br>o content (client is a pl<br>se absolute addressing<br>ess: 0x 0<br>rd: 8<br>words: 334;<br>setion | Hex                      | bits              | Brows               |        | Ok             | Cancel     |   |

#### Figure 56 • MSS eNVM MPM\_Firmware Client

After following above steps, generate the \*.stp file from FlashPro and copy the same to C:MicrosemiSF\_MPM\_RefDesign\_v4.0\template.

Now from MPM GUI, choose the above generated \*.stp file by selecting Choose STAPL Template option and load the default settings by selecting Load Values option from File submenu as shown in Figure 57 MPM GUI Menu.

Now you can set the all fields in GUI for your added channel(s) and click Write NVM & Fabric.

| Data View Help                                                                                                 |   |                            |
|----------------------------------------------------------------------------------------------------------------|---|----------------------------|
| FlashPro +                                                                                                     |   | Write NVM & Fabric         |
| 12C >                                                                                                          |   | Write NVM                  |
| File +                                                                                                         |   | Choose STAPL Template      |
| Create Memfile                                                                                                 |   | Locate FlashPro Executable |
| 1 SF_MPM_Reference_Design.txt                                                                                  |   | Flashpro Setup             |
| 2 C:\Microsemi\SF_MPM_RefDesign_v4.0\bin\SF_MPM_Reference_Design.txt                                           | P | mV                         |
| Exit                                                                                                           | μ | mV                         |
| 3 C:\Microsemi\SF_MPM_RefDesign_v4.0\bin\SF_MPM_Reference_Design_wrking.txt                                    |   |                            |
| 4 C:\Microsemi\SF_MPM_RefDesign_v4.0\bin\SF_MPM_Reference_Design_no2.txt                                       | Ь | mV                         |
| Rail A16         OV1:         3465         mV           Rail A17         Double         Trim Low :         850 | _ | mV                         |

Figure 57 • MPM GUI Menu

# **Appendix A**

### **Design Files**

You can download the design files from the Microsemi SoC Products Group website: www.microsemi.com/soc/download/rsc/?f=A2F\_AC385\_DF. The design file consists of Libero SoC projects and SoftConsole software projects. Refer to the ReadMe.txt file for directory structure, description, and software versions.

You can download the programming files (\*.stp) in release mode from the Microsemi SoC Products Group website: www.microsemi.com/soc/download/rsc/?f=A2F\_AC385\_PF.

# References

- MPM Product Brief: www.microsemi.com/soc/documents/MPM\_SmartFusion\_PB.pdf
- MPM Daughter Card: www.microsemi.com/soc/documents/MPM\_DC\_KIT\_QS.pdf
- MPM Design User Guide: www.microsemi.com/soc/documents/SmartFusion\_MPM\_UG.pdf
- MPM White Paper: www.microsemi.com/soc/documents/MPM\_WP.pdf



Microsemi Corporate Headquarters One Enterprise, Aliso Viejo CA 92656 USA Within the USA: +1 (949) 380-6100 Sales: +1 (949) 380-6136 Fax: +1 (949) 215-4996 Microsemi Corporation (NASDAQ: MSCC) offers a comprehensive portfolio of semiconductor solutions for: aerospace, defense and security; enterprise and communications; and industrial and alternative energy markets. Products include high-performance, high-reliability analog and RF devices, mixed signal and RF integrated circuits, customizable SoCs, FPGAs, and complete subsystems. Microsemi is headquartered in Aliso Viejo, Calif. Learn more at **www.microsemi.com**.

© 2012 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners.