# **Engineer-to-Engineer Note**

**EE-440** 

**ANALOG** DEVICES Technical notes on using Analog Devices products and development tools Visit our Web resources http://www.analog.com/ee-notes and http://www.analog.com/processors or e-mail processor.support@analog.com or processor.tools.support@analog.com for technical support.

# **Estimating Power for ADSP-SC596/SC598 SHARC+ Processors**

Contributed by Deepak Huchaiah

Rev 2 - July 10, 2023

# Introduction

This Engineer-to-Engineer application note describes how to estimate power consumption on the ADSP-SC596/SC598 processors, which include the SHARC+® high-performance cores and several peripherals, accelerators, and Direct Memory Access (DMA) channels. These processors have multiple power domains <sup>[6]</sup> and clock domains. Analog Devices provides a simple methodology for estimating the total System-on-Chip (SoC) power consumption that is dependent on processor activity usage.

Power estimates are based on design simulations and characterization data, measured across power supply voltage, core and system clock frequency, and junction temperature (T<sub>J</sub>). The power can vary depending on how a customer uses the on-chip ADSP-SC596/SC598 SHARC+ Processor resources. Engineers cannot accurately estimate power consumption without an understanding of the components in use and their usage patterns. By providing the usage parameters, board designers can obtain accurate consumption estimates for developing power supply and thermal relief solutions for the ADSPSC596/SC598 SHARC+ processor-based products.

Refer to the <u>ADSP-SC596/SC598</u>: <u>SHARC+</u> <u>Dual-Core</u> <u>DSP</u> with <u>Arm</u> <u>Cortex-A55</u> <u>Data Sheet</u> <sup>[1]</sup> for specific details described in this EE Note:

- Operating conditions-supported power supply ranges
- Electrical Characteristics and Total Internal Power Dissipation-current specifications

The <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u><sup>[2]</sup> software performs power calculations and as directed with this EE note. The software helps users obtain a total power profile by populating the spreadsheet cells with data from the processor data sheet <sup>[1]</sup> and calculations specific for an intended application. The EE-440 note explains the situations related to the power calculator that the data sheet does *not* describe.

This EE note also describes how to provide the input to the power calculator software to obtain a full power profile for an application. It describes how the calculations are done and how the results contribute to the overall power profile.

Copyright 2023, Analog Devices, Inc. All rights reserved. Analog Devices assumes no responsibility for customer product design or the use or application of customers' products or for any infringements of patents or rights of others which may result from Analog Devices assistance. All trademarks and logos are property of their respective holders. Information furnished by Analog Devices applications and development tools engineers is believed to be accurate and reliable, however no responsibility is assumed by Analog Devices regarding technical accuracy and topicality of the content provided in Analog Devices Engineer-to-Engineer Notes.



# **Power Domains**

There are multiple power domains associated with the ADSP-SC596/SC598 SHARC+ processor. Its total power consumption is the sum of the power consumed across all the power domains.

These power domains are significant contributors to the overall power profile:

- V<sub>DD\_INT</sub>-most internal on-chip logic (for example, core, accelerators, DMA engines, etc.)
- V<sub>DD\_EXT</sub>-for example, I/O pad ring, JTAG
- V<sub>DD\_REF</sub>-I/O reference supply
- V<sub>DD\_DMC</sub>-DDR controller

The power consumption from the  $V_{DD_ANA}$  power supply for HADC/TMU analog blocks is insignificant and not considered part of the power calculations.

# **Estimating Internal Power Consumption (PDD\_INT\_TOT)**

The total power consumption for the on-chip logic (V<sub>DD\_INT</sub> supply) is the sum of the static (leakage) and dynamic (switching) power parts. The dynamic part depends primarily on processor activity, which includes the instruction execution sequence, the data operands involved, and the instruction rate on each core. The dynamic part also depends on the number of active peripherals and accelerators, their clock rates, and any associated DMA data traffic. Dynamic current is also influenced by temperature and voltage. The static part is independent of processor activity and is *only* a function of temperature and voltage.

The internal current (IDD\_INT\_TOT) consumed by the ADSP-SC596/SC598 SHARC+ Processors includes the components in the <u>Table 1</u>.

| Internal Current Component | Leakage / Dynamic Current | Processor Area             |
|----------------------------|---------------------------|----------------------------|
| IDD_INT_STATIC             | Leakage                   | n/a                        |
| IDD_INT_CCLK_SHARC0_DYN    | Dynamic-CCLK domain       | SHARC+ core 1              |
| IDD_INT_CCLK_SHARC1_DYN    | Dynamic-CCLK domain       | SHARC+ core 2              |
| IDD_INT_CCLK_A55_DYN       | Dynamic-CCLK domain       | Cortex A55 core            |
| IDD_INT_DCLK_DYN           | Dynamic-DCLK domain       | No other activity          |
| IDD_INT_SYSCLK_DYN         | Dynamic-SYSCLK domain     | No other activity          |
| IDD_INT_SCLK0_DYN          | Dynamic-SCLK0 domain      | No other activity          |
| IDD_INT_SCLK1_DYN          | Dynamic-SCLK1 domain      | No other activity          |
| IDD_INT_OCLK_DYN           | Dynamic-OCLK domain       | No other activity          |
| IDD_INT_DMA_DR_DYN         | Dynamic                   | DMA activity               |
| IDD_INT_ACCL_DYN           | Dynamic                   | FIR/IIR accelerator blocks |

| Table 1: Internal Current | (IDD_INT_TOT) | Components |
|---------------------------|---------------|------------|
|---------------------------|---------------|------------|



The total internal current is the sum of each of the <u>Table 1</u> components, where there is a single static power component and several dynamic power components that must be included in the overall power profile.

The processor data sheet provides maximum specifications for  $I_{DD_{INT}}$  at specific voltages, frequencies, and temperatures. The following sections describe how to use the data sheet information to calculate the total power requirements of a specific application.

## **Estimating Total IDD\_INT Dynamic Current**

Because of the multi-featured clock and power capabilities of the ADSP-SC596/SC598 SHARC+ Processors, there are many contributors to the overall dynamic component. These components consist of power consumed by the core. While an application can disable clocks to the different domains, each component must be evaluated to determine what factors to account for. These components define how to compute the power dissipation for any combination of active domains.



The dynamic current data (part of this EE note) and associated power calculator spreadsheet applies to maximum junction temperature of 125°C and the worst-case (highest power) fabrication process.

#### Core Dynamic Current

The Core Dynamic Current includes the currents for IDD\_INT\_CCLK\_A55\_DYN, IDD\_INT\_CCLK\_SHARC0\_DYN, and IDD\_INT\_CCLK\_SHARC1\_DYN.

The ADSP-SC596/SC598 SHARC+ Processor data sheet<sup>[2]</sup> provides the baseline dynamic current consumption specifications that are obtained with the processor running a *typical* application. It is represented in the data sheet by the  $I_{DD-TYP}$  specification.

However, these conditions do not represent all possible application code. The silicon process variation is also ignored, which influences the power profile because of non-uniform transistor physics across the silicon. When making decisions regarding the power supply design, the worst-case scenario must always be considered.

The above assumptions are addressed using different tables in the data sheet, to extrapolate and obtain the maximum requirements for the power supply designs:

- *Dynamic Current* tables-provide the maximum (across process and temperature) core dynamic current specification as a function of voltage (V<sub>DD\_INT</sub>) and frequency (f<sub>CCLK</sub>), while running *typical* application code.
- Activity Scaling Factor (ASF) tables-describe discrete dynamic activity levels to provide insight on how the dynamic current scales with changing loads on the core.

Using these combined specifications, the dynamic component of core power consumption can be obtained by multiplying the baseline spec obtained from the *Dynamic Current* tables and the associated *Activity Scaling Factor*, as further explored in the following sections.



# ARM Cortex-A55 ASF Vectors

The Activity Scaling Factors (ASFs) for ARM Cortex-A55 Core table define these vectors:

- IDD-IDLE-ARM core executing the IDLE instruction ("idle activity") only
- IDD-DHRYSTON-ARM core executing Dhrystone benchmark algorithm
- IDD-2575–ARM core executing 25% peak activity and 75% idle activity
- IDD-5050-ARM core executing 50% peak activity and 50% idle activity
- IDD-7525-ARM core executing 75% peak activity and 25% idle activity (used for IDD\_TYP spec)
- I<sub>DD-PEAK\_100</sub>-ARM core continuously thrashes cache memory with maximum data changes, executing mix floating point and arithmetic instructions with PMU events enabled (peak activity).



The test code used to measure  $I_{DD-PEAK_{100}}$  represents the worst-case core operation and is not sustainable under normal application conditions.

In addition to the Activity Scaling Factors, the power calculator defines the following vector on the *Core Activity Factors* tab:

• IDD-CLOCK\_GATED-Arm core clock disabled (no dynamic power)

#### SHARC+ Core ASF Vectors

The Activity Scaling Factors (ASFs) for the SHARC+ Core0 table in the data sheet defines these vectors:

- I<sub>DD-IDLE</sub>-SHARC+ core executing the IDLE instruction only
- IDD-NOP–SHARC+ core executing 100% NOPs
- I<sub>DD-TYP\_3070</sub>–SHARC+ core executing 30% floating-point (FP) multiply/add/subtract and store instructions and 70% NOPs
- I<sub>DD-TYP\_5050</sub>-SHARC+ core executing 50% floating-point (FP) multiply/add/ subtract and store instructions and 50% NOPs
- IDD-TYP\_7030-SHARC+ core executing 70% floating-point (FP) multiply/add/ subtract and store instructions and 30% NOPs (used for IDD\_TYP specification)
- I<sub>DD-PEAK\_100</sub>–SHARC+ core executing 100% floating-point (FP) multiply/add/subtract and store instructions
- IDD-LS: SHARC+ core in light sleep mode



The test code used to measure  $I_{DD-PEAK_{-}100}$  represents the worst-case core operation and is not sustainable under normal application conditions.

In addition to the ASFs (Activity Scaling Factor), the <u>ADSP-SC596-SC598 Power Calculator Tool</u> <u>Rev00</u><sup>[2]</sup> software defines the following vector on the *Core Activity Factors* tab:

• IDD-CLOCK\_GATED: SHARC+ core clock disabled (no dynamic power)



#### Low Power Features

The ADSP-SC596/SC598 SHARC+ processors provide an additional power-saving feature to reduce power consumption in the on-chip L1 memory and when the core is idle.

• Low Power Idle Mode (core light sleep)–When the core goes into the idle state, upon executing the IDLE instruction, there exists active/switching power associated with all active clocks (even though there is no activity inside the core). To reduce the power, program the core light sleep enable field, which is a core clock gating mechanism (core light sleep) for switching off these clocks.



The core light sleep mechanism is effective only when the processor is booted, and *not* when executing from an emulator.

Additional modes such as Memory Sleep and Memory Shutdown mentioned in the SHARC+ Core Programming Reference do not provide significant power savings.

#### Using ASFs to Establish Application-Specific Total Average Power Profile

Once the baseline dynamic current specification from the *Dynamic Current* tables is obtained from the spread sheet cell associated with the CCLK frequency (fCCLK) and the input voltage (VDD\_INT) of interest, the next step is to analyze the application to identify and apply the proper Activity Scaling Factors The application must be broken down into percentages of time spent in states associated with one of these standard power vectors. With knowledge of the program flow and an estimate of the percentage of time spent at each activity level, the baseline dynamic current and the corresponding ASF can be used to determine the average dynamic current consumption for each core.

For example, IDD\_INT\_CCLK\_SHARC0\_DYN for the SHARC+ core0 in a specific application can be calculated according to <u>Equation 1</u>, where "%" is the percentage of the overall time that the application spends in that state:

#### Equation 1 Total Individual Core Dynamic Current

IDD\_INT\_CCLK\_SHARCO\_DYN = (% Peak activity level x IDD-PEAK\_100 ASF x IDD\_INT\_CCLK\_SHARCO\_DYN) +

(% High activity level x Idd-typ\_7030 ASF x Idd\_INT\_CCLK\_SHARC0\_dyn) +

(% Moderate activity level x IDD-TYP\_5050 ASF x IDD\_INT\_CCLK\_SHARC0\_DYN) +

(% Low activity level x IDD-TYP\_3070 ASF x IDD\_INT\_CCLK\_SHARC0\_DYN) +

(% NOP activity level x IDD-NOP ASF x IDD\_INT\_CCLK\_SHARC0\_DYN) +

(% IDLE activity level x IDD-IDLE ASF x IDD\_INT\_CCLK\_SHARC0\_DYN) +

(% CCLK disabled x IDD-CLOCK\_GATED ASF x IDD\_INT\_CCLK\_SHARCO\_DYN) +

(% LS activity level x Idd-ls ASF x Idd\_INT\_CCLK\_SHARCO\_DYN)



Note that the  $I_{DD_INT\_CCLK\_SHARC0\_DYN}$  output is the average current, whereas the  $I_{DD\_INT\_CCLK\_SHARC0\_DYN}$  inputs are with ASF = 1.0. Consider a SHARC+ core0 application that is continuously running and never idles, where the core activity is:

- I<sub>DD-PEAK\_100</sub> activity level-10%
- I<sub>DD-TYP\_7030</sub> activity level-20%
- I<sub>DD-TYP\_5050</sub> activity level-50%
- I<sub>DD-TYP\_3070</sub> activity level-10%
- I<sub>DD-NOP</sub> activity level–10%
- IDD-LS, IDD-IDLE and IDD-CLOCK\_GATED activity level -0%

## Applying <u>Equation 1</u> to this profile yields:

 $IDD_INT_CCLK\_SHARCO\_DYN = (0.1 \text{ x } IDD\_PEAK\_100 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.2 \text{ x } IDD\_TYP\_7030 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.5 \text{ x } IDD\_TYP\_5050 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_INT\_CCLK\_SHARCO\_DYN) + (0.1 \text{ x } IDD\_TYP\_3070 \quad ASF\_ \text{ x } IDD\_TT\_CCLK\_SHARC0\_DYN) + (0.1 \text{ x } IDD\_TT\_CCLK\_SHARC0\_DYN)$ 

## Estimating System Clock Tree Currents

ADSP-SC596/SC598 SHARC+ processors have multiple system clock domains to clock the system buses, various peripherals, DMA controllers, L2 memory, and a DDR controller. Each of these clock domains consumes power that dissipates in the internal power domain due to its respective clock toggling inside the chip. Additional power consumed by the peripherals and DMA (when active) is attributed to individual peripherals and DMAs running in the system. The power is estimated separately and added to the baseline system power when the total power profile is calculated.

There are four major system clock domains on the ADSP-SC596/SC598 SHARC+ processors:

- SYSCLK
- SCLK0
- SCLK1
- DCLK

There is also a programmable output clock (OCLK), which can be generated by one of the CGUs and routed to an external pin on the processor. It has a small influence on the overall power profile.

To estimate the impact to the current consumed in the  $V_{DD_{INT}}$  domain because of each of these system clocks, unique scaling factors are furnished in the processor data sheet.



The factors represent the currents consumed per MHz per volt in each system clock domain; therefore, V<sub>DD\_INT</sub> is in terms of volts, and fxxx is in terms of MHz in the system clock dynamic current equations:

- $IDD_INT_DCLK_DYN = 0.097 \text{ x } VDD_INT \text{ x } fDCLK$
- $I_{DD_INT_SYSCLK_DYN} = 0.792 \text{ x } V_{DD_INT} \text{ x } f_{SYSCLK}$
- $I_{DD_INT\_SCLK0\_DYN} = 0.451 \text{ x } V_{DD_INT} \text{ x } f_{SCLK0}$
- $I_{DD_INT\_SCLK1\_DYN} = 0.014 \text{ x } V_{DD_INT} \text{ x } f_{SCLK1}$
- $I_{DD_INT_OCLK_DYN} = 0.108 \text{ x } V_{DD_INT} \text{ x } f_{OCLK}$



The scaling factor for each of the system clock dynamic current equations is in units of mA/MHz/V; therefore, the result for each is in terms of mA.

#### Estimating DMA Contribution to Internal Dynamic Current (IDD\_INT\_DMA\_DR\_DYN)

Different types of DMA transactions in the system result in additional power consumption:

- DMA transfers between the various memory spaces
- DMA transfers from memory to peripherals
- DMA transfers from peripherals to memory

Power consumption varies with the number of running DMA channels and the rate at which they move data through the system. To estimate DMA power consumption, three power profiles are available in the *DMA Peripheral Usage, pull-down in the VDD\_INT Clock Domains & DMA Rates* table in the <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u><sup>[2]</sup> software:

- **HIGH**–comprised of high-speed MDMA, multiple low-speed MDMAs, and several high-speed peripheral DMAs running simultaneously in the system for a combined throughput of approximately **4695** MBPS.
- **MEDIUM**–comprised of medium-speed MDMA, multiple low-speed MDMAs, and several low-speed peripheral DMAs running simultaneously in the system for a combined throughput of approximately **3665** MBPS.
- LOW–comprised of low-speed MDMA and several low-speed peripheral DMAs running simultaneously in the system for a combined throughput of approximately **453** MBPS.

To estimate the DMA dynamic current  $(I_{DD_INT_DMA_DR_DYN})$  in the application, the combined data bandwidth of all the DMAs running in the system determines which profile to select as the closest match to the actual application and use as the  $I_{DD_INT_DMA_DR_DYN}$  component for the  $I_{DD_INT_TOT}$  calculation.



## High DMA Configuration

The following peripheral and memory DMAs are active in this high DMA configuration:

- 8 SPORTS at 62.5 MHz in RX mode with PRI/SEC enabled (writing data to L2 memory)
- 8 SPORTS at 62.5 MHz in TX mode with PRI/SEC enabled (reading data from L2 memory )
- SPI2/SPI1 in quad mode, SPI0 in dual mode TX operation at 62.5 MHz (reading data from L2 memory)
- LP TX mode at 125 MHz (reading data from L2 memory)
- One times medium speed MDMA transferring data from L1 to L2 memory
- One times medium speed MDMA transferring data from L2 to L1 memory
- One times medium speed MDMA transferring data from DDR to L1 memory
- One times high speed MDMA transferring data from L1 memory to DDR

In this configuration, the  $I_{DD_INT_DMA_DR_DYN}$  component (see the  $V_{DD_INT}DMA$  Usage tab of the <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u><sup>[2]</sup> software) is 220 mA.

## Medium DMA Configuration

The following peripheral and memory DMAs are active in this medium DMA configuration:

- 8 SPORTS at 62.5 MHz in RX mode with PRI/SEC enabled (writing data to L2 memory)
- 8 SPORTS at 62.5MHz in TX mode with PRI/SEC enabled (reading data from L2 memory)
- SPI2/SPI1 in quad mode, SPI0 in dual mode TX operation at 62.5MHz (reading data from L2 memory )
- LP TX mode at 125 MHz (reading data from L2 memory)
- One times medium speed MDMA transferring data from L1 to L2 memory
- One times medium speed MDMA transferring data from L2 to L1 memory

In this configuration, the IDD\_INT\_DMA\_DR\_DYN component (see the *VDD\_INT DMA Usage* tab of the ADSP-SC596-SC598 Power Calculator Tool Rev00<sup>[2]</sup> software) is 143 mA.

#### Low DMA Configuration

The following peripheral and memory DMAs are active in this low DMA configuration:

- 8 SPORTS at 62.5 MHz in RX mode with PRI/SEC enabled (writing data to L2 memory)
- 8 SPORTS at 62.5 MHz in TX mode with PRI/SEC enabled (reading data from L2 memory)
- SPI2/SPI1 in quad mode, SPI0 in dual mode TX operation at 62.5 MHz (reading data from L2 memory)
- LP TX mode at125 MHz (reading data from L2 memory)

In this configuration, the  $I_{DD_INT_DMA_DR_DYN}$  component (see the  $V_{DD_INT_DMA}$  Usage tab of the <u>ADSP-SC596-SC598</u> Power Calculator Tool Rev00<sup>[2]</sup> software is 36 mA.



The IDD\_INT\_DMA\_DR\_DYN component value specified for each of the three previous configurations is the difference between IDD\_INT current measurements obtained empirically on the ADSP-SC596/SC598 SHARC+ processors evaluation platform. The difference is measured before and after enabling the indicated DMA activity.

#### **Estimating Accelerator Contribution to Internal Dynamic Current (IDD\_INT\_ACCL\_DYN)**

The high-performance system accelerators (FIR and IIR) consume some current in the  $V_{DD_{INT}}$  domain. The total accelerator current is defined as the sum of the current consumed by each of the blocks.

Idd\_int\_accl\_dyn = Idd\_int\_accl\_fir0\_dyn + Idd\_int\_accl\_fir1\_dyn + Idd\_int\_accl\_iir0\_dyn + Idd\_int\_accl\_iir1\_dyn + Idd\_int\_accl\_iir2\_dyn + Idd\_int\_accl\_iir3\_dyn + Idd\_int\_accl\_iir4\_dyn + Idd\_int\_accl\_iir5\_dyn + Idd\_int\_accl\_iir6\_dyn + Idd\_int\_accl\_iir7\_dyn.

For a peak FIR use case, the IDD\_INT\_ACCL\_FIR\_DYN current is 330 mA. For a typical IIR use case, the IDD\_INT\_ACCL\_IIR\_DYN current is 80 mA.

## **Estimating Total Static Current (IDD\_INT\_STATIC)**

The static current ( $I_{DD_INT\_STATIC}$ ) dissipated across the entire device in the  $V_{DD_INT}$  power domain results from transistor leakage. It is present when power is applied to the power domains, even when all the internal clocks are shut off (by gating/cutting the SYS\_CLKIN to the ADSP-SC596/SC598 SHARC+ processor) and the device is held in reset. Alone, static current is solely a function of junction temperature ( $T_J$ ) and voltage ( $V_{DD_INT}$ ). Unlike dynamic current, it does not need to be adjusted for discrete core activity levels. IDD\_INT\_STATIC can be obtained by finding the value corresponding to the application conditions (such as at a specific  $V_{DD_INT}$  and  $T_J$ ) in the *Static Current* table of the <u>ADSP-SC598/SC598: SHARC+ Dual-Core DSP with Arm Cortex-A55 Data Sheet</u><sup>[1]</sup>.



The I<sub>DD\_INT\_STATIC</sub> specifications in the *Static Current* table in the data sheet are maximum specifications that account for the wafer fabrication process.

Because the static power component is constant for a given voltage and temperature, it is added to the total estimated dynamic current when calculating the total power consumption due to the processor core logic. When a customer develops power supply and thermal relief designs, ensure that the highest expected junction temperature and voltage is used when extracting data from the *Static Current* table of the data sheet.



# **Estimating External Power Consumption**

External power consumption consists of P<sub>DD\_EXT</sub>, P<sub>DD\_REF</sub>, and P<sub>DD\_DMC</sub>.

Total external power consumption (P<sub>DD\_EXT\_TOT</sub>, dissipated in the V<sub>DD\_EXT</sub> and V<sub>DD\_DMC</sub> power domains) depends on these parameters:

- O-number of output pins associated with the interface
- TR-toggle ratio (percentage of pins that switch for any given cycle)
- f-maximum frequency at which the output pins can switch
- V<sub>DD\_EXT</sub> or V<sub>DD\_DMC</sub>-voltage swing of the output pins
- C<sub>L</sub>-load capacitance of the output pins
- U-utilization factor (percentage of time for which peripheral is on and running)



In addition to the input capacitance of each device connected to an output, the total capacitance  $(C_L)$  must include the capacitance of the processor pin (C<sub>OUT</sub>), which is driving the load.

The worst-case external pin power scenario occurs when the load capacitor charges and discharges continuously. This requires the pin to toggle in each cycle in terms of external power supply, over the maximum  $V_{DD\_EXT}$  voltage swing (as specified in the data sheet). The maximum switching frequency (f) of a peripheral clock is twice the maximum toggling frequency (f/2) because the data pin state can change only once per clock cycle. When considering the full current profile for the  $V_{DD\_EXT}$  power domain, there are several peripherals that can contribute to it. Each peripheral must be considered separately and then added together to form the single  $I_{DD\_EXT}$  component of the total estimated power dissipation.

Equation 2 calculates the average external current (IDD\_EXT) using the previous parameters:

# Equation 2 Total External Current (IDD\_EXT) Calculation

$$I_{DD\_EXT} = O \mathbf{x} f \mathbf{x} V_{DD\_EXT} \mathbf{x} C_L \mathbf{x} U \mathbf{x} TR$$

Estimated average external power consumption (P<sub>DD\_EXT</sub>) can then be calculated as:

$$P_{DD\_EXT} = V_{DD\_EXT} \mathbf{x} I_{DD\_EXT}$$

Substituting from <u>Equation 2</u>, this calculation yields:

$$P_{DD\_EXT} = V_{DD\_EXT}^2 \mathbf{x} O \mathbf{x} f \mathbf{x} C_L \mathbf{x} U \mathbf{x} TR$$

<u>Table 2: VDD\_EXT Power Consumption Example</u> on page 11 is an excerpt from the example application use case in the  $V_{DD\_EXT}$  Power Domain tab of the <u>ADSP-SC596-SC598</u> <u>Power Calculator Tool Rev00</u>. It shows the Link Port interface portion to clearly illustrate the concept.



| Peripheral                                                             | Frequency in Hz (f) | Number of Output Pins (O) |                     |  |  |  |
|------------------------------------------------------------------------|---------------------|---------------------------|---------------------|--|--|--|
| Link Port - Data pins                                                  | 6.25 E+07           | 8                         |                     |  |  |  |
| Pin Capacitance in                                                     | Towale Defin (TD)   |                           | VDD_REF current per |  |  |  |
| Farads (CL)                                                            | Toggle Ratio (TR)   | Utilization Factor(U)     | IU (mA)             |  |  |  |
| 3.00E-11                                                               | 0.25                | 1.00                      | 0.8                 |  |  |  |
| VDD_EXT (V)                                                            | VDD_REF (V)         | PDD_EXT (mow)             | PDD_REF (mW)        |  |  |  |
| 3.30                                                                   | 1.80                | 40.838                    | 11.520              |  |  |  |
| Notes                                                                  |                     |                           |                     |  |  |  |
| 62.5 MHz max frequency cycle, 8-bit data (8 pins at 0.25 toggle ratio) |                     |                           |                     |  |  |  |

| _ / | Table 2: | VDD_EXT Power | Consumption Example |
|-----|----------|---------------|---------------------|
|-----|----------|---------------|---------------------|

When estimating the  $I_{DD\_EXT}$  current, the  $I_{DD\_DMC}$  current consumption for the on-chip DDR3 controller (DMC0) can be estimated, depending on the number of pins toggling and the toggle rate.  $V_{DD\_DMC}$  is used for the voltage swing (obtain the maximum  $V_{DD\_DMC}$  specification from the data sheet). The  $V_{DD\_DMC}$  *Power Domain* tab in the <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u> includes a table like the one referenced by <u>Table 2</u>. The DDR pins are grouped by function (for example, address, data, control, and clock) to help the user to customize their application.

# Estimating I/O Reference Power Consumption (P<sub>DD\_REF</sub>)

The I/O reference supply power consumption (P<sub>DD\_REF</sub>) depends on the frequency of I/O switching as depicted in Table 3.

| Frequency of I/O<br>switching (MHz) | V <sub>DD_REF</sub> current<br>per I/O (mA) |
|-------------------------------------|---------------------------------------------|
| 32 MHz or less                      | 0.4 mA                                      |
| 33 MHz through 62.5 MHz             | 0.8 mA                                      |
| 63 MHz through 125 MHz              | 1.1 mA                                      |

| Table 3: | Vdd_ref | current | per I/O |
|----------|---------|---------|---------|
|----------|---------|---------|---------|

The additional contribution for the  $VDD_{REF}$  current results from the internal oscillator (10 mA), One Time Programmable Memory Controller (OTPC = 18 mA), and the Media Local Bus (MLB = 20 mA), which can used as is for calculation purposes.



# General Guidelines for Power Supply and Thermal Relief Designs

While estimating average total power associated with a given application, power supply and thermal relief designs must always consider the worst-case scenario to prevent operational failures. Failures can happen with the processor operating out-of-spec because of a sagging power rail or an out-of-bounds junction temperature. The following sections provide specific recommendations when using this methodology.

## **Power Supply Sizing Recommendations**

Use the following recommendations when estimating the power supply sizing.

Do:

• Use the maximum expected voltages associated with all the influencing power domains involved in each of the look-up tables and computations discussed throughout this EE note.



Power supply should be designed to remain tuned to nominal voltages throughout its lifetime.

- Use the junction temperature associated with the maximum ambient temperature (T<sub>A</sub>) expected for this application, for all temperature-related lookups, and computations discussed throughout this EE note
- Use the highest ASF (Activity Scaling Factor) possible for the running application
- Separately calculate the power dissipation from each unique voltage domain

#### **Do Not:**

- Use typical I<sub>DD</sub>, nominal voltage, or room temperature specifications.
- Use the total device power alone.

## **Thermal Relief Recommendations**

Use the following recommendations when evaluating thermal relief solutions.

#### Do:

• Use nominal voltages.



Power supply should be designed to remain tuned to nominal voltages throughout its lifetime

- Use the junction temperature (Tj) that the processor is expected to be subjected to.
- Use the Full-on-Typical (or lower) ASF (Activity Scaling Factor) to match realistic application code activity levels.
- Calculate total thermal power for all voltage domains.



#### **Do Not:**

- Use the typical IDD specifications or room temperature when calculating thermal power.
- Use maximum voltage. (This is not realistic, as any transient exceeds the maximum voltage specification.)

# **Example Application Using the Power Calculator**

This section provides an example application to illustrate how to use the <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u>. There are three dialog tabs in the power calculator software that contain color-coded cells, plus the guidance to populate the yellow cells with the needed system settings. The software directs the calculator to automatically populate the green cells with data from other spreadsheet tabs or with a calculated result based on user inputs. Some of the yellow cells are free form, whereas others are selectable using a drop-down selection arrow. The following sections describe what user input is required on each power calculator tab to calculate the overall power dissipation estimate.

## **Power Estimation Tab**

The *Power Estimation* tab for <u>ADSP-SC596-SC598 Power Calculator Tool Rev00</u> is the main interface, where input is supplied to properly model the intended system. On this tab, the user must provide all the information for the system power supplies and clock rates. User also supplies other components that influence the overall power dissipation discussed in this EE note (for example, core activity and DMA rates). This tab works with other spreadsheet tabs to calculate the total power dissipation for the application, based on all the configurable system-dependent parameters.

The example application values used in this EE note derives its values from the default *Power Estimation* tab.

The default *Power Estimation* tab is pre-filled with data in the following list:

- Junction temperature at 125°C, to capture data at a worst-case temperature
- SHARC+ cores and A55 core running at 1 GHz and 1.2 GHz, with all other clocks at their maximum supported speeds
- A typical load profile of 70-30 considered for SHARC0 and SHARC1 (executes floating-point multiplication, addition, subtraction, and store instructions 70% of the time and 30% NOPs)
- ARM A55 performs peak operation 75% of the time and 25% IDLE)
- All instances of FIR and IIR accelerators infuse at 50% on time.
- DDR in use
- DMA bandwidth considered HIGH
- Link Port, 8xSPORT, and 3xSPI are considered the peripherals using and actively consuming I/O power.



Users can simulate any use case or application by modifying the default settings and configurations.



#### Set the Power Domains and Junction Temperature

Begin by setting the power domains and junction temperature to the maximum levels expected by the application. For example, consider a design with the measurements:

- $V_{DD_{INT}} = 1.0 V$
- $V_{DD\_EXT} = 3.3 V$
- $V_{DD\_REF} = 1.8 V$
- $V_{DD_DMC} = 1.39 V$
- T<sub>J</sub>=125°C

The V<sub>DD\_INT</sub> domain and T<sub>J</sub> values are used as inputs to look-up tables on other power calculator tabs to extract the needed current dissipation data for a calculation. Select the values using the drop-down selection lists in the *Operating Conditions* table on the *Power Estimation* tab. Make the selections based on the discrete levels defined in the *Static* and *Dynamic Current* tables of the <u>ADSP-SC596/SC598: SHARC+ Dual-Core DSP with Arm Cortex-A55 Data Sheet</u>.



The *Static* and *Dynamic Current* tables included in the power calculator are from the referenced processor data sheet. Always verify that the data in the calculator matches with the data in the current data sheet to ensure that the proper specifications are included.

Configure the other relevant power domains on the *Power Estimation* tab. Manually input the appropriate values for the  $V_{DD\_EXT}$  (in the  $V_{DD\_EXT}$  section),  $V_{DD\_REF}$  (in the  $V_{DD\_DMC}$  (in the  $V_{DD\_DMC}$  section) domains into the relevant yellow cells. The calculator computes the current and/or power in the associated green cells.



There is no error-checking built into the calculator for the range of these power domains. A *Configuration Warning* is associated with each of these yellow cells indicating that the input values must be verified by referring to the processor data sheet.

The VDD\_EXT, VDD\_REF, and VDD\_DMC cells are influenced by activity on the *VDD\_EXT* & *VDD\_REF Power* and *VDD\_DMC Power* tabs, respectively.



#### Set the Clocks

Input all the clock information that defines the dynamic currents expected throughout the system. For example, consider a design that uses the following values:

- $f_{CCLK\_SHARC0} = 1000 \text{ MHz}$
- $f_{CCLK\_SHARC1} = 1000 \text{ MHz}$
- $f_{CCLK_A55} = 1200 \text{ MHz}$
- $f_{DCLK} = 900 \text{ MHz}$
- $f_{SYSCLK} = 500 \text{ MHz}$
- $f_{SCLK0} = 125 \text{ MHz}$
- f<sub>SCLK1</sub> = 333 MHz
- foclk = 125 MHz

Input the values into the corresponding yellow cells of the *Clock Domains & DMA Rates* table. The calculator computes the associated dynamic current in the adjacent green cells.



There is no error-checking built into the calculator for the range of these operating frequencies. A *Configuration Warning* is associated with each of these yellow cells indicating that the input values input must be verified by referring to the processor data sheet.

#### Set the Activity Scaling Factors (ASFs)

As discussed in <u>Using ASFs to Establish Application-Specific Total Average Power Profile</u> on page 5, analyze the application and determine the core loads to associate with the application. This step establishes the dynamic power dissipation component for each core that is handled in the yellow cells in the *COREx Average ASF* tables in the *VDD\_INT* section of the *Power Estimation* tab. The proper cell value is a fractional number that ranges from 0.0 through 1.0. This indicates the percentage of time spent by the application at that discrete ASF level. The calculator outputs the *Average ASF* (as described by <u>Equation 1</u> on page 5) in the green cell based on the data on the *Core Activity Factors* tab.



There is no error-checking built into the calculator for the sum of these percentages. A hover message indicating that the "Sum of these fractions should be 1" displays, to advise the user when inputting data in this section.



The *ASF* tables included in the power calculator are from the referenced processor data sheet. Always verify that the data in the calculator matches the data in the current data sheet to ensure that the proper specifications are included.



A power supply design should use a maximum power dissipation profile that accounts for the worst-case scenario. However, to establish an average power profile, the calculator is built to account for all the discrete ASF levels defined by <u>ADSP-SC596/SC598: SHARC+</u> <u>Dual-Core DSP with Arm Cortex-A55 Data Sheet</u>. The yellow cells can be populated to reflect the actual system model.

For example, after analyzing the application, it is determined that the following describes the core activity levels:

- SHARC+ Core1–100% typical application (70-30 profile)
- SHARC+ Core2–100% typical application (70-30 profile)
- ARM A55 Core0–100% typical application (75-25 profile)

While providing input to the calculator, the corresponding average ASFs are defined as:

- $ASF_{SHARC1} = 1.00$
- $ASF_{SHARC1} = 1.00$
- $ASF_{A55} = 1.00$

The ASF is used by the calculator to compute the dynamic current in the green cells in the *Contribution (mA)* column, plus the *Clock Domains & DMA Rates* table.

#### Set the Accelerator Resource Usage

The system accelerator engines (FIR, IIR) dissipate dynamic power in the V<sub>DD\_INT</sub> domain. This is as part of the total internal dynamic current ( $I_{DD_INT_TOT}$ ) equation in the 'Total internal power dissipation' section of processor data sheet. This power is mentioned in the  $V_{DD_INT}$  section of the *Power Estimation* tab in a series of yellow cells in the *Resource Usage* table. These yellow cells should be written with the percentage of time for which each instance of FIR or IIR is active. Fifty percent (50%) active time is the default. The selectable mode options for each row insert a look-up value into the associated tables on  $V_{DD_INT}$  Accelerators of the calculator.

Only the *Peak usage* setting is available, as discussed in <u>Estimating Accelerator</u> <u>Contribution to Internal Dynamic Current (IDD\_INT\_ACCL\_DYN)</u> on page 9.

For example, when all instances of FIR and IIR (at 50% active time) are being used, then

 $I_{DD_{INT}ACCL_{DYN}} = 165 \text{ mA} + 165 \text{ mA} + 80 \text{ mA}$ 

+80 mA + 80 mA + 80 mA = 970 mA.

#### Select Appropriate DMA Activity Level

The final user input required on the *Power Estimation* tab is the *DMA/Peripheral Usage* row in the *Clock Domains & DMA Rates* table in the  $V_{DD\_INT}$  section. Here that the user must select from the three defined profiles discussed in <u>Estimating Accelerator</u> <u>Contribution to Internal Dynamic Current (IDD\_INT\_ACCL\_DYN)</u> (HIGH, MEDIUM, or LOW) on page 9 as the closest match to the system data activity. When selected using the yellow drop-down selection, the corresponding look-up value from the IDD\_INT\_DMA\_DR\_DYN column on the  $V_{DD_INT}$  DMA Usage tab populates the corresponding green cell in the *Contribution (mA)* column.



When considering serial peripherals, with DDR access and additional MDMA, select a HIGH profile (4695 MBPS).

The value for DMA contribution is  $I_{DD_INT_DMA_DR_DYN} = 220 \text{ mA}$ 

## VDD\_EXT & VDD\_REF Power Domain Tab

The *V*<sub>DD\_EXT</sub> & *V*<sub>DD\_REF</sub> Power Domain tab is used to calculate the contribution to power from the Link Ports, SPORTs, and SPI peripherals.

#### Calculating VDD\_EXT Power

Using the *V*<sub>DD\_EXT</sub> & *V*<sub>DD\_REF</sub> Power Domain tab, identify:

- Each V<sub>DD\_EXT</sub> power domain peripheral that is in use in the system, modelling its power profile as a function of how often it is active
- How many pins switch
- The load capacitance associated with the pins
- The voltage swing on the pins
- The frequency at which the pins can switch

Like the *Power Estimation* tab, the yellow cells require user input, and the green cells are populāted by the calculator. The  $V_{DD \ EXT}$  column is automatically populated from the *Power Estimation* tab. The user must fill in the yellow cells. Consider an application that uses the Link Port, eight serial ports (SPORTs), and three SPIs. For a rough estimation, consider external frame syncs for SPORTs and low target selects for SPIs. Most of the columns populate with the appropriate clock frequencies. However, some frequency area functions depend on the peripheral configuration. The configuration includes the pin capacitance from the design, the application's use of the peripheral (see <u>Estimating External Power</u> Consumption on page 10), the *Number of Output* pins, and the *Utilization Factor*.

With the following peripheral configuration information, <u>Table 4: Example VDD\_EXT</u> <u>Peripheral Usage</u> on page 18, would represent such a system, once the user:

- Inputs the proper number of output pins (O)
- Makes a reasonable guess of the number of pins switching in any given cycle (TR)
- Populates the frequency (*f*) and load capacitance (C<sub>L</sub>)
- Supplies information about the percentage of the time the peripheral is enabled (U)

The  $P_{DD\_EXT}$  (mW) column contains the results of the calculator applying Equation 2 Total External Current (IDD\_EXT) Calculation on page 10 to the input data in the other columns. The sum of the power contributions from each of the individual peripheral components is calculated at the bottom of the column. Peripherals can be added or deleted from this profile by inserting or removing rows.



| Table 4: Exam | ple VDD_EXT Pe | eripheral Usage |
|---------------|----------------|-----------------|
|               | -              |                 |

| Peripheral                                                           | Frequency in<br>Hz (f) | Number of<br>Output<br>Pins (O) | Pin<br>Capacitance in<br>Farads<br>(cL) | Toggle<br>Ratio<br>(TR) | Utilization<br>Factor (U) | VDD_REF<br>current per IO<br>(mA) | V <sub>DD_EXT</sub><br>(V) | VDD_REF<br>(V) | PDD_EXT<br>(mW) | PDD_REF<br>(mW) | Notes                                                                                 |
|----------------------------------------------------------------------|------------------------|---------------------------------|-----------------------------------------|-------------------------|---------------------------|-----------------------------------|----------------------------|----------------|-----------------|-----------------|---------------------------------------------------------------------------------------|
| Link Port<br>Data pins                                               | 6.25E+07               | 8                               | 3.00E-11                                | 0.25                    | 1.00                      | 0.8                               | 3.30                       | 1.80           | 40.838          | 11.520          | 62.5 MHz max frequency cycle, 8-bit data (8 pins at 0.25 toggle ratio)                |
| Link Port - Clock                                                    | 1.25E+08               | 1                               | 3.00E-11                                | 1                       | 1.00                      | 1.1                               | 3.30                       | 1.80           | 40.838          | 1.980           | 125Mhz operation                                                                      |
| SPORT0-7<br>-Data pins                                               | 3.13E+07               | 16                              | 3.00E-11                                | 0.25                    | 1.00                      | 0.4                               | 3.30                       | 1.80           | 40.838          | 11.520          | 31.25 MHz max frequency cycle, 2 pins per<br>SPORT x 8 (16 pins at 0.25 toggle ratio) |
| SPORT0-7 -<br>Clock                                                  | 6.25E+07               | 8                               | 3.00E-11                                | 1                       | 1.00                      | 0.8                               | 3.30                       | 1.80           | 163.350         | 11.520          | 62.5Mhz operation                                                                     |
| SPI2<br>Data pins                                                    | 3.13E+07               | 4                               | 3.00E-11                                | 0.25                    | 1.00                      | 0.4                               | 3.30                       | 1.80           | 10.209          | 2.880           | 31.25 MHz max frequency cycle, Quad mode<br>(4 pins at 0.25 toggle ratio)             |
| SPI2 - Clock                                                         | 6.25E+07               | 1                               | 3.00E-11                                | 1                       | 1.00                      | 0.8                               | 3.30                       | 1.80           | 20.419          | 1.440           | 62.5 MHz operation                                                                    |
| SPI1 - Data pins                                                     | 3.13E+07               | 4                               | 3.00E-11                                | 0.25                    | 1.00                      | 0.4                               | 3.30                       | 1.80           | 10.209          | 2.880           | 31.25 MHz max frequency cycle, Quad mode<br>(4 pins at 0.25 toggle ratio)             |
| SPI1- Clock                                                          | 6.25E+07               | 1                               | 3.00E-11                                | 1                       | 1.00                      | 0.8                               | 3.30                       | 1.80           | 20.419          | 1.440           | 62.5 MHz operation                                                                    |
| SPI10- Data pins                                                     | 3.13E+07               | 2                               | 3.00E-11                                | 0.25                    | 1.00                      | 0.4                               | 3.30                       | 1.80           | 5.105           | 1.440           | 31.25 MHz max frequency cycle,<br>Dual mode (2 pins at 0.25 toggle ratio)             |
| SPIO- Clock                                                          | 6.25E+07               | 1                               | 3.00E-11                                | 1                       | 1.00                      | 0.8                               | 3.30                       | 1.80           | 20.419          | 1.440           | 62.5 MHz operation                                                                    |
| Total External Power Dissipation (mW)<br>Total VREF Dissipation (mW) |                        |                                 |                                         |                         |                           |                                   | 372.64<br>89.460           |                |                 |                 |                                                                                       |



#### Calculating VDD\_REF Power

The  $V_{DD\_REF}$  power is automatically calculated in the same spreadsheet as  $V_{DD\_EXT}$  power, since both are related to I/O switching of peripherals. The calculation is done by referring to <u>Table 5</u> for each I/O pin.

| Frequency of I/O switching (MHz) | VDD_REF current per IO (mA) |
|----------------------------------|-----------------------------|
| 32 MHz or less                   | 0.4 mA                      |
| 33 MHz through 62.5 MHz          | 0.8 mA                      |
| 63 MHz through 125 MHz           | 1.1 mA                      |

Table 5: I/O VREF Current for PDD\_REF Calculation

#### VDD\_DMC Power Domain Tab

The *V*<sub>DD\_DMC</sub> *Power Domain* tab must be used when using DDR in the application. The concepts from <u>VDD\_EXT & VDD\_REF Power Domain Tab</u> on page 17 also apply to this tab. However, the table is slightly different because it is modeling a single interface that has numerous groups of pins that need to be treated differently, based on factors that do not remain consistent across the interface. Like the *V*<sub>DD\_EXT</sub> *Power Domain* tab, the green cells are populated by the calculator or are the output of a computation. The user must populate the yellow cells with information regarding the configuration of the DDR controller.

For the green cells on the *VDD\_DMC Power Domain* tab, the power supply information for the *VDD\_DMC (V)* column and the *Frequency in Hz (f)* column is obtained from the *Power Estimation* tab. The calculator automatically applies the fDCLK rate to the clock (*CLK*) and *Address pins [15:0]* rows, as these pins can switch at this rate in a worst-case scenario.

As indicated in the <u>Set the Clocks</u> section on page 15, the DDR clock was configured to 900 MHz on the *Power Estimation* tab. <u>Table 6: Example VDD\_DMC Use Case</u> on page 20 is an example model for the application DDR interface, after the user finalizes the pin capacitance and other inputs.

Because typical DDR accesses are sequential in nature, it is unlikely that the number of address pins toggling at any maximum frequency cycle will exceed 25% (four pins). The worst-case model assumes the interface is always running (U = 1.00). For average power dissipation, there can be low-power modes employed, This makes a fractional *Utilization Factor* possible, which is also supported by the calculator software.



| Periphera | al                        | Frequency in Hz (f) | Number of<br>Output Pins (O) | Pin<br>Capacitance in<br>Farads (C <sub>L</sub> ) | Toggle<br>Ratio (TR) | Utilization (U) | V <sub>DDDR</sub> (V) | Pout (mW) | Reasoning                                                                                                                                                                                       |
|-----------|---------------------------|---------------------|------------------------------|---------------------------------------------------|----------------------|-----------------|-----------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Address<br>pins<br>[15:0] | 4.50E+08            | 16                           | 5.00E-12                                          | 0.25                 | 1.00            | 1.39                  | 17.39     | DCLK_FREQ operation; Worst case execution> State of<br>pin changes roughly every one fourth max frequency cycle<br>(toggle ratio: 0.5)                                                          |
| DDR3L     | Data pins<br>[15:0]       | 9.00E+08            | 16                           | 5.00E-12                                          | 1                    | 1.00            | 1.39                  | 139.11    | 2x DCLK_FREQ operation, Assume DDR configured for write operation; Worst case execution> State of pin changes twice every clock cycle (toggle ratio:1)                                          |
|           | CTRL                      | 9.00E+08            | 15                           | 5.00E-12                                          | 0.25                 | 1.00            | 1.39                  | 16.30     | DCLK_FREQ/Burst Mode operation, Assume DDR configured<br>for write operation; Worst case execution> State of pin<br>changes roughly every one fourth max frequency cycle (toggle<br>ratio:0.25) |
|           | CLK                       | 9.00E+08            | 2                            | 5.00E-12                                          | 1                    | 1.00            | 1.39                  | 17.39     | DCLK_FREQ operation; Clk and the differential clock signal<br>; Worst case execution> State of pin changes twice every<br>clock cycle (toggle ratio:1)                                          |

# Table 6: Example Vod\_dmc Use Case

# **Procedure for Estimating Total Power**

Use the following major steps to estimate total overall power in an ADSP-SC596/SC598 SHARC+ processor design:

- 1. <u>Step 1–Obtain the Internal Static Current Component (IDD\_INT\_STATIC)</u>
- 2. Step 2-Obtain Baseline Core Dynamic Currents
- 3. Step 3-Model Application to Establish Activity Scale Factors (ASFSHARCO)
- 4. Step 4-Apply ASFs to Core Dynamic Components
- 5. Step 5-Calculate the System Clock Tree Core Dynamic Currents
- 6. <u>Step 6-Choose a DMA Profile to Obtain Core Dynamic DMA Current</u> (IDD\_INT\_DMA\_DR\_DYN)
- 7. <u>Step 7-Account for Core Dynamic Currents from Accelerator Blocks</u> (IDD\_INT\_ACCL\_DYN)
- 8. <u>Step 8-Calculate Total Internal Power Dissipation (PDD\_INT\_TOT)</u>
- 9. <u>Step 9-Calculate External Power Dissipation (PDD\_EXT\_TOT)</u>
- 10. Step 10-Calculate Total Power Dissipation (PDD\_TOT)

#### Step 1–Obtain the Internal Static Current Component (IDD\_INT\_STATIC)

Use the maximum power rail (VDD\_INT) and the junction temperature (TJ) values to obtain the maximum IDD\_INT\_STATIC specification from the *Static Current* table described in the processor data sheet. The example discussed in the <u>Set the Power Domains and Junction</u> <u>Temperature</u> section on page 14 where:

- $V_{DD_INT} = 1.0 \text{ V}$  and  $T_J = 125^{\circ}C$ , yields
- *VDD\_INT Maximum Static Current* tab is 3523 mA.



## **Step 2–Obtain Baseline Core Dynamic Currents**

The baseline core dynamic currents are IDD\_INT\_CCLK\_A55\_DYN, IDD\_INT\_CCLK\_SHARC1\_DYN, and IDD\_INT\_CCLK\_SHARC2\_DYN. Use the VDD\_INT power rail and the expected core clock frequency (fccLk) to obtain the values for each core in the *Dynamic Current* tables of the processor data sheet. For the example discussed in the <u>Set the Clocks</u> section on page 15, VDD\_INT = 1.0 V and the core is running at 1000 MHz. The equation values in the <u>Core Dynamic Current</u> on page 3 and in the *Dynamic Current* data sheet table are:

- Idd\_int\_cclk\_sharcx\_dyn=  $0.714 \text{ x Vdd_int } \mathbf{x} \text{ fcclk_sharcx } \rightarrow 0.714 \text{ x } 1.0 \text{ x } 1000 = 714 \text{ mA}$
- Idd\_int\_cclk\_a55\_dyn = 0.468 x Vdd\_int x fcclk\_a55 →0.468 x 1.0 x 1200 = 561 mA

## Step 3–Model Application to Establish Activity Scale Factors (ASFsharco)

Using the scale factor definitions found in the *Activity Scaling Factors* model tables of the processor data sheet, model each core's application to determine the processor load for the executed code. For a maximum calculation, use the worst-case ASF. Calculate an average ASF, as described in the <u>Using ASFs to Establish Application-Specific Total Average</u> <u>Power Profile</u> section on page 5. For the example provided in <u>Set the Activity Scaling</u> <u>Factors (ASFs)</u> section on page 15:

- ASF<sub>SHARC0</sub>=1.00
- $ASF_{SHARC1}=1.00$
- ASF<sub>A55</sub>=1.00

#### **Step 4-Apply ASFs to Core Dynamic Components**

Apply the calculated average ASF or the worst-case ASF to the core dynamic component for each core:

- Idd\_int\_cclk\_sharc0\_dyn = Idd\_int\_cclk\_sharc0\_dyn x ASFsharc0  $\rightarrow$  714 x 1.00 = 714 mA
- Idd\_int\_cclk\_sharc1\_dyn = Idd\_int\_cclk\_sharc1\_dyn **x** ASFsharc1 $\rightarrow$ 714 **x** 1.00 = 714 mA
- $I_{DD_INT\_CCLK\_A55\_DYN} = I_{DD_INT\_CCLK\_A55\_DYN} \mathbf{x} \text{ ASF}_{A55} \rightarrow 110 \mathbf{x} 1.00 = 110 \text{ mA}$

## **Step 5-Calculate the System Clock Tree Core Dynamic Currents**

The dynamic current dissipated in the  $V_{DD_{INT}}$  domain because of the clocks toggling inside the processor, are a function of the internal voltage (in Volts) and the frequency of each clock (in MHz), This is governed by the equations in the processor data sheet. Using the example from the <u>Estimating System Clock Tree Currents</u> section on page 6:

- IDD\_INT\_DCLK\_DYN = 0.097 x fdclk x Vdd\_INT  $\rightarrow 0.097 \text{ x}$  900 x 1.0 = 87.30 mA
- Idd\_int\_sysclk\_dyn = 0.792 x fsysclk x Vdd\_int  $\rightarrow$  0.792 x 500 x 1.0 = 396 mA
- IDD\_INT\_SCLK0\_DYN =  $0.451 \text{ x} \text{ fsclk0} \text{ x} \text{ Vdd_INT} \rightarrow 0.451 \text{ x} 125 \text{ x} 1.0 = 56.38 \text{ mA}$
- IDD\_INT\_SCLK1\_DYN =  $0.014 \text{ x} \text{ fsclk1} \text{ x} \text{ VDD_INT} \rightarrow 0.014 \text{ x} 333.3 \text{ x} 1.0 = 4.67 \text{ mA}$
- $I_{DD_INT_OCLK_DYN} = 0.108 \text{ x} \text{ foclk } \text{x} \text{ V}_{DD_INT} \rightarrow 0.108 \text{ x} 125 \text{ x} 1.0 = 13.50 \text{ mA}$



#### Step 6-Choose a DMA Profile to Obtain Core Dynamic DMA Current (Idd\_INT\_DMA\_DR\_DYN)

Calculate the total system DMA bandwidth during peak activity and select the profile that is the closest match. The example in <u>Select Appropriate DMA Activity Level</u> section on page 16 sets the DMA profile to **HIGH**:

• IDD\_INT\_DMA\_DR\_DYN=220 mA

#### Step 7-Account for Core Dynamic Currents from Accelerator Blocks (IDD\_INT\_ACCL\_DYN)

Each of these blocks dissipates power in the V<sub>DD\_INT</sub> domain and must be considered when estimating the total core dynamic current. The example discussed in the <u>Set the Accelerator</u> <u>Resource Usage</u> section on page 16 has the system acceleration engine enabled:

•  $I_{DD_INT_ACCL_DYN} = 650 \text{ mA}$ 

#### **Step 8-Calculate Total Internal Power Dissipation (PDD\_INT\_TOT)**

Add the static internal current [<u>Step 1–Obtain the Internal Static Current Component</u> (<u>IDD\_INT\_STATIC</u>)] component to the sum of all the dynamic internal current components [<u>Step 4-Apply ASFs to Core Dynamic Components</u> through <u>Step 7-Account</u> for Core Dynamic Currents from Accelerator Blocks (IDD\_INT\_ACCL\_DYN)] to get the total current in the VDD\_INT domain (IDD\_INT\_TOT):

| $I_{DD\_INT\_TOT} =$ | Idd_int_static + Idd_int_cclk_sharco_dyn +           | Idd | _INT_CCLK_SHARC1_DYN | + |
|----------------------|------------------------------------------------------|-----|----------------------|---|
|                      | IDD_INT_CCLK_A55_DYN + IDD_INT_DCLK_DYN              | +   | Idd_int_sysclk_dyn   | + |
|                      | Idd_int_sclk0_dyn + Idd_int_sclk1_dyn                | +   | Idd_int_oclk_dyn     | + |
|                      | $I_{DD\_INT\_ACCL\_DYN} + I_{DD\_INT\_DMA\_DR\_DYN}$ |     |                      |   |

 $I_{DD\_INT\_TOT} = 3523.00+714.00+714.00+561.60+87.30+$ 396.00+56.38+4.67+13.50+650.00+220=6940.45 mA

With the total IDD\_INT\_TOT current calculated, estimate the total power (PDD\_INT\_TOT):

 $PDD_INT_TOT = IDD_INT_TOT \mathbf{x} VDD_INT \rightarrow 6940.45 \text{ mA } \mathbf{x} 1.0 \text{ V} = 6940.45 \text{ mW}$ 

#### **Step 9-Calculate External Power Dissipation (PDD\_EXT\_TOT)**

The total external power dissipation (PDD\_EXT\_TOT) is comprised of the power dissipated in each of the two critical power domains (VDD\_EXT, VDD\_DMC) and the VDD\_REF domain.



#### Calculate Power Dissipated in the VDD\_EXT and VDD\_REF Domain (PDD\_EXT & PDD\_REF)

Model the application using the concepts discussed in <u>Estimating External Power</u> <u>Consumption</u> on page 10 to estimate the power dissipated in the VDD\_EXT domain (PDD\_EXT) and VDD\_REF domain (PDD\_REF). From the example discussed in the <u>VDD\_EXT &</u> <u>VDD\_REF Power Domain Tab</u> section on page 17:

- $P_{DD\_EXT} = 372.64 \text{ mW}$
- $P_{DD_{REF}} = 89.460 \text{ mW}$

#### Calculate Power Dissipated in the VDD\_DMC Domain (PDD\_DMC)

Model the application using the concepts discussed in <u>Estimating External Power</u> <u>Consumption</u> on page 10 to estimate the power dissipated in the VDD\_DMC domain (PDD\_DMC). From the example discussed in the <u>VDD\_EXT & VDD\_REF Power Domain</u> <u>Tab</u> section on page 17:

•  $P_{DD_DMC} = 190.19 \text{ mW}$ 

## Step 10-Calculate Total Power Dissipation (PDD\_TOT)

Once all the core and system elements are properly modelled, calculate the total power dissipation as the sum of the internal ( $P_{DD\_INT\_TOT}$ ) and external ( $P_{DD\_EXT\_TOT}$ ) power dissipation components:

 $P_{DD\_EXT\_TOT} = P_{DD\_EXT} + P_{DD\_REF} + P_{DD\_DMC}$ 

•  $P_{DD_TOT} = P_{DD_INT_TOT} + P_{DD_EXT_TOT} \rightarrow 6940.45 + 372.64 + 89.46 + 190.19$ = 7593 mW or approximately 7.593 W



Because of the rounding in the calculations for this example, the values in the green cells of the user power calculator can differ slightly from those in the EE note.



# References

- [1] ADSP-SC596/SC598: SHARC+ Dual-Core DSP with Arm Cortex-A55 Data Sheet (Rev. 0), March 2023. Analog Devices, Inc.
- [2] ADSP-SC596-SC598 Power Calculator Tool Rev00. Found in the associated file named EE440\_ADSP-SC596-SC598 Power Calculator Tool Rev00.ZIP, at the Analog.com website.
- [3] EE-414: Estimating Power for ADSP-2156x SHARC+ Processors Rev. 1, March 2021. Analog Devices, Inc.
- [4] ADSP-SC596/SC598 SHARC+ Processor Hardware Reference, August 2022. Analog Devices, Inc.
- [5] SHARC+ Core Programming Reference, Revision 1.4, May 2021. Analog Devices, Inc.
- [6] **Power Domains**—Power domains enable or disable power to a region of a system on chip (SoC) and can control the clock rate or amount of power supplied to that SoC region.

# **Document History**

| Revision                                         | Description                                      |
|--------------------------------------------------|--------------------------------------------------|
| Rev 1 – September 25, 2022<br>by Deepak Huchaiah | Initial Draft                                    |
| Rev 1 – April 13, 2023                           | Final Published version of EE-440 Note           |
| Rev 2 – July 10, 2023                            | Remove all references to the obsolete ADSP-SC595 |