# System Controller Firmware Release Notes

Generated by Doxygen 1.8.15

Mon Nov 19 2018 13:17:11

| 1 Introduction                                                            | 1      |
|---------------------------------------------------------------------------|--------|
| 1.1 Highlights                                                            | <br>1  |
| 2 Change List                                                             | 3      |
| 2.1 Bug                                                                   | <br>3  |
| 2.2 Improvement                                                           | <br>3  |
| 2.3 Prior 4.14.62 Beta Patch 2 Change List                                | <br>3  |
| 2.4 Improvement                                                           | <br>3  |
| 2.5 Prior 4.14.62 Beta Patch 1 Change List                                | <br>4  |
| 2.6 Bug                                                                   | <br>4  |
| 2.7 Prior 4.14.62 Beta Change List                                        | <br>4  |
| 2.8 New Feature                                                           | <br>4  |
| 2.9 Improvement                                                           | <br>5  |
| 2.10 Bug                                                                  | <br>6  |
| 2.11 Task                                                                 | <br>7  |
| 2.12 Details                                                              | <br>7  |
| 2.12.1 SCF-113: Support customer merge of porting kits                    | <br>7  |
| 2.12.2 SCF-122: Change MU assignments in ALT_CONFIG boot mode             | <br>7  |
| 2.12.3 SCF-123: Update temp sensor conversion equation                    | <br>7  |
| 2.12.4 SCF-126: Add misc control for CAN IPG_STOP                         | <br>7  |
| 2.12.5 SCF-146: Support SECO FW v0.1.0                                    | <br>8  |
| 2.12.6 SCF-150: Workaround temp sensor crosstalk HW issue for i.MX8QM     | <br>8  |
| 2.12.7 SCF-178: Add support for DDR retention mode                        | <br>8  |
| 2.12.8 SCF-189: Add function to configure the SNVS button time parameters | <br>8  |
| 2.12.9 SCF-192: Show SCU ROM patch version in monitor                     | <br>9  |
| 2.12.10 SCF-198: Remove R=A0 assumption from Makefile                     | <br>9  |
| 2.12.11 SCF-222: Add function to return boot type                         | <br>9  |
| 2.12.12 SCF-223: Add partition/virtualization support for DC DPR          | <br>9  |
| 3 Known Issues                                                            | 11     |
| 3.1 New Feature                                                           | <br>11 |
| 3.2 Improvement                                                           | <br>11 |
| 3.3 Bug                                                                   | <br>11 |
| 3.4 Documentation                                                         | <br>12 |
| 4 Additional Notes                                                        | 13     |
| 4.1 General                                                               | <br>13 |
| 4.2 SCFW API Changes                                                      | <br>13 |
| 4.3 Resource Changes                                                      | <br>14 |
| 4.4 Clock Changes                                                         | <br>14 |

| 15     |
|--------|
| <br>14 |
| <br>14 |
|        |

# Introduction

This document contains release notes for the i.MX8 System Controller Firmware (SCFW). This includes:

- Highlights
- · Changes from the previous release
- · Known issues
- · Additional info

The table below lists the release information:

| Release Info      |                                                            |
|-------------------|------------------------------------------------------------|
| Release name      | imx_4.14.62_beta_p3                                        |
| Previous release  | imx_4.9.88_imx8qxp_beta2                                   |
| Branch            | imx_4.14.62_1.0.0_beta                                     |
| Build number      | 2814                                                       |
| Commit ID         | 0x006ff1979                                                |
| Build date        | Nov 19 2018                                                |
| Supported devices | i.MX8QM (A0), i.MX8QM (B0), i.MX8QXP (B0), and derivatives |

## 1.1 Highlights

- Added support for i.MX8QM B0
- Dropped support for i.MX8QXP A0
- Supported SECO FW v0.1.0, dropped support for older SECO FW
- Added support for low power modes (KS1 and KS1.5)
- · Added DDR retention support to NXP board ports

Note SCFW version 0.1.0 is **REQUIRED** for correct operation!

| 2 | Introduction |
|---|--------------|
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |
|   |              |

# **Change List**

Below is a list of changes between the previous release (imx\_4.14.62\_beta\_p2) and this release (imx\_4.14.62\_beta\_p3).

## 2.1 Bug

| Key     | Summary                                                   | QM (A0) | QM (B0) | QXP (B0) |
|---------|-----------------------------------------------------------|---------|---------|----------|
| SCF-265 | Ensure clocks are enabled before performing memory repair | Υ       | Υ       | Υ        |

# 2.2 Improvement

| Key     | Summary                                                                                                 | QM (A0) | QM (B0) | QXP (B0) |
|---------|---------------------------------------------------------------------------------------------------------|---------|---------|----------|
| SCF-253 | Add ddr_stress_test_parser.cfg to all platform/board/ <so↔< th=""><th>Υ</th><th>Υ</th><th>Υ</th></so↔<> | Υ       | Υ       | Υ        |
|         | C>/dcd folders                                                                                          |         |         |          |

## 2.3 Prior 4.14.62 Beta Patch 2 Change List

Below is a list of changes between the previous release (imx\_4.14.62\_beta\_p1) and this release (imx\_4.14.62\_beta\_p2).

## 2.4 Improvement

| Key     | Summary                                                | QM (A0) | QM (B0) | QXP (B0) |
|---------|--------------------------------------------------------|---------|---------|----------|
| SCF-256 | Update 8QM GPU operating point based on design targets |         | Υ       |          |

4 Change List

### 2.5 Prior 4.14.62 Beta Patch 1 Change List

Below is a list of changes between the previous release (imx\_4.14.62\_beta) and this release (imx\_4.14.62\_beta\_p1).

## 2.6 Bug

| Key     | Summary                              | QM (A0) | QM (B0) | QXP (B0) |
|---------|--------------------------------------|---------|---------|----------|
| SCF-249 | PCIE internal clk jitter improvement |         | Υ       |          |

## 2.7 Prior 4.14.62 Beta Change List

Below is a list of changes between previous release (imx\_4.9.88\_imx8qxp\_beta2) and this release (imx\_4.14.62\_beta).

#### 2.8 New Feature

| Key     | Summary                                                                                        | QM (A0) | QM (B0) | QXP (B0) |
|---------|------------------------------------------------------------------------------------------------|---------|---------|----------|
| SCF-70  | Add support for KS1.5 during suspend                                                           | Υ       | Υ       | Υ        |
| SCF-78  | Add individual PF100 register access                                                           | Υ       | Υ       | Υ        |
| SCF-112 | Support MLB PLL                                                                                | Υ       | Υ       | Υ        |
| SCF-113 | Support customer merge of porting kits [detail]                                                | Υ       | Υ       | Υ        |
| SCF-126 | Add misc control for CAN IPG_STOP [detail]                                                     | Υ       | Υ       | Υ        |
| SCF-131 | Add support for missing eLCDIF clocks and PLL in the Audio $\text{D}{\leftarrow}$ MA subsystem |         |         | Y        |
| SCF-135 | Add support for multiple bypass clock inputs                                                   | Υ       | Υ       | Υ        |
| SCF-136 | Add DDR retention test for 8QM/QXP LPDDR4/DDR4/DDR3                                            | Υ       | Υ       | Υ        |
| SCF-143 | Support SECO FW v0.0.7                                                                         |         | Υ       | Υ        |
| SCF-144 | Use OP trim from fuses for i.MX8QM                                                             | Υ       | Υ       |          |
| SCF-146 | Support SECO FW v0.1.0 [detail]                                                                |         | Υ       | Υ        |
| SCF-151 | Add combined sync control for DC                                                               | Υ       | Υ       | Υ        |
| SCF-152 | Support C code in DCD config files                                                             | Υ       | Υ       | Υ        |
| SCF-154 | Changes for i.MX8QM B0 bring-up                                                                |         | Υ       |          |
| SCF-155 | Add support for KS1 during suspend                                                             | Υ       | Υ       | Υ        |
| SCF-157 | Support boot from OCRAM alias on B0                                                            |         | Υ       | Υ        |
| SCF-161 | Allow DC pixel clock to source from bypass clock inputs from H← DMI and VPU SS for i.MX8QM     | Y       | Υ       |          |
| SCF-163 | Add pmic_get_mode() for PF8100                                                                 | Υ       | Υ       | Υ        |
| SCF-164 | Add i.MX8QM support for HW limited GPU frequency for derivative parts                          | Y       | Y       |          |
| SCF-169 | Add support for new CLKOUT_ALT output in AVPLL required by HDMI in QM B0                       |         | Υ       |          |
| SCF-176 | Add new trim values programmed into fuses for iMX8QM B0                                        |         | Υ       |          |

2.9 Improvement 5

| Key     | Summary                                                        | QM (A0) | QM (B0) | QXP (B0) |
|---------|----------------------------------------------------------------|---------|---------|----------|
| SCF-177 | Ensure the regulator in AVPLL_0 added for DC in VPU is enabled |         | Υ       |          |
|         | all the time                                                   |         |         |          |
| SCF-178 | Add support for DDR retention mode [detail]                    | Υ       | Υ       | Υ        |
| SCF-181 | Add capability to track if a partition has booted              | Υ       |         |          |
| SCF-189 | Add function to configure the SNVS button time parameters      | Υ       | Υ       | Υ        |
|         | [detail]                                                       |         |         |          |
| SCF-192 | Show SCU ROM patch version in monitor [detail]                 |         | Υ       | Υ        |
| SCF-208 | Add i.MX8QXP support for HW limited GPU frequency for deriva-  |         |         | Υ        |
|         | tive parts                                                     |         |         |          |
| SCF-222 | Add function to return boot type [detail]                      | Υ       | Υ       | Υ        |

# 2.9 Improvement

| Key     | Summary                                                                    | QM (A0) | QM (B0) | QXP (B0) |
|---------|----------------------------------------------------------------------------|---------|---------|----------|
| SCF-61  | Implement new DPLL sequence for i.MX8QM B0                                 |         | Υ       |          |
| SCF-67  | Update M4 warm reset support to align with M4 LPM support                  |         | Υ       | Υ        |
| SCF-111 | Increase PMIC baud rate for MEK boards                                     | Υ       | Υ       | Υ        |
| SCF-118 | Implement command history buffer in debug monitor                          | Υ       | Υ       | Υ        |
| SCF-119 | Return system reset reason                                                 | Υ       | Υ       | Υ        |
| SCF-120 | Remove root clk handling from powerup/down xtal_osc                        | Υ       | Υ       | Υ        |
| SCF-122 | Change MU assignments in ALT_CONFIG boot mode [detail]                     | Υ       | Υ       | Υ        |
| SCF-123 | Update temp sensor conversion equation [detail]                            |         | Υ       | Υ        |
| SCF-125 | Allow character insert in debug monitor                                    | Υ       | Υ       | Υ        |
| SCF-128 | Improve debug output for MSI timeout errors                                | Υ       | Υ       | Υ        |
| SCF-130 | Enable debug monitor temp command to run concurrent with S← CFW clients    | Y       | Υ       | Y        |
| SCF-132 | Clean up SoC code to eliminate code duplication                            | Υ       | Υ       | Υ        |
| SCF-137 | Update i.MX8QXP DDR config to aligned with RPA v10                         |         |         | Υ        |
| SCF-139 | Fix incorrect copyright information                                        | Υ       | Υ       | Υ        |
| SCF-140 | Display SECO error in monitor                                              |         | Υ       | Υ        |
| SCF-142 | Dump actual temp panic values in monitor debug temp command                | Υ       | Υ       | Υ        |
| SCF-156 | Display warning if build options M=1 and D=0 are used together             | Υ       | Υ       | Υ        |
| SCF-160 | Sync operating frequencies with datasheet                                  | Υ       | Υ       |          |
| SCF-166 | Re-enable i.MX8QXP DB PG1 auto clock gating for B0                         |         |         | Υ        |
| SCF-170 | Optimize early boot time by avoiding SECO calls                            |         | Υ       | Υ        |
| SCF-182 | Update i.MX8QXP/DX DDR3L configs to aligned with RPA v15                   |         |         | Υ        |
| SCF-183 | Improve DC test                                                            |         | Υ       | Υ        |
| SCF-185 | Leave all refgens enabled when system is active - SW workaround for HW bug |         |         | Υ        |
| SCF-188 | Implement Digital PLL DCO PC selection based on frequency                  | Υ       | Υ       | Υ        |
| SCF-190 | Increase QM DB PLL to 750MHz from 744MHz                                   | Υ       | Υ       |          |
| SCF-191 | Allow Ctrl-C to terminate the debug monitor temp loop                      | Υ       | Υ       | Υ        |
| SCF-195 | Improve error reporting/handling for I2C transfers                         | Υ       | Υ       | Υ        |
| SCF-196 | Update i.MX8QXP LPDDR4 configs to aligned with RPA_v11                     |         |         | Υ        |

6 Change List

| Key     | Summary                                                                     | QM (A0) | QM (B0) | QXP (B0) |
|---------|-----------------------------------------------------------------------------|---------|---------|----------|
| SCF-197 | Update i.MX8QM LPDDR4 configs to aligned with RPA_v16                       |         | Υ       |          |
| SCF-198 | Remove R=A0 assumption from Makefile [detail]                               | Υ       | Υ       | Υ        |
| SCF-203 | Change board_parameter return type to uint32_t and add KS1 board parameters | Y       | Y       | Y        |
| SCF-205 | Align QXP/QM GPU operating points with datasheet                            |         | Υ       | Υ        |
| SCF-207 | Fix refgen autocal to reduce noise during measurements                      | Υ       | Υ       | Υ        |
| SCF-210 | Disable all 24MHz clocks when SS is powered down                            |         | Υ       | Υ        |
| SCF-211 | Relock SCU PLL for QXP B0                                                   |         |         | Υ        |
| SCF-212 | Restore DRC LPCG when resuming from KS1 state                               |         | Υ       | Υ        |
| SCF-213 | Align QXP A35 operating points with datasheet                               |         |         | Υ        |
| SCF-229 | Disable internal voltage regulator when an AP core is powered down          | Y       | Y       |          |
| SCF-236 | Improve debug pll command in monitor                                        | Υ       | Υ       | Υ        |
| SCF-237 | Display warning if old SECO FW used                                         |         | Υ       | Υ        |

# 2.10 Bug

| Key     | Summary                                                                | QM (A0) | QM (B0) | QXP (B0) |
|---------|------------------------------------------------------------------------|---------|---------|----------|
| SCF-51  | Partition reboot request hangs                                         | Υ       | Υ       | Υ        |
| SCF-121 | Fix diffclk disable order in SCU subsystem                             | Υ       | Υ       | Υ        |
| SCF-124 | Fix SCU root clock buffer for i.MX8QM B0                               |         | Υ       |          |
| SCF-127 | Fix HSIO phymix disable                                                | Υ       | Υ       | Υ        |
| SCF-129 | Some boards crash if DDR config by ROM but no DDR image                | Υ       | Υ       | Υ        |
| SCF-133 | Fix issue building SCFW with debug monitor from porting kit            | Υ       | Υ       | Υ        |
| SCF-138 | Fix SCFW test build break due to DDR retention test                    | Υ       | Υ       | Υ        |
| SCF-141 | Block access to eCSR controls if power state is STBY or OFF            | Υ       | Υ       | Υ        |
| SCF-149 | Add clock repeater work around to 8QXP DDR setup                       |         |         | Υ        |
| SCF-150 | Workaround temp sensor crosstalk HW issue for i.MX8QM [detail]         | Υ       | Υ       |          |
| SCF-153 | FTM0 clock incorrectly mapped to CAN0 clock                            |         |         | Υ        |
| SCF-158 | Fix i.MX8QM 800MHz DDR script for B0                                   |         | Υ       |          |
| SCF-159 | Fix i.MX8QM B0 DPLL v18 lock sequence                                  |         | Υ       |          |
| SCF-162 | PF8100 temp alarm interrupt triggers at incorrect temp                 | Υ       | Υ       | Υ        |
| SCF-165 | Fix i.MX8QM B0 VPU GPR bit definition                                  |         | Υ       |          |
| SCF-174 | Fix incorrect AHB/AXI clock frequencies during GPU DVFS operations     | Υ       | Υ       |          |
| SCF-175 | Fix bug in clock(pll) enable/disable code, add valid clock index check | Υ       | Y       | Y        |
| SCF-179 | Add workaround for hangs after exit from LPM on closed devices         |         | Υ       | Υ        |
| SCF-180 | Simulation compile with monitor broken                                 | Υ       | Υ       | Υ        |
| SCF-194 | Remove dynamic clock management of SCU UART/I2C to avoid LPCG hazards  |         | Υ       | Υ        |
| SCF-200 | PCIe detect issue on reset due to too short power off time             | Υ       | Υ       | Υ        |
| SCF-201 | Don't enable HW/SW auto clock gate for MSLICE clocks                   | Υ       | Υ       | Υ        |
| SCF-202 | Can't access CSI_1 without powering up DC_0                            | Υ       | Υ       | Υ        |

2.12 Details 7

| Key     | Summary                                                  | QM (A0) | QM (B0) | QXP (B0) |
|---------|----------------------------------------------------------|---------|---------|----------|
| SCF-204 | QXP DDR3L clock gating failure due to IO retn            |         |         | Υ        |
| SCF-206 | Fix HDMI and HDMI_RX phymix powerdown function           | Υ       | Υ       |          |
| SCF-214 | Reset HDMI RX HPD when HDMI powered on                   | Υ       | Υ       |          |
| SCF-215 | Configuration of ADMA UART for test in wrong place       |         |         | Υ        |
| SCF-223 | Add partition/virtualization support for DC DPR [detail] | Υ       | Υ       | Υ        |

#### 2.11 Task

| Key     | Summary                                                | QM (A0) | QM (B0) | QXP (B0) |
|---------|--------------------------------------------------------|---------|---------|----------|
| SCF-134 | Add a Bamboo job to test building from the porting kit | Υ       | Υ       | Υ        |
| SCF-167 | Remove i.MX8QXP A0 build option                        |         |         |          |
| SCF-184 | Rework Bamboo nightly builds and test                  | Υ       | Υ       | Υ        |

#### 2.12 Details

This section provides details for select changes.

#### 2.12.1 SCF-113: Support customer merge of porting kits

This change results in all object files being in a unique build directory for each SoC and SoC version. This allows users to combine multiple porting kits into a common kit by just merging the directory structures. The only conflicting file is build info.h but this is common except for the build time.

The porting kit contains separate tar files for each SoC/version combination. These can be combined using the following command:

find scfw export mx8\*.gz -exec tar -strip-components 1 -one-top-level=scfw export mx8 -xzvf {} \;

#### 2.12.2 SCF-122: Change MU assignments in ALT\_CONFIG boot mode

ALT\_CONFIG is only used for internal NXP test cases. No impact to customers except this code is used as an example.

#### 2.12.3 SCF-123: Update temp sensor conversion equation

Temp sensor conversion functions updated to new formula with a fuse-based per-sensor offset. No API changes.

#### 2.12.4 SCF-126: Add misc control for CAN IPG\_STOP

New controls added (IPG\_STOP and IPG\_STOP\_ACK) for all three CAN controllers.

8 Change List

#### 2.12.5 SCF-146: Support SECO FW v0.1.0

Added the following new APIs:

- Added sc\_misc\_seco\_attest\_mode()
- Added sc\_misc\_seco\_attest()
- Added sc\_misc\_seco\_get\_attest\_pkey()
- Added sc\_misc\_seco\_get\_attest\_sign()
- Added sc\_misc\_seco\_attest\_verify()
- Added sc misc seco commit()
- · Changed sc\_misc\_seco\_forward\_lifecycle() parameters and docs to make usage more clear
- · Added new SECO authentication commands for SECO FW

#### 2.12.6 SCF-150: Workaround temp sensor crosstalk HW issue for i.MX8QM

To avoid a temp sensor crosstalk issue, sensors are now sequentially driven by SCFW. This adds some delay in getting first reading after power up so read calls might return SC\_ERR\_BUSY if no reading is available yet. Clients should treat this error as a try again indicator.

#### 2.12.7 SCF-178: Add support for DDR retention mode

Requires customers update board.c to:

- · Define retention data structures
- Call soc\_ddr\_config\_retention() from board\_init\_ddr()
- Call soc\_self\_refresh\_power\_down\_clk\_disable\_entry() from board\_ddr\_config()
- Call soc\_refresh\_power\_down\_clk\_disable\_exit() from board\_ddr\_config()

DDR retention parameters come from defines generated by the DDR RPA tool.

See reference board.c implementations for NXP boards.

#### 2.12.8 SCF-189: Add function to configure the SNVS button time parameters

New internal SNVS\_ButtonTime() function added. This can be called from the board\_init() function in board.c. Allows the button debounce time, on time, and press time to be configured. See the SNVS section of the SRM for more details.

2.12 Details 9

#### 2.12.9 SCF-192: Show SCU ROM patch version in monitor

SCFW performs an XOR CRC or the ROM patch fuses. The value can be returned via the sc\_misc\_rompatch\_
checksum() function. It is also displayed in the SCFW debug monitor using the 'info' command.

For i.MX8QXP B0:

- V0.0.3 0x24180B1E
- V0.0.6 0x753A8E47
- V0.0.8 0x8B33D88F

#### 2.12.10 SCF-198: Remove R=A0 assumption from Makefile

Make no longer defaults to a silicon rev of A0. It now requires an R=<srev> argument, otherwise an error is displayed.

#### 2.12.11 SCF-222: Add function to return boot type

Added sc\_misc\_get\_boot\_type() function to return boot type:

- SC\_MISC\_BT\_PRIMARY
- · SC MISC BT SECONDARY
- SC\_MISC\_BT\_RECOVERY
- · SC MISC BT MANUFACTURE
- SC\_MISC\_BT\_SERIAL

#### 2.12.12 SCF-223: Add partition/virtualization support for DC DPR

Modified XRDC MDAC mask configuration to also catch DPR transactions. No API change.

| 10 | Change List |
|----|-------------|
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |

# **Known Issues**

Below is a list of known outstanding issues in this release (imx\_4.14.62\_beta\_p2).

## 3.1 New Feature

| Key     | Summary                                            | QM (A0) | QM (B0) | QXP (B0) |
|---------|----------------------------------------------------|---------|---------|----------|
| SCF-147 | Support SECO FW v0.2.0                             |         | Υ       | Υ        |
| SCF-148 | Support SECO FW v1.1.0                             |         | Υ       | Υ        |
| SCF-225 | Support SECO FW v1.2.0                             |         | Υ       | Υ        |
| SCF-230 | Limit the ethernet frequency for DX based on fuses |         |         | Υ        |
| SCF-234 | Eliminate need for srec for non-emulation builds   | Υ       | Υ       | Υ        |

## 3.2 Improvement

| Key     | Summary                                                           | QM (A0) | QM (B0) | QXP (B0) |
|---------|-------------------------------------------------------------------|---------|---------|----------|
| SCF-187 | Code clean-up to eliminate duplicate code between devices         | Υ       | Υ       | Υ        |
| SCF-218 | Support setting the rate of bypass clock in DC SS on QM B0        |         | Υ       |          |
| SCF-219 | Disallow transition from OFF to STBY power modes                  | Υ       | Υ       | Υ        |
| SCF-220 | Disable DB clock gating when R/W from debug monitor               | Υ       | Υ       | Υ        |
| SCF-226 | Reduce SCFW stack usage                                           | Υ       | Υ       | Υ        |
| SCF-228 | Call to board code for DDR actions and align actions to system PM | Υ       | Υ       | Υ        |

# 3.3 Bug

| Key     | Summary                                | QM (A0) | QM (B0) | QXP (B0) |
|---------|----------------------------------------|---------|---------|----------|
| SCF-173 | CM4 reset on boot when accessing RGPIO | Υ       | Υ       | Υ        |

12 Known Issues

| Key     | Summary                                                                   | QM (A0) | QM (B0) | QXP (B0) |
|---------|---------------------------------------------------------------------------|---------|---------|----------|
| SCF-209 | Sync LPM state and partition reboot                                       | Υ       | Υ       | Υ        |
| SCF-217 | For emulation builds, startup uses some uninitialized data                | Υ       | Υ       | Υ        |
| SCF-224 | Remove i.MX8QM A0 build option                                            | Υ       |         |          |
| SCF-238 | i.MX8QM validation board with DDR4 has incorrect PCIe clock configuration | Y       | Y       |          |

### 3.4 Documentation

| Key    | Summary                                        | QM (A0) | QM (B0) | QXP (B0) |
|--------|------------------------------------------------|---------|---------|----------|
| SCF-75 | Add documentation for porting the client API   | Υ       | Υ       | Υ        |
| SCF-89 | Add documentation of definition of power modes | Υ       | Υ       | Υ        |

# **Additional Notes**

This section details any additional notes about this release.

#### 4.1 General

When the SCFW is compiled for release into production devices, it is critical that this is done without debug (default is debug enabled, D=1) and without the debug monitor (default is no monitor, M=0). For example:

```
make qm R=B0 D=0 M=0
```

Turning off debug will eliminate the linking of the standard C library. See the porting guide for more information.

### 4.2 SCFW API Changes

#### Power Management (PM) Service

• Unified sc\_pm\_reset\_cause\_t and sc\_pm\_reset\_reason\_t

#### Miscellaneous (MISC) Service

Changes are associated with new SECO FW integration.

- Added sc\_misc\_seco\_attest\_mode()
- Added sc\_misc\_seco\_attest()
- Added sc\_misc\_seco\_get\_attest\_pkey()
- Added sc\_misc\_seco\_get\_attest\_sign()
- Added sc\_misc\_seco\_attest\_verify()
- Added sc\_misc\_seco\_commit()
- · Changed sc misc seco forward lifecycle() parameters and docs to make usage more clear
- · Added new SECO authentication commands for SECO FW

#### In addition:

Added sc misc rompatch checksum()

14 Additional Notes

### 4.3 Resource Changes

- Added SC\_R\_ELCDIF\_PLL for i.MX8QXP
- Added SC\_R\_DMA5\_CHx for future device(s)
- Added SC\_R\_ATTESTATION virtual resource; only owner can call misc\_seco\_attest\*() functions

### 4.4 Clock Changes

- · Added eLCDIF PLL
- · Added MLB PLL
- · Changed i.MX8QM DB from 744MHz to 750MHz
- · Remove default HDMI TX user PLL 2 frequency

### 4.5 Control Changes

• Added SC\_C\_SYNC\_CTRL - provides control for setting both DC sync controls in one call

### 4.6 Board Interface Changes

- · Added new board\_parm\_t values for KS1 retention and wake
- Changed board\_parm\_rtn\_t to a uint32\_t; moved returns to defines; added new return values
- · Added new board init() phase (3) used only for SCFW unit test board configuration

# **Disclaimer**

Information in this document is provided solely to enable system and software implementers to use NXP products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits based on the information in this document. NXP reserves the right to make changes without further notice to any products herein. NXP makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does NXP assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in NXP data sheets and/or specifications can and do vary in different applications, and actual performance may vary over time. All operating parameters, including "typicals," must be validated for each customer application by customer's technical experts. NXP does not convey any license under its patent rights nor the rights of others. NXP sells products pursuant to standard terms and conditions of sale, which can be found at the following address: nxp. com/SalesTermsandConditions. While NXP has implemented advanced security features, all products may be subject to unidentified vulnerabilities. Customers are responsible for the design and operation of their applications and products to reduce the effect of these vulnerabilities on customer's applications and products, and NXP accepts no liability for any vulnerability that is discovered. Customers should implement appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP, the NXP logo, NXP SECURE CONNECTIONS FOR A SMARTER WORLD, COOLFLUX, EMBRACE, GREE ← NCHIP, HITAG, I2C BUS, ICODE, JCOP, LIFE VIBES, MIFARE, MIFARE CLASSIC, MIFARE DESFire, MIFARE P LUS, MIFARE FLEX, MANTIS, MIFARE ULTRALIGHT, MIFARE4MOBILE, MIGLO, NTAG, ROADLINK, SMARTLX, SMARTMX, STARPLUG, TOPFET, TRENCHMOS, UCODE, Freescale, the Freescale logo, AltiVec, C 5, CodeTEST, CodeWarrior, ColdFire, ColdFire+, C Ware, the Energy Efficient Solutions logo, Kinetis, Layerscape, MagniV, mobile ← GT, PEG, PowerQUICC, Processor Expert, QorlQ, QorlQ Qonverge, Ready Play, SafeAssure, the SafeAssure logo, StarCore, Symphony, VortiQa, Vybrid, Airfast, BeeKit, BeeStack, CoreNet, Flexis, MXC, Platform in a Package, QUICC Engine, SMARTMOS, Tower, TurboLink, and UMEMS are trademarks of NXP B.V. All other product or service names are the property of their respective owners. Arm, AMBA, Arm Powered, Artisan, Cortex, Jazelle, Keil, SecurCore, Thumb, TrustZone, and ?Vision are registered trademarks of Arm Limited (or its subsidiaries) in the EU and/or elsewhere. Arm7, Arm9, Arm11, big.LITTLE, CoreLink, CoreSight, DesignStart, Mali, Mbed, NEON, POP, Sensinode, Socrates, ULINK and Versatile are trademarks of Arm Limited (or its subsidiaries) in the EU and/or elsewhere. All rights reserved. Oracle and Java are registered trademarks of Oracle and/or its affiliates. The Power Architecture and Power.org word marks and the Power and Power.org logos and related marks are trademarks and service marks licensed by Power.org.

(c) 2018 NXP B.V.



