# System Controller Firmware API Reference Guide i.MX8QM Die (Ver 1.21)

NXP

Fri Jun 19 2020 19:00:14

| 1 Overview                             |      | 1  |
|----------------------------------------|------|----|
| 1.1 System Initialization and Boot     | <br> | 2  |
| 1.2 System Controller Communication    | <br> | 2  |
| 1.3 System Controller Services         | <br> | 2  |
| 1.3.1 Power Management Service         | <br> | 2  |
| 1.3.2 Resource Management Service      | <br> | 3  |
| 1.3.3 Pad Configuration Service        | <br> | 3  |
| 1.3.4 Timer Service                    | <br> | 4  |
| 1.3.5 Interrupt Service                | <br> | 4  |
| 1.3.6 Security Service                 | <br> | 4  |
| 1.3.7 Miscellaneous Service            | <br> | 4  |
| 2 Disclaimer                           |      | 5  |
| 3 Usage                                |      | 7  |
| 3.1 SCFW API                           | <br> | 7  |
| 3.2 Loading                            | <br> | 7  |
| 3.3 Boot Flags                         | <br> | 7  |
| 3.4 CPU Start Address                  | <br> | 8  |
| 3.4.1 Cortex-A Start Address           | <br> | 8  |
| 3.4.2 Cortex-M Start Address           | <br> | 9  |
| 3.5 Cortex-M4 DDR Aliasing             | <br> | 9  |
| 4 Resource Management                  |      | 11 |
| 4.1 Partitions                         | <br> | 11 |
| 4.2 Resources                          | <br> | 12 |
| 4.3 Pads                               | <br> | 13 |
| 4.4 Memory Regions                     | <br> | 13 |
| 4.5 SCFW API                           | <br> | 14 |
| 4.6 Hardware Resource/Memory Isolation | <br> | 14 |
| 4.7 Example                            | <br> | 16 |
| 5 Power Management                     |      | 19 |
| 5.1 Wake from Low Power                | <br> | 19 |
| 5.1.1 Wake Event Sources               | <br> | 19 |
| 5.1.2 GIC Wake Events                  | <br> | 19 |
| 5.1.3 IRQSTEER Wake Events             | <br> | 20 |
| 5.1.4 SCU Wake Events                  | <br> | 20 |
| 5.1.5 Pad Wake Events                  | <br> | 21 |
| 5.2 System Power Off                   | <br> | 21 |
| 5.3 Reset Control                      | <br> | 21 |

| 6 Resource List                            | 23   |
|--------------------------------------------|------|
| 7 Clock List                               | 35   |
| 8 Control List                             | 41   |
| 9 Pad List                                 | 47   |
| 10 RPC Protocol                            | 57   |
| 10.1 Remote Procedure Call                 | . 57 |
| 10.2 Inter-Processor Communication         | . 58 |
| 10.3 Interrupts                            | . 58 |
| 10.3.1 SCFW to Client Interrupts           | . 58 |
| 10.3.1.1 Interrupt Service Request         | . 58 |
| 10.3.1.2 Cortex-M Wake                     | . 58 |
| 10.3.1.3 Cold Boot Flag                    | . 59 |
| 10.3.1.4 Cortex-M Debug Wake               | . 59 |
| 10.3.2 Client to SCFW Interrupts           | . 59 |
| 10.3.2.1 RPC/IPC Reset Request             | . 59 |
| 10.4 Flags/Status                          | . 59 |
| 10.4.1 SCFW to Client Flags/Status         | . 59 |
| 10.5 Porting                               | . 60 |
| 10.6 API Message Formats                   | . 60 |
| 10.6.1 sc_pm_set_sys_power_mode()          | . 60 |
| 10.6.2 sc_pm_set_partition_power_mode()    |      |
| 10.6.3 sc pm get sys power mode()          |      |
| 10.6.4 sc_pm_partition_wake()              | . 61 |
| 10.6.5 sc_pm_set_resource_power_mode()     |      |
| 10.6.6 sc pm set resource power mode all() |      |
| 10.6.7 sc_pm_get_resource_power_mode()     |      |
| 10.6.8 sc_pm_req_low_power_mode()          |      |
| 10.6.9 sc_pm_req_cpu_low_power_mode()      |      |
| 10.6.10 sc_pm_set_cpu_resume_addr()        |      |
| 10.6.11 sc_pm_set_cpu_resume()             |      |
| 10.6.12 sc_pm_req_sys_if_power_mode()      |      |
| 10.6.13 sc_pm_set_clock_rate()             |      |
| 10.6.14 sc_pm_get_clock_rate()             |      |
| 10.6.15 sc_pm_clock_enable()               |      |
| 10.6.16 sc_pm_set_clock_parent()           |      |
| 10.6.17 sc_pm_get_clock_parent()           |      |
| 10.6.18 sc_pm_reset()                      |      |
| 10.0.10 so_piii_reset()                    | . 00 |

| 10.6.19 sc_pm_reset_reason()               |
|--------------------------------------------|
| 10.6.20 sc_pm_get_reset_part()             |
| 10.6.21 sc_pm_boot()                       |
| 10.6.22 sc_pm_set_boot_parm()              |
| 10.6.23 sc_pm_reboot()                     |
| 10.6.24 sc_pm_reboot_partition()           |
| 10.6.25 sc_pm_reboot_continue()            |
| 10.6.26 sc_pm_cpu_start()                  |
| 10.6.27 sc_pm_cpu_reset()                  |
| 10.6.28 sc_pm_resource_reset()             |
| 10.6.29 sc_pm_is_partition_started()       |
| 10.6.30 sc_rm_partition_alloc()            |
| 10.6.31 sc_rm_set_confidential()           |
| 10.6.32 sc_rm_partition_free()             |
| 10.6.33 sc_rm_get_did()                    |
| 10.6.34 sc_rm_partition_static()           |
| 10.6.35 sc_rm_partition_lock()             |
| 10.6.36 sc_rm_get_partition()              |
| 10.6.37 sc_rm_set_parent()                 |
| 10.6.38 sc_rm_move_all()                   |
| 10.6.39 sc_rm_assign_resource()            |
| 10.6.40 sc_rm_set_resource_movable()       |
| 10.6.41 sc_rm_set_subsys_rsrc_movable()    |
| 10.6.42 sc_rm_set_master_attributes()      |
| 10.6.43 sc_rm_set_master_sid()             |
| 10.6.44 sc_rm_set_peripheral_permissions() |
| 10.6.45 sc_rm_is_resource_owned()          |
| 10.6.46 sc_rm_get_resource_owner()         |
| 10.6.47 sc_rm_is_resource_master()         |
| 10.6.48 sc_rm_is_resource_peripheral()     |
| 10.6.49 sc_rm_get_resource_info()          |
| 10.6.50 sc_rm_memreg_alloc()               |
| 10.6.51 sc_rm_memreg_split()               |
| 10.6.52 sc_rm_memreg_frag()                |
| 10.6.53 sc_rm_memreg_free()                |
| 10.6.54 sc_rm_find_memreg()                |
| 10.6.55 sc_rm_assign_memreg()              |
| 10.6.56 sc_rm_set_memreg_permissions()     |
| 10.6.57 sc_rm_set_memreg_iee()             |

| 10.6.58 sc_rm_is_memreg_owned()              |
|----------------------------------------------|
| 10.6.59 sc_rm_get_memreg_info()              |
| 10.6.60 sc_rm_assign_pad()                   |
| 10.6.61 sc_rm_set_pad_movable()              |
| 10.6.62 sc_rm_is_pad_owned()                 |
| 10.6.63 sc_rm_dump()                         |
| 10.6.64 sc_timer_set_wdog_timeout()          |
| 10.6.65 sc_timer_set_wdog_pre_timeout()      |
| 10.6.66 sc_timer_set_wdog_window()           |
| 10.6.67 sc_timer_start_wdog()                |
| 10.6.68 sc_timer_stop_wdog()                 |
| 10.6.69 sc_timer_ping_wdog()                 |
| 10.6.70 sc_timer_get_wdog_status()           |
| 10.6.71 sc_timer_pt_get_wdog_status()        |
| 10.6.72 sc_timer_set_wdog_action()           |
| 10.6.73 sc_timer_set_rtc_time()              |
| 10.6.74 sc_timer_get_rtc_time()              |
| 10.6.75 sc_timer_get_rtc_sec1970()           |
| 10.6.76 sc_timer_set_rtc_alarm()             |
| 10.6.77 sc_timer_set_rtc_periodic_alarm()    |
| 10.6.78 sc_timer_cancel_rtc_alarm()          |
| 10.6.79 sc_timer_set_rtc_calb()              |
| 10.6.80 sc_timer_set_sysctr_alarm()          |
| 10.6.81 sc_timer_set_sysctr_periodic_alarm() |
| 10.6.82 sc_timer_cancel_sysctr_alarm()       |
| 10.6.83 sc_pad_set_mux()                     |
| 10.6.84 sc_pad_get_mux()                     |
| 10.6.85 sc_pad_set_gp()                      |
| 10.6.86 sc_pad_get_gp()                      |
| 10.6.87 sc_pad_set_wakeup()                  |
| 10.6.88 sc_pad_get_wakeup()                  |
| 10.6.89 sc_pad_set_all()                     |
| 10.6.90 sc_pad_get_all()                     |
| 10.6.91 sc_pad_set()                         |
| 10.6.92 sc_pad_get()                         |
| 10.6.93 sc_pad_config()                      |
| 10.6.94 sc_pad_set_gp_28fdsoi()              |
| 10.6.95 sc_pad_get_gp_28fdsoi()              |
| 10.6.96 sc_pad_set_gp_28fdsoi_hsic()         |

| 10.6.97 sc_pad_get_gp_28fdsoi_hsic()  |
|---------------------------------------|
| 10.6.98 sc_pad_set_gp_28fdsoi_comp()  |
| 10.6.99 sc_pad_get_gp_28fdsoi_comp()  |
| 10.6.100 sc_misc_set_control()        |
| 10.6.101 sc_misc_get_control()        |
| 10.6.102 sc_misc_set_max_dma_group()  |
| 10.6.103 sc_misc_set_dma_group()      |
| 10.6.104 sc_misc_debug_out()          |
| 10.6.105 sc_misc_waveform_capture()   |
| 10.6.106 sc_misc_build_info()         |
| 10.6.107 sc_misc_api_ver()            |
| 10.6.108 sc_misc_unique_id()          |
| 10.6.109 sc_misc_set_ari()            |
| 10.6.110 sc_misc_boot_status()        |
| 10.6.111 sc_misc_boot_done()          |
| 10.6.112 sc_misc_otp_fuse_read()      |
| 10.6.113 sc_misc_otp_fuse_write()     |
| 10.6.114 sc_misc_set_temp()           |
| 10.6.115 sc_misc_get_temp()           |
| 10.6.116 sc_misc_get_boot_dev()       |
| 10.6.117 sc_misc_get_boot_type()      |
| 10.6.118 sc_misc_get_boot_container() |
| 10.6.119 sc_misc_get_button_status()  |
| 10.6.120 sc_misc_rompatch_checksum()  |
| 10.6.121 sc_misc_board_ioctl()        |
| 10.6.122 sc_seco_image_load()         |
| 10.6.123 sc_seco_authenticate()       |
| 10.6.124 sc_seco_enh_authenticate()   |
| 10.6.125 sc_seco_forward_lifecycle()  |
| 10.6.126 sc_seco_return_lifecycle()   |
| 10.6.127 sc_seco_commit()             |
| 10.6.128 sc_seco_attest_mode()        |
| 10.6.129 sc_seco_attest()             |
| 10.6.130 sc_seco_get_attest_pkey()    |
| 10.6.131 sc_seco_get_attest_sign()    |
| 10.6.132 sc_seco_attest_verify()      |
| 10.6.133 sc_seco_gen_key_blob()       |
| 10.6.134 sc_seco_load_key()           |
| 10.6.135 sc_seco_get_mp_key()         |

|     | 10.6.136 sc_seco_update_mpmr()                | 96  |
|-----|-----------------------------------------------|-----|
|     | 10.6.137 sc_seco_get_mp_sign()                | 97  |
|     | 10.6.138 sc_seco_build_info()                 | 97  |
|     | 10.6.139 sc_seco_chip_info()                  | 97  |
|     | 10.6.140 sc_seco_enable_debug()               | 98  |
|     | 10.6.141 sc_seco_get_event()                  | 98  |
|     | 10.6.142 sc_seco_fuse_write()                 | 98  |
|     | 10.6.143 sc_seco_patch()                      | 99  |
|     | 10.6.144 sc_seco_set_mono_counter_partition() | 99  |
|     | 10.6.145 sc_seco_set_fips_mode()              | 99  |
|     | 10.6.146 sc_seco_start_rng()                  | 99  |
|     | 10.6.147 sc_seco_sab_msg()                    | 100 |
|     | 10.6.148 sc_seco_secvio_enable()              | 100 |
|     | 10.6.149 sc_seco_secvio_config()              | 100 |
|     | 10.6.150 sc_seco_secvio_dgo_config()          | 101 |
|     | 10.6.151 sc_irq_enable()                      | 101 |
|     | 10.6.152 sc_irq_status()                      | 101 |
| 44  | Module Index                                  | 103 |
|     | 11.1 Modules                                  |     |
|     | TITI Wiodules                                 | 103 |
| 12  | File Index                                    | 105 |
|     | 12.1 File List                                | 105 |
| 10  | Module Documentation                          | 107 |
| 131 | 13.1 IRQ: Interrupt Service                   |     |
|     | 13.1.1 Detailed Description                   |     |
|     | 13.1.2 Function Documentation                 |     |
|     |                                               |     |
|     | 13.1.2.1 sc_irq_enable()                      |     |
|     | 13.1.2.2 sc_irq_status()                      |     |
|     | 13.2 MISC: Miscellaneous Service              |     |
|     | 13.2.2 Function Documentation                 |     |
|     |                                               |     |
|     | 13.2.2.1 sc_misc_set_control()                |     |
|     | 13.2.2.2 sc_misc_get_control()                |     |
|     | 13.2.2.3 sc_misc_set_max_dma_group()          |     |
|     | 13.2.2.4 sc_misc_set_dma_group()              |     |
|     | 13.2.2.5 sc_misc_debug_out()                  |     |
|     | 13.2.2.6 sc_misc_waveform_capture()           |     |
|     | 13.2.2.7 sc_misc_build_info()                 | 118 |

| 13.2.2.8 sc_misc_api_ver()             | 118 |
|----------------------------------------|-----|
| 13.2.2.9 sc_misc_unique_id()           | 118 |
| 13.2.2.10 sc_misc_set_ari()            | 119 |
| 13.2.2.11 sc_misc_boot_status()        | 119 |
| 13.2.2.12 sc_misc_boot_done()          | 120 |
| 13.2.2.13 sc_misc_otp_fuse_read()      | 120 |
| 13.2.2.14 sc_misc_otp_fuse_write()     | 121 |
| 13.2.2.15 sc_misc_set_temp()           | 122 |
| 13.2.2.16 sc_misc_get_temp()           | 122 |
| 13.2.2.17 sc_misc_get_boot_dev()       | 123 |
| 13.2.2.18 sc_misc_get_boot_type()      | 123 |
| 13.2.2.19 sc_misc_get_boot_container() | 124 |
| 13.2.2.20 sc_misc_get_button_status()  | 124 |
| 13.2.2.21 sc_misc_rompatch_checksum()  | 125 |
| 13.2.2.22 sc_misc_board_ioctl()        | 125 |
| 13.3 PAD: Pad Service                  | 126 |
| 13.3.1 Detailed Description            | 129 |
| 13.3.2 Typedef Documentation           | 131 |
| 13.3.2.1 sc_pad_config_t               | 131 |
| 13.3.2.2 sc_pad_iso_t                  | 131 |
| 13.3.2.3 sc_pad_28fdsoi_dse_t          | 131 |
| 13.3.2.4 sc_pad_28fdsoi_ps_t           | 131 |
| 13.3.2.5 sc_pad_28fdsoi_pus_t          | 131 |
| 13.3.3 Function Documentation          | 131 |
| 13.3.3.1 sc_pad_set_mux()              | 131 |
| 13.3.3.2 sc_pad_get_mux()              | 132 |
| 13.3.3.3 sc_pad_set_gp()               | 133 |
| 13.3.3.4 sc_pad_get_gp()               | 133 |
| 13.3.3.5 sc_pad_set_wakeup()           | 134 |
| 13.3.3.6 sc_pad_get_wakeup()           | 135 |
| 13.3.3.7 sc_pad_set_all()              | 135 |
| 13.3.3.8 sc_pad_get_all()              | 136 |
| 13.3.3.9 sc_pad_set()                  | 137 |
| 13.3.3.10 sc_pad_get()                 | 137 |
| 13.3.3.11 sc_pad_config()              | 138 |
| 13.3.3.12 sc_pad_set_gp_28fdsoi()      | 139 |
| 13.3.3.13 sc_pad_get_gp_28fdsoi()      | 139 |
| 13.3.3.14 sc_pad_set_gp_28fdsoi_hsic() | 140 |
| 13.3.3.15 sc_pad_get_gp_28fdsoi_hsic() | 141 |

| 13.3.3.16 sc_pad_set_gp_28fdsoi_comp()       |
|----------------------------------------------|
| 13.3.3.17 sc_pad_get_gp_28fdsoi_comp()       |
| 13.4 PM: Power Management Service            |
| 13.4.1 Detailed Description                  |
| 13.4.2 Typedef Documentation                 |
| 13.4.2.1 sc_pm_power_mode_t150               |
| 13.4.3 Function Documentation                |
| 13.4.3.1 sc_pm_set_sys_power_mode()          |
| 13.4.3.2 sc_pm_set_partition_power_mode()    |
| 13.4.3.3 sc_pm_get_sys_power_mode()          |
| 13.4.3.4 sc_pm_partition_wake()              |
| 13.4.3.5 sc_pm_set_resource_power_mode()     |
| 13.4.3.6 sc_pm_set_resource_power_mode_all() |
| 13.4.3.7 sc_pm_get_resource_power_mode()     |
| 13.4.3.8 sc_pm_req_low_power_mode()          |
| 13.4.3.9 sc_pm_req_cpu_low_power_mode()      |
| 13.4.3.10 sc_pm_set_cpu_resume_addr()        |
| 13.4.3.11 sc_pm_set_cpu_resume()             |
| 13.4.3.12 sc_pm_req_sys_if_power_mode()      |
| 13.4.3.13 sc_pm_set_clock_rate()             |
| 13.4.3.14 sc_pm_get_clock_rate()             |
| 13.4.3.15 sc_pm_clock_enable()               |
| 13.4.3.16 sc_pm_set_clock_parent()           |
| 13.4.3.17 sc_pm_get_clock_parent()           |
| 13.4.3.18 sc_pm_reset()                      |
| 13.4.3.19 sc_pm_reset_reason()               |
| 13.4.3.20 sc_pm_get_reset_part()             |
| 13.4.3.21 sc_pm_boot()                       |
| 13.4.3.22 sc_pm_set_boot_parm()              |
| 13.4.3.23 sc_pm_reboot()                     |
| 13.4.3.24 sc_pm_reboot_partition()           |
| 13.4.3.25 sc_pm_reboot_continue()            |
| 13.4.3.26 sc_pm_cpu_start()                  |
| 13.4.3.27 sc_pm_cpu_reset()                  |
| 13.4.3.28 sc_pm_resource_reset()             |
| 13.4.3.29 sc_pm_is_partition_started()       |
| 13.5 RM: Resource Management Service         |
| 13.5.1 Detailed Description                  |
| 13.5.2 Typedef Documentation                 |

| 13.5.2.1 sc_rm_perm_t                        | 1/4 |
|----------------------------------------------|-----|
| 13.5.2.2 sc_rm_rmsg_t                        | 174 |
| 13.5.3 Function Documentation                | 174 |
| 13.5.3.1 sc_rm_partition_alloc()             | 174 |
| 13.5.3.2 sc_rm_set_confidential()            | 175 |
| 13.5.3.3 sc_rm_partition_free()              | 176 |
| 13.5.3.4 sc_rm_get_did()                     | 176 |
| 13.5.3.5 sc_rm_partition_static()            | 177 |
| 13.5.3.6 sc_rm_partition_lock()              | 177 |
| 13.5.3.7 sc_rm_get_partition()               | 178 |
| 13.5.3.8 sc_rm_set_parent()                  | 178 |
| 13.5.3.9 sc_rm_move_all()                    | 179 |
| 13.5.3.10 sc_rm_assign_resource()            | 180 |
| 13.5.3.11 sc_rm_set_resource_movable()       | 181 |
| 13.5.3.12 sc_rm_set_subsys_rsrc_movable()    | 181 |
| 13.5.3.13 sc_rm_set_master_attributes()      | 182 |
| 13.5.3.14 sc_rm_set_master_sid()             | 183 |
| 13.5.3.15 sc_rm_set_peripheral_permissions() | 184 |
| 13.5.3.16 sc_rm_is_resource_owned()          | 184 |
| 13.5.3.17 sc_rm_get_resource_owner()         | 185 |
| 13.5.3.18 sc_rm_is_resource_master()         | 185 |
| 13.5.3.19 sc_rm_is_resource_peripheral()     | 186 |
| 13.5.3.20 sc_rm_get_resource_info()          | 186 |
| 13.5.3.21 sc_rm_memreg_alloc()               | 187 |
| 13.5.3.22 sc_rm_memreg_split()               | 188 |
| 13.5.3.23 sc_rm_memreg_frag()                | 188 |
| 13.5.3.24 sc_rm_memreg_free()                | 189 |
| 13.5.3.25 sc_rm_find_memreg()                | 190 |
| 13.5.3.26 sc_rm_assign_memreg()              | 190 |
| 13.5.3.27 sc_rm_set_memreg_permissions()     | 191 |
| 13.5.3.28 sc_rm_set_memreg_iee()             | 192 |
| 13.5.3.29 sc_rm_is_memreg_owned()            | 193 |
| 13.5.3.30 sc_rm_get_memreg_info()            | 193 |
| 13.5.3.31 sc_rm_assign_pad()                 | 194 |
| 13.5.3.32 sc_rm_set_pad_movable()            | 194 |
| 13.5.3.33 sc_rm_is_pad_owned()               | 195 |
| 13.5.3.34 sc_rm_dump()                       | 195 |
| 13.6 SECO: Security Service                  | 196 |
| 13.6.1 Detailed Description                  | 198 |

| 13.6.2 Function Documentation                  | 0 |
|------------------------------------------------|---|
| 13.6.2.1 sc_seco_image_load()                  | 0 |
| 13.6.2.2 sc_seco_authenticate()                | 1 |
| 13.6.2.3 sc_seco_enh_authenticate()            | 2 |
| 13.6.2.4 sc_seco_forward_lifecycle()           | 3 |
| 13.6.2.5 sc_seco_return_lifecycle()            | 4 |
| 13.6.2.6 sc_seco_commit()                      | 4 |
| 13.6.2.7 sc_seco_attest_mode()                 | 5 |
| 13.6.2.8 sc_seco_attest()                      | 6 |
| 13.6.2.9 sc_seco_get_attest_pkey()             | 6 |
| 13.6.2.10 sc_seco_get_attest_sign()            | 7 |
| 13.6.2.11 sc_seco_attest_verify()              | 8 |
| 13.6.2.12 sc_seco_gen_key_blob()               | 9 |
| 13.6.2.13 sc_seco_load_key()                   | 0 |
| 13.6.2.14 sc_seco_get_mp_key()                 | 0 |
| 13.6.2.15 sc_seco_update_mpmr()                | 1 |
| 13.6.2.16 sc_seco_get_mp_sign()                | 2 |
| 13.6.2.17 sc_seco_build_info()                 | 3 |
| 13.6.2.18 sc_seco_chip_info()                  | 3 |
| 13.6.2.19 sc_seco_enable_debug()               | 4 |
| 13.6.2.20 sc_seco_get_event()                  | 4 |
| 13.6.2.21 sc_seco_fuse_write()                 | 5 |
| 13.6.2.22 sc_seco_patch()                      | 5 |
| 13.6.2.23 sc_seco_set_mono_counter_partition() | 6 |
| 13.6.2.24 sc_seco_set_fips_mode()              | 7 |
| 13.6.2.25 sc_seco_start_rng()                  | 8 |
| 13.6.2.26 sc_seco_sab_msg()                    | 8 |
| 13.6.2.27 sc_seco_secvio_enable()              | 9 |
| 13.6.2.28 sc_seco_secvio_config()              | 0 |
| 13.6.2.29 sc_seco_secvio_dgo_config()          | 1 |
| 13.7 TIMER: Timer Service                      | 2 |
| 13.7.1 Detailed Description                    | 3 |
| 13.7.2 Function Documentation                  | 3 |
| 13.7.2.1 sc_timer_set_wdog_timeout()           | 3 |
| 13.7.2.2 sc_timer_set_wdog_pre_timeout()       | 4 |
| 13.7.2.3 sc_timer_set_wdog_window()            | 4 |
| 13.7.2.4 sc_timer_start_wdog()                 | 5 |
| 13.7.2.5 sc_timer_stop_wdog()                  | 5 |
| 13.7.2.6 sc_timer_ping_wdog()                  | 6 |
|                                                |   |

| 13.7.2.7 sc_timer_get_wdog_status()              |     |
|--------------------------------------------------|-----|
| 13.7.2.8 sc_timer_pt_get_wdog_status()           |     |
| 13.7.2.9 sc_timer_set_wdog_action()              |     |
| 13.7.2.10 sc_timer_set_rtc_time()                |     |
| 13.7.2.11 sc_timer_get_rtc_time()                |     |
| 13.7.2.12 sc_timer_get_rtc_sec1970()             |     |
| 13.7.2.13 sc_timer_set_rtc_alarm()               |     |
| 13.7.2.14 sc_timer_set_rtc_periodic_alarm()      |     |
| 13.7.2.15 sc_timer_cancel_rtc_alarm()            |     |
| 13.7.2.16 sc_timer_set_rtc_calb()                |     |
| 13.7.2.17 sc_timer_set_sysctr_alarm()            |     |
| 13.7.2.18 sc_timer_set_sysctr_periodic_alarm()   |     |
| 13.7.2.19 sc_timer_cancel_sysctr_alarm()         |     |
| 14 File Documentation                            | 235 |
| 14.1 platform/config/mx8qm/pads.h File Reference |     |
| 14.1.1 Detailed Description                      |     |
| 14.2 platform/main/ipc.h File Reference          |     |
| 14.2.1 Detailed Description                      |     |
| 14.2.2 Function Documentation                    |     |
| 14.2.2.1 sc_ipc_open()                           |     |
| 14.2.2.2 sc_ipc_close()                          |     |
| 14.2.2.3 sc ipc read()                           |     |
| 14.2.2.4 sc_ipc_write()                          |     |
| 14.3 platform/main/types.h File Reference        |     |
| 14.3.1 Detailed Description                      |     |
| 14.3.2 Macro Definition Documentation            |     |
| 14.3.2.1 SC R NONE                               |     |
| 14.3.2.2 SC_P_ALL                                |     |
| 14.3.3 Typedef Documentation                     |     |
| 14.3.3.1 sc_rsrc_t                               |     |
| 14.3.3.2 sc_pad_t                                |     |
| 14.4 platform/svc/irq/api.h File Reference       |     |
| 14.4.1 Detailed Description                      |     |
| 14.5 platform/svc/misc/api.h File Reference      |     |
| 14.5.1 Detailed Description                      |     |
| 14.6 platform/svc/pad/api.h File Reference       |     |
| 14.6.1 Detailed Description                      |     |
| 14.7 platform/svc/pm/api.h File Reference        |     |

| Index                                       |     |      | 287 |
|---------------------------------------------|-----|------|-----|
| 14.10.1 Detailed Description                |     | <br> | 285 |
| 14.10 platform/svc/timer/api.h File Refere  | nce | <br> |     |
| 14.9.1 Detailed Description                 |     | <br> | 283 |
| 14.9 platform/svc/seco/api.h File Reference | ce  | <br> |     |
| 14.8.1 Detailed Description                 |     | <br> |     |
| 14.8 platform/svc/rm/api.h File Reference   |     | <br> |     |
| 14.7.1 Detailed Description                 |     | <br> | 277 |

# **Overview**

The System Controller (SC) provides an abstraction to many of the underlying features of the hardware. This function runs on a Cortex-M processor which executes SC firmware (FW). This overview describes the features of the SCFW and the APIs exposed to other software components.

#### Features include:

- System Initialization and Boot
- System Controller Communication
- Power Management
- · Resource Management
- · Pad Configuration
- Timers
- Interrupts
- Security
- Miscellaneous

Due to this abstraction, some HW described in the SoC RM that is used by the SCFW is not directly accessible to other cores. This includes:

- All resources in the SCU subsystem (SCU M4, SCU LPUART, SCU LPI2C, etc.).
- · All resource accessed via MSI links from the SCU subsystem (inc. pads, DSC, XRDC2, eCSR)
- · OCRAM controller, CAAM MP, eDMA MP & LPCG
- DB STC & LPCG, IMG GPR
- · GIC/IRQSTR LPCG, IRQSTR.SCU and IRQSTR.CTI
- · Some features of SNVS such as the RTC, button, and LPGPR1
- · Any other resources reserved by the port of the SCFW to the board

Note also the SECO uses some resources like CAAM JR0-1, SNVS LPGPR0, etc.

2 Overview

# 1.1 System Initialization and Boot

The SC firmware runs on the SCU immediately after the SCU Read-only-memory (ROM) finishes loading code/data images from the first container. It is responsible for initializing many aspects of the system. This includes additional power and clock configuration and resource isolation hardware configuration. By default, the SC firmware configures the primary boot core to own most of the resources and launches the boot core. Additional configuration can be done by boot code.

# 1.2 System Controller Communication

Other software components in the system communicate to the SC via an exposed API library. This library is implemented to make Remote Procedure Calls (RPC) via an underlying Inter-Processor Communication (IPC) mechanism. The IPC is facilitated by a hardware-based mailbox system.

Software components (Linux, QNX, FreeRTOS, KSDK) delivered for i.MX8 already include ports of the client API. Other 3rd parties will need to first port the API to their environment before the API can be used. The porting kit release includes archives of the client API for existing SW. These can be used as reference for porting the client API. All that needs to be implemented is the IPC layer which will utilize messaging units (MU) to communicate with the SCFW.

# 1.3 System Controller Services

The SCFW provides API access to all the system controller functionality exported to other software systems. This includes:

### 1.3.1 Power Management Service

All aspects of power management including power control, bias control, clock control, reset control, and wake-up event monitoring are grouped within the SC Power Management service.

- **Power Control** The SC firmware is responsible for centralized management of power controls and external power management devices. It manages the power state and voltage of power domains as well as bias control. It also resets peripherals as required due to power state transitions. This is all done via the API by communicating power state needs for individual resources.
- Clock Control The SC firmware is responsible for centralized management of clock controls. This includes clock sources such as oscillators and PLLs as well as clock dividers, muxes, and gates. This is all done via the API by communicating clocking needs for individual resources.
- Reset Control The SC firmware is responsible for reset control. This includes booting/rebooting a partition, obtaining reset reasons, and starting/stopping of CPUs.

Before any hardware in the SoC can be used, SW must first power up the resource and enable any clocks that it requires, otherwise access will generate a bus error. More detail can be found in the Power Management section. The Power Management (PM) API is documented here.

### 1.3.2 Resource Management Service

SC firmware is responsible for managing ownership and access permissions to system resources. The features of the resource management service supported by SC firmware include:

- Management of system resources such as SoC peripherals, memory regions, and pads
- Allows resources to be partitioned into different ownership groupings that are associated with different execution environments including multiple operating systems executing on different cores, TrustZone, and hypervisor
- · Associates ownership with requests from messaging units within a resource partition
- · Allows memory to be divided into memory regions that are then managed like other resources
- Allows owners to configure access permissions to resources
- Configures hardware components to provide hardware enforced isolation
- · Configures hardware components to directly control secure/nonsecure attribute driven on bus fabric
- Provides ownership and access permission information to other system controller functions (e.g. pad ownership information to the pad muxing functions)

Protection of resources is provided in two ways. First, the SCFW itself checks resource access rights when API calls are made that affect a specific resource. Depending on the API call, this may require that the caller be the owner, parent of the owner, or an ancestor of the owner. Second, any hardware available to enforce access controls is configured based on the RM state. This includes the configuration of IP such as XRDC2, XRDC, or RDC, as well as management pages of IP like CAAM.

Partitions own resources, pads, and memory regions. This includes owning MU resources to communicate with the  $S \leftarrow CFW$ . API calls to the SCFW lookup the owner of the MU the call comes in on, and that is treated as the calling partition. Different API calls then enforce operations based on the relationship of the calling partition to the partition being acted on. This association does not directly determine who can access the programming model of a resource IP. This is solely determine by the access rights defined (per partition) for the resource. Note partitions do not have owners (they are the owners), but they do have parent/child relationships. The creator of a partition is the parent unless that parent calls the API to change the parent. If no parent is desired, then the parent should be set to 0 (the SCFW itself). Being the patent provides some rights with respect to API calling (but not peripheral access).

More detail can be found in the Resource Management section. The Resource Management (RM) API is documented here.

### 1.3.3 Pad Configuration Service

Pad configuration is managed by SC firmware. The pad configuration features supported by the SC firmware include:

- Configuring the mux, input/output connection, and low-power isolation mode.
- · Configuring the technology-specific pad setting such as drive strength, pullup/pulldown, etc.
- Configuring compensation for pad groups with dual voltage capability.

The Pad (PAD) API is documented here.

4 Overview

#### 1.3.4 Timer Service

Many timer oriented services are grouped within the SC Timer service. This includes watchdogs, RTC, and system counter.

- Watchdog The SC firmware provides "virtual" watchdogs for all execution environments. Features include
  update of the watchdog timeout, start/stop of the watchdog, refresh of the watchdog, return of the watchdog
  status such as maximum watchdog timeout that can be set, watchdog timeout interval, and watchdog timeout
  interval remaining.
- Real-Time-Clock The SC firmware is responsible for providing access to the RTC. Features include setting the time, getting the time, and setting alarms.
- System Counter The SC firmware is responsible for providing access to the SYSCTR. Features include setting
  an absolute alarm or a relative, periodic alarm. Reading is done directly via local hardware interfaces available
  for each CPU.

The Timer API is documented here.

#### 1.3.5 Interrupt Service

The System Controller needs a method to inform users about asynchronous notification events. This is done via the Interrupt service. The service provides APIs to enable/disable interrupts to the user and to read the status of pending interrupts. Reading the status automatically clears any pending state. The Interrupt (IRQ) API is documented here.

### 1.3.6 Security Service

The SC firmware provides access to many security functions including:

- · Image Authentication
- Generating, exporting, and loading key blobs
- · Fuse programming
- Lifecycle management
- Attestation

The Security (SECO) API is documented here.

See the SECO API Reference Guide for more info.

#### 1.3.7 Miscellaneous Service

On previous i.MX devices, miscellaneous features were controlled using IOMUX GPR registers with signals connected to configurable hardware. This functionality is being replaced with DSC GPR signals. SC firmware is responsible for programming the GPR signals to configure these subsystem features. The SC firmware also responsible for monitoring various temperature, voltage, and clock sensors.

- **Controls** The SC firmware provides access to miscellaneous controls. Features include software request to set (write) miscellaneous controls and software request to get (read) miscellaneous controls.
- DMA The SC firmware provides access to DMA channel grouping and priority functions.
- Temp The SC firmware provides access to temperature sensors.

The Miscellaneous (MISC) API is documented here.

# **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) 2020 NXP B.V.



| 6 | Disclaime |
|---|-----------|
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |
|   |           |

# **Usage**

### 3.1 SCFW API

Calling the functions in the SCFW requires a client API which utilizes an RPC/IPC layer to communicate to the SC—FW binary running on the SCU. Application environments (Linux, QNX, FreeRTOS, KSDK) delivered for i.MX8 already include ports of the client API. Other 3rd parties will need to first port the API to their environment before the API can be used. The porting kit release includes archives of the client API for existing SW. These can be used as reference for porting the client API. All that needs to be implemented is the IPC layer which will utilize messaging units (MU) to communicate with the SCFW.

The SCFW API is documented in the individual API sections. There are examples in the Details section for each service.

- · Resource Management
- Power Management
- Pad Configuration
- Timers
- Interrupts
- Miscellaneous

# 3.2 Loading

The SCFW is loaded by including the binary (scfw\_tcm.bin) in the boot container.

# 3.3 Boot Flags

The image container holding the SCFW should also have the boot flags configured. This is a set of flags (32-bits) specified with the -flags option to mkimage.

These are defined as:

8 Usage

| Flag                        | Bit | Meaning                                          |
|-----------------------------|-----|--------------------------------------------------|
| SC_BD_FLAGS_NOT_SECURE      | 16  | Initial boot partition is not secure             |
| SC_BD_FLAGS_NOT_ISOLATED    | 17  | Initial boot partition is not isolated           |
| SC_BD_FLAGS_RESTRICTED      | 18  | Initial boot partition is restricted             |
| SC_BD_FLAGS_GRANT           | 19  | Initial boot partition grants access to the SCFW |
| SC_BD_FLAGS_NOT_COHERENT    | 20  | Initial boot partition is not coherent           |
| SC_BD_FLAGS_ALT_CONFIG      | 21  | Alternate SCFW config (passed to board.c)        |
| SC_BD_FLAGS_EARLY_CPU_START | 22  | Start some CPUs early                            |
| SC_BD_FLAGS_DDRTEST         | 23  | Config for DDR stress test                       |
| SC_BD_FLAGS_NO_AP           | 24  | Don't boot AP even if requested by ROM           |

See the sc\_rm\_partition\_alloc() function for more info. Note some of the flags are inverted before calling this function! This results in a default (all 0) which is appropriate for normal OS execution. That is a partition which is secure, isolated, not restricted, not grant, coherent, no early start, and no DDR test.

# 3.4 CPU Start Address

The execution address passed in the boot container is used by the SCFW to start the CPU. This is done by calling sc\_pm\_boot() or sc\_pm\_cpu\_start(), depending on the partition info specified in the container. This address is restricted by the hardware implementation.

#### 3.4.1 Cortex-A Start Address

These cores are restricted to the following. Note the allowed address is CPU dependent.

| Address    | CPU |
|------------|-----|
| 0x00000000 | Any |
| 0x00000040 | 1   |
| 0x00000080 | 2   |
| 0x000000C0 | 3   |
| 0x00000100 | 0   |
| 0x00000140 | 1   |
| 0x00000180 | 2   |
| 0x000001C0 | 3   |
| 0x00010000 | 1   |
| 0x00020000 | 2   |
| 0x00030000 | 3   |
| 0x80000000 | Any |
| 0x80000040 | 1   |
| 0x80000080 | 2   |
| 0x800000C0 | 3   |
| 0x80000100 | 0   |
| 0x80000140 | 1   |
| 0x80000180 | 2   |
| 0x800001C0 | 3   |
| 0x80010000 | 1   |
| 0x80020000 | 2   |
| 0x80030000 | 3   |

NXP - All Rights Reserved

Some devices alias OCRAM to ROM. On these, if an OCRAM address is specified the SCFW will modify it to a ROM address. This will allow the code to be fetched from the OCRAM. Be warned the PC will be in the ROM address space.

#### 3.4.2 Cortex-M Start Address

The hardware has no mechanism to set the boot address. These cores will always start at the beginning of TCM. The SCFW will take any other address specified and write a jump instruction to the beginning of TCM.

# 3.5 Cortex-M4 DDR Aliasing

Devices without a SMMU include a basic translation block that can be leveraged to alias DDR memory onto the Cortex-M4 code bus. This aliasing allows performance improvements when Cortex-M4 code is located in DDR memory. The Cortex-M4 image can active aliasing during execution by updating the MCM Process ID register (MCM\_PID). The DDR region will be aliased to the FlexSPI0 memory-mapped (XIP) space.

The following mappings are supported:

| MCM_PID | DDR Region             | Size  | Alias                  |
|---------|------------------------|-------|------------------------|
| 0x7E    | 0x88000000 - 0x8FFFFFF | 128MB | 0x08000000 - 0x0FFFFFF |
| 0x7F    | 0x90000000 - 0x97FFFFF | 128MB | 0x10000000 - 0x17FFFFF |
| Other   | N/A                    | N/A   | No Alias               |

Aliasing must be activated while executing from a non-aliased region. The recommended flow to boot the Cortex-M4 into an aliased DDR region is as follows:

- · Link the image for the aliased region
- Reset vector must point to unaliased DDR start address
- · Specify the load address to be unaliased DDR region in the boot container
- · After Cortex-M4 execution begins from unaliased DDR, jump to the aliased region

#### Notes:

- Enabling aliasing via the MCM PID will result in loss of access to the corresponding FlexSPI address space.
- Use caution when using the Cortex-M4 code and system bus caches while aliasing is active to avoid coherency issues.

| 10 | Usage |
|----|-------|
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |
|    |       |

# **Resource Management**

SCFW is responsible for managing ownership and access permissions to system resources. The resource management functions of the SCFW are used to divide up the System on a Chip (SoC) resources and to control master transaction attributes and peripheral access permissions. The features supported by the SCFW are:

- Management of system resources such as SoC peripherals, memory regions and pads.
- Allows resources to be partitioned into different ownership groupings that are associated with different execution environments.
- · Allows owners to configure access permissions to resources.
- · Provides hardware enforced isolation.

See the Overview. The Resource Management (RM) API is documented here.

## 4.1 Partitions

One of the primary concepts of resource management in the SCFW is resource partitions (aka partitions). These are used to define a 'logical SoC' made up of resources, pads, and memory regions.

Partitions have the following characteristics. All partitions:

- · can be created and destroyed, at boot and dynamically during run-time,
- · have a hierarchical relationship, every partition has a parent,
- own resources (master and peripheral), pads, and memory regions,
- are restricted, by default, to only accessing the resources they own,
- · can be booted, rebooted, and powered down,
- have a power state; can transition to other power states,
- have a watchdog timer, RTC alarm, and system counter alarm.

Partitions are created by calling the SCFW to allocate them. Resources, pads, memory regions, etc. are then assigned or moved to the new partition thus defining the 'logical SoC'. The SCFW uses an assignment scheme for resource management rather than an allocation scheme. This is similar to virtualization and VMs.

At boot all resources belong to one partition. The SCFW creates some partitions in the board porting layer and then others are created dynamically by the running CPUs. Partitions should be created in the SCFW for any CPU that will be started by the SCFW due to parameters passed from the ROM and defined in the boot image containers.

Partitions can be created in several ways. They can be created by default by the SCFW using parameters passed from the ROM (determined by parameters in the boot container), they can be created in the board\_system\_config() function of the board porting layer of the SCFW, or be created dynamically by calling sc rm partition alloc().

Partitions have several attributes that are defined when they are created:

- Secure by default, master would generate secure transactions and resources would require secure access. Only a secure partition can create another secure partition. Used primarily for TrustZone.
- **Isolated** use XRDC2 to isolate. Should be true for all partitions except when a secure partition creates a non-secure partitions running on the same CPU as a secure partition. This parameter just results in the partition having the same DID as the parent.
- Restricted true if the partition cannot create partitions.
- Grant true if all resources in this partition should always remain accessible to the parent. Only used when
  creating a partition with no CPUs. Useful to just isolate the access of a bus master like a DMA channel to a
  subset of memory.
- Coherent true if this partition will contain both AP clusters running in an SMP configuration.

The boot partition parameters come from the container. See the Boot Flags section.

In addition, partitions can be made confidential using the sc\_rm\_set\_confidential() function. A confidential partition cannot not have any resource or memory assigned to it anymore. Useful for some security related use-cases.

The parent/child relationship directly affects partition reboot. When a partition is rebooted, its child partitions are automatically deleted and all resources returned to the parent. This allows the parent to rerun and again recreate the child partition like it did when it ran the first time. For more information on resets and partition reboot, see the Reset section of the Porting Guide.

### 4.2 Resources

Resources represent the IP blocks in the SoC. They can be masters (i.e. generate bus transactions), peripherals (i.e. e. have a programming model), or both. Resources always have an owning (only one) partition. Access control of resources consists of two primary mechanisms:

• API Access - the SCFW API functions use info like the calling partition and resource parameter to decide if actions can be take on a resource. The ownership of the resource and hierarchical relationship of the owning partition and the calling partition are used to decide if operations are authorized. These access rights vary by function and are described in the function documentation.

4.3 Pads 13

• Hardware Protection - the SCFW programs the underlying protection hardware (XRDC2 in the case of i.MX8) to control which masters can access which peripherals. Access permissions are maintained for each resource and can be set by the owner for each accessing partition. By default, only masters in a partition can only access peripherals in the same partition.

Resources can be assigned or moved by the owner to another partition. Master resources can have security, privilege, SMMU bypass, and streamID (SID) set. Peripheral resources can have access permissions set. The security state of masters can only be set if the partition owning the master is secure. Master resources generate a domain ID (DID) on the bus identifying what partition they belong to. All master resources in a partition generate the same ID so they all have the same access rights (CPUs and all other bus masters). For example, a DC assigned to a partition can only access memory accessible to that partition. The partition needs to either own the memory or the memory needs to have access rights granted to that partition using sc\_rm\_set\_memreg\_permissions(). If this needs to be a subset of memory then a new memory region should be created using one of the split or frag functions.

Note that not all resources have independent access controls. This is a function of the hardware design. Some peripherals share access control programming. This is often the case for display and camera interfaces. The entire interface (interface IP, PWM, I2C, LPCG, etc.) are in a single 64K page and have a single access control slot.

While Cortex-A cores part of a cluster can be assigned to different partitions, this is not guaranteed to always identify bus transactions as belonging to a core. Due to variations in microarchitecture of different Cortex-A cores, they have varying abilities to identify traffic as belonging to a specific core. This ability depends on transaction type (strongly ordered, device, exclusive, normal, etc.) as well as L1/L2 cache usage. Because cores can define these transaction properties themselves, isolation between CPUs in a cluster can never be considered secure. Because of this, i.MX8 processors do not have a product requirement to support this capability and the ability to isolate cores is not tested. CPUs in a cluster should always be in the same partition as the cluster.

### 4.3 Pads

Pads represent the individual pads of the SoC. They are owned by partitions. They have no direct access, so access control is similar to the SCFW API access control of resources.

# 4.4 Memory Regions

Memory regions represent blocks of memory with a start and end address. Once defined, they have ownership and access controls similar to resources. They support both kinds of access protections. The memory region owner can:

- · assign/move to another partition
- · can create a new memory region within the bounds of an existing owned region
- · can split a region
- · can configure access permissions

The SCFW implementation supports a maximum of 64 memory regions. Beyond this, the HW implementation further restricts the number of regions and this restriction varies depending on what HW checker is used for each memory and how many regions that specific checker supports. For example, most i.MX8 SoC have a limit of 16 regions for the DDR address range. Of these 16, one is used by the SCFW to define a I/O space pass through so the effective limit for SCFW API use is 15 unique DDR regions. Also, the SCFW will optimize usage of the HW regions. For example, if two regions are coincident, it will only use one HW region to enforce the access policy. These totals are for the entire system.

### 4.5 SCFW API

CPUs in partitions make SCFW API calls via a remote procedure call (RPC) mechanism. The RPC mechanism serializes the call and sends it over an inter-processor communication (IPC) mechanism implemented via message units (MU). Message units are resources and since all resources are owned by a partition, the SCFW can identify the owner and hence determine the calling partition. The calling partition is often used to determine if an operation is allowed or not.

The SCFW has the following services that operate on partitions and resources:

- · Resource Management (RM) used to manage partitions, resources, pads, memory regions
- · Power Management (PM) used to boot, reboot, and change power state of partitions and resources
- · Timer used to configure and use partitions-specific watchdogs and alarms
- Interrupt (IRQ) used to manage interrupts sent to partitions via their MUs

The other services (pad, miscellaneous, and security) do not operate on partitions or resources. The Resource Management (RM) API is documented here.

Note there are eight MUs (five in LSIO, one in each M4, and one in the SCU itself) that are used to communicate to the SCFW). This is because one end of each of these is accessible only via a private bus used by the SCU.

- SC R MU 0A-4A (A side used by CPUs, B-side used by SCU)
- SC\_R\_M4\_0\_MU\_1A (A side used by CPU, B-side used by SCU)
- SC R M4 1 MU 1A (A side used by CPU, B-side used by SCU)
- SC\_R\_SC\_MU\_1A in the SCU (both sides used by SCU for loopback testing)

The SCFW does not dictate which CPU uses each of these. Access is controlled by the standard SCFW RM partitioning. SCFW has to power at least one up for each CPU and these are specified in the boot container. The default in mkimage is the M4 MU for each M4 and MU 0A for the AP.

Beyond this, all usage is determined by the board.c port and the AP/M4 SW. Access to MUs is controlled by the SCFW RM partitioning which is configured in board.c and at run-time by the SW themselves. Typical usage is MU\_0A is kept and used by the AP secure code and MU\_1A is used by the AP non-secure code. Using AP clusters to run separate OSes or using a hypervisor would require additional usage of these MUs.

# 4.6 Hardware Resource/Memory Isolation

The i.MX8 SoC contains a mix of Cortex-A and Cortex-M CPUs which frequently operate in an asymmetric mode with different software environments executing on them (OSes, RTOSes, etc.). To keep these SW environments from unintentionally interfering with each other, i.MX8 contains HW mechanisms to enforce isolation. These mechanisms operate in a manner similar to ARM's TrustZone in that transactions from masters are annotated with user-side band information to indicate their domain and the access controls allow/disallow access to peripherals/memory based on this information.

The HW that does this is the XRDC2 (aka XRDC). The XRDC consists of a manager (per subsystem), MDAC, PAC, MSC, and MRC components. The MDAC is used to annotate the transactions and the PAC, MSC, and MRC are used to control access. See the figure below for the basic XRDC integration architecture. In i.MX8, the XRDC replaces the RDC and TrustZone components (CSU, TZASC, etc.) found in previous i.MX processors.



Figure 4.1 XRDC Interaction for Bus Transactions

There are five XRDC components:

- Manager (MGR) provides the programming interface for the entire XRDC
- Master Domain Assignment Controller (MDAC) identifies transaction sources/types and appends information such as domain ID (DID), streamID (SID), etc.
- Peripheral Access Controller (PAC) accepts/rejects transactions based on transaction attributes and programmed permissions; supports up to 128 different peripherals (IPS or APB based); based on module enables and/or select signals so has no concept of addressing
- Memory Space Controller (MSC) accepts/rejects transactions based on transaction attributes and programmed permissions; supports a single memory space; has no concept of addressing
- Memory Region Controller (MRC) accepts/rejects transactions based on transaction attributes and programmed permissions; supports multiple memory spaces by allowing the overall space to be divided into regions (with programmable start/end addresses)

16 Resource Management

The SCFW configures the XRDC2 components based on partition, resource, and memory region configuration. For more information on the XRDC capabilities, refer to the XRDC2 section of the RM.

# 4.7 Example

The following shows the partition creation for an example system. Initially, the SCFW creates three partitions. The SCFW and SECO partitions are secure and isolated. The boot partition parameters depend on the boot flags from the boot image container. These would also normally be secure and isolated. The boot partition contains all the memory and almost all the resources. Only the minimal resources required for the SCFW and SECO to function are owned by those partitions.



Figure 4.2 Initial Partition Configuration

Before starting the CPUs, the SCFW calls board\_system\_config(). This is where the partitions are created for CPUs started by the SCFW. These partitions usually have code loaded by the ROM and execution automatically started by the SCFW. Partitions can also be created for CPUs that aren't started immediately by the SCFW. Code can be loaded for these partitions by the ROM at boot by defining them as data images with mkimage. Code could also be loaded by the parent so long as it has access rights to the memory. The parent can then boot such a partition later by calling sc pm\_boot(). An M4 partition would normally be non-secure.

4.7 Example 17



Figure 4.3 Board Partition Configuration

The boot partition can also be considered the ATF partition because that is the first thing run on the AP core. ATF creates a partition for Linux to use. This partition would typically be non-secure and not isolated. The Cortex-A CPUs, MU0A, the SC\_R\_SYSTEM resource, and a little bit of memory are kept by the ATF partition. All other resources are assigned to the Linux partition.



Figure 4.4 Final Partition Configuration

ATF starts Linux. Linux could dynamically create an additional partition for the other M4 to handle something like sensor fusion or a media processing engine.

| Resource Ma | anagement |
|-------------|-----------|
|-------------|-----------|

# **Power Management**

SCFW is responsible for managing the power state of the SoC. This includes static and dynamic power management, clock management, and reset control. The features supported by the SCFW are:

- · Changing the power state of the system, partitions, and resources.
- · Configuring clocks and PLLs.
- · Configuring and responding to wake-up sources.
- · Reset control including booting/rebooting a partition, obtaining reset reasons, and starting/stopping of CPUs.

See the Overview. The Power Management (PM) API is documented here.

### 5.1 Wake from Low Power

#### 5.1.1 Wake Event Sources

The SoC RM provides some background on the wakeup capability of the IRQSTEER and GIC modules. The wakeup outputs of the IRQSTEER and GIC are connected to IRQ lines of the SCU and fielded by SCFW to wake up the respective CPU for wake event processing. The SCFW Interrupt Service can also generate wakeup events that do not require the GIC or IRQSTEER to remain active. Each of these wake events sources are described in the sections below. Note the tradeoff between flexibility of the wakeup method and power consumption that must considered during system design.

#### 5.1.2 GIC Wake Events

The GIC module provides a facility to transition each redistributor interface into a sleep state with wakeup capability. AP software uses the GICR\_WAKER register to quiesce the respective redistributor interface. Prior to executing WFI, AP software notifies SCFW of the request to enter a deeper low-power mode using sc\_pm\_req\_cpu\_low\_power\_mode(). Note that the GIC must be powered and clocked to generate a wake event. The following table shows the GIC wakeup options available:

20 Power Management

| sc_pm_req_cpu_low_power_← mode wake src parameter | Wakeup Description                                    | Notes                                                                                                                                                                                                                    |
|---------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SC_PM_SRC_GIC                                     | GIC wakeup will cause SCFW to wake the respective CPU | GIC resource must remain powered and clocked (power mode >= LP). System power consumption will be higher to keep respective subsystem with GIC powered and clocked. K← S1 power mode is inhibited with this wake method. |
| SC_PM_WAKE_SRC_IRQSTEE↔<br>R_GIC                  | Refer to IRQSTEER wake events in the next section     |                                                                                                                                                                                                                          |

#### 5.1.3 IRQSTEER Wake Events

One of the IRQSTEER module instances (SC\_R\_IRQSTR\_SCU2) is reserved for AP wake events. The IRQST—EER does not require clocks to generate a wakeup event and therefore offers lower power consumption than GIC wakeup methods. Prior to executing WFI, AP software notifies SCFW of the request to enter a deeper low-power mode using sc\_pm\_req\_cpu\_low\_power\_mode(). Note that the IRQSTEER must be powered to generate a wake event. The following table shows the IRQSTEER wakeup options available:

| sc_pm_req_cpu_low_power_←     | Wakeup Description                                                        | Notes                                                                                                                                                                                                                                                                                                               |
|-------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mode                          |                                                                           |                                                                                                                                                                                                                                                                                                                     |
| wake_src parameter            | O at a second constitute first at a second constitute                     | OIO LIDOOTEED                                                                                                                                                                                                                                                                                                       |
| SC_PM_WAKE_SRC_IRQSTEE↔ R_GIC | 2-stage wakeup with first stage being IRQSTEER and second stage being GIC | GIC and IRQSTEER resources must remain powered (power mode >= STBY). AP software must "replicate" the desired wake sources from the GIC to the IRQSTEER. System power consumption will be higher to keep respective subsystem with G← IC and IRQSTEER powered. K← S1 power mode is inhibited with this wake method. |
| SC_PM_WAKE_SRC_IRQSTEER       | IRQSTEER wakeup will cause SC← FW to wake the "primary" CPU               | IRQSTEER resource must remain powered (power mode >= STBY). System power consumption will be higher to keep respective subsystem with IRQSTEER powered. K← S1 power mode is inhibited with this wake method. Primary CPU designated using sc_pm_set_cpu← _resume.                                                   |

#### 5.1.4 SCU Wake Events

SCU wake events allow the entire system to be placed into retention/powered down. These wake sources are enabled using the SCFW IRQ service API (sc\_irq\_enable). Prior to executing WFI, AP software notifies SCFW of the request to enter a deeper low-power mode using sc\_pm\_req\_cpu\_low\_power\_mode(). The following table shows the SCU wakeup options available:

5.2 System Power Off 21

| sc_pm_req_cpu_low_power_←<br>mode<br>wake_src parameter | Wakeup Description                         | Notes                                                                                             |
|---------------------------------------------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------|
| SC_PM_WAKE_SRC_SCU                                      | SCU wake event will wake the "primary" CPU | GIC and IRQSTEER resources can be powered down. KS1 power mode is possible with this wake method. |

A summary of SCU wake events supported by SCFW:

- RTC
- ON\_OFF button
- Pad event
- · System Counter

### 5.1.5 Pad Wake Events

The pad modules provide a programmable wakeup capability. Software must enable and configure the respective pad to generate a wakeup using the SCFW IRQ Service API. The following is an example of the calls required to enable and service a pad wake events for the UART RX signal (note that SCFW API return error checking removed for simplicity).

```
/* Register for PAD wakeup *
sc_irq_enable(ipc, MU_RSRC, SC_IRQ_GROUP_WAKE, SC_IRQ_PAD, SC_TRUE);
/* Enable UART_RX pad wakeup */
sc_pad_set_wakeup(ipc, UART_RX_PAD, SC_PAD_WAKEUP_LOW_LVL);
/* Enter low-power mode and wait for wakeup... */
/* Query SCU wakeup event status */
uint32_t status;
sc_irq_status(ipc, MU_RSRC, SC_IRQ_GROUP_WAKE, &status);
/* Check for pad wakeup */
if (status & SC_IRQ_PAD)
    /* Check for UART_RX pad wakeup */
    /* Note: SCFW updates pending pad wakeup config to SC_PAD_WAKEUP_OFF */
    sc_pad_wakeup_t uart_wakeup;
    sc_pad_get_wakeup(ipc, UART_RX_PAD, &uart_wakeup);
    if (uart_wakeup == SC_PAD_WAKEUP_OFF)
        /* UART_RX pad generated wake event */
        /* Else some other pad caused the wake event */
        /* Disable the UART_RX pad wakeup */
        sc_pad_set_wakeup(ipc, UART_RX_PAD, SC_PAD_WAKEUP_OFF);
```

# 5.2 System Power Off

The system can be powered off by calling sc\_pm\_set\_sys\_power\_mode() with mode = SC\_PM\_PW\_MODE\_OFF. This calls board\_power() in board.c to allow for port specific control of the PMIC. Note only a caller with access to the SC\_R\_SYSTEM resource can call this function.

### 5.3 Reset Control

For more info on resets, see the Reset section. This includes booting and rebooting partitions, rebooting the system, starting/stopping CPUs, and watchdog usage.

22 **Power Management** 

## **Resource List**

The table below lists the resources available in the system (SoC specific). Resource is a parameter to many API calls.

The \*\_PIDx resources represent multiple contexts that the master can act as (aka process IDs). The master functions normally as PID0 but can switch to other PIDs if it needs to access the resources of another SW system. This is primarily used to support virtualization. Each master PID resource can be assigned a different SID and as a result a different translation contect in the SMMU. If not using virtualization, all PIDs for a resource should be assigned to the partition owning the master IP.

Note the resource define values (index) are listed here but the define should be used. These are defined in types.h. Functions like sc\_rm\_set\_resource\_movable() take a resource range. This range is numerical by index and not alphabetical by define name. Range should be lowest to highest index.

#### See also

RM: Resource Management Service PM: Power Management Service

| Resource         | Index | Subsystem | Instance | Description   |
|------------------|-------|-----------|----------|---------------|
| SC_R_A53         | 0     | A53       | 0        | Cluster       |
| SC_R_A53_0       | 1     | A53       | 0        | CPU 0         |
| SC_R_A53_1       | 2     | A53       | 0        | CPU 1         |
| SC_R_A53_2       | 3     | A53       | 0        | CPU 2         |
| SC_R_A53_3       | 4     | A53       | 0        | CPU 3         |
| SC_R_A72         | 5     | A72       | 0        | Cluster       |
| SC_R_A72_0       | 6     | A72       | 0        | CPU 0         |
| SC_R_A72_1       | 7     | A72       | 0        | CPU 1         |
| SC_R_ADC_0       | 101   | DMA       | 0        | ADC 0         |
| SC_R_ADC_1       | 102   | DMA       | 0        | ADC 1         |
| SC_R_AMIX        | 458   | AUDIO     | 0        | Audio mixer   |
| SC_R_ASRC_0      | 414   | AUDIO     | 0        | ASRC 0        |
| SC_R_ASRC_1      | 454   | AUDIO     | 0        | ASRC 1        |
| SC_R_ATTESTATION | 545   | SC        | 0        | Attestation   |
| SC_R_AUDIO_CLK_0 | 493   | AUDIO     | 0        | Audio clock 0 |
| SC_R_AUDIO_CLK_1 | 494   | AUDIO     | 0        | Audio clock 1 |

| Resource               | Index | Subsystem  | Instance | Description             |
|------------------------|-------|------------|----------|-------------------------|
| SC_R_AUDIO_PLL_0       | 325   | AUDIO      | 0        | Audio PLL 0             |
| SC_R_AUDIO_PLL_1       | 492   | AUDIO      | 0        | Audio PLL 1             |
| SC_R_BOARD_R0          | 524   | BOARD      | 0        | Misc. board component 0 |
| SC_R_BOARD_R1          | 525   | BOARD      | 0        | Misc. board component 1 |
| SC_R_BOARD_R2          | 526   | BOARD      | 0        | Misc. board component 2 |
| SC_R_BOARD_R3          | 527   | BOARD      | 0        | Misc. board component 3 |
| SC R BOARD R4          | 528   | BOARD      | 0        | Misc. board component 4 |
| SC R BOARD R5          | 529   | BOARD      | 0        | Misc. board component 5 |
| SC R BOARD R6          | 530   | BOARD      | 0        | Misc. board component 6 |
| SC R BOARD R7          | 531   | BOARD      | 0        | Misc. board component 7 |
| SC R CAAM JR1          | 500   | SC         | 0        | CAAM job ring 1         |
| SC R CAAM JR1 OUT      | 514   | SC         | 0        | CAAM job ring 1 out     |
| SC_R_CAAM_JR2          | 501   | SC         | 0        | CAAM job ring 2         |
| SC R CAAM JR2 OUT      | 515   | SC         | 0        | CAAM job ring 2 out     |
| SC_R_CAAM_JR3          | 502   | SC         | 0        | CAAM job ring 3         |
| SC R CAAM JR3 OUT      | 516   | SC         | 0        | CAAM job ring 3 out     |
|                        |       |            |          |                         |
| SC_R_CAN_0             | 105   | DMA        | 0        | CAN 0<br>CAN 1          |
| SC_R_CAN_1             | 106   | DMA        | 0        |                         |
| SC_R_CAN_2             | 107   | DMA<br>CCI | 0        | CAN 2<br>CCI            |
| SC_R_CCI<br>SC R CSI 0 | 401   | CSI        | 0        | CSI                     |
| SC R CSI 0 I2C 0       | 403   | CSI        | 0        | I2C                     |
| SC R CSI 0 PWM 0       | 403   | CSI        | 0        | PWM                     |
| SC R CSI 1             | 404   | CSI        | 1        | CSI                     |
| SC_R_CSI_1_I2C_0       | 406   | CSI        | 1        | 12C                     |
| SC R CSI 1 PWM 0       | 405   | CSI        | 1        | PWM                     |
| SC R DB                | 11    | DB         | 0        | DB                      |
| SC_R_DBLOGIC           | 522   | DBLOGIC    | 0        | DBLOGIC                 |
| SC R DC 0              | 32    | DC         | 0        | DC                      |
| SC_R_DC_0_BLIT0        | 19    | DC         | 0        | BLIT0                   |
| SC_R_DC_0_BLIT1        | 20    | DC         | 0        | BLIT1                   |
| SC R DC 0 BLIT2        | 21    | DC         | 0        | BLIT2                   |
| SC_R_DC_0_BLIT_OUT     | 22    | DC         | 0        | BLIT OUT                |
| SC R DC 0 FRAC0        | 30    | DC         | 0        | FRAC0                   |
| SC_R_DC_0_PLL_0        | 34    | DC         | 0        | PLL 0                   |
| SC_R_DC_0_PLL_1        | 35    | DC         | 0        | PLL 1                   |
| SC_R_DC_0_VIDEO0       | 28    | DC         | 0        | VIDEO0                  |
| SC_R_DC_0_VIDEO1       | 29    | DC         | 0        | VIDEO1                  |
| SC_R_DC_0_WARP         | 25    | DC         | 0        | WARP                    |
| SC_R_DC_1              | 49    | DC         | 1        | DC                      |
| SC_R_DC_1_BLIT0        | 36    | DC         | 1        | BLIT0                   |
| SC_R_DC_1_BLIT1        | 37    | DC         | 1        | BLIT1                   |
| SC_R_DC_1_BLIT2        | 38    | DC         | 1        | BLIT2                   |
| SC_R_DC_1_BLIT_OUT     | 39    | DC         | 1        | BLIT OUT                |
| SC_R_DC_1_FRAC0        | 47    | DC         | 1        | FRAC0                   |
| SC_R_DC_1_PLL_0        | 51    | DC         | 1        | PLL 0                   |
| SC_R_DC_1_PLL_1        | 52    | DC         | 1        | PLL 1                   |

| Resource         | Index | Subsystem | Instance | Description      |
|------------------|-------|-----------|----------|------------------|
| SC_R_DC_1_VIDEO0 | 45    | DC        | 1        | VIDEO0           |
| SC_R_DC_1_VIDEO1 | 46    | DC        | 1        | VIDEO1           |
| SC_R_DC_1_WARP   | 42    | DC        | 1        | WARP             |
| SC_R_DEBUG       | 354   | SC        | 0        | Debug            |
| SC R DMA 0 CH0   | 64    | DMA       | 0        | DMA 0 channel 0  |
| SC R DMA 0 CH1   | 65    | DMA       | 0        | DMA 0 channel 1  |
| SC_R_DMA_0_CH10  | 74    | DMA       | 0        | DMA 0 channel 10 |
| SC R DMA 0 CH11  | 75    | DMA       | 0        | DMA 0 channel 11 |
| SC R DMA 0 CH12  | 76    | DMA       | 0        | DMA 0 channel 12 |
| SC R DMA 0 CH13  | 77    | DMA       | 0        | DMA 0 channel 13 |
| SC R DMA 0 CH14  | 78    | DMA       | 0        | DMA 0 channel 14 |
| SC R DMA 0 CH15  | 79    | DMA       | 0        | DMA 0 channel 15 |
| SC R DMA 0 CH16  | 80    | DMA       | 0        | DMA 0 channel 16 |
| SC_R_DMA_0_CH17  | 81    | DMA       | 0        | DMA 0 channel 17 |
| SC_R_DMA_0_CH18  | 82    | DMA       | 0        | DMA 0 channel 18 |
| SC R DMA 0 CH19  | 83    | DMA       | 0        | DMA 0 channel 19 |
| SC R DMA 0 CH2   | 66    | DMA       | 0        | DMA 0 channel 2  |
| SC R DMA 0 CH20  | 84    | DMA       | 0        | DMA 0 channel 20 |
| SC R DMA 0 CH21  | 85    | DMA       | 0        | DMA 0 channel 21 |
| SC R DMA 0 CH22  | 86    | DMA       | 0        | DMA 0 channel 22 |
| SC R DMA 0 CH23  | 87    | DMA       | 0        | DMA 0 channel 23 |
| SC R DMA 0 CH24  | 88    | DMA       | 0        | DMA 0 channel 24 |
| SC_R_DMA_0_CH25  | 89    | DMA       | 0        | DMA 0 channel 25 |
| SC_R_DMA_0_CH26  | 90    | DMA       | 0        | DMA 0 channel 26 |
| SC R DMA 0 CH27  | 91    | DMA       | 0        | DMA 0 channel 27 |
| SC_R_DMA_0_CH28  | 92    | DMA       | 0        | DMA 0 channel 28 |
| SC R DMA 0 CH29  | 93    | DMA       | 0        | DMA 0 channel 29 |
| SC R DMA 0 CH3   | 67    | DMA       | 0        | DMA 0 channel 3  |
| SC R DMA 0 CH30  | 94    | DMA       | 0        | DMA 0 channel 30 |
| SC R DMA 0 CH31  | 95    | DMA       | 0        | DMA 0 channel 31 |
| SC_R_DMA_0_CH4   | 68    | DMA       | 0        | DMA 0 channel 4  |
| SC_R_DMA_0_CH5   | 69    | DMA       | 0        | DMA 0 channel 5  |
| SC_R_DMA_0_CH6   | 70    | DMA       | 0        | DMA 0 channel 6  |
| SC_R_DMA_0_CH7   | 71    | DMA       | 0        | DMA 0 channel 7  |
| SC_R_DMA_0_CH8   | 72    | DMA       | 0        | DMA 0 channel 8  |
| SC_R_DMA_0_CH9   | 73    | DMA       | 0        | DMA 0 channel 9  |
| SC_R_DMA_1_CH0   | 108   | DMA       | 0        | DMA 1 channel 0  |
| SC_R_DMA_1_CH1   | 109   | DMA       | 0        | DMA 1 channel 1  |
| SC_R_DMA_1_CH10  | 118   | DMA       | 0        | DMA 1 channel 10 |
| SC_R_DMA_1_CH11  | 119   | DMA       | 0        | DMA 1 channel 11 |
| SC_R_DMA_1_CH12  | 120   | DMA       | 0        | DMA 1 channel 12 |
| SC_R_DMA_1_CH13  | 121   | DMA       | 0        | DMA 1 channel 13 |
| SC_R_DMA_1_CH14  | 122   | DMA       | 0        | DMA 1 channel 14 |
| SC_R_DMA_1_CH15  | 123   | DMA       | 0        | DMA 1 channel 15 |
| SC_R_DMA_1_CH16  | 124   | DMA       | 0        | DMA 1 channel 16 |
| SC_R_DMA_1_CH17  | 125   | DMA       | 0        | DMA 1 channel 17 |
| SC_R_DMA_1_CH18  | 126   | DMA       | 0        | DMA 1 channel 18 |

| Resource        | Index | Subsystem | Instance | Description      |
|-----------------|-------|-----------|----------|------------------|
| SC_R_DMA_1_CH19 | 127   | DMA       | 0        | DMA 1 channel 19 |
| SC_R_DMA_1_CH2  | 110   | DMA       | 0        | DMA 1 channel 2  |
| SC_R_DMA_1_CH20 | 128   | DMA       | 0        | DMA 1 channel 20 |
| SC_R_DMA_1_CH21 | 129   | DMA       | 0        | DMA 1 channel 21 |
| SC_R_DMA_1_CH22 | 130   | DMA       | 0        | DMA 1 channel 22 |
| SC_R_DMA_1_CH23 | 131   | DMA       | 0        | DMA 1 channel 23 |
| SC_R_DMA_1_CH24 | 132   | DMA       | 0        | DMA 1 channel 24 |
| SC_R_DMA_1_CH25 | 133   | DMA       | 0        | DMA 1 channel 25 |
| SC_R_DMA_1_CH26 | 134   | DMA       | 0        | DMA 1 channel 26 |
| SC_R_DMA_1_CH27 | 135   | DMA       | 0        | DMA 1 channel 27 |
| SC_R_DMA_1_CH28 | 136   | DMA       | 0        | DMA 1 channel 28 |
| SC_R_DMA_1_CH29 | 137   | DMA       | 0        | DMA 1 channel 29 |
| SC_R_DMA_1_CH3  | 111   | DMA       | 0        | DMA 1 channel 3  |
| SC_R_DMA_1_CH30 | 138   | DMA       | 0        | DMA 1 channel 30 |
| SC_R_DMA_1_CH31 | 139   | DMA       | 0        | DMA 1 channel 31 |
| SC_R_DMA_1_CH4  | 112   | DMA       | 0        | DMA 1 channel 4  |
| SC_R_DMA_1_CH5  | 113   | DMA       | 0        | DMA 1 channel 5  |
| SC_R_DMA_1_CH6  | 114   | DMA       | 0        | DMA 1 channel 6  |
| SC_R_DMA_1_CH7  | 115   | DMA       | 0        | DMA 1 channel 7  |
| SC_R_DMA_1_CH8  | 116   | DMA       | 0        | DMA 1 channel 8  |
| SC_R_DMA_1_CH9  | 117   | DMA       | 0        | DMA 1 channel 9  |
| SC_R_DMA_2_CH0  | 254   | AUDIO     | 0        | DMA 0 channel 0  |
| SC_R_DMA_2_CH1  | 255   | AUDIO     | 0        | DMA 0 channel 1  |
| SC_R_DMA_2_CH10 | 432   | AUDIO     | 0        | DMA 0 channel 10 |
| SC_R_DMA_2_CH11 | 433   | AUDIO     | 0        | DMA 0 channel 11 |
| SC_R_DMA_2_CH12 | 434   | AUDIO     | 0        | DMA 0 channel 12 |
| SC_R_DMA_2_CH13 | 435   | AUDIO     | 0        | DMA 0 channel 13 |
| SC_R_DMA_2_CH14 | 436   | AUDIO     | 0        | DMA 0 channel 14 |
| SC_R_DMA_2_CH15 | 437   | AUDIO     | 0        | DMA 0 channel 15 |
| SC_R_DMA_2_CH16 | 438   | AUDIO     | 0        | DMA 0 channel 16 |
| SC_R_DMA_2_CH17 | 439   | AUDIO     | 0        | DMA 0 channel 17 |
| SC_R_DMA_2_CH18 | 440   | AUDIO     | 0        | DMA 0 channel 18 |
| SC_R_DMA_2_CH19 | 441   | AUDIO     | 0        | DMA 0 channel 19 |
| SC_R_DMA_2_CH2  | 256   | AUDIO     | 0        | DMA 0 channel 2  |
| SC_R_DMA_2_CH20 | 442   | AUDIO     | 0        | DMA 0 channel 20 |
| SC_R_DMA_2_CH21 | 443   | AUDIO     | 0        | DMA 0 channel 21 |
| SC_R_DMA_2_CH22 | 444   | AUDIO     | 0        | DMA 0 channel 22 |
| SC_R_DMA_2_CH23 | 445   | AUDIO     | 0        | DMA 0 channel 23 |
| SC_R_DMA_2_CH24 | 446   | AUDIO     | 0        | DMA 0 channel 24 |
| SC_R_DMA_2_CH25 | 447   | AUDIO     | 0        | DMA 0 channel 25 |
| SC_R_DMA_2_CH26 | 448   | AUDIO     | 0        | DMA 0 channel 26 |
| SC_R_DMA_2_CH27 | 449   | AUDIO     | 0        | DMA 0 channel 27 |
| SC_R_DMA_2_CH28 | 450   | AUDIO     | 0        | DMA 0 channel 28 |
| SC_R_DMA_2_CH29 | 451   | AUDIO     | 0        | DMA 0 channel 29 |
| SC_R_DMA_2_CH3  | 257   | AUDIO     | 0        | DMA 0 channel 3  |
| SC_R_DMA_2_CH30 | 452   | AUDIO     | 0        | DMA 0 channel 30 |
| SC_R_DMA_2_CH31 | 453   | AUDIO     | 0        | DMA 0 channel 31 |

| Resource        | Index | Subsystem | Instance | Description        |
|-----------------|-------|-----------|----------|--------------------|
| SC_R_DMA_2_CH4  | 258   | AUDIO     | 0        | DMA 0 channel 4    |
| SC R DMA 2 CH5  | 427   | AUDIO     | 0        | DMA 0 channel 5    |
| SC_R_DMA_2_CH6  | 428   | AUDIO     | 0        | DMA 0 channel 6    |
| SC R DMA 2 CH7  | 429   | AUDIO     | 0        | DMA 0 channel 7    |
| SC R DMA 2 CH8  | 430   | AUDIO     | 0        | DMA 0 channel 8    |
| SC_R_DMA_2_CH9  | 431   | AUDIO     | 0        | DMA 0 channel 9    |
| SC_R_DMA_3_CH0  | 460   | AUDIO     | 0        | DMA 1 channel 0    |
| SC_R_DMA_3_CH1  | 461   | AUDIO     | 0        | DMA 1 channel 1    |
| SC R DMA 3 CH10 | 470   | AUDIO     | 0        | DMA 1 channel 10   |
| SC R DMA 3 CH11 | 471   | AUDIO     | 0        | DMA 1 channel 11   |
| SC R DMA 3 CH12 | 472   | AUDIO     | 0        | DMA 1 channel 12   |
| SC_R_DMA_3_CH13 | 473   | AUDIO     | 0        | DMA 1 channel 13   |
| SC R DMA 3 CH14 | 474   | AUDIO     | 0        | DMA 1 channel 14   |
| SC R DMA 3 CH15 | 475   | AUDIO     | 0        | DMA 1 channel 15   |
| SC R DMA 3 CH16 | 476   | AUDIO     | 0        | DMA 1 channel 16   |
| SC R DMA 3 CH17 | 477   | AUDIO     | 0        | DMA 1 channel 17   |
| SC_R_DMA_3_CH18 | 478   | AUDIO     | 0        | DMA 1 channel 18   |
| SC_R_DMA_3_CH19 | 479   | AUDIO     | 0        | DMA 1 channel 19   |
| SC R DMA 3 CH2  | 462   | AUDIO     | 0        | DMA 1 channel 2    |
| SC_R_DMA_3_CH20 | 480   | AUDIO     | 0        | DMA 1 channel 20   |
| SC_R_DMA_3_CH21 | 481   | AUDIO     | 0        | DMA 1 channel 21   |
| SC_R_DMA_3_CH22 | 482   | AUDIO     | 0        | DMA 1 channel 22   |
| SC R DMA 3 CH23 | 483   | AUDIO     | 0        | DMA 1 channel 23   |
| SC_R_DMA_3_CH24 | 484   | AUDIO     | 0        | DMA 1 channel 24   |
| SC_R_DMA_3_CH25 | 485   | AUDIO     | 0        | DMA 1 channel 25   |
| SC_R_DMA_3_CH26 | 486   | AUDIO     | 0        | DMA 1 channel 26   |
| SC_R_DMA_3_CH27 | 487   | AUDIO     | 0        | DMA 1 channel 27   |
| SC_R_DMA_3_CH28 | 488   | AUDIO     | 0        | DMA 1 channel 28   |
| SC_R_DMA_3_CH29 | 489   | AUDIO     | 0        | DMA 1 channel 29   |
| SC_R_DMA_3_CH3  | 463   | AUDIO     | 0        | DMA 1 channel 3    |
| SC_R_DMA_3_CH30 | 490   | AUDIO     | 0        | DMA 1 channel 30   |
| SC_R_DMA_3_CH31 | 491   | AUDIO     | 0        | DMA 1 channel 31   |
| SC_R_DMA_3_CH4  | 464   | AUDIO     | 0        | DMA 1 channel 4    |
| SC_R_DMA_3_CH5  | 465   | AUDIO     | 0        | DMA 1 channel 5    |
| SC_R_DMA_3_CH6  | 466   | AUDIO     | 0        | DMA 1 channel 6    |
| SC_R_DMA_3_CH7  | 467   | AUDIO     | 0        | DMA 1 channel 7    |
| SC_R_DMA_3_CH8  | 468   | AUDIO     | 0        | DMA 1 channel 8    |
| SC_R_DMA_3_CH9  | 469   | AUDIO     | 0        | DMA 1 channel 9    |
| SC_R_DMA_4_CH0  | 372   | CONN      | 0        | DMA channel 0      |
| SC_R_DMA_4_CH1  | 373   | CONN      | 0        | DMA channel 1      |
| SC_R_DMA_4_CH2  | 374   | CONN      | 0        | DMA channel 2      |
| SC_R_DMA_4_CH3  | 375   | CONN      | 0        | DMA channel 3      |
| SC_R_DMA_4_CH4  | 376   | CONN      | 0        | DMA channel 4      |
| SC_R_DRC_0      | 12    | DRC       | 0        | DDR controller/phy |
| SC_R_DRC_1      | 13    | DRC       | 1        | DDR controller/phy |
| SC_R_DSP        | 512   | VPU       | 0        | DSP                |
| SC_R_DSP_RAM    | 513   | VPU       | 0        | DSP RAM            |

| Resource            | Index | Subsystem | Instance | Description                                   |
|---------------------|-------|-----------|----------|-----------------------------------------------|
| SC_R_DTCP           | 264   | CONN      | 0        | DTCP                                          |
| SC_R_EMVSIM_0       | 62    | DMA       | 0        | EMVSIM 0                                      |
| SC_R_EMVSIM_1       | 63    | DMA       | 0        | EMVSIM 1                                      |
| SC_R_ENET_0         | 251   | CONN      | 0        | ENET 1                                        |
| SC_R_ENET_1         | 252   | CONN      | 0        | ENET 2                                        |
| SC_R_ESAI_0         | 415   | AUDIO     | 0        | ESAI 0                                        |
| SC_R_ESAI_1         | 455   | AUDIO     | 0        | ESAI 1                                        |
| SC_R_FSPI_0         | 237   | LSIO      | 0        | Flexible Serial Peripheral Interface (FSPI) 0 |
| SC R FSPI 1         | 238   | LSIO      | 0        | FSPI 1                                        |
| SC R FTM 0          | 103   | DMA       | 0        | FTM 0                                         |
| SC R FTM 1          | 104   | DMA       | 0        | FTM 1                                         |
| SC_R_GIC            | 18    | DBLOGIC   | 0        | GIC                                           |
| SC_R_GIC_SMMU       | 14    | DBLOGIC   | 0        | GIC & SMMU                                    |
| SC_R_GPIO_0         | 199   | LSIO      | 0        | General Purpose I/O (GPIO) 0                  |
| SC R GPIO 1         | 200   | LSIO      | 0        | GPIO 1                                        |
| SC R GPIO 2         | 201   | LSIO      | 0        | GPIO 2                                        |
| SC R GPIO 3         | 202   | LSIO      | 0        | GPIO 3                                        |
| SC R GPIO 4         | 203   | LSIO      | 0        | GPIO 4                                        |
| SC_R_GPIO_5         | 204   | LSIO      | 0        | GPIO 5                                        |
| SC R GPIO 6         | 205   | LSIO      | 0        | GPIO 6                                        |
| SC_R_GPIO_7         | 206   | LSIO      | 0        | GPIO 7                                        |
| SC_R_GPT_0          | 207   | LSIO      | 0        | General Purpose Timer (GPT) 0                 |
| SC_R_GPT_1          | 208   | LSIO      | 0        | GPT 1                                         |
| SC R GPT 10         | 426   | AUDIO     | 0        | GPT 5                                         |
| SC R GPT 2          | 209   | LSIO      | 0        | GPT 2                                         |
| SC_R_GPT_3          | 210   | LSIO      | 0        | GPT 3                                         |
| SC R GPT 4          | 211   | LSIO      | 0        | GPT 4                                         |
| SC_R_GPT_5          | 421   | AUDIO     | 0        | GPT 0                                         |
| SC R GPT 6          | 422   | AUDIO     | 0        | GPT 1                                         |
| SC R GPT 7          | 423   | AUDIO     | 0        | GPT 2                                         |
| SC_R_GPT_8          | 424   | AUDIO     | 0        | GPT 3                                         |
| SC_R_GPT_9          | 425   | AUDIO     | 0        | GPT 4                                         |
| SC_R_GPU_0_PID0     | 144   | GPU       | 0        | PID0                                          |
| SC_R_GPU_0_PID1     | 145   | GPU       | 0        | PID1                                          |
| SC_R_GPU_0_PID2     | 146   | GPU       | 0        | PID2                                          |
| SC_R_GPU_0_PID3     | 147   | GPU       | 0        | PID3                                          |
| SC_R_GPU_1_PID0     | 148   | GPU       | 1        | PID0                                          |
| SC_R_GPU_1_PID1     | 149   | GPU       | 1        | PID1                                          |
| SC_R_GPU_1_PID2     | 150   | GPU       | 1        | PID2                                          |
| SC_R_GPU_1_PID3     | 151   | GPU       | 1        | PID3                                          |
| SC_R_HDMI           | 407   | HDMI      | 0        | HDMI                                          |
| SC_R_HDMI_I2C_0     | 409   | HDMI      | 0        | I2C                                           |
| SC_R_HDMI_I2S       | 408   | HDMI      | 0        | HDMI I2S                                      |
| SC_R_HDMI_PLL_0     | 410   | HDMI      | 0        | PLL 0                                         |
| SC_R_HDMI_PLL_1     | 523   | HDMI      | 0        | PLL 1                                         |
| SC_R_HDMI_RX        | 411   | HDMI_RX   | 0        | HDMI_RX                                       |
| SC_R_HDMI_RX_BYPASS | 412   | HDMI_RX   | 0        | HDMI RX Bypass                                |

| Resource           | Index | Subsystem | Instance | Description                    |
|--------------------|-------|-----------|----------|--------------------------------|
| SC_R_HDMI_RX_I2C_0 | 413   | HDMI_RX   | 0        | I2C                            |
| SC_R_HDMI_RX_PWM_0 | 506   | HDMI_RX   | 0        | PWM                            |
| SC_R_HSIO_GPIO     | 172   | HSIO      | 0        | GPIO/MISC                      |
| SC_R_I2C_0         | 96    | DMA       | 0        | I2C 0                          |
| SC_R_I2C_1         | 97    | DMA       | 0        | I2C 1                          |
| SC_R_I2C_2         | 98    | DMA       | 0        | I2C 2                          |
| SC_R_I2C_3         | 99    | DMA       | 0        | I2C 3                          |
| SC_R_I2C_4         | 100   | DMA       | 0        | I2C 4                          |
| SC_R_IEE           | 239   | LSIO      | 0        | Inline Encryption Engine (IEE) |
| SC_R_IEE_R0        | 240   | LSIO      | 0        | IEE region 0                   |
| SC_R_IEE_R1        | 241   | LSIO      | 0        | IEE region 1                   |
| SC_R_IEE_R2        | 242   | LSIO      | 0        | IEE region 2                   |
| SC R IEE R3        | 243   | LSIO      | 0        | IEE region 3                   |
| SC R IEE R4        | 244   | LSIO      | 0        | IEE region 4                   |
| SC R IEE R5        | 245   | LSIO      | 0        | IEE region 5                   |
| SC R IEE R6        | 246   | LSIO      | 0        | IEE region 6                   |
| SC R IEE R7        | 247   | LSIO      | 0        | IEE region 7                   |
| SC R IRQSTR DSP    | 322   | DBLOGIC   | 0        | IRQSTR DSP                     |
| SC R IRQSTR M4 0   | 15    | DBLOGIC   | 0        | IRQSTR M4 0                    |
| SC R IRQSTR M4 1   | 16    | DBLOGIC   | 0        | IRQSTR M4 1                    |
| SC_R_IRQSTR_SCU2   | 321   | DBLOGIC   | 0        | IRQSTR MI4 I                   |
| SC R ISI CH0       | 377   | IMG       | 0        | ISI channel 0                  |
| SC_R_ISI_CH1       | 378   | IMG       | 0        | ISI channel 1                  |
| SC R ISI CH2       | 379   | IMG       | 0        | ISI channel 2                  |
| SC R ISI CH3       | 380   | IMG       | 0        | ISI channel 3                  |
| SC_R_ISI_CH4       | 381   | IMG       | 0        | ISI channel 4                  |
| SC_R_ISI_CH5       | 382   | IMG       | 0        | ISI channel 5                  |
| SC_R_ISI_CH6       | 383   | IMG       | 0        | ISI channel 6                  |
| SC_R_ISI_CH7       | 384   | IMG       | 0        | ISI channel 7                  |
| SC_R_KPP           | 212   | LSIO      | 0        | Keypad Port (KPP)              |
| SC_R_LVDS_0        | 266   | LVDS      | 0        | LVDS                           |
| SC_R_LVDS_0_I2C_0  | 268   | LVDS      | 0        | I2C 0 & 1                      |
| SC_R_LVDS_0_PWM_0  | 267   | LVDS      | 0        | PWM                            |
| SC R LVDS 1        | 270   | LVDS      | 1        | LVDS                           |
| SC_R_LVDS_1_I2C_0  | 272   | LVDS      | 1        | I2C 0 & 1                      |
| SC_R_LVDS_1_PWM_0  | 271   | LVDS      | 1        | PWM                            |
| SC_R_M4_0_I2C      | 288   | M4        | 0        | I2C                            |
| SC_R_M4_0_INTMUX   | 289   | M4        | 0        | INTMUX                         |
| SC_R_M4_0_MU_0A0   | 293   | M4        | 0        | MU 0A0                         |
| SC_R_M4_0_MU_0A1   | 294   | M4        | 0        | MU 0A1                         |
| SC_R_M4_0_MU_0A2   | 295   | M4        | 0        | MU 0A2                         |
| SC_R_M4_0_MU_0A3   | 296   | M4        | 0        | MU 0A3                         |
| SC_R_M4_0_MU_0B    | 292   | M4        | 0        | MU 0B                          |
| SC_R_M4_0_MU_1A    | 297   | M4        | 0        | MU 1A                          |
| SC_R_M4_0_PID0     | 278   | M4        | 0        | PID0                           |
| SC_R_M4_0_PID1     | 279   | M4        | 0        | PID1                           |
| SC_R_M4_0_PID2     | 280   | M4        | 0        | PID2                           |

| Resource         | Index | Subsystem | Instance | Description |
|------------------|-------|-----------|----------|-------------|
| SC_R_M4_0_PID3   | 281   | M4        | 0        | PID3        |
| SC_R_M4_0_PID4   | 282   | M4        | 0        | PID4        |
| SC_R_M4_0_PIT    | 286   | M4        | 0        | PIT         |
| SC_R_M4_0_RGPIO  | 283   | M4        | 0        | RGPIO       |
| SC_R_M4_0_SEMA42 | 284   | M4        | 0        | SEMA42      |
| SC_R_M4_0_TPM    | 285   | M4        | 0        | TPM         |
| SC_R_M4_0_UART   | 287   | M4        | 0        | UART        |
| SC_R_M4_1_I2C    | 308   | M4        | 1        | I2C         |
| SC_R_M4_1_INTMUX | 309   | M4        | 1        | INTMUX      |
| SC_R_M4_1_MU_0A0 | 313   | M4        | 1        | MU 0A0      |
| SC_R_M4_1_MU_0A1 | 314   | M4        | 1        | MU 0A1      |
| SC_R_M4_1_MU_0A2 | 315   | M4        | 1        | MU 0A2      |
| SC_R_M4_1_MU_0A3 | 316   | M4        | 1        | MU 0A3      |
| SC_R_M4_1_MU_0B  | 312   | M4        | 1        | MU 0B       |
| SC_R_M4_1_MU_1A  | 317   | M4        | 1        | MU 1A       |
| SC_R_M4_1_PID0   | 298   | M4        | 1        | PID0        |
| SC_R_M4_1_PID1   | 299   | M4        | 1        | PID1        |
| SC_R_M4_1_PID2   | 300   | M4        | 1        | PID2        |
| SC_R_M4_1_PID3   | 301   | M4        | 1        | PID3        |
| SC_R_M4_1_PID4   | 302   | M4        | 1        | PID4        |
| SC_R_M4_1_PIT    | 306   | M4        | 1        | PIT         |
| SC_R_M4_1_RGPIO  | 303   | M4        | 1        | RGPIO       |
| SC_R_M4_1_SEMA42 | 304   | M4        | 1        | SEMA42      |
| SC_R_M4_1_TPM    | 305   | M4        | 1        | TPM         |
| SC_R_M4_1_UART   | 307   | M4        | 1        | UART        |
| SC_R_MATCH_0     | 154   | HSIO      | 0        | Match 0     |
| SC_R_MATCH_1     | 155   | HSIO      | 0        | Match 1     |
| SC_R_MATCH_10    | 164   | HSIO      | 0        | Match 10    |
| SC_R_MATCH_11    | 165   | HSIO      | 0        | Match 11    |
| SC_R_MATCH_12    | 166   | HSIO      | 0        | Match 12    |
| SC_R_MATCH_13    | 167   | HSIO      | 0        | Match 13    |
| SC_R_MATCH_14    | 168   | HSIO      | 0        | Match 14    |
| SC_R_MATCH_15    | 173   | HSIO      | 0        | Match 15    |
| SC_R_MATCH_16    | 174   | HSIO      | 0        | Match 16    |
| SC_R_MATCH_17    | 175   | HSIO      | 0        | Match 17    |
| SC_R_MATCH_18    | 176   | HSIO      | 0        | Match 18    |
| SC_R_MATCH_19    | 177   | HSIO      | 0        | Match 19    |
| SC_R_MATCH_2     | 156   | HSIO      | 0        | Match 2     |
| SC_R_MATCH_20    | 178   | HSIO      | 0        | Match 20    |
| SC_R_MATCH_21    | 179   | HSIO      | 0        | Match 21    |
| SC_R_MATCH_22    | 180   | HSIO      | 0        | Match 22    |
| SC_R_MATCH_23    | 181   | HSIO      | 0        | Match 23    |
| SC_R_MATCH_24    | 182   | HSIO      | 0        | Match 24    |
| SC_R_MATCH_25    | 183   | HSIO      | 0        | Match 25    |
| SC_R_MATCH_26    | 184   | HSIO      | 0        | Match 26    |
| SC_R_MATCH_27    | 185   | HSIO      | 0        | Match 27    |
| SC_R_MATCH_28    | 186   | HSIO      | 0        | Match 28    |

| Resource          | Index | Subsystem | Instance | Description            |
|-------------------|-------|-----------|----------|------------------------|
| SC_R_MATCH_3      | 157   | HSIO      | 0        | Match 3                |
| SC_R_MATCH_4      | 158   | HSIO      | 0        | Match 4                |
| SC R MATCH 5      | 159   | HSIO      | 0        | Match 5                |
| SC R MATCH 6      | 160   | HSIO      | 0        | Match 6                |
| SC R MATCH 7      | 161   | HSIO      | 0        | Match 7                |
| SC_R_MATCH_8      | 162   | HSIO      | 0        | Match 8                |
| SC_R_MATCH_9      | 163   | HSIO      | 0        | Match 9                |
| SC R MCLK OUT 0   | 495   | AUDIO     | 0        | MCLK out 0             |
| SC R MCLK OUT 1   | 496   | AUDIO     | 0        | MCLK out 1             |
| SC R MIPI 0       | 393   | MIPI      | 0        | MIPI                   |
| SC R MIPI 0 I2C 0 | 395   | MIPI      | 0        | I2C 0                  |
| SC R MIPI 0 I2C 1 | 396   | MIPI      | 0        | I2C 1                  |
| SC R MIPI 0 PWM 0 | 394   | MIPI      | 0        | PWM                    |
| SC R MIPI 1       | 397   | MIPI      | 1        | MIPI                   |
| SC R MIPI 1 I2C 0 | 399   | MIPI      | 1        | I2C 0                  |
| SC R MIPI 1 I2C 1 | 400   | MIPI      | 1        | I2C 1                  |
| SC R MIPI 1 PWM 0 | 398   | MIPI      | 1        | PWM                    |
| SC R MJPEG DEC MP | 532   | IMG       | 0        | MJPEG decoder MP       |
| SC R MJPEG DEC S0 | 385   | IMG       | 0        | MJPEG decoder stream 0 |
| SC R MJPEG DEC S1 | 386   | IMG       | 0        | MJPEG decoder stream 1 |
| SC R MJPEG DEC S2 | 387   | IMG       | 0        | MJPEG decoder stream 2 |
| SC R MJPEG DEC S3 | 388   | IMG       | 0        | MJPEG decoder stream 3 |
| SC R MJPEG ENC MP | 533   | IMG       | 0        | MJPEG encoder MP       |
| SC R MJPEG ENC S0 | 389   | IMG       | 0        | MJPEG encoder stream 0 |
| SC R MJPEG ENC S1 | 390   | IMG       | 0        | MJPEG encoder stream 1 |
| SC R MJPEG ENC S2 | 391   | IMG       | 0        | MJPEG encoder stream 2 |
| SC_R_MJPEG_ENC_S3 | 392   | IMG       | 0        | MJPEG encoder stream 3 |
| SC R MLB 0        | 253   | CONN      | 0        | MLB                    |
| SC_R_MQS_0        | 459   | AUDIO     | 0        | MQS                    |
| SC_R_MU_0A        | 213   | LSIO      | 0        | Message Unit (MU) 0A   |
| SC R MU 10A       | 223   | LSIO      | 0        | MU 10A                 |
| SC R MU 10B       | 232   | LSIO      | 0        | MU 10B                 |
| SC_R_MU_11A       | 224   | LSIO      | 0        | MU 11A                 |
| SC_R_MU_11B       | 233   | LSIO      | 0        | MU 11B                 |
| SC_R_MU_12A       | 225   | LSIO      | 0        | MU 12A                 |
| SC_R_MU_12B       | 234   | LSIO      | 0        | MU 12B                 |
| SC_R_MU_13A       | 226   | LSIO      | 0        | MU 13A                 |
| SC_R_MU_13B       | 235   | LSIO      | 0        | MU 13B                 |
| SC_R_MU_1A        | 214   | LSIO      | 0        | MU 1A                  |
| SC_R_MU_2A        | 215   | LSIO      | 0        | MU 2A                  |
| SC_R_MU_3A        | 216   | LSIO      | 0        | MU 3A                  |
| SC_R_MU_4A        | 217   | LSIO      | 0        | MU 4A                  |
| SC_R_MU_5A        | 218   | LSIO      | 0        | MU 5A                  |
| SC_R_MU_5B        | 227   | LSIO      | 0        | MU 5B                  |
| SC_R_MU_6A        | 219   | LSIO      | 0        | MU 6A                  |
| SC_R_MU_6B        | 228   | LSIO      | 0        | MU 6B                  |
| SC_R_MU_7A        | 220   | LSIO      | 0        | MU 7A                  |

| Resource       | Index | Subsystem | Instance | Description                   |
|----------------|-------|-----------|----------|-------------------------------|
| SC_R_MU_7B     | 229   | LSIO      | 0        | MU 7B                         |
| SC_R_MU_8A     | 221   | LSIO      | 0        | MU 8A                         |
| SC_R_MU_8B     | 230   | LSIO      | 0        | MU 8B                         |
| SC_R_MU_9A     | 222   | LSIO      | 0        | MU 9A                         |
| SC_R_MU_9B     | 231   | LSIO      | 0        | MU 9B                         |
| SC_R_NAND      | 265   | CONN      | 0        | NAND BCH/GPMI/DMA             |
| SC_R_OCRAM     | 324   | LSIO      | 0        | OCRAM                         |
| SC_R_OTP       | 357   | SC        | 0        | OTP                           |
| SC_R_PCIE_A    | 152   | HSIO      | 0        | PCIE A                        |
| SC_R_PCIE_B    | 169   | HSIO      | 0        | PCIE B                        |
| SC_R_PMIC_0    | 497   | BOARD     | 0        | PMIC 0                        |
| SC_R_PMIC_1    | 498   | BOARD     | 0        | PMIC 1                        |
| SC_R_PMIC_2    | 521   | BOARD     | 0        | PMIC 2                        |
| SC_R_PWM_0     | 191   | LSIO      | 0        | Pulse Width Modulator (PWM) 0 |
| SC_R_PWM_1     | 192   | LSIO      | 0        | PWM 1                         |
| SC_R_PWM_2     | 193   | LSIO      | 0        | PWM 2                         |
| SC_R_PWM_3     | 194   | LSIO      | 0        | PWM 3                         |
| SC_R_PWM_4     | 195   | LSIO      | 0        | PWM 4                         |
| SC_R_PWM_5     | 196   | LSIO      | 0        | PWM 5                         |
| SC_R_PWM_6     | 197   | LSIO      | 0        | PWM 6                         |
| SC_R_PWM_7     | 198   | LSIO      | 0        | PWM 7                         |
| SC_R_SAI_0     | 318   | AUDIO     | 0        | SAI 0                         |
| SC_R_SAI_1     | 319   | AUDIO     | 0        | SAI 1                         |
| SC_R_SAI_2     | 320   | AUDIO     | 0        | SAI 2                         |
| SC_R_SAI_3     | 418   | AUDIO     | 0        | SAI 3                         |
| SC_R_SAI_4     | 419   | AUDIO     | 0        | HDMI RX SAI                   |
| SC_R_SAI_5     | 420   | AUDIO     | 0        | HDMI TX SAI                   |
| SC_R_SAI_6     | 456   | AUDIO     | 0        | SAI_6                         |
| SC_R_SAI_7     | 457   | AUDIO     | 0        | SAI_7                         |
| SC_R_SATA_0    | 170   | HSIO      | 0        | SATA 0                        |
| SC_R_SC_I2C    | 345   | SC        | 0        | I2C                           |
| SC_R_SC_MU_0A0 | 347   | SC        | 0        | MU 0A0                        |
| SC_R_SC_MU_0A1 | 348   | SC        | 0        | MU 0A1                        |
| SC_R_SC_MU_0A2 | 349   | SC        | 0        | MU 0A2                        |
| SC_R_SC_MU_0A3 | 350   | SC        | 0        | MU 0A3                        |
| SC_R_SC_MU_0B  | 346   | SC        | 0        | MU 0B                         |
| SC_R_SC_MU_1A  | 351   | SC        | 0        | MU 1A                         |
| SC_R_SC_PID0   | 336   | SC        | 0        | PID0                          |
| SC_R_SC_PID1   | 337   | SC        | 0        | PID1                          |
| SC_R_SC_PID2   | 338   | SC        | 0        | PID2                          |
| SC_R_SC_PID3   | 339   | SC        | 0        | PID3                          |
| SC_R_SC_PID4   | 340   | SC        | 0        | PID4                          |
| SC_R_SC_PIT    | 343   | SC        | 0        | PIT                           |
| SC_R_SC_SEMA42 | 341   | SC        | 0        | SEMA42                        |
| SC_R_SC_TPM    | 342   | SC        | 0        | TPM                           |
| SC_R_SC_UART   | 344   | SC        | 0        | UART                          |
| SC_R_SDHC_0    | 248   | CONN      | 0        | uSDHC 1                       |

| Resource        | Index            | Subsystem | Instance | Description           |
|-----------------|------------------|-----------|----------|-----------------------|
| SC_R_SDHC_1     | 249              | CONN      | 0        | uSDHC 2               |
| SC_R_SDHC_2     | 250              | CONN      | 0        | uSDHC 3               |
| SC_R_SECO       | 499              | SC        | 0        | SECO                  |
| SC_R_SECO_MU_2  | 503              | SC        | 0        | SECO MU 2             |
| SC_R_SECO_MU_3  | 504              | SC        | 0        | SECO MU 3             |
| SC_R_SECO_MU_4  | 505              | SC        | 0        | SECO MU 4             |
| SC_R_SECVIO     | 44               | SC        | 0        | Security Violation    |
| SC_R_SERDES_0   | 153              | HSIO      | 0        | PHYx2                 |
| SC_R_SERDES_1   | 171              | HSIO      | 0        | PHYx1                 |
| SC_R_SMMU       | 17               | DBLOGIC   | 0        | SMMU                  |
| SC_R_SPDIF_0    | 416              | AUDIO     | 0        | SPDIF 0               |
| SC_R_SPDIF_1    | 417              | AUDIO     | 0        | SPDIF 1               |
| SC_R_SPI_0      | 53               | DMA       | 0        | SPI 0                 |
| SC_R_SPI_1      | 54               | DMA       | 0        | SPI 1                 |
| SC_R_SPI_2      | 55               | DMA       | 0        | SPI 2                 |
| SC_R_SPI_3      | 56               | DMA       | 0        | SPI 3                 |
| SC_R_SYSCNT_CMP | 353              | SC        | 0        | SYSCNT CMP            |
| SC_R_SYSCNT_RD  | 352              | SC        | 0        | SYSCNT RD             |
| SC_R_SYSTEM     | 355              | SC        | 0        | System                |
| SC R UART 0     | 57               | DMA       | 0        | UART 0                |
| SC_R_UART_1     | 58               | DMA       | 0        | UART 1                |
| SC R UART 2     | 59               | DMA       | 0        | UART 2                |
| SC R UART 3     | 60               | DMA       | 0        | UART 3                |
| SC_R_UART_4     | 61               | DMA       | 0        | UART 4                |
| SC_R_USB_0      | 259              | CONN      | 0        | USB2.0 OTG            |
| SC_R_USB_0_PHY  | 261              | CONN      | 0        | USB2.0 OTG phy        |
| SC R USB 1      | 260              | CONN      | 0        | USB2.0 HSIC           |
| SC R USB 2      | 262              | CONN      | 0        | USB3.0                |
| SC R USB 2 PHY  | 263              | CONN      | 0        | USB3.0 phy            |
| SC R VPU        | 540              | VPU       | 0        | VPU (XMEM peripheral) |
| SC R VPU DEC 0  | 517              | VPU       | 0        | Decoder               |
| SC R VPU ENC 0  | 518              | VPU       | 0        | Encoder 0             |
| SC R VPU ENC 1  | 539              | VPU       | 0        | Encoder 1             |
| SC R VPU MU 0   | 535              | VPU       | 0        | MU 0                  |
| SC R VPU MU 1   | 536              | VPU       | 0        | MU 1                  |
| SC R VPU MU 2   | 537              | VPU       | 0        | MU 2                  |
| SC_R_VPU_MU_3   | 538              | VPU       | 0        | MU3                   |
| SC R VPU PID0   | 358              | VPU       | 0        | XMEM master ID=0      |
| SC R VPU PID1   | 359              | VPU       | 0        | XMEM master ID=1      |
| SC R VPU PID2   | 360              | VPU       | 0        | XMEM master ID=2      |
| SC_R_VPU_PID3   | 361              | VPU       | 0        | XMEM master ID=3      |
| SC R VPU PID4   | 362              | VPU       | 0        | XMEM master ID=4      |
| SC R VPU PID5   | 363              | VPU       | 0        | XMEM master ID=5      |
| SC R VPU PID6   | 364              | VPU       | 0        | XMEM master ID=6      |
| SC R VPU PID7   | 365              | VPU       | 0        | XMEM master ID=7      |
| SC R VPU TS 0   | 534              | VPU       | 0        | XUVI                  |
| 00_11_41 0_10_0 | JU- <del>1</del> | V1 0      |          | 7.0 11                |

| 34 | Resource List |
|----|---------------|
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |
|    |               |

# **Clock List**

The table below lists the clocks/PLLs available in the system (SoC specific). Resource and Clock are parameters to several PM API calls. Set=Y indicates the clock/PLL is not shared and the rate can be set via sc\_pm\_set\_clock\_rate(). Enable=Y indicates the clock is not auto gated and must be enabled via sc\_pm\_clock\_enable().

### See also

### PM: Power Management Service

| Resource         | Clock           | Default Rate | Set | Enable | Description           |
|------------------|-----------------|--------------|-----|--------|-----------------------|
| SC_R_A53         | SC_PM_CLK_CPU   | 1200MHZ      | Υ   |        | CPU                   |
| SC_R_A72         | SC_PM_CLK_CPU   | 1600MHZ      | Υ   |        | CPU                   |
| SC_R_ADC_0       | SC_PM_CLK_PER   |              | Υ   | Υ      | ADC 0 peripheral      |
| SC_R_ADC_1       | SC_PM_CLK_PER   |              | Υ   | Υ      | ADC 1 peripheral      |
| SC_R_AUDIO_PLL_0 | SC_PM_CLK_MISC0 |              | Υ   | Υ      | Audio PLL div 0       |
| SC_R_AUDIO_PLL_0 | SC_PM_CLK_MISC1 |              | Υ   | Υ      | Audio rec 0           |
| SC_R_AUDIO_PLL_0 | SC_PM_CLK_PLL   |              | Υ   | Υ      | User programmable PLL |
| SC_R_AUDIO_PLL_1 | SC_PM_CLK_MISC0 |              | Υ   | Υ      | Audio PLL div 1       |
| SC_R_AUDIO_PLL_1 | SC_PM_CLK_MISC1 |              | Υ   | Υ      | Audio rec 1           |
| SC_R_AUDIO_PLL_1 | SC_PM_CLK_PLL   |              | Υ   | Υ      | User programmable PLL |
| SC_R_CAN_0       | SC_PM_CLK_PER   |              | Υ   | Υ      | CAN 0 peripheral      |
| SC_R_CAN_1       | SC_PM_CLK_PER   |              | Υ   | Υ      | CAN 1 peripheral      |
| SC_R_CAN_2       | SC_PM_CLK_PER   |              | Υ   | Υ      | CAN 2 peripheral      |
| SC_R_CSI_0       | SC_PM_CLK_MISC  |              | Υ   | Υ      | MIPI escape           |
| SC_R_CSI_0       | SC_PM_CLK_PER   |              | Υ   | Υ      | MIPI core             |
| SC_R_CSI_0_I2C_0 | SC_PM_CLK_PER   |              | Υ   | Υ      | I2C baud              |
| SC_R_CSI_0_PWM_0 | SC_PM_CLK_PER   |              | Υ   | Υ      | PWM high              |
| SC_R_CSI_1       | SC_PM_CLK_MISC  |              | Υ   | Υ      | MIPI escape           |
| SC_R_CSI_1       | SC_PM_CLK_PER   |              | Υ   | Υ      | MIPI core             |
| SC_R_CSI_1_I2C_0 | SC_PM_CLK_PER   |              | Υ   | Υ      | I2C baud              |
| SC_R_CSI_1_PWM_0 | SC_PM_CLK_PER   |              | Υ   | Υ      | PWM high              |
| SC_R_DC_0        | SC_PM_CLK_MISC0 |              | Υ   | Υ      | Display 0             |
| SC_R_DC_0        | SC_PM_CLK_MISC1 |              | Υ   | Υ      | Display 1             |

36 Clock List

| Resource            | Clock                              | Default Rate | Set      | Enable | Description                     |
|---------------------|------------------------------------|--------------|----------|--------|---------------------------------|
| SC_R_DC_0_PLL_0     | SC_PM_CLK_PLL                      |              | Υ        | Υ      | User programmable PLL           |
| SC_R_DC_0_PLL_1     | SC_PM_CLK_PLL                      |              | Υ        | Υ      | User programmable PLL           |
| SC_R_DC_0_VIDEO0    | SC_PM_CLK_MISC                     | 24MHZ        | Υ        | Υ      | Bypass 0                        |
| SC_R_DC_0_VIDEO1    | SC_PM_CLK_MISC                     | 24MHZ        | Υ        | Υ      | Bypass 1                        |
| SC_R_DC_1           | SC_PM_CLK_MISC0                    |              | Υ        | Υ      | Display 0                       |
| SC_R_DC_1           | SC_PM_CLK_MISC1                    |              | Υ        | Υ      | Display 1                       |
| SC_R_DC_1_PLL_0     | SC_PM_CLK_PLL                      |              | Υ        | Υ      | User programmable PLL           |
| SC_R_DC_1_PLL_1     | SC PM CLK PLL                      |              | Υ        | Υ      | User programmable PLL           |
| SC R DC 1 VIDEO0    | SC PM CLK MISC                     | 24MHZ        | Υ        | Υ      | Bypass 0                        |
| SC_R_DC_1_VIDEO1    | SC PM CLK MISC                     | 24MHZ        | Υ        | Υ      | Bypass 1                        |
| SC_R_DRC_0          | SC_PM_CLK_SLV_B↔<br>US             | 800MHZ       | Y        |        | DRC root                        |
| SC_R_DRC_1          | SC_PM_CLK_SLV_B↔<br>US             | 800MHZ       | Y        |        | DRC root                        |
| SC_R_EMVSIM_0       | SC_PM_CLK_PER                      |              | Υ        | Υ      | EMV_SIM 0 peripheral            |
| SC_R_EMVSIM_1       | SC_PM_CLK_PER                      |              | Υ        | Υ      | EMV_SIM 1 peripheral            |
| SC_R_ENET_0         | SC_PM_CLK_BYPASS                   | 24MHZ        | Υ        | Υ      | ENET 0 bypass                   |
| SC_R_ENET_0         | SC_PM_CLK_MISC0                    | 24MHZ        | Υ        | Y      | ENET 0 RXCLK/RGM↔<br>II_CLK     |
| SC_R_ENET_0         | SC_PM_CLK_PER                      | 125MHZ       | Υ        | Y      | ENET 0 PER_CLK/RE↔<br>F_CLK/CLK |
| SC_R_ENET_1         | SC_PM_CLK_BYPASS                   | 24MHZ        | Υ        | Υ      | ENET 1 bypass                   |
| SC_R_ENET_1         | SC_PM_CLK_MISC0                    | 24MHZ        | Υ        | Y      | ENET 1 RXCLK/RGM↔<br>II_CLK     |
| SC_R_ENET_1         | SC_PM_CLK_PER                      | 125MHZ       | Y        | Y      | ENET 1 PER_CLK/RE↔<br>F_CLK/CLK |
| SC_R_FSPI_0         | SC_PM_CLK_PER                      |              | Υ        | Υ      | FSPI 0 baud                     |
| SC_R_FSPI_1         | SC_PM_CLK_PER                      |              | Υ        | Υ      | FSPI 1 baud                     |
| SC_R_FTM_0          | SC_PM_CLK_PER                      |              | Υ        | Υ      | FTM 0 peripheral                |
| SC_R_FTM_1          | SC_PM_CLK_PER                      |              | Υ        | Υ      | FTM 1 peripheral                |
| SC_R_GPT_0          | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPT 0 peripheral                |
| SC_R_GPT_1          | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPT 1 peripheral                |
| SC_R_GPT_2          | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPT 2 peripheral                |
| SC_R_GPT_3          | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPT 3 peripheral                |
| SC_R_GPT_4          | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPT 4 peripheral                |
| SC_R_GPU_0_PID0     | SC_PM_CLK_MISC                     |              | Υ        | Υ      | Shader                          |
| SC_R_GPU_0_PID0     | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPU                             |
| SC_R_GPU_1_PID0     | SC_PM_CLK_MISC                     |              | Υ        | Y      | Shader                          |
| SC_R_GPU_1_PID0     | SC_PM_CLK_PER                      |              | Υ        | Υ      | GPU                             |
| SC_R_HDMI           | SC_PM_CLK_MISC0                    |              | Y        | Y      | Pixel link mux                  |
| SC_R_HDMI           | SC_PM_CLK_MISC1                    | 20014117     | Y        | Y      | Pixel link                      |
| SC_R_HDMI SC_R_HDMI | SC_PM_CLK_MISC2<br>SC_PM_CLK_MISC3 | 200MHZ       | Y        | Y      | HDP core<br>Pixel               |
| SC_R_HDMI           | SC_PM_CLK_MISC3                    | 100MHZ       | Y        | Y      | Bus                             |
| SC_R_HDMI_I2C_0     | SC_PM_CLK_MISC1                    | 100MHZ       | Y        | Y      | Bus                             |
| SC_R_HDMI_I2C_0     | SC_PM_CLK_MISC2                    | 24MHZ        | Y        | Y      | I2C baud                        |
| SC_R_HDMI_I2S       | SC_PM_CLK_MISC0                    |              | Y        | Y      | I2S Badd                        |
|                     | 00_1 141_0211_1411000              |              | <u>'</u> | '      | :=5                             |

| Resource                          | Clock                       | Default Rate   | Set      | Enable | Description                |
|-----------------------------------|-----------------------------|----------------|----------|--------|----------------------------|
| SC_R_HDMI_I2S                     | SC_PM_CLK_MISC1             | 100MHZ         | Υ        | Υ      | Bus                        |
| SC_R_HDMI_I2S                     | SC_PM_CLK_MISC4             |                | Υ        | Υ      | I2S bypass                 |
| SC_R_HDMI_PLL_0                   | SC PM CLK PLL               | 800MHZ         | Υ        | Υ      | User programmable PLL      |
| SC R HDMI PLL 1                   | SC PM CLK PLL               |                | Υ        | Υ      | User programmable PLL      |
| SC R HDMI RX                      | SC PM CLK MISCO             |                | Υ        | Y      | SPDIF                      |
| SC R HDMI RX                      | SC PM CLK MISC1             |                | Y        | Y      | HDP ref                    |
| SC R HDMI RX                      | SC_PM_CLK_MISC2             | 200MHZ         | Y        | •      | HDP core                   |
| SC R HDMI RX                      | SC PM CLK MISC3             | 20011112       | Y        | Υ      | Pixel                      |
| SC R HDMI RX                      | SC_PM_CLK_MISC4             |                | Y        | Y      | I2S                        |
| SC_R_HDMI_RX_BY↔                  | SC_PM_CLK_MISC0             |                | Y        | Y      | I2S bypass                 |
| PASS                              | 00_102.1                    |                |          | •      | 120 0) paoo                |
| SC_R_HDMI_RX_BY↔                  | SC_PM_CLK_MISC1             |                | Υ        | Υ      | SPDIF bypass               |
| PASS                              |                             |                |          |        |                            |
| SC_R_HDMI_RX_BY↔                  | SC_PM_CLK_MISC2             |                | Υ        | Υ      | HDMI bypass                |
| PASS                              |                             |                |          |        |                            |
| SC_R_HDMI_RX_I2C←                 | SC_PM_CLK_MISC2             | 24MHZ          | Υ        | Υ      | I2C baud                   |
| _0                                | 00 014 014 14000            |                | .,       | .,     | D14041114                  |
| SC_R_HDMI_RX_P↔                   | SC_PM_CLK_MISC2             |                | Υ        | Y      | PWM highfreq               |
| WM_0                              | SC PM CLK PER               |                | Υ        | Υ      | I2C 0 baud                 |
| SC_R_I2C_0                        |                             |                | Y        | Y      |                            |
| SC_R_I2C_1                        | SC_PM_CLK_PER               |                | Y        | Y      | I2C 1 baud<br>I2C 2 baud   |
| SC_R_I2C_2                        | SC_PM_CLK_PER SC PM CLK PER |                | Y        | Y      | 12C 3 baud                 |
| SC_R_I2C_3<br>SC_R_I2C_4          | SC PM CLK PER               |                | Y        | Y      | I2C 3 baud                 |
| SC_R_LVDS_0                       | SC_PM_CLK_BYPASS            |                | Y        | Y      | Bypass                     |
| SC R LVDS 0                       | SC PM CLK PER               |                | Y        | Y      | Pixel                      |
| SC_R_LVDS_0                       | SC_PM_CLK_PER SC_PM_CLK_PHY |                | Y        | Y      | Phy                        |
|                                   |                             | 041417         | Y        | Y      | •                          |
| SC_R_LVDS_0_I2C_0 SC R LVDS 0 PW← | SC_PM_CLK_PER SC PM CLK PER | 24MHZ<br>24MHZ | Y        | Y      | I2C 0 & 1 baud<br>PWM baud |
| SC_R_LVDS_0_PW↔<br>  M_0          | SC_PWI_CLK_PER              | 24IVITZ        | Ť        | Ť      | P VVIVI Daud               |
| SC_R_LVDS_1                       | SC PM CLK BYPASS            |                | Υ        | Υ      | Bypass                     |
| SC_R_LVDS_1                       | SC PM CLK PER               |                | Υ        | Υ      | Pixel                      |
| SC_R_LVDS_1                       | SC_PM_CLK_PHY               |                | Υ        | Υ      | Phy                        |
| SC R LVDS 1 I2C 0                 | SC_PM_CLK_PER               | 24MHZ          | Υ        | Υ      | I2C 0 & 1 baud             |
| SC R LVDS 1 PW↔                   | SC PM CLK PER               | 24MHZ          | Υ        | Υ      | PWM baud                   |
| M_0                               |                             |                |          |        |                            |
| SC_R_M4_0_I2C                     | SC_PM_CLK_PER               |                | Υ        | Υ      | I2C baud                   |
| SC_R_M4_0_PID0                    | SC_PM_CLK_CPU               | 264MHZ         | Υ        |        | System                     |
| SC_R_M4_0_PIT                     | SC_PM_CLK_PER               | 1              | Υ        | Υ      | LPIT peripheral            |
| SC R M4 0 TPM                     | SC PM CLK PER               |                | Υ        | Υ      | TPM peripheral             |
| SC R M4 0 UART                    | SC PM CLK PER               |                | Υ        | Υ      | UART baud                  |
| SC_R_M4_1_I2C                     | SC_PM_CLK_PER               |                | Y        | Y      | I2C baud                   |
| SC_R_M4_1_PID0                    | SC_PM_CLK_CPU               | 264MHZ         | Υ        |        | System                     |
| SC R M4 1 PIT                     | SC_PM_CLK_PER               |                | Υ        | Υ      | LPIT peripheral            |
| SC_R_M4_1_TPM                     | SC_PM_CLK_PER               |                | Y        | Y      | TPM peripheral             |
| SC R M4 1 UART                    | SC PM CLK PER               |                | Y        | Y      | UART baud                  |
| SC R MIPI 0                       | SC PM CLK BYPASS            | 24MHZ          | Y        | Y      | Bypass                     |
| OO_H_IVIIFI_U                     | OO_FWI_OLK_BTFA33           | ZHIVITIZ       | <u>'</u> | I      | Dypass                     |

38 Clock List

| Resource               | Clock                           | Default Rate | Set | Enable | Description        |
|------------------------|---------------------------------|--------------|-----|--------|--------------------|
| SC_R_MIPI_0            | SC_PM_CLK_MST_B↔                |              | Υ   | Υ      | DSI tx escape      |
| SC_R_MIPI_0            | US<br>SC_PM_CLK_PER             | 24MHZ        | Υ   | Υ      | DPI - pixel        |
| SC_R_MIPI_0            | SC PM CLK PHY                   | 27MHZ        | Y   | Y      | DPHY PLL ref       |
| SC_R_MIPI_0            | SC_PM_CLK_PH1  SC_PM_CLK_SLV_B↔ | 2/101172     | Y   | Y      | DSI rx escape      |
| SO_h_WIFI_U            | US                              |              | , r | T      | DSITX escape       |
| SC_R_MIPI_0_I2C_0      | SC_PM_CLK_PER                   | 40MHZ        | Υ   | Υ      | I2C 0 baud         |
| SC_R_MIPI_0_I2C_1      | SC_PM_CLK_PER                   | 40MHZ        | Υ   | Υ      | I2C 1 baud         |
| SC_R_MIPI_0_PWM↔       | SC_PM_CLK_PER                   | 24MHZ        | Υ   | Υ      | PWM baud           |
| _0<br>SC_R_MIPI_1      | SC_PM_CLK_BYPASS                | 24MHZ        | Υ   | Υ      | Bypass             |
| SC R MIPI 1            | SC PM CLK MST B↔                | ZTIVII IZ    | Y   | Y      | DSI tx escape      |
| 00_11_WIII 1_1         | US                              |              | '   | '      | Doi ix escape      |
| SC_R_MIPI_1            | SC_PM_CLK_PER                   | 24MHZ        | Υ   | Υ      | DPI - pixel        |
| SC_R_MIPI_1            | SC_PM_CLK_PHY                   | 27MHZ        | Υ   | Υ      | DPHY PLL ref       |
| SC_R_MIPI_1            | SC_PM_CLK_SLV_B↔<br>US          |              | Υ   | Y      | DSI rx escape      |
| SC_R_MIPI_1_I2C_0      | SC_PM_CLK_PER                   | 40MHZ        | Υ   | Υ      | I2C 0 baud         |
| SC_R_MIPI_1_I2C_1      | SC_PM_CLK_PER                   | 40MHZ        | Υ   | Υ      | I2C 1 baud         |
| SC_R_MIPI_1_PWM↔<br>_0 | SC_PM_CLK_PER                   | 24MHZ        | Y   | Υ      | PWM baud           |
| SC_R_NAND              | SC_PM_CLK_MST_B↔<br>US          | 500MHZ       | Υ   | Y      | NAND GPMI          |
| SC R NAND              | SC PM CLK PER                   | 400MHZ       | Υ   | Υ      | NAND BCH           |
| SC_R_PWM_0             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 0 peripheral   |
| SC_R_PWM_1             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 1 peripheral   |
| SC_R_PWM_2             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 2 peripheral   |
| SC_R_PWM_3             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 3 peripheral   |
| SC_R_PWM_4             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 4 peripheral   |
| SC_R_PWM_5             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 5 peripheral   |
| SC_R_PWM_6             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 6 peripheral   |
| SC_R_PWM_7             | SC_PM_CLK_PER                   |              | Υ   | Υ      | PWM 7 peripheral   |
| SC_R_SC_I2C            | SC_PM_CLK_PER                   | 24MHZ        | Υ   |        | I2C baud           |
| SC_R_SC_PID0           | SC_PM_CLK_CPU                   | 264MHZ       | N   |        | System             |
| SC_R_SC_PIT            | SC_PM_CLK_PER                   | 8MHZ         | Υ   |        | LPIT peripheral    |
| SC_R_SC_TPM            | SC_PM_CLK_PER                   |              | Υ   | Υ      | TPM peripheral     |
| SC_R_SC_UART           | SC_PM_CLK_PER                   | 24MHZ        | Υ   |        | UART baud          |
| SC_R_SDHC_0            | SC_PM_CLK_PER                   | 396MHZ       | Υ   | Υ      | uSDHC 0 peripheral |
| SC_R_SDHC_1            | SC_PM_CLK_PER                   | 396MHZ       | Υ   | Υ      | uSDHC 1 peripheral |
| SC_R_SDHC_2            | SC_PM_CLK_PER                   | 396MHZ       | Υ   | Υ      | uSDHC 2 peripheral |
| SC_R_SPI_0             | SC_PM_CLK_PER                   |              | Υ   | Υ      | SPI 0 baud         |
| SC_R_SPI_1             | SC_PM_CLK_PER                   |              | Υ   | Υ      | SPI 1 baud         |
| SC_R_SPI_2             | SC_PM_CLK_PER                   |              | Υ   | Υ      | SPI 2 baud         |
| SC_R_SPI_3             | SC_PM_CLK_PER                   |              | Υ   | Υ      | SPI 3 baud         |
| SC_R_UART_0            | SC_PM_CLK_PER                   |              | Υ   | Υ      | UART 0 baud        |
| SC_R_UART_1            | SC_PM_CLK_PER                   |              | Υ   | Υ      | UART 1 baud        |
| SC_R_UART_2            | SC_PM_CLK_PER                   |              | Υ   | Υ      | UART 2 baud        |

| Resource    | Clock                  | Default Rate | Set | Enable | Description |
|-------------|------------------------|--------------|-----|--------|-------------|
| SC_R_UART_3 | SC_PM_CLK_PER          |              | Υ   | Υ      | UART 3 baud |
| SC_R_UART_4 | SC_PM_CLK_PER          |              | Υ   | Υ      | UART 4 baud |
| SC_R_USB_2  | SC_PM_CLK_MISC         | 12MHZ        | Υ   | Υ      | USB 2 lpm   |
| SC_R_USB_2  | SC_PM_CLK_MST_B↔<br>US | 500MHZ       | Υ   | Y      | USB 2 bus   |
| SC_R_USB_2  | SC_PM_CLK_PER          | 125MHZ       | Υ   | Υ      | USB 2       |

| 10 | Clock List |
|----|------------|
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |
|    |            |

## **Control List**

The table below lists the miscellaneous controls available in the system (SoC specific). Resource and Control are parameters to several MISC API calls. Set=Y indicates the control can be written via sc\_misc\_set\_control(). All controls can be read via sc\_misc\_get\_control(). Temp sensors can be accessed via these but use raw sensor values. The sc\_misc\_set\_temp() and sc\_misc\_get\_temp() functions use degrees in celsius. The list below can also be used to identify which resources have an associated temp sensor for these functions.

Note the control define values are defined in types.h.

### See also

### MISC: Miscellaneous Service

| Resource   | Control           | Width | Set | Description                               |
|------------|-------------------|-------|-----|-------------------------------------------|
| SC_R_A53   | SC_C_TEMP         | 16    |     | Temperature sensor value                  |
| SC_R_A53   | SC_C_TEMP_HI      | 16    | Y   | Temperature sensor high limit alarm value |
| SC_R_A53   | SC_C_TEMP_LOW     | 16    | Y   | Temperature sensor low limit alarm value  |
| SC_R_A72   | SC_C_TEMP         | 16    |     | Temperature sensor value                  |
| SC_R_A72   | SC_C_TEMP_HI      | 16    | Υ   | Temperature sensor high limit alarm value |
| SC_R_A72   | SC_C_TEMP_LOW     | 16    | Y   | Temperature sensor low limit alarm value  |
| SC_R_CAN_0 | SC_C_IPG_DOZE     | 1     | Υ   | CAN0 IPG_DOZE                             |
| SC_R_CAN_0 | SC_C_IPG_STOP     | 1     | Υ   | CAN0 IPG_STOP                             |
| SC_R_CAN_0 | SC_C_IPG_STOP_ACK | 1     | Υ   | CAN0 IPG_STOP_ACK                         |
| SC_R_CAN_1 | SC_C_IPG_DOZE     | 1     | Υ   | CAN1 IPG_DOZE                             |
| SC_R_CAN_1 | SC_C_IPG_STOP     | 1     | Υ   | CAN1 IPG_STOP                             |
| SC_R_CAN_1 | SC_C_IPG_STOP_ACK | 1     | Υ   | CAN1 IPG_STOP_ACK                         |
| SC_R_CAN_2 | SC_C_IPG_DOZE     | 1     | Υ   | CAN2 IPG_DOZE                             |
| SC_R_CAN_2 | SC_C_IPG_STOP     | 1     | Υ   | CAN2 IPG_STOP                             |
| SC_R_CAN_2 | SC_C_IPG_STOP_ACK | 1     | Υ   | CAN2 IPG_STOP_ACK                         |
| SC_R_CSI_0 | SC_C_CALIB1       | 2     | Υ   | MIPI CSI LP-RX threshold voltage          |
| SC_R_CSI_0 | SC_C_CALIB2       | 2     | Υ   | MIPI CSI LP-CD threshold voltage          |

42 Control List

| Resource         | Control                 | Width | Set | Description                       |
|------------------|-------------------------|-------|-----|-----------------------------------|
| SC_R_CSI_0       | SC_C_MIPI_RESET         | 1     | Υ   | MIPI CSI reset_n, escape and UI   |
|                  |                         |       |     | resets                            |
| SC_R_CSI_1       | SC_C_CALIB1             | 2     | Υ   | MIPI CSI LP-RX threshold voltage  |
| SC_R_CSI_1       | SC_C_CALIB2             | 2     | Υ   | MIPI CSI LP-CD threshold voltage  |
| SC_R_CSI_1       | SC_C_MIPI_RESET         | 1     | Υ   | MIPI CSI reset_n, escape and UI   |
|                  |                         |       |     | resets                            |
| SC_R_DC_0        | SC_C_KACHUNK_CNT        | 16    | Υ   | CTX kachunk count                 |
| SC_R_DC_0        | SC_C_MODE               | 1     | Υ   | Sync mode                         |
| SC_R_DC_0        | SC_C_PANIC              | 2     | Υ   | Panic switch                      |
| SC_R_DC_0        | SC_C_PXL_LINK_MST1_ADDR | 2     | Υ   | Master 1 pixel link address       |
| SC_R_DC_0        | SC_C_PXL_LINK_MST1_ENB  | 1     | Υ   | Master 1 pixel link enable        |
| SC_R_DC_0        | SC_C_PXL_LINK_MST1_VLD  | 1     | Υ   | Master 1 pixel link valid         |
| SC_R_DC_0        | SC_C_PXL_LINK_MST2_ADDR | 2     | Υ   | Master 2 pixel link address       |
| SC_R_DC_0        | SC_C_PXL_LINK_MST2_ENB  | 1     | Υ   | Master 2 pixel link enable        |
| SC_R_DC_0        | SC_C_PXL_LINK_MST2_VLD  | 1     | Υ   | Master 2 pixel link valid         |
| SC_R_DC_0        | SC_C_PXL_LINK_MST_ENB   | 2     | Υ   | Combined master pixel link enable |
| SC_R_DC_0        | SC_C_PXL_LINK_MST_VLD   | 2     | Υ   | Combined master pixel link valid  |
| SC_R_DC_0        | SC_C_RST0               | 1     | Υ   | Display Stream 0 reset            |
| SC_R_DC_0        | SC_C_RST1               | 1     | Υ   | Display Stream 1 reset            |
| SC_R_DC_0        | SC_C_SYNC_CTRL          | 2     | Υ   | PL sync ctrl 0 & 1                |
| SC_R_DC_0        | SC_C_SYNC_CTRL0         | 1     | Υ   | PL sync ctrl 0                    |
| SC_R_DC_0        | SC_C_SYNC_CTRL1         | 1     | Υ   | PL sync ctrl 1                    |
| SC_R_DC_0_BLIT0  | SC_C_SEL0               | 1     | Υ   | Blit channel 0 select             |
| SC_R_DC_0_FRAC0  | SC_C_KACHUNK_SEL        | 1     | Υ   | FRAC0 kachunk sel                 |
| SC_R_DC_0_VIDEO0 | SC_C_KACHUNK_SEL        | 1     | Υ   | VID0 kachunk sel                  |
| SC_R_DC_0_VIDEO1 | SC_C_KACHUNK_SEL        | 1     | Υ   | VID1 kachunk sel                  |
| SC_R_DC_0_WARP   | SC_C_KACHUNK_SEL        | 1     | Υ   | WARP kachunk sel                  |
| SC_R_DC_1        | SC_C_KACHUNK_CNT        | 16    | Υ   | CTX kachunk count                 |
| SC_R_DC_1        | SC_C_MODE               | 1     | Υ   | Sync mode                         |
| SC_R_DC_1        | SC_C_PANIC              | 2     | Υ   | Panic switch                      |
| SC_R_DC_1        | SC_C_PXL_LINK_MST1_ADDR | 2     | Υ   | Master 1 pixel link address       |
| SC_R_DC_1        | SC_C_PXL_LINK_MST1_ENB  | 1     | Υ   | Master 1 pixel link enable        |
| SC_R_DC_1        | SC_C_PXL_LINK_MST1_VLD  | 1     | Υ   | Master 1 pixel link valid         |
| SC_R_DC_1        | SC_C_PXL_LINK_MST2_ADDR | 2     | Υ   | Master 2 pixel link address       |
| SC_R_DC_1        | SC C PXL LINK MST2 ENB  | 1     | Υ   | Master 2 pixel link enable        |
| SC_R_DC_1        | SC C PXL LINK MST2 VLD  | 1     | Υ   | Master 2 pixel link valid         |
| SC_R_DC_1        | SC_C_PXL_LINK_MST_ENB   | 2     | Υ   | Combined master pixel link enable |
| SC_R_DC_1        | SC C PXL LINK MST VLD   | 2     | Υ   | Combined master pixel link valid  |
| SC_R_DC_1        | SC_C_RST0               | 1     | Y   | Display Stream 0 reset            |
| SC_R_DC_1        | SC_C_RST1               | 1     | Y   | Display Stream 1 reset            |
| SC_R_DC_1        | SC_C_SYNC_CTRL          | 2     | Y   | PL sync ctrl 0 & 1                |
|                  |                         |       | Y   | PL sync ctrl 0                    |
| SC_R_DC_1        | SC_C_SYNC_CTRL0         | 1     | Y   | PL sync ctrl 1                    |
| SC_R_DC_1        | SC_C_SYNC_CTRL1         | 1     |     | •                                 |
| SC_R_DC_1_BLIT0  | SC_C_SEL0               | 1     | Y   | Blit channel 0 select             |
| SC_R_DC_1_FRAC0  | SC_C_KACHUNK_SEL        | 1     | Y   | FRAC0 kachunk sel                 |
| SC_R_DC_1_VIDEO0 | SC_C_KACHUNK_SEL        | 1     | ľ   | VID0 kachunk sel                  |

| Resource         | Control          | Width | Set | Description                                          |
|------------------|------------------|-------|-----|------------------------------------------------------|
| SC_R_DC_1_VIDEO1 | SC_C_KACHUNK_SEL | 1     | Υ   | VID1 kachunk sel                                     |
| SC_R_DC_1_WARP   | SC_C_KACHUNK_SEL | 1     | Υ   | WARP kachunk sel                                     |
| SC_R_DRC_0       | SC_C_CALIB0      | 0     | Υ   | Call DQS2DQ init function (for                       |
|                  |                  |       |     | stress test only)                                    |
| SC_R_DRC_0       | SC_C_CALIB1      | 0     | Υ   | Call RDBI bit deskew function (for                   |
|                  |                  |       |     | stress test only)                                    |
| SC_R_DRC_0       | SC_C_TEMP        | 16    |     | Temperature sensor value                             |
| SC_R_DRC_0       | SC_C_TEMP_HI     | 16    | Y   | Temperature sensor high limit alarm value            |
| SC_R_DRC_0       | SC_C_TEMP_LOW    | 16    | Υ   | Temperature sensor low limit alarm value             |
| SC_R_DRC_1       | SC_C_CALIB0      | 0     | Υ   | Call DQS2DQ init function (for stress test only)     |
| SC_R_DRC_1       | SC_C_CALIB1      | 0     | Y   | Call RDBI bit deskew function (for stress test only) |
| SC_R_DRC_1       | SC_C_TEMP        | 16    |     | Temperature sensor value                             |
| SC_R_DRC_1       | SC_C_TEMP_HI     | 16    | Y   | Temperature sensor high limit alarm value            |
| SC_R_DRC_1       | SC_C_TEMP_LOW    | 16    | Υ   | Temperature sensor low limit alarm value             |
| SC_R_DSP         | SC_C_DSP_BYP     | 1     | Υ   | DSP to DMA bypass (0=enb/1=dis)                      |
| SC_R_DSP         | SC_C_OFS_AUDIO   | 8     | Υ   | System address offset of AUDIO                       |
| SC_R_DSP         | SC_C_OFS_IRQ     | 8     | Υ   | System address offset of IRQ                         |
| SC_R_DSP         | SC_C_OFS_SEL     | 1     | Υ   | System address offset source select                  |
| SC_R_ENET_0      | SC_C_CLKDIV      | 1     | Υ   | ENET1 divided clock                                  |
| SC_R_ENET_0      | SC_C_DISABLE_125 | 1     | Υ   | ENET1 125/25MHz clock disable                        |
| SC_R_ENET_0      | SC_C_DISABLE_50  | 1     | Υ   | ENET1 50MHz clock disable                            |
| SC_R_ENET_0      | SC_C_IPG_STOP    | 1     | Υ   | ENET1 IPG stop mode                                  |
| SC_R_ENET_0      | SC_C_SEL_125     | 1     | Υ   | ENET1 125/25MHz ref clk sel                          |
| SC_R_ENET_0      | SC_C_TXCLK       | 1     | Υ   | ENET1 TXCLK selection                                |
| SC_R_ENET_1      | SC_C_CLKDIV      | 1     | Υ   | ENET2 divided clock                                  |
| SC_R_ENET_1      | SC_C_DISABLE_125 | 1     | Υ   | ENET2 125/25MHz clock disable                        |
| SC_R_ENET_1      | SC_C_DISABLE_50  | 1     | Υ   | ENET2 50MHz clock disable                            |
| SC_R_ENET_1      | SC_C_IPG_STOP    | 1     | Υ   | ENET2 IPG stop mode                                  |
| SC_R_ENET_1      | SC_C_SEL_125     | 1     | Υ   | ENET2 125/25MHz ref clk sel                          |
| SC_R_ENET_1      | SC_C_TXCLK       | 1     | Υ   | ENET2 TXCLK selection                                |
| SC_R_FSPI_0      | SC_C_MISC0       | 9     | Υ   | FSPI 0 swap                                          |
| SC_R_FSPI_0      | SC_C_MISC1       | 9     | Υ   | FSPI 0 swap mask                                     |
| SC_R_GPU_0_PID0  | SC_C_ID          | 4     | Υ   | Identifier                                           |
| SC_R_GPU_0_PID0  | SC_C_SINGLE_MODE | 1     | Υ   | Force to single mode                                 |
| SC_R_GPU_0_PID0  | SC_C_TEMP        | 16    |     | Temperature sensor value                             |
| SC_R_GPU_0_PID0  | SC_C_TEMP_HI     | 16    | Υ   | Temperature sensor high limit alarm value            |
| SC_R_GPU_0_PID0  | SC_C_TEMP_LOW    | 16    | Υ   | Temperature sensor low limit alarm value             |
| SC_R_GPU_1_PID0  | SC_C_ID          | 4     | Υ   | Identifier                                           |
| SC_R_GPU_1_PID0  | SC_C_SINGLE_MODE | 1     | Υ   | Force to single mode                                 |
|                  |                  |       | 1   | <u> </u>                                             |

44 Control List

| Resource        | Control                            | Width | Set | Description                                                            |
|-----------------|------------------------------------|-------|-----|------------------------------------------------------------------------|
| SC_R_GPU_1_PID0 | SC_C_TEMP                          | 16    |     | Temperature sensor value                                               |
| SC_R_GPU_1_PID0 | SC_C_TEMP_HI                       | 16    | Υ   | Temperature sensor high limit alarm value                              |
| SC_R_GPU_1_PID0 | SC_C_TEMP_LOW                      | 16    | Υ   | Temperature sensor low limit alarm value                               |
| SC_R_HDMI       | SC_C_MODE                          | 1U    | Υ   | 0 = HDMI, 1 = DP                                                       |
| SC_R_HDMI       | SC_C_PHY_RESET                     | 1U    | Υ   | HDMI PHY reset                                                         |
| SC_R_HDMI_RX    | SC_C_PHY_RESET                     | 1     | Υ   | HDMI PHY reset                                                         |
| SC_R_LVDS_0     | SC_C_PXL_LINK_RATE_COR↔<br>RECTION | 2     | Y   |                                                                        |
| SC_R_LVDS_1     | SC_C_PXL_LINK_RATE_COR↔<br>RECTION | 2     | Y   |                                                                        |
| SC_R_MIPI_0     | SC_C_DPI_RESET                     | 1     | Υ   | MIPI DSI DPI reset                                                     |
| SC_R_MIPI_0     | SC_C_MIPI_RESET                    | 1     | Υ   | MIPI DSI escape reset                                                  |
| SC_R_MIPI_0     | SC_C_PHY_RESET                     | 1     | Υ   | MIPI DSI byte reset (PHY reset)                                        |
| SC_R_MIPI_1     | SC_C_DPI_RESET                     | 1     | Υ   | MIPI DSI DPI reset                                                     |
| SC_R_MIPI_1     | SC_C_MIPI_RESET                    | 1     | Υ   | MIPI DSI escape reset                                                  |
| SC_R_MIPI_1     | SC_C_PHY_RESET                     | 1     | Υ   | MIPI DSI byte reset (PHY reset)                                        |
| SC_R_MLB_0      | SC_C_CLKDIV                        | 3     | Y   | MLB PLL Multiplier (0 - refclk, 1, 2 and 4)                            |
| SC_R_MLB_0      | SC_C_MODE                          | 1     | Υ   | 0 - disable MLB PLL, 1 - Enable<br>MLB PLL                             |
| SC_R_MLB_0      | SC_C_VOLTAGE                       | 1     | Y   | 0 - disable MLB PHY BG, 1 - Enable MLB PHY BG (Required for MLB 6-pin) |
| SC_R_PMIC_0     | SC_C_TEMP                          | 8     |     | Temperature sensor temp                                                |
| SC_R_PMIC_0     | SC_C_TEMP_HI                       | 8     | Y   | Temperature sensor high limit alarm temp                               |
| SC_R_PMIC_1     | SC_C_TEMP                          | 8     |     | Temperature sensor temp                                                |
| SC_R_PMIC_1     | SC_C_TEMP_HI                       | 8     | Υ   | Temperature sensor high limit alarm temp                               |
| SC_R_PMIC_2     | SC_C_TEMP                          | 8     |     | Temperature sensor temp                                                |
| SC_R_PMIC_2     | SC_C_TEMP_HI                       | 8     | Y   | Temperature sensor high limit alarm temp                               |
| SC_R_SDHC_0     | SC_C_VOLTAGE                       | 1     | Υ   | uSDHC1 IO voltage                                                      |
| SC_R_SDHC_1     | SC_C_VOLTAGE                       | 1     | Υ   | uSDHC2 IO voltage                                                      |
| SC_R_SDHC_2     | SC_C_VOLTAGE                       | 1     | Υ   | uSDHC3 IO voltage                                                      |
| SC_R_SYSTEM     | SC_C_ID                            | 9     |     | Chip ID and revision value                                             |
| SC_R_SYSTEM     | SC_C_MODE                          | 8     |     | Boot mode pads                                                         |
| SC_R_SYSTEM     | SC_C_TEMP                          | 16    |     | Temperature sensor value                                               |
| SC_R_SYSTEM     | SC_C_TEMP_HI                       | 16    | Υ   | Temperature sensor high limit alarm value                              |
| SC_R_SYSTEM     | SC_C_TEMP_LOW                      | 16    | Y   | Temperature sensor low limit alarm value                               |
| SC_R_VPU        | SC_C_TEMP                          | 16    |     | Temperature sensor value                                               |
| SC_R_VPU        | SC_C_TEMP_HI                       | 16    | Y   | Temperature sensor high limit alarm value                              |

| Resource | Control       | Width | Set | Description                        |
|----------|---------------|-------|-----|------------------------------------|
| SC_R_VPU | SC_C_TEMP_LOW | 16    | Υ   | Temperature sensor low limit alarm |
|          |               |       |     | value                              |

| 46 | Control Lis |
|----|-------------|
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |
|    |             |

## **Pad List**

The table below lists the pads available in the system (SoC specific). Pad is a parameter to several PAD API calls.

Note, if two pads are configured for the same IP signal, one is successful and the other will not get the signal. This prioritization is done in HW and some pads have a default mux setting to a signal that another pad can be set to. If SW tries to set the other pad to this setting, it may not make a connection if that pad is lower priority in the HW than the one that has this setting due to default. To resolve this, the SW has to move the conflicting pad to something other than the offending signal. This isn't always possible if the offending pad is owned by another partition. As a result, the SCFW changes the mux configuration of all the pads that could be in conflict to GPIO as those are never in conflict. Refer to the SC\_PAD\_INIT\_INIT define in the SoC-specific soc.h for a list of these pads.

Note the pad define values (index) are listed here but the define should be used. These are defined in the SoC-specific pads.h. Functions like sc\_rm\_set\_pad\_movable() take a pad range. This range is numerical by index and not alphabetical by define name. Range should be lowest to highest index.

#### See also

PAD: Pad Service

| Pad          | Index | Mux Options                               |
|--------------|-------|-------------------------------------------|
| SC_P_ADC_IN0 | 141   | DMA.ADC0.IN0, LSIO.KPP0.COL0, LSIO.GPI↔   |
|              |       | O3.IO18                                   |
| SC_P_ADC_IN1 | 140   | DMA.ADC0.IN1, LSIO.KPP0.COL1, LSIO.GPI←   |
|              |       | O3.IO19                                   |
| SC_P_ADC_IN2 | 139   | DMA.ADC0.IN2, LSIO.KPP0.COL2, LSIO.GPI←   |
|              |       | O3.IO20                                   |
| SC_P_ADC_IN3 | 138   | DMA.ADC0.IN3, DMA.SPI1.SCK, LSIO.KPP0.C←  |
|              |       | OL3, LSIO.GPIO3.IO21                      |
| SC_P_ADC_IN4 | 137   | DMA.ADC1.IN0, DMA.SPI1.SDO, LSIO.KPP0.R←  |
|              |       | OW0, LSIO.GPIO3.IO22                      |
| SC_P_ADC_IN5 | 136   | DMA.ADC1.IN1, DMA.SPI1.SDI, LSIO.KPP0.RO← |
|              |       | W1, LSIO.GPIO3.IO23                       |
| SC_P_ADC_IN6 | 135   | DMA.ADC1.IN2, DMA.SPI1.CS0, LSIO.KPP0.R←  |
|              |       | OW2, LSIO.GPIO3.IO24                      |
| SC_P_ADC_IN7 | 134   | DMA.ADC1.IN3, DMA.SPI1.CS1, LSIO.KPP0.R←  |
|              |       | OW3, LSIO.GPIO3.IO25                      |

| Pad                                         | Index | Mux Options                                                              |
|---------------------------------------------|-------|--------------------------------------------------------------------------|
| SC_P_CALIBRATION_0_HSIC                     | 207   |                                                                          |
| SC_P_CALIBRATION_1_HSIC                     | 208   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_ENET_EN↔<br>ETA  | 268   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_ENET_EN↔<br>ETB  | 255   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIOCT           | 171   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIOLH           | 29    |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIOLHT          | 145   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIORHB          | 103   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIORHC          | 116   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIORHT          | 133   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_GPIOTHR          | 152   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_LVDSGPIO         | 62    |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_MIPIDSIG←<br>PIO | 71    |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_PCIESEP          | 204   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_QSPI0            | 197   |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_QSPI1            | 180   |                                                                          |
| SC P COMP CTL GPIO 1V8 3V3 SD1FIX           | 221   |                                                                          |
| SC P COMP CTL GPIO 1V8 3V3 SIM              | 6     |                                                                          |
| SC_P_COMP_CTL_GPIO_1V8_3V3_VSEL2            | 235   |                                                                          |
| SC P COMP CTL GPIO 1V8 3V3 VSEL3            | 242   |                                                                          |
| SC P COMP CTL GPIO 1V8 3V3 VSELSEP          | 164   |                                                                          |
| SC P COMP CTL GPIO 3V3 HDMIGPIO             | 84    |                                                                          |
| SC P COMP CTL GPIO 3V3 USB3IO               | 157   |                                                                          |
| SC P CTL NAND DQS P N                       | 229   |                                                                          |
| SC P CTL NAND RE P N                        | 226   |                                                                          |
| SC P EMMC0 CLK                              | 209   | CONN.EMMC0.CLK, CONN.NAND.READY B                                        |
| SC_P_EMMC0_CMD                              | 210   | CONN.EMMC0.CMD, CONN.NAND.DQS, AUD.← MQS.R, LSIO.GPIO5.IO03              |
| SC_P_EMMC0_DATA0                            | 211   | CONN.EMMC0.DATA0, CONN.NAND.DATA00,                                      |
|                                             |       | LSIO.GPIO5.IO04                                                          |
| SC_P_EMMC0_DATA1                            | 212   | CONN.EMMC0.DATA1, CONN.NAND.DATA01, LSIO.GPIO5.IO05                      |
| SC_P_EMMC0_DATA2                            | 213   | CONN.EMMC0.DATA2, CONN.NAND.DATA02, LSIO.GPIO5.IO06                      |
| SC_P_EMMC0_DATA3                            | 214   | CONN.EMMC0.DATA3, CONN.NAND.DATA03, LSIO.GPIO5.IO07                      |
| SC_P_EMMC0_DATA4                            | 215   | CONN.EMMC0.DATA4, CONN.NAND.DATA04, LSIO.GPIO5.IO08                      |
| SC_P_EMMC0_DATA5                            | 216   | CONN.EMMC0.DATA5, CONN.NAND.DATA05, LSIO.GPIO5.IO09                      |
| SC_P_EMMC0_DATA6                            | 217   | CONN.EMMC0.DATA6, CONN.NAND.DATA06, LSIO.GPIO5.IO10                      |
| SC_P_EMMC0_DATA7                            | 218   | CONN.EMMC0.DATA7, CONN.NAND.DATA07, LSIO.GPIO5.IO11                      |
| SC_P_EMMC0_RESET_B                          | 220   | CONN.EMMC0.RESET_B, CONN.NAND.WP_B, CONN.USDHC1.VSELECT, LSIO.GPIO5.IO13 |

| SC_P_ENETO_RGMII_RXD0  SC_P_ENETO_RGMII_RXD1  SC_P_ENETO_RGMII_RXD2  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD1  SC_P_ENETO_RGMII_RXD3  SC_P_ENETO_RGMII_RXD3 | _, LSIO.GPI←  A, LSIO.GPI←  , CONN.EN←  ART3.CTS_←  O04  TSI_S0.SYNC,  TSI_S0.DATA, |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| SC_P_ENET0_MDC         166         CONN.ENET0.MDC, DMA.I2C4.SCI. O4.IO14           SC_P_ENET0_MDIO         165         CONN.ENET0.MDIO, DMA.I2C4.SD/. O4.IO13           SC_P_ENET0_REFCLK_125M_25M         167         CONN.ENET0.REFCLK_125M_25M ET0.PPS, LSIO.GPIO4.IO15           SC_P_ENET0_RGMII_RXC         249         CONN.ENET0.RGMII_RXC, DMA.U. B, VPU.TSI_S1.DATA, LSIO.GPIO6.IO.ID           SC_P_ENET0_RGMII_RXD0         251         CONN.ENET0.RGMII_RXD0, VPU.T. LSIO.GPIO6.IO.06           SC_P_ENET0_RGMII_RXD1         252         CONN.ENET0.RGMII_RXD1, VPU.T. LSIO.GPIO6.IO.07           SC_P_ENET0_RGMII_RXD2         253         CONN.ENET0.RGMII_RXD2, C                                                                                                                                                                                                                                                                                                                   | A, LSIO.GPI↔ , CONN.EN↔  ART3.CTS_↔ O04  TSI_S0.SYNC,  TSI_S0.DATA,                 |
| O4.IO14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | A, LSIO.GPI↔ , CONN.EN↔  ART3.CTS_↔ O04  TSI_S0.SYNC,  TSI_S0.DATA,                 |
| SC_P_ENET0_MDIO  165 CONN.ENET0.MDIO, DMA.I2C4.SD/O4.IO13  SC_P_ENET0_REFCLK_125M_25M  167 CONN.ENET0.REFCLK_125M_25M, ET0.PPS, LSIO.GPIO4.IO15  SC_P_ENET0_RGMII_RXC  249 CONN.ENET0.RGMII_RXC, DMA.U B, VPU.TSI_S1.DATA, LSIO.GPIO6.I SC_P_ENET0_RGMII_RXD0  SC_P_ENET0_RGMII_RXD0  251 CONN.ENET0.RGMII_RXD0, VPU.T LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252 CONN.ENET0.RGMII_RXD1, VPU.T LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253 CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.GO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ART3.CTS_← O04 FSI_S0.SYNC, TSI_S0.DATA,                                            |
| O4.IO13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ART3.CTS_← O04 FSI_S0.SYNC, TSI_S0.DATA,                                            |
| SC_P_ENET0_REFCLK_125M_25M  167 CONN.ENET0.REFCLK_125M_25M  ET0.PPS, LSIO.GPIO4.IO15  SC_P_ENET0_RGMII_RXC  249 CONN.ENET0.RGMII_RXC, DMA.U B, VPU.TSI_S1.DATA, LSIO.GPIO6.I  SC_P_ENET0_RGMII_RXD0  251 CONN.ENET0.RGMII_RXD0, VPU.T LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252 CONN.ENET0.RGMII_RXD1, VPU.T LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253 CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ART3.CTS_←<br>O04<br>FSI_S0.SYNC,<br>TSI_S0.DATA,                                   |
| ET0.PPS, LSIO.GPIO4.IO15  SC_P_ENET0_RGMII_RXC  249  CONN.ENET0.RGMII_RXC, DMA.U B, VPU.TSI_S1.DATA, LSIO.GPIO6.I  SC_P_ENET0_RGMII_RXD0  251  CONN.ENET0.RGMII_RXD0, VPU.T LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252  CONN.ENET0.RGMII_RXD1, VPU.T LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253  CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ART3.CTS_←<br>O04<br>FSI_S0.SYNC,<br>TSI_S0.DATA,                                   |
| SC_P_ENET0_RGMII_RXC  249  CONN.ENET0.RGMII_RXC, DMA.U B, VPU.TSI_S1.DATA, LSIO.GPIO6.I SC_P_ENET0_RGMII_RXD0  251  CONN.ENET0.RGMII_RXD0, VPU.T LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252  CONN.ENET0.RGMII_RXD1, VPU.T LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253  CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | O04 TSI_S0.SYNC, TSI_S0.DATA,                                                       |
| B, VPU.TSI_S1.DATA, LSIO.GPIO6.I  SC_P_ENET0_RGMII_RXD0  251 CONN.ENET0.RGMII_RXD0, VPU.T LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252 CONN.ENET0.RGMII_RXD1, VPU.T LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253 CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | O04 TSI_S0.SYNC, TSI_S0.DATA,                                                       |
| LSIO.GPIO6.IO06  SC_P_ENET0_RGMII_RXD1  252  CONN.ENET0.RGMII_RXD1, VPU. LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253  CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TSI_S0.DATA,                                                                        |
| SC_P_ENET0_RGMII_RXD1  252 CONN.ENET0.RGMII_RXD1, VPU. LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253 CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _ `                                                                                 |
| LSIO.GPIO6.IO07  SC_P_ENET0_RGMII_RXD2  253  CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | _                                                                                   |
| SC_P_ENET0_RGMII_RXD2 253 CONN.ENET0.RGMII_RXD2, CONN II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                     |
| II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | IA.UART3.RX,                                                                        |
| VPU.TSI_S1.CLK, LSIO.GPIO6.IO09                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |
| SC P ENETO RGMII RX CTL 250 CONN.ENETO.RGMII RX CTL, VPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                     |
| LSIO.GPIO6.IO05                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0.101_00.VID,                                                                       |
| SC P ENETO RGMII TXC 243 CONN.ENETO.RGMII TXC, CONN.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ENET0.RCL                                                                           |
| K50M_OUT, CONN.ENET0.RCLK50                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                     |
| GPIO5.IO30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                     |
| SC_P_ENET0_RGMII_TXD0 245 CONN.ENET0.RGMII_TXD0, LSIO.G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PIO6.IO00                                                                           |
| SC_P_ENET0_RGMII_TXD1 246 CONN.ENET0.RGMII_TXD1, LSIO.G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PIO6.IO01                                                                           |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | MA.UART3.TX,                                                                        |
| VPU.TSI_S1.VID, LSIO.GPIO6.IO02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |
| SC_P_ENET0_RGMII_TXD3 248 CONN.ENET0.RGMII_TXD3, DMA.I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                     |
| _B, VPU.TSI_S1.SYNC, LSIO.GPI06                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |
| SC_P_ENET0_RGMII_TX_CTL 244 CONN.ENET0.RGMII_TX_CTL, LSIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                     |
| SC_P_ENET1_MDC 170 CONN.ENET1.MDC, DMA.I2C4.SCI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | _, LSIO.GPI←                                                                        |
| SC P ENET1 MDIO 169 CONN.ENET1.MDIO, DMA.I2C4.SD/                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | A LSIO GPL.                                                                         |
| 36_F_ENETT_MIDIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4, LSIO.GFI←                                                                        |
| SC_P_ENET1_REFCLK_125M_25M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . CONN.EN←                                                                          |
| ET1.PPS, LSIO.GPIO4.IO16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                     |
| SC_P_ENET1_RGMII_RXC 262 CONN.ENET1.RGMII_RXC, DMA.U.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ART3.CTS_←                                                                          |
| B, VPU.TSI_S1.DATA, LSIO.GPIO6.I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | O16                                                                                 |
| SC_P_ENET1_RGMII_RXD0 264 CONN.ENET1.RGMII_RXD0, VPU.T                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ΓSI_S0.SYNC,                                                                        |
| LSIO.GPIO6.IO18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                     |
| SC_P_ENET1_RGMII_RXD1 265 CONN.ENET1.RGMII_RXD1, VPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | TSI_S0.DATA,                                                                        |
| LSIO.GPIO6.IO19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ENET LON                                                                            |
| SC_P_ENET1_RGMII_RXD2 266 CONN.ENET1.RGMII_RXD2, CONN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                     |
| II_RX_ER, VPU.TSI_S0.CLK, LSIO.C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                     |
| SC_P_ENET1_RGMII_RXD3 267 CONN.ENET1.RGMII_RXD3, DM VPU.TSI S1.CLK, LSIO.GPIO6.IO21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | IA.UART3.RX,                                                                        |
| SC P ENET1 RGMII RX CTL 263 CONN.ENET1.RGMII RX CTL, VPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                     |
| LSIO.GPI06.IO17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0.131_30.VID,                                                                       |
| SC P ENET1 RGMII TXC 256 CONN.ENET1.RGMII TXC, CONN.I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ENET1.RCL←                                                                          |
| K50M_OUT, CONN.ENET1.RCLK50I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                     |
| GPIO6.IO10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                     |

| SC.P. ENETT. RGMILTXDD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Pad                   | Index | Mux Options                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------|--------------------------------------------------------------------|
| SC_P_ENET1_RGMII_TXD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SC_P_ENET1_RGMII_TXD0 | 258   | CONN.ENET1.RGMII_TXD0, LSIO.GPIO6.IO12                             |
| VPUTSI S1.VID. LSIO.GPI06.IO14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SC_P_ENET1_RGMII_TXD1 | 259   | CONN.ENET1.RGMII_TXD1, LSIO.GPIO6.IO13                             |
| SC_P_ENET1_RGMII_TXD3         261         CONN.ENET1.RGMII_TXD3.DMA.UART3.RTSB, VPU.TSI_SI.SYNC, LSIO.GPIO6.IO15           SC_P_ESAIO_FSR         104         AUD.ESAIO.FSR, LSIO.GPIO2.IO22           SC_P_ESAIO_FST         105         AUD.ESAIO.SKR, LSIO.GPIO2.IO23           SC_P_ESAIO_SCKR         106         AUD.ESAIO.SKR, LSIO.GPIO2.IO24           SC_P_ESAIO_SCKR         106         AUD.ESAIO.SKR, LSIO.GPIO2.IO25           SC_P_ESAIO_TX0         108         AUD.ESAIO.TX1, LSIO.GPIO2.IO26           SC_P_ESAIO_TX1         109         AUD.ESAIO.TX1, LSIO.GPIO2.IO27           SC_P_ESAIO_TX2_RX3         110         AUD.ESAIO.TX2, RX3, LSIO.GPIO2.IO27           SC_P_ESAIO_TX3_RX2         111         AUD.ESAIO.TX3_RX2, LSIO.GPIO2.IO29           SC_P_ESAIO_TX4_RX1         112         AUD.ESAIO.TX4_RX1, LSIO.GPIO2.IO29           SC_P_ESAIO_TX5_RX0         113         AUD.ESAIO.TX4_RX1, LSIO.GPIO2.IO30           SC_P_ESAIO_TX5_RX0         113         AUD.ESAIO.TX4_RX1, LSIO.GPIO2.IO31           SC_P_ESAII_FST         86         AUD.ESAII.FST, AUD.SPIDIFO.EXT_CLK, LSIO.GPIO2.IO36           SC_P_ESAII_FST         87         AUD.ESAII.SCKT, AUD.SAI2.RXC, AUD.SPDIFO.EXT_CLK, LSIO.GPIO2.IO36           SC_P_ESAII_SCKT         88         AUD.ESAII.SCKT, AUD.SAI2.RXC, AUD.SPDIFO.EXT_CLK, LSIO.GPIO2.IO36           SC_P_ESAII_TX0         89                                                                                                                                                                                                                                                                                                                     | SC_P_ENET1_RGMII_TXD2 | 260   | _ :                                                                |
| B, VPU.TSL_SI.SYNC, LISIO.GPIOS.IO15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |       | _ ,                                                                |
| SC_P_ENETI_RGMIL_TX_CTL         257         CONN.ENETI.RGMIL_TX_CTL, LSIO.GPI06.I011           SC_P_ESAI0_FSR         104         AUD.ESAI0.FSR, LSIO.GPI02.I022           SC_P_ESAI0_FST         105         AUD.ESAI0.SCKT, LSIO.GPI02.I023           SC_P_ESAI0_SCKR         106         AUD.ESAI0.SCKT, LSIO.GPI02.I024           SC_P_ESAI0_TX0         108         AUD.ESAI0.SCKT, LSIO.GPI02.I025           SC_P_ESAI0_TX0         108         AUD.ESAI0.TX0, LSIO.GPI02.I026           SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1, LSIO.GPI02.I027           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2, RX3, LSIO.GPI02.I028           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2, LSIO.GPI02.I029           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPI02.I030           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPI02.I031           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPI02.I004           SC_P_ESAI1_FSR         86         AUD.ESAI1.SCKR, LSIO.GPI02.I006           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPI02.I006           SC_P_ESAI1_TX0         88         AUD.ESAI1.TX0, AUD.SAI2.RXC, AUD.SPDIF                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | SC_P_ENET1_RGMII_TXD3 | 261   | _ :                                                                |
| SC_P_ESAI0_FSR         104         AUD.ESAI0.FSR, LSIO.GPI02.IO22           SC_P_ESAI0_FST         105         AUD.ESAI0.FST, LSIO.GPI02.IO23           SC_P_ESAI0_SCKR         106         AUD.ESAI0.SCKR, LSIO.GPI02.IO24           SC_P_ESAI0_SCKT         107         AUD.ESAI0.SCKT, LSIO.GPI02.IO25           SC_P_ESAI0_TX0         108         AUD.ESAI0.TX0, LSIO.GPI02.IO26           SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1, LSIO.GPI02.IO27           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX1, LSIO.GPI02.IO28           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX4_RX1, LSIO.GPI02.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPI02.IO30           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPI02.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPI02.IO04           SC_P_ESAI1_FST         86         AUD.ESAI1.SCKR, LSIO.GPI02.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.EXCLK, LSIO.GPI02.IO06           SC_P_ESAI1_TX0         88         AUD.ESAI1.TX1, AUD.SAI2.RXC, AUD.SPDIF0.EXCLK, LSIO.GPI02.IO07           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXD, AUD.SPDIF0.EXCLK, LSIO.GPI02.IO09           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIF0.TX, LSIO.GPI02.IO0<                                                                                                                                                                                                                                                                                                                     |                       |       |                                                                    |
| SC_P_ESAI0_FST         105         AUD.ESAI0.FST, LSIO.GPIO2.IO24           SC_P_ESAI0_SCKR         106         AUD.ESAI0.SCKR, LSIO.GPIO2.IO24           SC_P_ESAI0_SCKT         107         AUD.ESAI0.SCKT, LSIO.GPIO2.IO25           SC_P_ESAI0_TX0         108         AUD.ESAI0.SCKT, LSIO.GPIO2.IO26           SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1, LSIO.GPIO2.IO26           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2_RX3, LSIO.GPIO2.IO28           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX3_RX2, LSIO.GPIO2.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI1.FSR, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         86         AUD.ESAI1.FSR, LSIO.GPIO2.IO03           SC_P_ESAI1_FSR         86         AUD.ESAI1.FSR, LSIO.GPIO2.IO03           SC_P_ESAI1_FSR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO03           SC_P_ESAI1_FSR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_TX0         88         AUD.ESAI1.TX1, AUD.SAI2.RXC, AUD.SPDIF0.FV           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX1, AUD.SAI2.RXD, AUD.SPDIF0.FX           SC_P_ESAI1_TX1         90 <t< td=""><td></td><td></td><td></td></t<>                                                                                                                                                                                                                                                                                                                             |                       |       |                                                                    |
| SC_P_ESAI0_SCKR         106         AUD.ESAI0.SCKR, LSIO.GPIO2.IO24           SC_P_ESAI0_SCKT         107         AUD.ESAI0.SCKT, LSIO.GPIO2.IO25           SC_P_ESAI0_TX0         108         AUD.ESAI0.TX0, LSIO.GPIO2.IO26           SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1, LSIO.GPIO2.IO27           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2_RX3, LSIO.GPIO2.IO28           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO31           SC_P_ESAI1_FST         86         AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO04           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKT, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKT         88         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO06           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX0, AUD.SAI2.RXC, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO06           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF0.EXT.LSIO.GPIO2.IO08           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.GPIO2.IO06           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.GPIO2.IO06                                                                                                                                                                                                                                                                                                   |                       |       | •                                                                  |
| SC_P_ESAI0_SCKT         107         AUD.ESAI0.SCKT, LSIO.GPI02.I025           SC_P_ESAI0_TX0         108         AUD.ESAI0.TX0, LSIO.GPI02.I026           SC_P_ESAI0_TX2         109         AUD.ESAI0.TX1, LSIO.GPI02.I027           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2, RX3, LSIO.GPI02.I028           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2, LSIO.GPI02.I029           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPI02.I031           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPI02.I031           SC_P_ESAI1_FSR         85         AUD.ESAI1.TSR, LSIO.GPI02.I004           SC_P_ESAI1_FSR         86         AUD.ESAI1.FSR, LSIO.GPI02.I004           SC_P_ESAI1_FST         86         AUD.ESAI1.SCKT, LSIO.GPI02.I006           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIFO.EXT.CLK, LSIO.GPI02.I007           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX1, AUD.SAI2.RXC, AUD.SPDIFO.EXT.CLK, LSIO.GPI02.I009           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXF, AUD.SPDIFO.EXT.LSIO.GPI02.I009           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2, RX3, AUD.SPDIFO.RX, LSIO.GPI02.I009           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX4_RX1, LSIO.GPI03.I030           SC_P_ESAI1_TX5_RX0         94         AUD.ESA                                                                                                                                                                                                                                                                                                                     | SC_P_ESAI0_FST        | 105   | AUD.ESAI0.FST, LSIO.GPIO2.IO23                                     |
| SC_P_ESAI0_TX0         108         AUD.ESAI0.TX0_LSIO.GPIO2.IO26           SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1_LSIO.GPIO2.IO27           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2_RX3_LSIO.GPIO2.IO28           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2_LSIO.GPIO2.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX3_RX1_LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0_LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR_LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         86         AUD.ESAI1.FSR_LSIO.GPIO2.IO06           SC_P_ESAI1_FST         86         AUD.ESAI1.SCKR_LSIO.GPIO2.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR_LSIO.GPIO2.IO06           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX0_AUD.SAI2.RXC_AUD.SPDIFO.F           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1_AUD.SAI2.RXFS_AUD.SPDIFO.F           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX2_RX3_AUD.SPDIFO.RX_LSIO.GFO           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3_AUD.SPDIFO.TX_LSIO.GFO           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX3_RX2_AUD.SPDIFO.TX_LSIO.GFO           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX4_RX1_LSIO.GPIO2.IO13           SC_P_ESAI1_TX5_RX0                                                                                                                                                                                                                                                                                                                                                    |                       |       | ·                                                                  |
| SC_P_ESAI0_TX1         109         AUD.ESAI0.TX1, LSIO.GPIO2.IO27           SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2_RX3, LSIO.GPIO2.IO28           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2, LSIO.GPIO2.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO04           SC_P_ESAI1_FST         86         AUD.ESAI1.SCKR, LSIO.GPIO2.IO04           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX0, AUD.SAI2.RXC, AUD.SPDIFO.GRAY, LSIO.GPIO2.IO07           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIFO.GRAY, LSIO.GPIO2.IO09           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIFO.RX, LSIO.GGGGGAPIO2.IO13           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIFO.TX, LSIO.GGGGAPIO2.IO12           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO3.IO29           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO29           SC_P_ESAI1_TX5_RX0         94         AUD.E                                                                                                                                                                                                                                                                                                                     | SC_P_ESAI0_SCKT       | 107   | AUD.ESAI0.SCKT, LSIO.GPIO2.IO25                                    |
| SC_P_ESAI0_TX2_RX3         110         AUD.ESAI0.TX2_RX3_LSIO.GPIO2.IO28           SC_P_ESAI0_TX3_RX2         111         AUD.ESAI0.TX3_RX2_LSIO.GPIO2.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1_LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO04           SC_P_ESAI1_FST         86         AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.FO.EXT_CLK, LSIO.GPIO2.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX1, AUD.SAI2.RXF, AUD.SPDIF0.FO.EXT_CLK, LSIO.GPIO2.IO08           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXF, AUD.SPDIF0.FO.EXT_CLK, LSIO.GPIO2.IO09           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.GFIO2.IO09           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIF0.RX, LSIO.GFIO2.IO12           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO32           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO32 <td>SC_P_ESAI0_TX0</td> <td>108</td> <td>AUD.ESAI0.TX0, LSIO.GPIO2.IO26</td>                                                                                                                                                                                               | SC_P_ESAI0_TX0        | 108   | AUD.ESAI0.TX0, LSIO.GPIO2.IO26                                     |
| SC_P_ESAI0_TX3_RX2         1111         AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO29           SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO04           SC_P_ESAI1_FSR         86         AUD.ESAI1.FST, AUD.SPDIFIO.EXT_CLK, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKT         88         AUD.ESAI1.TXC, AUD.SAI2.RXC, AUD.SPDIFO.GED.EXT_CLK, LSIO.GPIO2.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX1, AUD.SAI2.RXD, AUD.SPDIFO.GED.EXT.CLK, LSIO.GPIO2.IO08           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIFO.GED.EXT.CLK, LSIO.GPIO2.IO09           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIFO.RX, LSIO.GGGGG.GED.EXT.CLK, LSIO.GPIO2.IO19           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIFO.TX, LSIO.GGGGG.GED.EXT.CLK, LSIO.GPIO2.IO12           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO13           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO39           SC_P_FLEXCAND_RX         146         DMA.FLEXCAND.RX,                                                                                                                                                                                                                                                                         |                       | 109   | AUD.ESAI0.TX1, LSIO.GPIO2.IO27                                     |
| SC_P_ESAI0_TX4_RX1         112         AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30           SC_P_ESAI0_TX5_RX0         113         AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO04           SC_P_ESAI1_FST         86         AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO05           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKT         88         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.GET_CLK, LSIO.GPIO2.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX10, AUD.SAI2.RXD, AUD.SPDIF0.GET_CLK, LSIO.GPIO2.IO08           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF0.GET_CLK, LSIO.GPIO2.IO08           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF0.RX, LSIO.GET_CLTA, LSIO.GET_CLTA | SC_P_ESAI0_TX2_RX3    | 110   | AUD.ESAI0.TX2_RX3, LSIO.GPIO2.IO28                                 |
| SC_P_ESAID_TX5_RX0         113         AUD.ESAID.TX5_RX0, LSIO.GPIO2.IO31           SC_P_ESAI1_FSR         85         AUD.ESAI1.FSR, LSIO.GPIO2.IO04           SC_P_ESAI1_FST         86         AUD.ESAI1.FSR, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPIO2.IO06           SC_P_ESAI1_SCKT         88         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDI-           F0_EXT_CLK, LSIO.GPIO2.IO07         F0_EXT_CLK, LSIO.GPIO2.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX1, AUD.SAI2.RXD, AUD.SPDIF0           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF0           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.GPDIF0.RX, LSIO.GPDIF0.RX           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.GPDIF0.TX, LSIO.GPDIF0.TX           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13           SC_P_ELEXCANO_RX         146         DMA.FLEXCANO.RX, LSIO.GPIO3.IO29           SC_P_FLEXCANO_TX         147         DMA.FLEXCANO.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_RX         148         DMA.FLEXCANO.TX, LSIO.GPIO3.IO31           SC_P_FLEXCANO_TX         149         DMA.FLEXCANO.TX, LSIO.GPIO4.IO00                                                                                                                                                                                                                                                                                                                         | SC_P_ESAI0_TX3_RX2    | 111   | AUD.ESAI0.TX3_RX2, LSIO.GPIO2.IO29                                 |
| SC_P_ESAIT_FSR         85         AUD.ESAIT.FSR, LSIO.GPIO2.IO04           SC_P_ESAIT_FST         86         AUD.ESAIT.FST, AUD.SPDIFO.EXT_CLK, LSIO           SC_P_ESAIT_SCKR         87         AUD.ESAIT.SCKR, LSIO.GPIO2.IO06           SC_P_ESAIT_SCKT         88         AUD.ESAIT.SCKT, AUD.SAIZ.RXC, AUD.SPDI           SC_P_ESAIT_TX0         89         AUD.ESAIT.TX0, AUD.SAIZ.RXD, AUD.SPDIFO           SC_P_ESAIT_TX1         90         AUD.ESAIT.TX1, AUD.SAIZ.RXFS, AUD.SPDIF           SC_P_ESAIT_TX2         91         AUD.ESAIT.TX2, RX3, AUD.SPDIFO.RX, LSIO.GP           SC_P_ESAIT_TX2_RX3         91         AUD.ESAIT.TX3, RX2, AUD.SPDIFO.TX, LSIO.GP           SC_P_ESAIT_TX3_RX2         92         AUD.ESAIT.TX3, RX2, AUD.SPDIFO.TX, LSIO.GP           SC_P_ESAIT_TX4_RX1         93         AUD.ESAIT.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAIT_TX5_RX0         94         AUD.ESAIT.TX5_RX0, LSIO.GPIO2.IO13           SC_P_ESAIT_TX5_RX0         94         AUD.ESAIT.TX5_RX0, LSIO.GPIO3.IO31           SC_P_FLEXCANO_RX         146         DMA.FLEXCANO.RX, LSIO.GPIO3.IO31           SC_P_FLEXCANI_RX         147         DMA.FLEXCANI.RX, LSIO.GPIO3.IO31           SC_P_FLEXCANI_RX         148         DMA.FLEXCANI.RX, LSIO.GPIO4.IO00           SC_P_FLEXCANI_RX         150         DMA.FLEXCANI.RX, LSIO.GPIO4.IO01                                                                                                                                                                                                                                                                                                                                                  | SC_P_ESAI0_TX4_RX1    | 112   | AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30                                 |
| SC_P_ESAI1_FST       86       AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO. → GPIO2.IO05         SC_P_ESAI1_SCKR       87       AUD.ESAI1.SCKR, LSIO.GPIO2.IO06         SC_P_ESAI1_SCKT       88       AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDI → F0.EXT_CLK, LSIO.GPIO2.IO07         SC_P_ESAI1_TX0       89       AUD.ESAI1.TX0, AUD.SAI2.RXD, AUD.SPDIF0. → RX, LSIO.GPIO2.IO08         SC_P_ESAI1_TX1       90       AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF → F0.TX, LSIO.GPIO2.IO09         SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G → PIO2.IO10         SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G → PIO2.IO11         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO12         SC_P_ESAI1_TX4_RX1       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO3         SC_P_FLEXCANO_RX       146       DMA.FLEXCANO.RX, LSIO.GPIO3.IO30         SC_P_FLEXCANI_RX       147       DMA.FLEXCANI.RX, LSIO.GPIO3.IO31         SC_P_FLEXCANI_TX       149       DMA.FLEXCANI.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.K → PPO.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_COMPARE       17       LSIO.GP                                                                                                                                                                                                                                                                                                                             | SC_P_ESAI0_TX5_RX0    | 113   | AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31                                 |
| GPIO2.IO05                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | SC_P_ESAI1_FSR        | 85    | AUD.ESAI1.FSR, LSIO.GPIO2.IO04                                     |
| SC_P_ESAI1_SCKR         87         AUD.ESAI1.SCKR, LSIO.GPI02.IO06           SC_P_ESAI1_SCKT         88         AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDI→ F0.EXT_CLK, LSIO.GPI02.IO07           SC_P_ESAI1_TX0         89         AUD.ESAI1.TX0, AUD.SAI2.RXD, AUD.SPDIF0.→ RX, LSIO.GPI02.IO08           SC_P_ESAI1_TX1         90         AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDI→ F0.TX, LSIO.GPI02.IO09           SC_P_ESAI1_TX2_RX3         91         AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G→ PI02.IO10           SC_P_ESAI1_TX3_RX2         92         AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G→ PI02.IO11           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPI02.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPI02.IO13           SC_P_FLEXCANO_RX         146         DMA.FLEXCANO.RX, LSIO.GPI03.IO29           SC_P_FLEXCANO_TX         147         DMA.FLEXCANO.TX, LSIO.GPI03.IO31           SC_P_FLEXCAN1_TX         148         DMA.FLEXCAN1.TX, LSIO.GPI04.IO00           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPI04.IO00           SC_P_FLEXCAN2_TX         150         DMA.FLEXCAN2.TX, LSIO.GPI04.IO01           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SCL, LSIO.KPP0.C→ OL4, LSIO.GPI00.IO15           SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI→ O.KPP0.COL6, LSIO.GPI00.IO16<                                                                                                                                                                                                                                                                         | SC_P_ESAI1_FST        | 86    | AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.↔                          |
| SC_P_ESAI1_SCKT       88       AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDI.         SC_P_ESAI1_TX0       89       AUD.ESAI1.TX0, AUD.SAI2.RXD, AUD.SPDIFO         SC_P_ESAI1_TX1       90       AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDI         SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIFO.RX, LSIO.G         SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIFO.RX, LSIO.G         PIO2.IO10       SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIFO.TX, LSIO.G         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_FLEXCANO_RX       146       DMA.FLEXCAN0.RX, LSIO.GPIO2.IO13         SC_P_FLEXCANO_TX       147       DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_TX       148       DMA.FLEXCAN1.TX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_TX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO01         SC_P_FLEXCAN2_TX       150       DMA.FLEXCAN2.TX, LSIO.GPIO4.IO01         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                       |       |                                                                    |
| F0.EXT_CLK, LSIO.GPIO2.IO07   SC_P_ESAI1_TX0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                       | 87    | · ·                                                                |
| SC_P_ESAI1_TX0       89       AUD.ESAI1.TX0, AUD.SAI2.RXD, AUD.SPDIFO. → RX, LSIO.GPIO2.IO08         SC_P_ESAI1_TX1       90       AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDI → F0.TX, LSIO.GPIO2.IO09         SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIFO.RX, LSIO.G → PIO2.IO10         SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIFO.TX, LSIO.G → PIO2.IO11         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_FLEXCANO_RX       146       DMA.FLEXCANO.RX, LSIO.GPIO3.IO29         SC_P_FLEXCANO_TX       147       DMA.FLEXCANO.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_RX       148       DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_TX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K → PPO.COL5, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE       17       LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI → O.K PPO.COL6, LSIO.GPIO0.IO16         SC_P_GPT1_CAPTURE       19       LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K → O.K PPO.COL6, LSIO.GPIO1.IO16                                                                                                                                                                                                                                                                                                                                                                                                                            | SC_P_ESAI1_SCKT       | 88    |                                                                    |
| RX, LSIO.GPIO2.IO08         SC_P_ESAI1_TX1       90       AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDI         F0.TX, LSIO.GPIO2.IO09       SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G         SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_FLEXCAN0_RX       146       DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29         SC_P_FLEXCAN0_TX       147       DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_RX       148       DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_TX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_FLEXCAN2_TX       151       DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                       |       |                                                                    |
| SC_P_ESAI1_TX1       90       AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDI         SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G         SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_FLEXCAN0_RX       146       DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29         SC_P_FLEXCAN0_TX       147       DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_RX       148       DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_RX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_FLEXCAN2_TX       151       DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CPTURE, DMA.I2C1.SDA, LSIO.K         PPO.COL5, LSIO.GPIO0.IO14       SC_P_GPT0_COMPARE       17       LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI         SC_P_GPT1_CAPTURE       19       LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | SC_P_ESAI1_TX0        | 89    | ·                                                                  |
| F0.TX, LSIO.GPIO2.IO09                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CO D FOALL TV4        | 00    | 1                                                                  |
| SC_P_ESAI1_TX2_RX3       91       AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G ↔ PIO2.IO10         SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G ↔ PIO2.IO11         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13         SC_P_FLEXCAN0_RX       146       DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29         SC_P_FLEXCAN0_TX       147       DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_RX       148       DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_TX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_FLEXCAN2_TX       151       DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K ↔ PPO.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK       15       LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPPO.C ↔ OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE       17       LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI ↔ O.KPPO.COL6, LSIO.GPIO0.IO16         SC_P_GPT1_CAPTURE       19       LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K ↔                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | SC_P_ESAII_IXI        | 90    | ·                                                                  |
| SC_P_ESAI1_TX3_RX2       92       AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.G→ PIO2.IO11         SC_P_ESAI1_TX4_RX1       93       AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12         SC_P_ESAI1_TX5_RX0       94       AUD.ESAI1.TX5_RX0, LSIO.GPIO3.IO29         SC_P_FLEXCAN0_RX       146       DMA.FLEXCAN0.RX, LSIO.GPIO3.IO30         SC_P_FLEXCAN0_TX       147       DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30         SC_P_FLEXCAN1_RX       148       DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31         SC_P_FLEXCAN1_TX       149       DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00         SC_P_FLEXCAN2_RX       150       DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01         SC_P_FLEXCAN2_TX       151       DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02         SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←         SC_P_GPT0_CLK       15       LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←         OL4, LSIO.GPIO0.IO14       SC_P_GPT1_CAPTURE       17       LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←         SC_P_GPT1_CAPTURE       19       LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SC_P_ESAI1_TX2_RX3    | 91    | AUD.ESAI1.TX2_RX3, AUD.SPDIF0.RX, LSIO.G↔                          |
| PIO2.IO11           SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13           SC_P_FLEXCAN0_RX         146         DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29           SC_P_FLEXCAN0_TX         147         DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30           SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                       |       |                                                                    |
| SC_P_ESAI1_TX4_RX1         93         AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12           SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13           SC_P_FLEXCAN0_RX         146         DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29           SC_P_FLEXCAN0_TX         147         DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30           SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | SC_P_ESAI1_TX3_RX2    | 92    | _ :                                                                |
| SC_P_ESAI1_TX5_RX0         94         AUD.ESAI1.TX5_RX0, LSIO.GPIO2.IO13           SC_P_FLEXCAN0_RX         146         DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29           SC_P_FLEXCAN0_TX         147         DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30           SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       |       |                                                                    |
| SC_P_FLEXCAN0_RX         146         DMA.FLEXCAN0.RX, LSIO.GPIO3.IO29           SC_P_FLEXCAN0_TX         147         DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30           SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K ← PP0.COL5, LSIO.GPIO0.IO15           SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C ← OL4, LSIO.GPIO0.IO14           SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI ← O.KPP0.COL6, LSIO.GPIO0.IO16           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                       | 1     | _                                                                  |
| SC_P_FLEXCAN0_TX         147         DMA.FLEXCAN0.TX, LSIO.GPIO3.IO30           SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                       |       | _ '                                                                |
| SC_P_FLEXCAN1_RX         148         DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31           SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |       | ·                                                                  |
| SC_P_FLEXCAN1_TX         149         DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00           SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                       |       | 1                                                                  |
| SC_P_FLEXCAN2_RX         150         DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01           SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                       |       | ·                                                                  |
| SC_P_FLEXCAN2_TX         151         DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02           SC_P_GPT0_CAPTURE         16         LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←           PP0.COL5, LSIO.GPIO0.IO15         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←           OL4, LSIO.GPIO0.IO14         OL4, LSIO.GPIO0.IO14         SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←           O.KPP0.COL6, LSIO.GPIO0.IO16         SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                       | 149   | 1                                                                  |
| SC_P_GPT0_CAPTURE       16       LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.K←         PP0.COL5, LSIO.GPI00.IO15       15       LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C←         OL4, LSIO.GPI00.IO14       17       LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←         O.KPP0.COL6, LSIO.GPI00.IO16       19       LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SC_P_FLEXCAN2_RX      | 150   | •                                                                  |
| PP0.COL5, LSIO.GPIO0.IO15           SC_P_GPT0_CLK         15         LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C ← OL4, LSIO.GPIO0.IO14           SC_P_GPT0_COMPARE         17         LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI ← O.KPP0.COL6, LSIO.GPIO0.IO16           SC_P_GPT1_CAPTURE         19         LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | SC_P_FLEXCAN2_TX      | 151   | DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02                                   |
| SC_P_GPT0_CLK15LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C ←<br>OL4, LSIO.GPI00.IO14SC_P_GPT0_COMPARE17LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI ←<br>O.KPP0.COL6, LSIO.GPI00.IO16SC_P_GPT1_CAPTURE19LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K ←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SC_P_GPT0_CAPTURE     | 16    | · ·                                                                |
| SC_P_GPT0_COMPARE17LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSI←<br>O.KPP0.COL6, LSIO.GPIO0.IO16SC_P_GPT1_CAPTURE19LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SC_P_GPT0_CLK         | 15    | LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.C↔                          |
| O.KPP0.COL6, LSIO.GPIO0.IO16  SC_P_GPT1_CAPTURE 19 LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K←                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SC P GPT0 COMPARE     | 17    | *                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 30_1_GFT0_OOMFARE     | 17    |                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | SC_P_GPT1_CAPTURE     | 19    | LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.K← PP0.ROW4, LSIO.GPIO0.IO18 |

| Pad                     | Index | Mux Options                                                    |
|-------------------------|-------|----------------------------------------------------------------|
| SC_P_GPT1_CLK           | 18    | LSIO.GPT1.CLK, DMA.I2C2.SCL, LSIO.KPP0.C↔                      |
|                         |       | OL7, LSIO.GPIO0.IO17                                           |
| SC_P_GPT1_COMPARE       | 20    | LSIO.GPT1.COMPARE, LSIO.PWM2.OUT, LSI←                         |
| CC D LIDMI TVO TC CCI   | 00    | O.KPP0.ROW5, LSIO.GPIO0.IO19                                   |
| SC_P_HDMI_TX0_TS_SCL    | 82    | HDMI_TX0.I2C0.SCL, DMA.I2C0.SCL, LSIO.GPI↔ O2.IO02             |
| SC_P_HDMI_TX0_TS_SDA    | 83    | HDMI_TX0.I2C0.SDA, DMA.I2C0.SDA, LSIO.GP←                      |
| GG_Ib.liii_1740_16_65/4 |       | IO2.IO03                                                       |
| SC_P_LVDS0_GPIO00       | 50    | LVDS0.GPIO0.IO00, LVDS0.PWM0.OUT, LSIO.↔                       |
|                         |       | GPIO1.IO04                                                     |
| SC_P_LVDS0_GPIO01       | 51    | LVDS0.GPIO0.IO01, LSIO.GPIO1.IO05                              |
| SC_P_LVDS0_I2C0_SCL     | 52    | LVDS0.I2C0.SCL, LVDS0.GPIO0.IO02, LSIO.GP←                     |
| SC_P_LVDS0_I2C0_SDA     | 53    | IO1.IO06<br>  LVDS0.I2C0.SDA, LVDS0.GPIO0.IO03, LSIO.G↔        |
| 30_F_LVD30_1200_3DA     | 33    | PIO1.IO07                                                      |
| SC_P_LVDS0_I2C1_SCL     | 54    | LVDS0.I2C1.SCL, DMA.UART2.TX, LSIO.GPI↔                        |
|                         |       | O1.IO08                                                        |
| SC_P_LVDS0_I2C1_SDA     | 55    | LVDS0.I2C1.SDA, DMA.UART2.RX, LSIO.GPI↔                        |
|                         |       | O1.IO09                                                        |
| SC_P_LVDS1_GPIO00       | 56    | LVDS1.GPIO0.IO00, LVDS1.PWM0.OUT, LSIO.←                       |
| SC P LVDS1 GPIO01       | 57    | GPIO1.IO10<br>LVDS1.GPIO0.IO01, LSIO.GPIO1.IO11                |
| SC_P_LVDS1_GF1001       | 58    | LVDS1.I2C0.SCL, LVDS1.GPIO0.IO02, LSIO.GP↔                     |
| 30_F_LVD31_1200_30L     | 36    | 101.1012                                                       |
| SC P LVDS1 I2C0 SDA     | 59    | LVDS1.I2C0.SDA, LVDS1.GPIO0.IO03, LSIO.G↔                      |
|                         |       | PIO1.IO13                                                      |
| SC_P_LVDS1_I2C1_SCL     | 60    | LVDS1.I2C1.SCL, DMA.UART3.TX, LSIO.GPI↔                        |
|                         |       | 01.1014                                                        |
| SC_P_LVDS1_I2C1_SDA     | 61    | LVDS1.I2C1.SDA, DMA.UART3.RX, LSIO.GPI↔ O1.IO15                |
| SC P M40 GPIO0 00       | 9     | M40.GPIO0.IO00, M40.TPM0.CH0, DMA.UAR↔                         |
| SS_10_G1                |       | T4.RX, LSIO.GPIO0.IO08                                         |
| SC_P_M40_GPIO0_01       | 10    | M40.GPIO0.IO01, M40.TPM0.CH1, DMA.UAR↔                         |
|                         |       | T4.TX, LSIO.GPIO0.IO09                                         |
| SC_P_M40_I2C0_SCL       | 7     | M40.I2C0.SCL, M40.UART0.RX, M40.GPIO0.I↔                       |
|                         |       | O02, LSIO.GPIO0.IO06                                           |
| SC_P_M40_I2C0_SDA       | 8     | M40.I2C0.SDA, M40.UART0.TX, M40.GPIO0.IO03,                    |
| CC D MAL CDIOD 00       | 13    | LSIO.GPIO0.IO07                                                |
| SC_P_M41_GPIO0_00       | 13    | M41.GPIO0.IO00, M41.TPM0.CH0, DMA.UAR ← T3.RX, LSIO.GPIO0.IO12 |
| SC P M41 GPIO0 01       | 14    | M41.GPIO0.IO01, M41.TPM0.CH1, DMA.UAR↔                         |
|                         | ' '   | T3.TX, LSIO.GPIO0.IO13                                         |
| SC_P_M41_I2C0_SCL       | 11    | M41.I2C0.SCL, M41.UART0.RX, M41.GPIO0.I↔                       |
|                         |       | O02, LSIO.GPIO0.IO10                                           |
| SC_P_M41_I2C0_SDA       | 12    | M41.I2C0.SDA, M41.UART0.TX, M41.GPIO0.IO03,                    |
|                         |       | LSIO.GPIO0.IO11                                                |
| SC_P_MCLK_IN0           | 114   | AUD.ACM.MCLK_INO, AUD.ESAIO.RX_HF_CLK,                         |
| CO P MOLIC OUTS         | 445   | AUD ACM MOLK OUTS AUD FOAD TV HE C                             |
| SC_P_MCLK_OUT0          | 115   | AUD.ACM.MCLK_OUTO, AUD.ESAI0.TX_HF_C↔                          |
|                         |       | LK, AUD.ESAI1.TX_HF_CLK, LSIO.GPIO3.IO01                       |

| Pad                      | Index | Mux Options                                                               |
|--------------------------|-------|---------------------------------------------------------------------------|
| SC_P_MIPI_CSI0_GPIO0_00  | 75    | MIPI_CSI0.GPIO0.IO00, DMA.I2C0.SCL, MIPI_                                 |
|                          |       | CSI1.I2C0.SCL, LSIO.GPIO1.IO27                                            |
| SC_P_MIPI_CSI0_GPIO0_01  | 76    | MIPI_CSI0.GPIO0.IO01, DMA.I2C0.SDA, MIPI_←                                |
|                          |       | CSI1.I2C0.SDA, LSIO.GPIO1.IO28                                            |
| SC_P_MIPI_CSI0_I2C0_SCL  | 73    | MIPI_CSI0.I2C0.SCL, LSIO.GPIO1.IO25                                       |
| SC_P_MIPI_CSI0_I2C0_SDA  | 74    | MIPI_CSI0.I2C0.SDA, LSIO.GPIO1.IO26                                       |
| SC_P_MIPI_CSI0_MCLK_OUT  | 72    | MIPI_CSI0.ACM.MCLK_OUT, LSIO.GPIO1.IO24                                   |
| SC_P_MIPI_CSI1_GPIO0_00  | 78    | MIPI_CSI1.GPIO0.IO00, DMA.UART4.RX, LSIO. ← GPIO1.IO30                    |
| SC_P_MIPI_CSI1_GPIO0_01  | 79    | MIPI_CSI1.GPIO0.IO01, DMA.UART4.TX, LSIO.↔<br>GPIO1.IO31                  |
| SC_P_MIPI_CSI1_I2C0_SCL  | 80    | MIPI_CSI1.I2C0.SCL, LSIO.GPIO2.IO00                                       |
| SC_P_MIPI_CSI1_I2C0_SDA  | 81    | MIPI_CSI1.I2C0.SDA, LSIO.GPIO2.IO01                                       |
| SC_P_MIPI_CSI1_MCLK_OUT  | 77    | MIPI_CSI1.ACM.MCLK_OUT, LSIO.GPIO1.IO29                                   |
| SC_P_MIPI_DSI0_GPIO0_00  | 65    | MIPI_DSI0.GPIO0.IO00, MIPI_DSI0.PWM0.OUT, LSIO.GPIO1.IO18                 |
| SC_P_MIPI_DSI0_GPIO0_01  | 66    | MIPI_DSI0.GPIO0.IO01, LSIO.GPIO1.IO19                                     |
| SC_P_MIPI_DSI0_I2C0_SCL  | 63    | MIPI_DSI0.I2C0.SCL, LSIO.GPIO1.IO16                                       |
| SC_P_MIPI_DSI0_I2C0_SDA  | 64    | MIPI_DSI0.I2C0.SDA, LSIO.GPIO1.IO17                                       |
| SC_P_MIPI_DSI1_GPIO0_00  | 69    | MIPI_DSI1.GPIO0.IO00, MIPI_DSI1.PWM0.OUT,                                 |
|                          |       | LSIO.GPIO1.IO22                                                           |
| SC_P_MIPI_DSI1_GPIO0_01  | 70    | MIPI_DSI1.GPIO0.IO01, LSIO.GPIO1.IO23                                     |
| SC_P_MIPI_DSI1_I2C0_SCL  | 67    | MIPI_DSI1.I2C0.SCL, LSIO.GPIO1.IO20                                       |
| SC_P_MIPI_DSI1_I2C0_SDA  | 68    | MIPI_DSI1.I2C0.SDA, LSIO.GPIO1.IO21                                       |
| SC_P_MLB_CLK             | 143   | CONN.MLB.CLK, AUD.SAI3.RXFS, LSIO.GPI↔ O3.IO27                            |
| SC_P_MLB_DATA            | 144   | CONN.MLB.DATA, AUD.SAI3.RXD, LSIO.GPI↔ O3.IO28                            |
| SC_P_MLB_SIG             | 142   | CONN.MLB.SIG, AUD.SAI3.RXC, LSIO.GPIO3.I↔<br>O26                          |
| SC_P_PCIE_CTRL0_CLKREQ_B | 198   | HSIO.PCIE0.CLKREQ_B, LSIO.GPIO4.IO27                                      |
| SC_P_PCIE_CTRL0_PERST_B  | 200   | HSIO.PCIE0.PERST_B, LSIO.GPIO4.IO29                                       |
| SC_P_PCIE_CTRL0_WAKE_B   | 199   | HSIO.PCIE0.WAKE_B, LSIO.GPIO4.IO28                                        |
| SC_P_PCIE_CTRL1_CLKREQ_B | 201   | HSIO.PCIE1.CLKREQ_B, DMA.I2C1.SDA, CON←<br>N.USB_OTG2.OC, LSIO.GPIO4.IO30 |
| SC_P_PCIE_CTRL1_PERST_B  | 203   | HSIO.PCIE1.PERST_B, DMA.I2C1.SCL, CONN.←<br>USB_OTG1.PWR, LSIO.GPIO5.IO00 |
| SC_P_PCIE_CTRL1_WAKE_B   | 202   | HSIO.PCIE1.WAKE_B, DMA.I2C1.SCL, CONN.↔ USB_OTG2.PWR, LSIO.GPIO4.IO31     |
| SC_P_PMIC_EARLY_WARNING  | 34    | SCU.PMIC_EARLY_WARNING                                                    |
| SC P PMIC I2C SCL        | 33    | SCU.PMIC I2C.SCL                                                          |
| SC_P_PMIC_I2C_SDA        | 32    | SCU.PMIC I2C.SDA                                                          |
| SC_P_PMIC_INT_B          | 35    | SCU.DSC.PMIC_INT_B                                                        |
| SC_P_QSPI0A_DATA0        | 181   | LSIO.QSPI0A.DATA0                                                         |
| SC_P_QSPI0A_DATA1        | 182   | LSIO.QSPI0A.DATA1                                                         |
| SC_P_QSPI0A_DATA2        | 183   | LSIO.QSPI0A.DATA2                                                         |
| SC_P_QSPI0A_DATA3        | 184   | LSIO.QSPI0A.DATA3                                                         |
| SC_P_QSPI0A_DQS          | 185   | LSIO.QSPI0A.DQS                                                           |
| SC P QSPI0A SCLK         | 188   | LSIO.QSPI0A.SCLK                                                          |

| Pad                 | Index | Mux Options                                 |
|---------------------|-------|---------------------------------------------|
| SC_P_QSPI0A_SS0_B   | 186   | LSIO.QSPI0A.SS0_B                           |
| SC_P_QSPI0A_SS1_B   | 187   | LSIO.QSPI0A.SS1_B, LSIO.QSPI0A.SCLK2        |
| SC_P_QSPI0B_DATA0   | 190   | LSIO.QSPI0B.DATA0                           |
| SC_P_QSPI0B_DATA1   | 191   | LSIO.QSPI0B.DATA1                           |
| SC P QSPI0B DATA2   | 192   | LSIO.QSPI0B.DATA2                           |
| SC P QSPI0B DATA3   | 193   | LSIO.QSPI0B.DATA3                           |
| SC_P_QSPI0B_DQS     | 194   | LSIO.QSPI0B.DQS                             |
| SC_P_QSPI0B_SCLK    | 189   | LSIO.QSPI0B.SCLK                            |
| SC P QSPI0B SS0 B   | 195   | LSIO.QSPI0B.SS0 B                           |
| SC P QSPI0B SS1 B   | 196   | LSIO.QSPI0B.SS1 B, LSIO.QSPI0B.SCLK2        |
| SC_P_QSPI1A_DATA0   | 179   | LSIO.QSPI1A.DATA0, LSIO.GPIO4.IO26          |
| SC P QSPI1A DATA1   | 178   | LSIO.QSPI1A.DATA1, DMA.I2C1.SDA, CONN.U←    |
|                     |       | SB_OTG2.OC, LSIO.GPIO4.IO25                 |
| SC P QSPI1A DATA2   | 177   | LSIO.QSPI1A.DATA2, DMA.I2C1.SCL, CONN.U←    |
|                     |       | SB_OTG2.PWR, LSIO.GPIO4.IO24                |
| SC_P_QSPI1A_DATA3   | 176   | LSIO.QSPI1A.DATA3, DMA.I2C1.SDA, CONN.U↔    |
|                     |       | SB_OTG1.OC, LSIO.GPIO4.IO23                 |
| SC_P_QSPI1A_DQS     | 175   | LSIO.QSPI1A.DQS, LSIO.GPIO4.IO22            |
| SC_P_QSPI1A_SCLK    | 174   | LSIO.QSPI1A.SCLK, LSIO.GPIO4.IO21           |
| SC_P_QSPI1A_SS0_B   | 172   | LSIO.QSPI1A.SS0_B, LSIO.GPIO4.IO19          |
| SC_P_QSPI1A_SS1_B   | 173   | LSIO.QSPI1A.SS1_B, LSIO.QSPI1A.SCLK2, LSI←  |
|                     |       | O.GPIO4.IO20                                |
| SC_P_SAI1_RXC       | 127   | AUD.SAI1.RXC, AUD.SAI0.TXD, LSIO.GPIO3.IO12 |
| SC_P_SAI1_RXD       | 128   | AUD.SAI1.RXD, AUD.SAI0.TXFS, LSIO.GPIO3.I←  |
|                     |       | O13                                         |
| SC_P_SAI1_RXFS      | 129   | AUD.SAI1.RXFS, AUD.SAI0.RXD, LSIO.GPIO3.I←  |
| 00 B 044 TV0        | 400   | 014                                         |
| SC_P_SAI1_TXC       | 130   | AUD.SAI1.TXC, AUD.SAI0.TXC, LSIO.GPIO3.IO15 |
| SC_P_SAI1_TXD       | 131   | AUD.SAI1.TXD, AUD.SAI1.RXC, LSIO.GPIO3.IO16 |
| SC_P_SAI1_TXFS      | 132   | AUD.SAI1.TXFS, AUD.SAI1.RXFS, LSIO.GPIO3.↔  |
| SC P SCU BOOT MODE0 | 44    | IO17 SCU.DSC.BOOT_MODE0                     |
| SC_P_SCU_BOOT_MODE1 | 45    | SCU.DSC.BOOT_MODE1                          |
| SC P SCU BOOT MODE2 | 46    | SCU.DSC.BOOT_MODE1                          |
| SC P SCU BOOT MODE3 | 47    | SCU.DSC.BOOT_MODE3                          |
| SC P SCU BOOT MODE4 | 48    | SCU.DSC.BOOT_MODE4, SCU.PMIC_I2C.SCL        |
| SC P SCU BOOT MODE5 | 49    | SCU.DSC.BOOT MODE5, SCU.PMIC 12C.SDA        |
| SC P SCU GPIO0 00   |       | SCU.GPIO0.IO00, SCU.UARTO.RX, LSIO.GPI      |
| SC_P_SCU_GPIOU_00   | 36    | O0.IO28                                     |
| SC P SCU GPIO0 01   | 37    | SCU.GPIO0.IO01, SCU.UART0.TX, LSIO.GPI←     |
| 00_1 _000_d1 100_01 | 07    | 00.1029                                     |
| SC P SCU GPIO0 02   | 38    | SCU.GPIO0.IO02, SCU.GPIO0.IOXX_PMIC_GP←     |
|                     |       | U0_ON, LSIO.GPIO0.IO30                      |
| SC_P_SCU_GPIO0_03   | 39    | SCU.GPIO0.IO03, SCU.GPIO0.IOXX_PMIC_GP←     |
|                     |       | U1_ON, LSIO.GPIO0.IO31                      |
| SC_P_SCU_GPIO0_04   | 40    | SCU.GPIO0.IO04, SCU.GPIO0.IOXX_PMIC_        |
|                     |       | A72_ON, LSIO.GPIO1.IO00                     |
| SC_P_SCU_GPIO0_05   | 41    | SCU.GPIO0.IO05, SCU.GPIO0.IOXX_PMIC_←       |
|                     |       | A53_ON, LSIO.GPIO1.IO01                     |

| Pad                   | Index | Mux Options                                                          |
|-----------------------|-------|----------------------------------------------------------------------|
| SC_P_SCU_GPIO0_06     | 42    | SCU.GPIO0.IO06, SCU.TPM0.CH0, LSIO.GPI←                              |
|                       |       | O1.IO02                                                              |
| SC_P_SCU_GPIO0_07     | 43    | SCU.GPIO0.IO07, SCU.TPM0.CH1, SCU.DSC.R←                             |
|                       |       | TC_CLOCK_OUTPUT_32K, LSIO.GPIO1.IO03                                 |
| SC_P_SCU_PMIC_MEMC_ON | 30    | SCU.GPIO0.IOXX_PMIC_MEMC_ON                                          |
| SC_P_SCU_WDOG_OUT     | 31    | SCU.WDOG0.WDOG_OUT                                                   |
| SC_P_SIM0_CLK         | 0     | DMA.SIM0.CLK, LSIO.GPIO0.IO00                                        |
| SC_P_SIM0_GPIO0_00    | 5     | DMA.SIM0.POWER_EN, LSIO.GPIO0.IO05                                   |
| SC_P_SIM0_IO          | 2     | DMA.SIM0.IO, LSIO.GPIO0.IO02                                         |
| SC_P_SIM0_PD          | 3     | DMA.SIM0.PD, DMA.I2C3.SCL, LSIO.GPIO0.IO03                           |
| SC_P_SIM0_POWER_EN    | 4     | DMA.SIM0.POWER_EN, DMA.I2C3.SDA, LSIO.↔<br>GPIO0.IO04                |
| SC_P_SIM0_RST         | 1     | DMA.SIM0.RST, LSIO.GPIO0.IO01                                        |
| SC_P_SPDIF0_EXT_CLK   | 97    | AUD.SPDIF0.EXT_CLK, DMA.DMA0.REQ_IN0, LSIO.GPIO2.IO16                |
| SC_P_SPDIF0_RX        | 95    | AUD.SPDIF0.RX, AUD.MQS.R, AUD.ACM.MCLK↔ _IN1, LSIO.GPIO2.IO14        |
| SC_P_SPDIF0_TX        | 96    | AUD.SPDIF0.TX, AUD.MQS.L, AUD.ACM.MCLK←<br>_OUT1, LSIO.GPIO2.IO15    |
| SC_P_SPI0_CS0         | 120   | DMA.SPI0.CS0, AUD.SAI0.RXFS, LSIO.GPIO3.I↔ 005                       |
| SC_P_SPI0_CS1         | 121   | DMA.SPI0.CS1, AUD.SAI0.TXC, LSIO.GPIO3.IO06                          |
| SC_P_SPI0_SCK         | 117   | DMA.SPI0.SCK, AUD.SAI0.RXC, LSIO.GPIO3.I↔ 002                        |
| SC_P_SPI0_SDI         | 119   | DMA.SPI0.SDI, AUD.SAI0.RXD, LSIO.GPIO3.IO04                          |
| SC_P_SPI0_SDO         | 118   | DMA.SPI0.SDO, AUD.SAI0.TXD, LSIO.GPIO3.I↔ O03                        |
| SC_P_SPI2_CS0         | 125   | DMA.SPI2.CS0, LSIO.GPIO3.IO10                                        |
| SC_P_SPI2_CS1         | 126   | DMA.SPI2.CS1, AUD.SAI0.TXFS, LSIO.GPIO3.I↔<br>O11                    |
| SC_P_SPI2_SCK         | 122   | DMA.SPI2.SCK, LSIO.GPIO3.IO07                                        |
| SC_P_SPI2_SDI         | 124   | DMA.SPI2.SDI, LSIO.GPIO3.IO09                                        |
| SC_P_SPI2_SDO         | 123   | DMA.SPI2.SDO, LSIO.GPIO3.IO08                                        |
| SC_P_SPI3_CS0         | 101   | DMA.SPI3.CS0, DMA.FTM.CH2, LSIO.GPIO2.I↔<br>O20                      |
| SC_P_SPI3_CS1         | 102   | DMA.SPI3.CS1, LSIO.GPIO2.IO21                                        |
| SC_P_SPI3_SCK         | 98    | DMA.SPI3.SCK, LSIO.GPIO2.IO17                                        |
| SC_P_SPI3_SDI         | 100   | DMA.SPI3.SDI, DMA.FTM.CH1, LSIO.GPIO2.IO19                           |
| SC_P_SPI3_SDO         | 99    | DMA.SPI3.SDO, DMA.FTM.CH0, LSIO.GPIO2.I↔<br>O18                      |
| SC_P_UART0_CTS_B      | 24    | DMA.UARTO.CTS_B, LSIO.PWM1.OUT, DMA.U↔ ART2.TX, LSIO.GPIO0.IO23      |
| SC_P_UART0_RTS_B      | 23    | DMA.UARTO.RTS_B, LSIO.PWM0.OUT, DMA.U↔ ART2.RX, LSIO.GPIO0.IO22      |
| SC_P_UART0_RX         | 21    | DMA.UART0.RX, SCU.UART0.RX, LSIO.GPIO0.↔                             |
| SC_P_UART0_TX         | 22    | DMA.UART0.TX, SCU.UART0.TX, LSIO.GPIO0.I↔ O21                        |
| SC_P_UART1_CTS_B      | 28    | DMA.UART1.CTS_B, DMA.SPI3.CS0, DMA.UA↔<br>RT1.RTS_B, LSIO.GPIO0.IO27 |

| Pad                   | Index | Mux Options                                                                    |
|-----------------------|-------|--------------------------------------------------------------------------------|
| SC_P_UART1_RTS_B      | 27    | DMA.UART1.RTS_B, DMA.SPI3.SDI, DMA.UAR←<br>T1.CTS B, LSIO.GPIO0.IO26           |
| SC_P_UART1_RX         | 26    | DMA.UART1.RX, DMA.SPI3.SDO, LSIO.GPIO0.I↔<br>O25                               |
| SC_P_UART1_TX         | 25    | DMA.UART1.TX, DMA.SPI3.SCK, LSIO.GPIO0.I↔<br>O24                               |
| SC_P_USB_HSIC0_DATA   | 205   | CONN.USB_HSICO.DATA, DMA.I2C1.SDA, LSI←<br>O.GPIO5.IO01                        |
| SC_P_USB_HSIC0_STROBE | 206   | CONN.USB_HSIC0.STROBE, DMA.I2C1.SCL, L← SIO.GPIO5.IO02                         |
| SC_P_USB_SS3_TC0      | 153   | DMA.I2C1.SCL, CONN.USB_OTG1.PWR, LSIO.←<br>GPIO4.IO03                          |
| SC_P_USB_SS3_TC1      | 154   | DMA.I2C1.SCL, CONN.USB_OTG2.PWR, LSIO.←<br>GPIO4.IO04                          |
| SC_P_USB_SS3_TC2      | 155   | DMA.I2C1.SDA, CONN.USB_OTG1.OC, LSIO.G↔ PIO4.IO05                              |
| SC_P_USB_SS3_TC3      | 156   | DMA.I2C1.SDA, CONN.USB_OTG2.OC, LSIO.G← PIO4.IO06                              |
| SC_P_USDHC1_CLK       | 222   | CONN.USDHC1.CLK, AUD.MQS.R                                                     |
| SC_P_USDHC1_CMD       | 223   | CONN.USDHC1.CMD, AUD.MQS.L, LSIO.GPI↔ O5.IO14                                  |
| SC_P_USDHC1_DATA0     | 224   | CONN.USDHC1.DATA0, CONN.NAND.RE_N, L↔ SIO.GPIO5.IO15                           |
| SC_P_USDHC1_DATA1     | 225   | CONN.USDHC1.DATA1, CONN.NAND.RE_P, L⇔ SIO.GPIO5.IO16                           |
| SC_P_USDHC1_DATA2     | 227   | CONN.USDHC1.DATA2, CONN.NAND.DQS_N, LSIO.GPIO5.IO17                            |
| SC_P_USDHC1_DATA3     | 228   | CONN.USDHC1.DATA3, CONN.NAND.DQS_P, LSIO.GPIO5.IO18                            |
| SC_P_USDHC1_DATA4     | 230   | CONN.USDHC1.DATA4, CONN.NAND.CE0_B, AUD.MQS.R, LSIO.GPIO5.IO19                 |
| SC_P_USDHC1_DATA5     | 231   | CONN.USDHC1.DATA5, CONN.NAND.RE_B, A← UD.MQS.L, LSIO.GPIO5.IO20                |
| SC_P_USDHC1_DATA6     | 232   | CONN.USDHC1.DATA6, CONN.NAND.WE_B, C←ONN.USDHC1.WP, LSIO.GPIO5.IO21            |
| SC_P_USDHC1_DATA7     | 233   | CONN.USDHC1.DATA7, CONN.NAND.ALE, CO↔ NN.USDHC1.CD_B, LSIO.GPIO5.IO22          |
| SC_P_USDHC1_RESET_B   | 158   | CONN.USDHC1.RESET_B, LSIO.GPIO4.IO07                                           |
| SC_P_USDHC1_STROBE    | 234   | CONN.USDHC1.STROBE, CONN.NAND.CE1_←<br>B, CONN.USDHC1.RESET_B, LSIO.GPIO5.IO23 |
| SC_P_USDHC1_VSELECT   | 159   | CONN.USDHC1.VSELECT, LSIO.GPIO4.IO08                                           |
| SC_P_USDHC2_CD_B      | 163   | CONN.USDHC2.CD_B, LSIO.GPIO4.IO12                                              |
| SC_P_USDHC2_CLK       | 236   | CONN.USDHC2.CLK, AUD.MQS.R, LSIO.GPI↔ O5.IO24                                  |
| SC_P_USDHC2_CMD       | 237   | CONN.USDHC2.CMD, AUD.MQS.L, LSIO.GPI↔ O5.IO25                                  |
| SC_P_USDHC2_DATA0     | 238   | CONN.USDHC2.DATA0, DMA.UART4.RX, LSI←<br>O.GPIO5.IO26                          |
| SC_P_USDHC2_DATA1     | 239   | CONN.USDHC2.DATA1, DMA.UART4.TX, LSIO.←<br>GPIO5.IO27                          |

| Pad                 | Index | Mux Options                            |
|---------------------|-------|----------------------------------------|
| SC_P_USDHC2_DATA2   | 240   | CONN.USDHC2.DATA2, DMA.UART4.CTS_B, L↔ |
|                     |       | SIO.GPIO5.IO28                         |
| SC_P_USDHC2_DATA3   | 241   | CONN.USDHC2.DATA3, DMA.UART4.RTS_B, L↔ |
|                     |       | SIO.GPI05.I029                         |
| SC_P_USDHC2_RESET_B | 160   | CONN.USDHC2.RESET_B, LSIO.GPIO4.IO09   |
| SC_P_USDHC2_VSELECT | 161   | CONN.USDHC2.VSELECT, LSIO.GPIO4.IO10   |
| SC_P_USDHC2_WP      | 162   | CONN.USDHC2.WP, LSIO.GPIO4.IO11        |

### **RPC Protocol**

Clients of the SCFW make function calls using a Remote Procedure Call (RPC) mechanism. This is constructed on top of an Inter-Processor Communication (IPC) layer. The RPC mechanism is independent of the IPC mechanism. All that is required is that the IPC mechanism can send and receive messages consisting of a series of 32-bit words. Message lengths can vary between different APIs but are fixed for a specific API.

The RPC protocol is documented here for reference ONLY. It is expected clients will make use of the exported API. Using the protocol directly is not supported and makes it impossible to provide customer support.

### 10.1 Remote Procedure Call

The RPC implementation is all generated via script. Interface Description Language (IDL) lines exist in the API header files to describe the calling conventions of each API call. This supports integer and unsigned values of 8-, 16-, 32-, and 64-bit sizes. Special provisions are also provided for boolean types and error returns. Float is not supported.

The RPC mechanism is synchronous. Almost all API calls construct a series of 32-bit words to form a request, send the request, receive a response, deconstruct the response (also a series of 32-bit words), and return to the caller. The corresponding function on the SCFW side (server side) is not called until a complete valid request is received.

Messages consist of a header followed by a variable number of parameter words. Parameter words are packed starting with the largest parameters. Parameters passed by pointer may exist in the send request and the response depending on how they are defined in the IDL (in, out, both). Empty slots are undefined and may not be 0.

The header is a single 32-bit word consisting of four bytes:

- · version the protocol version
- size size of the message in words including the header
- · svc service index
- · func function index within the service

Note for return messages, svc=1U. Also, to minimize the number of words in the return value, func is replaced by the return value if it is an 8-bit type.

58 RPC Protocol

### 10.2 Inter-Processor Communication

The primary IPC mechanism implemented by the SCFW is via Message Unit (MU) IP (up to eight of them).

The MU has four TX and four RX registers, each capable of generating an interrupt. The SCFW IPC uses all four to create a single channel in both directions.

All message start with the first MU TX register. Words are written in order into successive registers and wrap back to the first if the message is greater than four words. Transmission blocks if the next TX register is not empty. The response is handled the same way. It always starts with the first RX register and wraps if the message is longer than four words. Transmission blocks if the next RX register is empty. On the SCFW-side, this is all interrupt driven. The message is buffered (per MU) and the API call into the SCFW only occurs when a complete valid request is received.

RPC messages can take many mS to complete. The API is fully synchronous and a timeout period should not be used as it would confuse the IPC state machine in the SCFW.

There is also an IPC mechanism implemented via UART as part of the SCFW debug monitor. This can be used to write test code that runs on a host connected via the SCU UART.

### 10.3 Interrupts

### 10.3.1 SCFW to Client Interrupts

The client-side IPC driver usually makes use of the MU TX/RX interrupts to transfer data. In addition, the SCFW makes use of the MU general-purpose interrupts to inform the client of various events that need attention. These four interrupts are defined in the rpc.h file delivered as part of the API export package:

| Interrupt          | MU GIRx | Use                       |
|--------------------|---------|---------------------------|
| SC_RPC_MU_GIR_SVC  | 0       | Interrupt Service Request |
| SC_RPC_MU_GIR_WAKE | 1       | Cortex-M Wake             |
| SC_RPC_MU_GIR_BOOT | 2       | Cold Boot Flag            |
| SC_RPC_MU_GIR_DBG  | 3       | Cortex-M Debug Wake       |

#### 10.3.1.1 Interrupt Service Request

This interrupt is generated when the SCFW needs servicing. This behavior is managed using the Interrupt Service API. Interrupts are collected into groups, each containing up to 32 interrupts. The groups and interrupts are listed in the api.h file for the interrupt service.

The client should call <code>sc\_irq\_enable()</code> to enable an interrupt. When the interrupt is serviced, the client should call <code>sc\_irq\_status()</code> for each group to determine the needed actions and figure out what component (i.e. OS driver) call-backs should be called. Calling <code>sc\_irq\_status()</code> also clears the pending status of the interrupt. As a result, the SCFW Interrupt Service acts as an interrupt collector/dispatcher mechanism.

#### 10.3.1.2 Cortex-M Wake

This MU general-purpose IRQ is used to force a wakeup event prior to stopping a Cortex-M CPU in order to maintain coherency between the AWIC and core sleep state. Cortex-M SW should always enable.

10.4 Flags/Status 59

#### 10.3.1.3 Cold Boot Flag

This interrupt is not used as an interrupt. It is used as a clearable flag that indicates the client is booting after a cold reset. Because the SoC has multiple CPUs that could be sharing memory, a cold reset of a single CPU may not be able to actually reset the memory that CPU is using. This flag informs clients they should clear any state maintained in memory.

#### 10.3.1.4 Cortex-M Debug Wake

This MU general-purpose IRQ is used to force a wakeup event prior to attaching debug to a Cortex-M CPU. This wake event will be sent when the respective CoreSight GPR (Granular Power Requestor) is set by the debugger to notify SCFW that power/clocks should be restored to Cortex-M core debug registers. Cortex-M SW should always enable.

#### 10.3.2 Client to SCFW Interrupts

| Interrupt         | MU GIRx | Use                   |
|-------------------|---------|-----------------------|
| SC_RPC_MU_GIR_RST | 0       | RPC/IPC Reset Request |

#### 10.3.2.1 RPC/IPC Reset Request

This MU general-purpose IRQ is used to request the SCFW to reset the RPC/IPC interface. This request can be used to recover the RPC/IPC interface if a client driver/task is terminated/restarted in the middle of RPC/IPC communication. The RPC/IPC reset sequence should be executed as follows:

- 1. Driver or task performing RPC/IPC communication is stopped
- 2. Client requests RPC reset by writing to the SC\_RPC\_MU\_GIR\_RST bit of the MU.CR register
- Client polls MU.CR register until SC\_RPC\_MU\_GIR\_RST bit is cleared to indicate SCFW has completed the RPC/IPC reset
- 4. Client side of MU module should be reconfigured for RPC/IPC communication
- 5. RPC/IPC communication can proceed normally

#### 10.4 Flags/Status

#### 10.4.1 SCFW to Client Flags/Status

SCFW makes use of the MU general-purpose flags to provide the client status and information. Currently these flags are only used to convey the instance (Core ID) of Cortex-M4 subsystems.

| MU Fx | Use                                                    |
|-------|--------------------------------------------------------|
| 0-2   | Conveys subsystem instance (only Cortex-M4 subsystems) |

#### 10.5 Porting

The SCFW porting kit contains ports of the SCFW client API for ATF, FreeRTOS, Linux, QNX, and u-boot. All implement the same API and protocol. The variations involve license, directory structure, file names, and include paths.

```
scfw_export_atf.tar.gz
scfw_export_freertos.tar.gz
scfw_export_linux.tar.gz
scfw_export_qnx.tar.gz
scfw_export_uboot.tar.gz
scfw_export_headers.tar.gz
```

Integrating the API involves implementing the IPC layer. This primarily involves implementing:

```
void sc_call_rpc(sc_ipc_t ipc, sc_rpc_msg_t *msg, sc_bool_t no_resp)
```

This function should send the message pointed to by msg via an MU (identified by ipc), word by word. If no\_resp is SC\_FALSE then it should wait on a response and return it in the same structure pointed to by msg. sc\_call\_rpc() must be atomic and often requires a semaphore to insure this is the case. The size of the message is in the message itself. The IPC implementation can be interrupt or poll driven, directly to the MU or via an MU driver.

The IPC layer typically implements functions like:

```
sc_err_t sc_ipc_open(sc_ipc_t *ipc, sc_ipc_id_t id)
void sc_ipc_close(sc_ipc_t ipc)
void sc_ipc_read(sc_ipc_t ipc, void *data)
void sc_ipc_write(sc_ipc_t ipc, const void *data)
```

but that is up to the implementer. All that the SCFW API requires is that sc\_call\_rpc() be implemented.

#### 10.6 API Message Formats

Below is a list of all API calls and their message formats to send a request and receive a response. A select few API calls do not return a response (self reset and reboot functions).

Messages are expected to be in little-endian format. The description accounts for this in the location of the parameter but within a parameter bytes may be in a reverse order depending on how the protocol is examined.

#### 10.6.1 sc\_pm\_set\_sys\_power\_mode()

| Send    |           |       |           |      |           |           |        |           |
|---------|-----------|-------|-----------|------|-----------|-----------|--------|-----------|
| w[0]    | func=19U  |       | svc=2U    | I    | size=2U   | <br>      | ver=1U | I         |
| w[1]    | undefined | l<br> | undefined |      | undefined | l<br>     | mode   | <br>      |
| Receive |           |       |           |      |           |           |        |           |
| w[0]    | err       | <br>  | svc=1U    | <br> | size=1U   | <br> <br> | ver=1U | <br> <br> |
|         |           |       |           |      |           |           |        |           |

## 10.6.2 sc\_pm\_set\_partition\_power\_mode()

| Send    |           |      |           |      |         |      |        |   |
|---------|-----------|------|-----------|------|---------|------|--------|---|
| w[0]    | func=1U   | ı    | svc=2U    | I    | size=2U | l    | ver=1U |   |
| w[1]    | undefined | <br> | undefined | <br> | mode    | <br> | pt<br> | I |
| Receive |           |      |           |      |         |      |        |   |
| w[0]    | err       | ı    | svc=1U    | <br> | size=1U | <br> | ver=1U |   |

#### 10.6.3 sc\_pm\_get\_sys\_power\_mode()

| Send    |           |   |           |      |           |   |        |      |
|---------|-----------|---|-----------|------|-----------|---|--------|------|
| w[0]    | func=2U   | ı | svc=2U    |      | size=2U   | l | ver=1U | I    |
| w[1]    | undefined |   | undefined | I    | undefined | I | pt     | <br> |
| Receive |           |   |           |      |           |   |        |      |
| w[0]    | err       | ı | svc=1U    | I    | size=2U   | ı | ver=1U | I    |
| w[1]    | undefined |   | undefined | <br> | undefined |   | mode   |      |

## 10.6.4 sc\_pm\_partition\_wake()

| Send    |           |   |           |     |           |      |        |  |
|---------|-----------|---|-----------|-----|-----------|------|--------|--|
| w[0]    | func=28U  |   | svc=2U    | I   | size=2U   | <br> | ver=1U |  |
| w[1]    | undefined | I | undefined | I   | undefined | I    | pt     |  |
|         |           |   |           |     |           |      |        |  |
| Receive |           |   |           |     |           |      |        |  |
| w[0] w  | err       | I | svc=1U    | - 1 | size=1U   | I    | ver=1U |  |

#### 10.6.5 sc\_pm\_set\_resource\_power\_mode()

| Send    |           |   |        |   |         |          |        |  |
|---------|-----------|---|--------|---|---------|----------|--------|--|
| w[0]    | func=3U   | ı | svc=2U | ı | size=2U |          | ver=1U |  |
| w[1]    | undefined |   | mode   |   |         | resource |        |  |
|         |           |   |        |   |         |          |        |  |
| Receive |           |   |        |   |         |          |        |  |
| w[0] w  | err       | l | svc=1U | l | size=1U | <u> </u> | ver=1U |  |
|         |           |   |        |   |         |          |        |  |

#### 10.6.6 sc\_pm\_set\_resource\_power\_mode\_all()

| Send    |          |      |        |      |         |         |        |   |
|---------|----------|------|--------|------|---------|---------|--------|---|
| w[0]    | func=22U | ı    | svc=2U | ı    | size=2U | ı       | ver=1U |   |
| w[1]    | mode     | <br> | pt     | <br> |         | exclude |        |   |
| Receive |          |      |        |      |         |         |        |   |
| w[0]    | err      | I    | svc=1U | I    | size=1U | ı       | ver=1U | l |

## 10.6.7 sc\_pm\_get\_resource\_power\_mode()

| Send    |           |      |           |      |           |         |        |   |
|---------|-----------|------|-----------|------|-----------|---------|--------|---|
| w[0]    | func=4U   | I    | svc=2U    | ı    | size=2U   | ı       | ver=1U | I |
| w[1]    | undefined | <br> | undefined | <br> | r         | esource |        |   |
| Receive |           |      |           |      |           |         |        |   |
| w[0]    | err       | I    | svc=1U    | I    | size=2U   | ı       | ver=1U |   |
| w[1]    | undefined | ı    | undefined | ı    | undefined | ı       | mode   | I |
|         |           |      |           |      |           |         |        |   |

# 10.6.8 sc\_pm\_req\_low\_power\_mode()

| Send    |           |   |        |   |         |          |        |   |
|---------|-----------|---|--------|---|---------|----------|--------|---|
| w[0]    | func=16U  | I | svc=2U |   | size=2U | I        | ver=1U |   |
| w[1]    | undefined | I | mode   | I |         | resource |        |   |
|         |           |   |        |   |         |          |        |   |
| Receive |           |   |        |   |         |          |        |   |
| w[0]    | err       | l | svc=1U | I | size=1U | <br>     | ver=1U | I |

## 10.6.9 sc\_pm\_req\_cpu\_low\_power\_mode()

| Send    |          |   |        |   |         |          |        |      |
|---------|----------|---|--------|---|---------|----------|--------|------|
| w[0]    | func=20U | ı | svc=2U | I | size=2U |          | ver=1U | <br> |
| w[1]    | wake_src | l | mode   |   |         | resource |        |      |
| Receive |          |   |        |   |         |          |        |      |
|         | err      |   | svc=1U |   | size=1U | <br>I    | ver=1U |      |
|         |          |   |        |   |         |          |        |      |

## 10.6.10 sc\_pm\_set\_cpu\_resume\_addr()

|                                          | func=17U         |        |            |        |           |         |         |
|------------------------------------------|------------------|--------|------------|--------|-----------|---------|---------|
| w[1]                                     |                  |        |            | ress ( | MSW)      |         |         |
| <br>  w[2]                               |                  |        | add        | ress ( |           |         |         |
| w[3]                                     | undefined        |        |            |        | re        | esource |         |
| Receive                                  |                  |        |            |        |           |         |         |
| w[0]                                     | err              |        | svc=1U     |        | size=1U   | l       | ver=1U  |
| w[0]                                     | func=21U         |        |            |        |           |         |         |
| Send<br>                                 |                  |        |            |        |           |         |         |
|                                          |                  |        |            |        |           |         |         |
| <br>  w[2]                               |                  |        | add        | ress ( | LSW)      |         |         |
| w[3]                                     | undefined        |        |            |        | re        | esource |         |
| Receive                                  |                  |        |            |        |           |         |         |
| <br>  w[0]                               | err              |        | svc=1U     |        | size=1U   |         | ver=1U  |
| 10.6.12 s                                | c_pm_req_sys_    | if_pow | ver_mode() |        |           |         |         |
| Send                                     | func=18U         |        | svc=2U     |        | size=3U   | l<br>   | ver=1U  |
|                                          |                  |        | sys_if     | -      | r         | esource |         |
| w[0]                                     | hpm              | <br>   |            |        |           |         |         |
| w[0]  <br>  w[1]                         | hpm<br>undefined |        |            |        | undefined | <br>    | lpm<br> |
| w[0]  <br>  w[1]  <br>  w[2]  <br>  w[2] | undefined        | <br>   |            |        | undefined | <br>    | 1pm     |

# 10.6.13 sc\_pm\_set\_clock\_rate()

| Send |         |   |        |   |         |        |     |
|------|---------|---|--------|---|---------|--------|-----|
|      |         |   |        |   |         | <br>   |     |
| [0]w | func=5U | 1 | svc=2U | 1 | size=3U | ver=1U | - 1 |
|      |         |   |        |   |         | <br>   |     |

| w[1]    |           |      |            | rate     |             |          |            |  |
|---------|-----------|------|------------|----------|-------------|----------|------------|--|
| w[2]    | undefined | <br> | clk        | I        |             | resource |            |  |
| Receive |           |      |            |          |             |          |            |  |
| w[0]    | err<br>   |      | svc=1U<br> | ·        | size=2U<br> |          | ver=1U<br> |  |
| w[1]    |           |      |            | rate<br> |             |          |            |  |

## 10.6.14 sc\_pm\_get\_clock\_rate()

| w[0]w   | func=6U   |   | svc=2U | I    | size=2U | I        | ver=1U |  |
|---------|-----------|---|--------|------|---------|----------|--------|--|
| w[1]    | undefined | ı | clk    | ı    |         | resource |        |  |
|         |           |   |        |      |         |          |        |  |
| Receive |           |   |        |      |         |          |        |  |
| [0]w    | err       |   | svc=1U | I    | size=2U | 1        | ver=1U |  |
| w[1]    |           |   |        | rate |         |          |        |  |

## 10.6.15 sc\_pm\_clock\_enable()

#### Send

| w[0]    | func=7U   |   | svc=2U    | I    | size=3U   | <br>    | ver=1U |   |
|---------|-----------|---|-----------|------|-----------|---------|--------|---|
| w[1]    | enable    | l | clk       |      | re        | esource |        |   |
| w[2]    | undefined |   | undefined | <br> | undefined |         | autog  |   |
| Receive |           |   |           |      |           |         |        |   |
| w[0]    | err       | 1 | svc=1U    |      | size=1U   | 1       | ver=1U | 1 |

#### 10.6.16 sc\_pm\_set\_clock\_parent()

#### Send

| w[0]    | func=14U | ı    | svc=2U | ı    | size=2U | I       | ver=1U |      |
|---------|----------|------|--------|------|---------|---------|--------|------|
| w[1]    | parent   | l    | clk    |      | 1       | esource |        |      |
| Receive |          |      |        |      |         |         |        |      |
| w[0]    | err      | <br> | svc=1U | <br> | size=1U | l       | ver=1U | <br> |

## 10.6.17 sc\_pm\_get\_clock\_parent()

| Send    |           |   |           |      |           |         |        |  |
|---------|-----------|---|-----------|------|-----------|---------|--------|--|
| w[0]    | func=15U  | ı | svc=2U    | ı    | size=2U   | I       | ver=1U |  |
| w[1]    | undefined | ı | clk       | ı    | re        | esource |        |  |
| Receive |           |   |           |      |           |         |        |  |
| w[0]    | err       |   | svc=1U    | ı    | size=2U   |         | ver=1U |  |
| w[1]    | undefined |   | undefined | <br> | undefined |         | parent |  |
|         |           |   |           |      |           |         |        |  |

#### 10.6.18 sc\_pm\_reset()

| Send    |           |      |           |       |           |   |        |       |
|---------|-----------|------|-----------|-------|-----------|---|--------|-------|
| w[0]    | func=13U  | I    | svc=2U    | I     | size=2U   | ı | ver=1U |       |
| w[1]    | undefined | <br> | undefined |       | undefined |   | type   | <br>  |
| Receive |           |      |           |       |           |   |        |       |
|         | err       |      | svc=1U    | <br>I | size=1U   |   | ver=1U | <br>I |
|         |           |      |           |       |           |   |        |       |

## 10.6.19 sc\_pm\_reset\_reason()

| Send    |           |   |           |      |           |   |        |           |
|---------|-----------|---|-----------|------|-----------|---|--------|-----------|
| w[0]    | func=10U  |   | svc=2U    | <br> | size=1U   |   | ver=1U | <br> <br> |
| Receive |           |   |           |      |           |   |        |           |
| w[0]    | err       | l | svc=1U    | ı    | size=2U   | I | ver=1U | I         |
| w[1]    | undefined |   | undefined | I    | undefined |   | reason |           |

## 10.6.20 sc\_pm\_get\_reset\_part()

| Send    |           |   |           |   |           |   |        |   |
|---------|-----------|---|-----------|---|-----------|---|--------|---|
| w[0]    | func=26U  | I | svc=2U    | I | size=1U   | I | ver=1U | 1 |
|         |           |   |           |   |           |   |        |   |
| Receive |           |   |           |   |           |   |        |   |
| w[0]    | err       | ı | svc=1U    | I | size=2U   | ı | ver=1U |   |
| w[1]    | undefined | I | undefined | I | undefined | 1 | pt     |   |
|         |           |   |           |   |           |   |        |   |

# 10.6.21 sc\_pm\_boot()

| w[0]                                          | func=8U                     | 1                                       | svc=2U                      |                       | size=5U                 | 1           | ver=1U      |
|-----------------------------------------------|-----------------------------|-----------------------------------------|-----------------------------|-----------------------|-------------------------|-------------|-------------|
| w[1]                                          |                             |                                         |                             | addr                  | (MSW)                   |             |             |
| w[2]                                          |                             |                                         | boot                        | _addr                 | (LSW)                   |             |             |
| w[3]                                          | res                         | source                                  |                             |                       | reso                    | ource_c     | pu          |
|                                               |                             |                                         | pt                          |                       |                         | ource_d     |             |
| Receive                                       |                             |                                         |                             |                       |                         |             |             |
|                                               | err                         |                                         | svc=1U                      |                       |                         |             |             |
|                                               |                             |                                         | svc=2U                      |                       | <br>size=5U             |             | ver=1U      |
| 10.6.22 so                                    | _pm_set_boot                | _parm                                   | 0                           |                       |                         |             |             |
| Send                                          |                             |                                         |                             |                       |                         |             |             |
| w[0]                                          | func=270                    |                                         | svc=2U<br>                  |                       |                         |             | ver=1U<br>  |
|                                               |                             |                                         |                             |                       |                         |             |             |
| w[1]  <br>                                    |                             |                                         | boot<br>                    | _addr<br>             |                         |             |             |
| <br>  w[2]                                    |                             |                                         |                             | <br>_addr             | (LSW)                   |             |             |
| w[2]  <br>  <br>  w[3]                        | re:                         | <br>source                              | boot                        | <br>_addr<br>         | (LSW)                   | <br>ource_c | <br>pu      |
| w[2]  <br>  w[3]                              | re:                         | <br>source                              | boot<br>                    | addr<br>              | (LSW)                   | <br>ource_c | <br>:pu<br> |
| w[2]  <br> <br>  w[3]  <br>  w[4]  <br>  w[4] | re:<br>undefined            | <br>source<br> <br> <br>                | boot<br>e_mu<br>undefined   | addr<br>addr<br> <br> | (LSW)  resc             | ource_c     | <br>:pu<br> |
| w[2]  <br>  w[3]  <br>  w[3]  <br>  w[4]      | re:                         | source<br><br> <br>                     | boot<br>e_mu<br>undefined   | _addr<br> <br> <br>   | (LSW)  resc             | ource_d     | .pu<br>     |
| w[2]  <br>  w[3]  <br>  w[3]  <br>  w[4]      | re:<br>undefined            | source<br><br> <br>                     | boot<br>e_mu<br>undefined   | _addr<br> <br> <br>   | (LSW)  resc             | ource_d     | .pu<br>     |
| w[2]  <br>  w[3]  <br>  w[4]  <br>  Receive   | re:<br>undefined            | source<br><br> <br>                     | boot<br>e_mu<br>undefined   | _addr<br> <br> <br>   | (LSW)  resc             | ource_d     | .pu<br>     |
| w[2]     w[3]     w[4]     Receive   w[0]     | undefined err c_pm_reboot() | <br>source<br> <br> <br> <br> <br> <br> | boot  mu  undefined  svc=1U | addr                  | resoresize=1U           | ource_c     | ppu<br>     |
| w[2]     w[3]     w[4]     Receive   w[0]     | err c_pm_reboot()           | source                                  | boot  mu  undefined  svc=1U | addr                  | resc<br>resc<br>size=1U | ource_c     | ver=1U      |

## 10.6.24 sc\_pm\_reboot\_partition()

| Send    |           |      |           |      |         |   |        |           |
|---------|-----------|------|-----------|------|---------|---|--------|-----------|
| w[0] w  | func=12U  |      | svc=2U    | I    | size=2U | I | ver=1U | 1         |
| w[1]    | undefined | <br> | undefined | <br> | type    | l | pt     | <br>      |
| Receive |           |      |           |      |         |   |        |           |
| w[0]    | err       | <br> | svc=1U    | <br> | size=1U |   | ver=1U | <br> <br> |

#### 10.6.25 sc\_pm\_reboot\_continue()

| w[0]  <br>           | func=25U         | svc=2U                              | size=2U   | <br>         | ver=1U |            |
|----------------------|------------------|-------------------------------------|-----------|--------------|--------|------------|
| w[1]                 | undefined        | undefined                           | undefined | <br>         | pt<br> |            |
| Receive              |                  |                                     |           |              |        |            |
|                      |                  | svc=1U                              |           |              |        |            |
|                      | c_pm_cpu_start() |                                     |           |              |        |            |
|                      |                  |                                     |           |              |        |            |
|                      |                  | svc=2U                              |           |              |        |            |
| w[1]  <br><br>  w[2] |                  | address                             |           |              |        | ا<br><br>ا |
|                      |                  | address                             |           |              |        |            |
|                      |                  |                                     |           | resource<br> |        |            |
| Receive              |                  |                                     |           |              |        |            |
| w[0]                 | err              | svc=1U                              | size=1U   | l            | ver=1U |            |
| <b>10.6.27 s</b> o   |                  | <br>  svc=2U                        |           |              | ver=1U |            |
|                      |                  |                                     |           |              | ·      |            |
|                      |                  |                                     |           |              |        |            |
| w[1]                 |                  | address                             |           |              |        |            |
| w[1]  <br>  w[2]     |                  | address<br>address<br><br>undefined | (LSW)     |              |        | <br>       |

| w[0] | func=29U | svc=2U | size=2U | ver=1U |

| w[0] | err | svc=1U | size=1U | ver=1U |

| w[1] | undefined | undefined |

Receive

## 10.6.29 sc\_pm\_is\_partition\_started()

| Send    |           |   |           |   |           |      |        |   |
|---------|-----------|---|-----------|---|-----------|------|--------|---|
| w[0]    | func=24U  | ı | svc=2U    | ı | size=2U   | ı    | ver=1U | I |
| w[1]    | undefined |   | undefined |   | undefined | <br> | pt<br> | I |
| Receive |           |   |           |   |           |      |        |   |
| w[0]    | result    | ı | svc=1U    |   | size=1U   |      | ver=1U |   |

## 10.6.30 sc\_rm\_partition\_alloc()

| Send    |           |   |            |  |           |   |          |      |
|---------|-----------|---|------------|--|-----------|---|----------|------|
| w[0]    | func=1U   | ı | svc=3U     |  | size=3U   | ı | ver=1U   |      |
| w[1]    | grant     |   | restricted |  | isolated  | ı | secure   |      |
| w[2]    | undefined |   | undefined  |  | undefined |   | coherent |      |
| Receive |           |   |            |  |           |   |          |      |
| w[0]    | err       |   | svc=1U     |  | size=2U   |   | ver=1U   | <br> |
| w[1]    | undefined |   | undefined  |  | undefined |   | pt       |      |
|         |           |   |            |  |           |   |          |      |

## 10.6.31 sc\_rm\_set\_confidential()

| Send    |           |   |           |      |         |   |        |      |
|---------|-----------|---|-----------|------|---------|---|--------|------|
| w[0]    | func=31U  | I | svc=3U    | ı    | size=2U | l | ver=1U | I    |
| w[1]    | undefined |   | undefined | <br> | retro   | I | pt     |      |
| Receive |           |   |           |      |         |   |        |      |
| w[0]    | err       |   | svc=1U    | <br> | size=1U |   | ver=1U | <br> |

## 10.6.32 sc\_rm\_partition\_free()

| e=2U   ver=1U |
|---------------|
| Fined   pt    |
|               |
|               |
| e=1U ver=1U l |
| -<br>f        |

## 10.6.33 sc\_rm\_get\_did()

| Send    |          |      |        |      |         |      |        |           |
|---------|----------|------|--------|------|---------|------|--------|-----------|
| w[0]    | func=26U | I    | svc=3U |      | size=1U | I    | ver=1U |           |
| Receive |          |      |        |      |         |      |        |           |
| w[0]    | result   | <br> | svc=1U | <br> | size=1U | <br> | ver=1U | <br> <br> |

## 10.6.34 sc\_rm\_partition\_static()

| Send    |           |      |           |      |         |   |        |   |
|---------|-----------|------|-----------|------|---------|---|--------|---|
| w[0]    | func=3U   | ı    | svc=3U    | ı    | size=2U | l | ver=1U | I |
| w[1]    | undefined | <br> | undefined |      | did     |   | pt     | I |
| Receive |           |      |           |      |         |   |        |   |
| w[0]    | err       | <br> | svc=1U    | <br> | size=1U |   | ver=1U |   |

## 10.6.35 sc\_rm\_partition\_lock()

| Send    |           |      |           |   |           |   |        |   |
|---------|-----------|------|-----------|---|-----------|---|--------|---|
| w[0]    | func=4U   | ı    | svc=3U    | ı | size=2U   | ı | ver=1U | I |
| w[1]    | undefined |      | undefined |   | undefined |   | pt     |   |
| Receive |           |      |           |   |           |   |        |   |
| w[0]    | err       | <br> | svc=1U    | l | size=1U   |   | ver=1U | l |

## 10.6.36 sc\_rm\_get\_partition()

| Send    |           |      |           |   |           |      |        |      |
|---------|-----------|------|-----------|---|-----------|------|--------|------|
| w[0]    | func=5U   | <br> | svc=3U    |   | size=1U   | l    | ver=1U | <br> |
| Receive |           |      |           |   |           |      |        |      |
| w[0]    | err       | I    | svc=1U    | I | size=2U   | I    | ver=1U | 1    |
| w[1]    | undefined |      | undefined |   | undefined | <br> | pt     |      |
|         |           |      |           |   |           |      |        |      |

#### 10.6.37 sc\_rm\_set\_parent()

| Send    |           |   |           |   |           |   |        |     |
|---------|-----------|---|-----------|---|-----------|---|--------|-----|
| w[0]    | func=6U   |   | svc=3U    | I | size=2U   | l | ver=1U |     |
| w[1]    | undefined | ı | undefined | ı | pt_parent | ı | pt     |     |
| Receive |           |   |           |   |           |   |        |     |
|         |           |   |           |   |           |   |        |     |
| w[0]    | err       |   | svc=1U    | 1 | size=1U   | - | ver=1U | - 1 |
|         |           |   |           |   |           |   |        |     |

## 10.6.38 sc\_rm\_move\_all()

| Send    |           |           |           |           |         |           |        |  |
|---------|-----------|-----------|-----------|-----------|---------|-----------|--------|--|
| w[0]    | func=7U   | l         | svc=3U    | l         | size=2U |           | ver=1U |  |
| w[1]    | move_pads |           | move_rsrc | I         | pt_dst  | <br>      | pt_src |  |
| Receive |           |           |           |           |         |           |        |  |
| w[0]    | err       | <br> <br> | svc=1U    | <br> <br> | size=1U | <br> <br> | ver=1U |  |

# 10.6.39 sc\_rm\_assign\_resource()

| Send    |           |      |        |      |         |          |        |           |
|---------|-----------|------|--------|------|---------|----------|--------|-----------|
| w[0]    | func=8U   | ı    | svc=3U |      | size=2U | ı        | ver=1U |           |
| w[1]    | undefined |      | pt     | <br> |         | resource |        | <br>      |
| Receive |           |      |        |      |         |          |        |           |
| w[0]    | err       | <br> | svc=1U | I    | size=1U | <br>     | ver=1U | <br> <br> |

## 10.6.40 sc\_rm\_set\_resource\_movable()

| Send    |           |     |           |         |           |   |         |      |
|---------|-----------|-----|-----------|---------|-----------|---|---------|------|
| w[0]    | func=9U   | I   | svc=3U    | I       | size=3U   | ı | ver=1U  | I    |
| w[1]    | resc      | lst | resc      | ource_: | fst       | I |         |      |
| w[2]    | undefined | ı   | undefined |         | undefined |   | movable | <br> |
| Receive |           |     |           |         |           |   |         |      |
| w[0]    | err       | ı   | svc=1U    |         | size=1U   |   | ver=1U  | <br> |

#### 10.6.41 sc\_rm\_set\_subsys\_rsrc\_movable()

| Send    |           |   |         |       |         |          |        |   |
|---------|-----------|---|---------|-------|---------|----------|--------|---|
| w[0]    | func=28U  | I | svc=3U  | ı     | size=2U | I        | ver=1U |   |
| w[1]    | undefined |   | movable | l<br> |         | resource |        | I |
| Receive |           |   |         |       |         |          |        |   |
| w[0]    | err       |   | svc=1U  |       | size=1U | ı        | ver=1U |   |

## 10.6.42 sc\_rm\_set\_master\_attributes()

| Send    |           |   |           |   |           |        |             |   |
|---------|-----------|---|-----------|---|-----------|--------|-------------|---|
| w[0]    | func=10U  |   | svc=3U    | I | size=3U   |        | ver=1U      |   |
| w[1]    | pa        | I | sa        | I | re        | esouro | ce          | ı |
| w[2]    | undefined |   | undefined |   | undefined |        | smmu_bypass |   |
| Receive |           |   |           |   |           |        |             |   |
| w[0]    | err       |   | svc=1U    |   | size=1U   | <br>   | ver=1U      |   |

## 10.6.43 sc\_rm\_set\_master\_sid()

| Send    |          |      |        |   |         |          |        |  |
|---------|----------|------|--------|---|---------|----------|--------|--|
| w[0]    | func=11U | <br> | svc=3U |   | size=2U | l        | ver=1U |  |
| w[1]    |          | sid  |        | I |         | resource |        |  |
|         |          |      |        |   |         |          |        |  |
| Receive |          |      |        |   |         |          |        |  |
| w[0]    | err      | I    | svc=1U | ı | size=1U | ı        | ver=1U |  |

## 10.6.44 sc\_rm\_set\_peripheral\_permissions()

| Send    |          |      |        |   |         |          |        |      |
|---------|----------|------|--------|---|---------|----------|--------|------|
| w[0]    | func=12U | l    | svc=3U | l | size=2U | ı        | ver=1U |      |
| w[1]    | perm     | ı    | pt     | ı |         | resource |        |      |
| Receive |          |      |        |   |         |          |        |      |
| w[0]    | err      | <br> | svc=1U |   | size=1U | <br>     | ver=1U | <br> |

#### 10.6.45 sc\_rm\_is\_resource\_owned()

| Send    |           |  |           |      |         |          |        |   |
|---------|-----------|--|-----------|------|---------|----------|--------|---|
| w[0]    | func=13U  |  | svc=3U    |      | size=2U | l        | ver=1U |   |
| w[1]    | undefined |  | undefined | <br> |         | resource |        |   |
|         |           |  |           |      |         |          |        |   |
| Receive |           |  |           |      |         |          |        |   |
| w[0]w   | result    |  | svc=1U    | I    | size=1U | 1        | ver=1U | I |
|         |           |  |           |      |         |          |        |   |

## 10.6.46 sc\_rm\_get\_resource\_owner()

| Send    |           |      |           |   |           |         |        |       |
|---------|-----------|------|-----------|---|-----------|---------|--------|-------|
| w[0]    | func=33U  | I    | svc=3U    |   | size=2U   |         | ver=1U | <br>  |
| w[1]    | undefined | <br> | undefined |   | r         | esource |        | I<br> |
| Receive |           |      |           |   |           |         |        |       |
| w[0]    | err       |      | svc=1U    | l | size=2U   |         | ver=1U |       |
| w[1]    | undefined |      | undefined |   | undefined |         | pt     | <br>  |

## 10.6.47 sc\_rm\_is\_resource\_master()

| Send    |           |   |           |   |         |          |        |   |
|---------|-----------|---|-----------|---|---------|----------|--------|---|
| w[0]    | func=14U  | I | svc=3U    |   | size=2U | <br>     | ver=1U |   |
| w[1]    | undefined | ı | undefined | l |         | resource |        |   |
|         |           |   |           |   |         |          |        |   |
| Receive |           |   |           |   |         |          |        |   |
| w[0] w  | result    | 1 | svc=1U    | I | size=1U | I        | ver=1U | 1 |

## 10.6.48 sc\_rm\_is\_resource\_peripheral()

| Send    |           |           |           |  |         |          |        |   |
|---------|-----------|-----------|-----------|--|---------|----------|--------|---|
| w[0]    | func=15U  | I         | svc=3U    |  | size=2U | <br>     | ver=1U | I |
| w[1]    | undefined | <br> <br> | undefined |  |         | resource |        |   |
| Receive |           |           |           |  |         |          |        |   |
| w[0]    | result    | <br>      | svc=1U    |  | size=1U | <br>     | ver=1U |   |

## 10.6.49 sc\_rm\_get\_resource\_info()

| Send    |           |      |           |      |         |          |        |   |
|---------|-----------|------|-----------|------|---------|----------|--------|---|
| w[0]    | func=16U  | ı    | svc=3U    |      | size=2U | I        | ver=1U |   |
| w[1]    | undefined | <br> | undefined | <br> | 1       | resource |        |   |
| Receive |           |      |           |      |         |          |        |   |
| w[0]    | err       | ı    | svc=1U    | ı    | size=2U | ı        | ver=1U |   |
| w[1]    | undefined | <br> | undefined | I    |         | sid      |        | I |

# 10.6.50 sc\_rm\_memreg\_alloc()

| func=17U  |      | svc=3U    |                                  | size=5U                                     | I                                                                                          | ver=1U                                                                                     |                                                                                   |
|-----------|------|-----------|----------------------------------|---------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
|           |      | _         |                                  | , ,                                         |                                                                                            |                                                                                            |                                                                                   |
|           |      | addr_     | start                            | (LSW)                                       |                                                                                            |                                                                                            |                                                                                   |
|           |      | addr.     | _end (                           | MSW)                                        |                                                                                            |                                                                                            | ı                                                                                 |
|           |      |           |                                  |                                             |                                                                                            |                                                                                            |                                                                                   |
|           |      |           |                                  |                                             |                                                                                            |                                                                                            |                                                                                   |
| err       | ı    | svc=1U    | l                                |                                             |                                                                                            |                                                                                            |                                                                                   |
| undefined | <br> | undefined | <br> <br>                        |                                             |                                                                                            |                                                                                            | <br> <br>                                                                         |
|           | err  | err       | addraddraddraddraddraddraddraddr | addr_start addr_start addr_end ( addr_end ( | addr_start (MSW)  addr_start (LSW)  addr_end (MSW)  addr_end (LSW)  err   svc=1U   size=2U | addr_start (MSW)  addr_start (LSW)  addr_end (MSW)  addr_end (LSW)  err   svc=1U   size=2U | addr_start (LSW)  addr_end (MSW)  addr_end (LSW)  err   svc=1U   size=2U   ver=1U |

## 10.6.51 sc\_rm\_memreg\_split()

| Send    | <br> |      |        |           |   |    |       |
|---------|------|------|--------|-----------|---|----|-------|
|         |      |      |        | size=6U   |   |    | I     |
| w[1]    |      |      | start  |           |   |    | 1     |
| w[2]    |      | _    | start  | (LSW)     |   |    | - 1   |
| w[3]    |      | addr | _end ( |           |   |    |       |
| w[4]    |      | addr | _end ( |           |   |    | - 1   |
|         |      |      |        | undefined | ı | mr | I     |
| Receive |      |      |        |           |   |    |       |
| w[0]    |      |      |        | size=2U   |   |    | - 1   |
|         |      |      |        | undefined |   |    | I<br> |

## 10.6.52 sc\_rm\_memreg\_frag()

| Send    |           |       |        |       |      |           |
|---------|-----------|-------|--------|-------|------|-----------|
|         | func=32U  |       |        |       |      | I         |
| w[1]    |           | addr_ | start  | (MSW) |      |           |
| w[2]    |           | addr_ | start  | (LSW) |      | l         |
| w[3]    |           | addr  | _end ( | MSW)  |      | I         |
| w[4]    |           | addr  | _end ( | LSW)  |      | l         |
| Receive |           | <br>  |        |       | <br> |           |
|         | err       |       |        |       |      | I         |
|         | undefined |       |        |       |      | <br> <br> |

# 10.6.53 sc\_rm\_memreg\_free()

| Send    |           |   |           |      |           |   |        |   |
|---------|-----------|---|-----------|------|-----------|---|--------|---|
| w[0]    | func=18U  |   | svc=3U    | <br> | size=2U   |   | ver=1U | I |
| w[1]    | undefined | I | undefined | I    | undefined | ı | mr     | ı |
| Receive |           |   |           |      |           |   |        |   |
|         |           |   |           |      |           |   |        |   |
| w[0] w  | err       | I | svc=1U    | 1    | size=1U   | I | ver=1U | - |

# 10.6.54 sc\_rm\_find\_memreg()

| Send    |           | <br>     |        |          |   |    |     |
|---------|-----------|----------|--------|----------|---|----|-----|
|         | func=30U  |          |        |          |   |    | - 1 |
| w[1]    |           |          | start  | (MSW)    |   |    |     |
| w[2]    |           |          | start  |          |   |    |     |
| w[3]    |           | <br>addr | _end ( | <br>MSW) |   |    |     |
| w[4]    |           | <br>addr | end (  | <br>LSW) |   |    |     |
|         |           |          |        |          |   |    |     |
| Receive |           | <br>     |        |          |   |    |     |
|         | err       |          |        |          | ' |    |     |
|         | undefined |          |        |          |   | mr |     |
|         |           | <br>     |        |          |   |    |     |

#### 10.6.55 sc\_rm\_assign\_memreg()

| Send    |           |       |           |      |         |   |        |  |
|---------|-----------|-------|-----------|------|---------|---|--------|--|
| w[0]    | func=19U  | I     | svc=3U    | Ι    | size=2U |   | ver=1U |  |
| w[1]    | undefined | ı     | undefined | I    | mr      | l | pt     |  |
| Receive |           |       |           |      |         |   |        |  |
| receive |           |       |           |      |         |   |        |  |
| w[0]    | err       | l<br> | svc=1U    | <br> | size=1U |   | ver=1U |  |

#### 10.6.56 sc\_rm\_set\_memreg\_permissions()

| Send    |           |      |        |      |         |      |        |           |
|---------|-----------|------|--------|------|---------|------|--------|-----------|
| w[0]    | func=20U  | ı    | svc=3U | ı    | size=2U | ı    | ver=1U |           |
| w[1]    | undefined |      | perm   | <br> | pt<br>  | <br> | mr<br> |           |
| Receive |           |      |        |      |         |      |        |           |
| w[0]    | err       | <br> | svc=1U | <br> | size=1U | <br> | ver=1U | <br> <br> |

## 10.6.57 sc\_rm\_set\_memreg\_iee()

| Send    |           |   |        |   |         |   |        |   |
|---------|-----------|---|--------|---|---------|---|--------|---|
| w[0]    | func=34U  | I | svc=3U |   | size=2U |   | ver=1U |   |
| w[1]    | undefined | ı | rmsg   |   | det     | I | mr     |   |
|         |           |   |        |   |         |   |        |   |
| Receive |           |   |        |   |         |   |        |   |
| w[0]w   | err       | 1 | svc=1U | I | size=1U |   | ver=1U | - |

## 10.6.58 sc\_rm\_is\_memreg\_owned()

| Send    |           |           |           |   |           |      |        |           |
|---------|-----------|-----------|-----------|---|-----------|------|--------|-----------|
| w[0]    | func=21U  | I         | svc=3U    | I | size=2U   | I    | ver=1U |           |
| w[1]    | undefined | <br> <br> | undefined |   | undefined | <br> | mr     | <br> <br> |
| Receive |           |           |           |   |           |      |        |           |
| w[0]    | result    | <br>      | svc=1U    | l | size=1U   | <br> | ver=1U | <br> <br> |
|         |           |           |           |   |           |      |        |           |

## 10.6.59 sc\_rm\_get\_memreg\_info()

| Send    |           |   |           |        |           |   |        |   |
|---------|-----------|---|-----------|--------|-----------|---|--------|---|
| w[0]    | func=22U  | I | svc=3U    | ı      | size=2U   | ı | ver=1U |   |
| w[1]    | undefined | I | undefined | l      | undefined | ı | mr     | I |
| Receive |           |   |           |        |           |   |        |   |
| w[0]    | err       | I | svc=1U    | ı      | size=5U   | ı | ver=1U | I |
| w[1]    |           |   | addr_     | start  | (MSW)     |   |        |   |
| w[2]    |           |   | addr_     | start  | (LSW)     |   |        |   |
| w[3]    |           |   | addr      | _end ( | MSW)      |   |        |   |
| w[4]    |           |   | addr      | _end ( | LSW)      |   |        |   |
|         |           |   |           |        |           |   |        |   |

## 10.6.60 sc\_rm\_assign\_pad()

| Send    |           |       |        |      |             |      |            |      |
|---------|-----------|-------|--------|------|-------------|------|------------|------|
| w[0]    | func=23U  | ı     | svc=3U | ı    | size=2U     | ı    | ver=1U     | I    |
| w[1]    | undefined | l<br> | pt     | <br> |             | pad  |            | <br> |
| Receive |           |       |        |      |             |      |            |      |
|         |           |       |        |      |             |      |            |      |
| w[0]    | err<br>   | <br>  | svc=1U |      | size=1U<br> | <br> | ver=1U<br> |      |

## 10.6.61 sc\_rm\_set\_pad\_movable()

| Send    |           |        |           |   |           |         |         |   |
|---------|-----------|--------|-----------|---|-----------|---------|---------|---|
| w[0]    | func=24U  | I      | svc=3U    | ı | size=3U   | I       | ver=1U  |   |
| w[1]    |           | pad_ls | t<br>     |   |           | pad_fst | :<br>   |   |
| w[2]    | undefined | <br>   | undefined |   | undefined | <br>    | movable | I |
| Receive |           |        |           |   |           |         |         |   |
| w[0]    | err       |        | svc=1U    |   | size=1U   |         | ver=1U  |   |

# 10.6.62 sc\_rm\_is\_pad\_owned()

| Send |          |   |        |   |         |        |  |
|------|----------|---|--------|---|---------|--------|--|
|      |          |   |        |   |         | <br>   |  |
| w[0] | func=25U | 1 | svc=3U | 1 | size=2U | ver=1U |  |
|      |          |   |        |   |         | <br>   |  |

| w[1]                                                  | undefined                      | undefined               | ı         |         | pad       |            | l         |
|-------------------------------------------------------|--------------------------------|-------------------------|-----------|---------|-----------|------------|-----------|
| Receive                                               |                                |                         |           |         |           |            |           |
| w[0]                                                  |                                | svc=1U                  | ı         | size=1U | <br>      | ver=1U     | <br>      |
|                                                       |                                |                         |           |         |           |            |           |
| 10.6.63 so                                            | c_rm_dump()                    |                         |           |         |           |            |           |
| Send                                                  |                                |                         |           |         |           |            |           |
| w[0]                                                  | func=27U                       | svc=3U                  | l<br>     | size=1U | I         | ver=1U     | I         |
| Receive                                               |                                |                         |           |         |           |            |           |
| w[0]                                                  |                                | svc=1U                  | <br> <br> | size=1U | <br>      | ver=1U     | <br> <br> |
|                                                       |                                |                         |           |         |           |            |           |
| 10.6.64 so                                            | c_timer_set_wdo                | g_timeout()             |           |         |           |            |           |
| Send                                                  |                                |                         |           |         |           |            |           |
| [0]w                                                  | func=1U                        | svc=5U                  |           | size=2U | I         | ver=1U     | <br>      |
| w[1]                                                  |                                | t.                      | imeout    | :<br>   |           |            | <br>      |
| Receive                                               |                                |                         |           |         |           |            |           |
| w[0]                                                  | err                            | svc=1U                  |           | size=1U |           | ver=1U     | <br> <br> |
|                                                       |                                |                         |           |         |           |            |           |
| 10.6.65 so                                            | c_timer_set_wdo                | g_pre_timeout()         |           |         |           |            |           |
| Send                                                  |                                |                         |           |         |           |            |           |
| w[0]                                                  | func=12U                       | svc=5U                  | <br>      | size=2U | <br>      | ver=1U<br> | <br>      |
| w[1]                                                  |                                | pre_                    | _timed    | out<br> |           |            |           |
|                                                       |                                |                         |           |         |           |            |           |
| Receive                                               |                                |                         |           |         |           |            |           |
|                                                       | err                            | svc=1U                  | <br> <br> | size=1U | <br> <br> | ver=1U     | <br> <br> |
|                                                       | err                            | svc=1U                  | <br> <br> | size=1U | <br>      | ver=1U     | <br> <br> |
| w[0]                                                  | err<br>err<br>c_timer_set_wdo( |                         | <br> <br> | size=1U | <br> <br> | ver=1U     | <br> <br> |
| w[0]                                                  |                                |                         | <br>      | size=1U | l<br>     | ver=1U     | <br> <br> |
| 10.6.66 sc                                            | c_timer_set_wdog               |                         |           |         |           |            |           |
| 10.6.66 sc<br>Send                                    | c_timer_set_wdoo               | g_window()              | <br> <br> | size=2U |           |            |           |
| 10.6.66 sc<br>Send<br>  w[0]  <br>  w[1]  <br>Receive | c_timer_set_wdoo               | g_window()    svc=5U w. | <br> <br> | size=2U |           |            |           |

#### 10.6.67 sc\_timer\_start\_wdog()

| Send    |           |      |           |   |           |      |        |  |
|---------|-----------|------|-----------|---|-----------|------|--------|--|
| w[0]    | func=2U   |      | svc=5U    |   | size=2U   | <br> | ver=1U |  |
| w[1]    | undefined |      | undefined | I | undefined |      | lock   |  |
|         |           |      |           |   |           |      |        |  |
| Receive |           |      |           |   |           |      |        |  |
| w[0]    | err       | <br> | svc=1U    |   | size=1U   |      | ver=1U |  |

## 10.6.68 sc\_timer\_stop\_wdog()

| Send    |         |  |        |  |         |  |        |  |
|---------|---------|--|--------|--|---------|--|--------|--|
| w[0] w  | func=3U |  | svc=5U |  | size=1U |  | ver=1U |  |
|         |         |  |        |  |         |  |        |  |
| Receive |         |  |        |  |         |  |        |  |
| w[0]    | err     |  | svc=1U |  | size=1U |  | ver=1U |  |
|         |         |  |        |  |         |  |        |  |

# 10.6.69 sc\_timer\_ping\_wdog()

| Send    |         |           |        |           |         |           |        |      |
|---------|---------|-----------|--------|-----------|---------|-----------|--------|------|
| w[0]    | func=4U |           | svc=5U | <br>      | size=1U |           | ver=1U |      |
| Receive |         |           |        |           |         |           |        |      |
| w[0]    | err     | <br> <br> | svc=1U | <br> <br> | size=1U | <br> <br> | ver=1U | <br> |

# 10.6.70 sc\_timer\_get\_wdog\_status()

| Send    |         |   |        |        |         |   |        |   |
|---------|---------|---|--------|--------|---------|---|--------|---|
| w[0]    | func=5U | I | svc=5U | I      | size=1U | I | ver=1U | - |
|         |         |   |        |        |         |   |        |   |
| Receive |         |   |        |        |         |   |        |   |
| w[0]    | err     |   | svc=1U |        | size=4U |   | ver=1U |   |
| w[1]    |         |   |        | timeou | t<br>   |   |        |   |
| w[2]    |         |   | ma     | x_time | out     |   |        |   |
| w[3]    |         |   | rema   | ining_ | time    |   |        |   |
|         |         |   |        |        |         |   |        |   |

## 10.6.71 sc\_timer\_pt\_get\_wdog\_status()

| Send                                                   |                                                         |          |                                    |           |                        |                |                            |  |
|--------------------------------------------------------|---------------------------------------------------------|----------|------------------------------------|-----------|------------------------|----------------|----------------------------|--|
|                                                        |                                                         |          | svc=5U                             |           |                        |                |                            |  |
| w[1]                                                   | undefined                                               |          | undefined                          |           |                        | 1              |                            |  |
| Receive                                                |                                                         |          |                                    |           |                        |                |                            |  |
|                                                        |                                                         |          | svc=1U                             |           |                        |                |                            |  |
| w[1]                                                   |                                                         |          |                                    | imeou     | t                      |                |                            |  |
| w[2]                                                   |                                                         |          | rema                               | ining_    | time                   |                |                            |  |
|                                                        |                                                         |          | undefined                          |           |                        |                |                            |  |
|                                                        | c_timer_set_wd                                          | <b>-</b> | Ü                                  |           |                        |                |                            |  |
|                                                        |                                                         |          |                                    |           |                        |                |                            |  |
| 10.6.72 so                                             |                                                         | <b>-</b> | Ü                                  |           |                        |                |                            |  |
| Send<br>                                               | func=10U                                                | <br>I    | Ü                                  | 1         | size=2U                |                | ver=1U                     |  |
| Send<br><br>  w[0]                                     | func=10U                                                |          | svc=5U                             | l         | size=2U                | <br>           | ver=1U                     |  |
| Send<br><br>  w[0]                                     | func=10U                                                |          | svc=5U                             | l         | size=2U<br>action      | <br> <br> <br> | ver=1U<br><br>pt           |  |
| Send<br><br>  w[0]  <br><br>  w[1]                     | func=10U                                                | <br>     | svc=5U                             | <br> <br> | size=2U<br>action      | <br>           | ver=1U<br><br>pt           |  |
| Send                                                   | func=10U<br>undefined                                   |          | svc=5U undefined svc=1U            | <br> <br> | size=2U<br>action      | <br>           | ver=1U<br>pt               |  |
| Send                                                   | func=10U undefined err c_timer_set_rtc_                 |          | svc=5U undefined svc=1U            |           | size=2U action size=1U | <br>           | ver=1U  pt  ver=1U         |  |
| Send                                                   | func=10U undefined err c_timer_set_rtc_                 | _time()  | svc=5U undefined svc=1U svc=5U     | <br>      | size=2U action size=1U | <br>           | ver=1U  pt  ver=1U  ver=1U |  |
| Send   w[0]     w[1]     Receive   w[0]     10.6.73 sc | func=10U  undefined  err  c_timer_set_rtc  func=6U  day |          | svc=5U undefined svc=1U svc=5U mon | <br>      | size=2U action size=1U | <br>           | ver=1U  pt  ver=1U  ver=1U |  |

#### 10.6.74 sc\_timer\_get\_rtc\_time()

| w[0]   func=7U   svc=5U   size=1U   ver=1U | Send  |         |   |        |         |   |        |  |
|--------------------------------------------|-------|---------|---|--------|---------|---|--------|--|
| w[0]   func=7U   svc=5U   size=1U   ver=1U |       |         |   |        | <br>    |   |        |  |
|                                            | w[0]w | func=7U | 1 | svc=5U | size=1U | - | ver=1U |  |

| w[0] | err | svc=1U | size=1U | ver=1U |

Receive

Receive

| [0]w | err       |   | svc=1U | I | size=3U | I    | ver=1U |  |
|------|-----------|---|--------|---|---------|------|--------|--|
| w[1] | day       | ı | mon    | ı |         | year |        |  |
| w[2] | undefined | ı | sec    | ı | min     | ı    | hour   |  |

# 10.6.75 sc\_timer\_get\_rtc\_sec1970()

| Send    |         |   |        |     |         |      |        |      |
|---------|---------|---|--------|-----|---------|------|--------|------|
| w[0]    | func=9U |   | svc=5U | I   | size=1U | <br> | ver=1U | <br> |
| Receive |         |   |        |     |         |      |        |      |
| w[0]    | err     | l | svc=1U | I   | size=2U |      | ver=1U |      |
| w[1]    |         |   |        | sec |         |      |        | I    |

# 10.6.76 sc\_timer\_set\_rtc\_alarm()

| Send    |           |      |        |      |         |      |        |      |
|---------|-----------|------|--------|------|---------|------|--------|------|
| w[0]    | func=8U   | ı    | svc=5U | ı    | size=3U | ı    | ver=1U | <br> |
| w[1]    | day       |      | mon    |      |         | year |        |      |
| w[2]    | undefined | <br> | sec    | <br> | min     |      | hour   |      |
| Receive |           |      |        |      |         |      |        |      |
| w[0]    | err       |      | svc=1U | <br> | size=1U |      | ver=1U |      |

## 10.6.77 sc\_timer\_set\_rtc\_periodic\_alarm()

| Send    |          |   |        |      |         |   |        |      |
|---------|----------|---|--------|------|---------|---|--------|------|
| w[0]    | func=14U | ı | svc=5U | ı    | size=2U | ı | ver=1U | I    |
| w[1]    |          |   |        | sec  |         |   |        | I    |
| Receive |          |   |        |      |         |   |        |      |
| w[0]    | err      |   | svc=1U | <br> | size=1U |   | ver=1U | <br> |

## 10.6.78 sc\_timer\_cancel\_rtc\_alarm()

| Send               |                |         |           |           |           |           |            |  |
|--------------------|----------------|---------|-----------|-----------|-----------|-----------|------------|--|
|                    | func=15U       | <br>    | svc=5U    | <br> <br> | size=1U   | <br> <br> | ver=1U     |  |
| Receive            |                |         |           |           |           |           |            |  |
| w[0]               | err            | <br>    | svc=1U    | <br>      | size=1U   | <br>      | ver=1U     |  |
|                    | _timer_set_rtc | _calb() | )         |           |           |           |            |  |
| Send<br><br>  w[0] | <br>func=11U   |         | svc=5U    |           | size=2U   | <br>I     | <br>ver=1U |  |
| <br>  w[1]         | undefined      |         | undefined |           | undefined | <br>      | count      |  |
| Receive            |                |         |           |           |           |           |            |  |
| w[0]w              | err            | <br>    | svc=1U    |           | size=1U   |           | ver=1U     |  |
| <b>10.6.80 sc</b>  | _timer_set_sys |         | arm()     |           |           |           |            |  |
| w[0]               | func=16U       |         | svc=5U    |           | size=3U   |           | ver=1U     |  |
| w[1]               |                |         | ti        | cks (M    | ISW)      |           |            |  |
| w[2]               |                |         | ti        | cks (L    | .SW)      |           |            |  |
| Receive            |                |         |           |           |           |           |            |  |
| w[0]               | err            |         | svc=1U    |           | size=1U   |           | ver=1U     |  |

## 10.6.81 sc\_timer\_set\_sysctr\_periodic\_alarm()

| Send    |          |      |        |         |         |      |        |      |
|---------|----------|------|--------|---------|---------|------|--------|------|
| w[0]    | func=17U |      | svc=5U | I       | size=3U |      | ver=1U |      |
| w[1]    |          |      | tic    | cks (MS | 5W)     |      |        | I    |
| w[2]    |          |      | tic    | cks (LS | SW)     |      |        |      |
| Receive |          |      |        |         |         |      |        |      |
| w[0]    | err      | <br> | svc=1U | <br>    | size=1U | <br> | ver=1U | <br> |

#### 10.6.82 sc\_timer\_cancel\_sysctr\_alarm()

| Send    |          |   |        |   |         |  |        |  |
|---------|----------|---|--------|---|---------|--|--------|--|
| w[0]    | func=18U |   | svc=5U |   | size=1U |  | ver=1U |  |
| Receive |          |   |        |   |         |  |        |  |
| Receive |          |   |        |   |         |  |        |  |
| w[0]    | err      | ı | svc=1U | I | size=1U |  | ver=1U |  |

## 10.6.83 sc\_pad\_set\_mux()

| Send    |           |   |           |   |           |     |        |      |
|---------|-----------|---|-----------|---|-----------|-----|--------|------|
| w[0]    | func=1U   |   | svc=6U    | I | size=3U   | I   | ver=1U | I    |
| w[1]    | config    |   | mux       | I |           | pad |        | I    |
| w[2]    | undefined | ı | undefined | ı | undefined | ı   | iso    | <br> |
| Receive |           |   |           |   |           |     |        |      |
| w[0]    | err       | l | svc=1U    | ı | size=1U   | I   | ver=1U |      |

# 10.6.84 sc\_pad\_get\_mux()

| Send    |           |      |           |      |         |      |        |      |
|---------|-----------|------|-----------|------|---------|------|--------|------|
| w[0]    | func=6U   |      | svc=6U    | I    | size=2U |      | ver=1U |      |
| w[1]    | undefined | <br> | undefined | <br> |         | pad  |        | <br> |
| Receive |           |      |           |      |         |      |        |      |
| w[0]    | err       |      | svc=1U    |      | size=2U |      | ver=1U |      |
| w[1]    | undefined |      | iso       | I    | config  | <br> | mux    |      |

# 10.6.85 sc\_pad\_set\_gp()

| Send    |           |      |           |      |         |      |        |      |
|---------|-----------|------|-----------|------|---------|------|--------|------|
| w[0]    | func=2U   | ı    | svc=6U    | I    | size=3U | ı    | ver=1U | I    |
| w[1]    |           |      |           | ctrl |         |      |        |      |
| w[2]    | undefined | l    | undefined | l    |         | pad  |        | I    |
| Receive |           |      |           |      |         |      |        |      |
| w[0]    | err       | <br> | svc=1U    |      | size=1U | <br> | ver=1U | <br> |

#### 10.6.86 sc\_pad\_get\_gp()

| w[0]                                                                                 | func=7U                                                               | svc=6U                                           |           | size=2U                         |          | ver=1U               |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--------------------------------------------------|-----------|---------------------------------|----------|----------------------|
| w[1]                                                                                 | undefined                                                             | undefined                                        | I         |                                 | pad      |                      |
| Receive                                                                              |                                                                       |                                                  |           |                                 |          |                      |
|                                                                                      |                                                                       | svc=1U                                           |           | size=2U                         |          | ver=1U               |
| w[1]                                                                                 |                                                                       |                                                  | ctrl      |                                 |          |                      |
| 10007                                                                                |                                                                       | Λ                                                |           |                                 |          |                      |
| 10.6.87 S                                                                            | c_pad_set_wakeup                                                      | 0                                                |           |                                 |          |                      |
| Send<br>                                                                             |                                                                       |                                                  |           |                                 |          |                      |
| w[0]  <br>                                                                           | func=4U<br>                                                           | svc=6U<br>                                       | <br>      | size=2U                         | <br>     | ver=1U<br>           |
| w[1]                                                                                 | undefined                                                             | wakeup<br>                                       | l<br>     |                                 | pad<br>  |                      |
| Receive                                                                              |                                                                       |                                                  |           |                                 |          |                      |
| w[0] w                                                                               | err                                                                   | svc=1U                                           | I         | size=1U                         |          | ver=1U               |
|                                                                                      | c_pad_get_wakeup                                                      | 0                                                |           |                                 |          |                      |
| Send<br>                                                                             | func=9U                                                               | svc=6U                                           |           |                                 |          | ver=1U               |
| Send<br><br>  w[0]                                                                   |                                                                       | svc=6U                                           |           | size=2U                         |          | ver=1U               |
| Send<br><br>  w[0]                                                                   | func=9U                                                               | svc=6U                                           |           |                                 | <u>-</u> |                      |
| Send<br>  w[0]  <br>  w[1]  <br>  w[1]                                               | func=9U<br>undefined                                                  | svc=6U<br>  undefined                            | <br> <br> |                                 | pad      |                      |
| Send   w[0]     w[1]     Receive                                                     | func=9U<br>undefined<br>err                                           | svc=6U<br>  undefined<br>  svc=1U                | <br>      |                                 | pad      |                      |
| Send   w[0]     w[1]     Receive   w[0]                                              | func=9U  undefined  err  undefined                                    | svc=6U<br>  undefined<br>  svc=1U                | <br>      | size=2U                         | pad      | ver=1U               |
| Send   w[0]     w[1]     Receive   w[0]                                              | func=9U<br>undefined<br>err                                           | svc=6U<br>  undefined<br>  svc=1U                | <br>      | size=2U                         | pad      | ver=1U               |
| Send   w[0]     w[1]     Receive   w[0]     w[1]                                     | func=9U  undefined  err  undefined                                    | svc=6U<br>  undefined<br>  svc=1U<br>  undefined | <br>      | size=2U<br>undefined            | pad      | ver=1U<br>wakeup     |
| Send   w[0]     w[1]     Receive   w[0]     w[1]                                     | func=9U  undefined  err  undefined  c_pad_set_all()                   | svc=6U   undefined   svc=1U   undefined          | <br>      | size=2U<br>undefined<br>size=4U | pad      | ver=1U<br>wakeup     |
| Send   w[0]     w[1]     Receive   w[0]     w[1]     Send   w[0]     w[1]            | func=9U  undefined  err  undefined  cc_pad_set_all()  func=5U  config | svc=6U   undefined   svc=1U   undefined          | l         | size=2U<br>undefined<br>size=4U | pad      | ver=1U wakeup ver=1U |
| Send   w[0]     w[1]     Receive   w[0]     w[1]     w[1]     w[0]     w[1]     w[2] | func=9U  undefined  err  undefined  cc_pad_set_all()  func=5U  config | svc=6U   undefined   svc=1U   undefined          | l<br>l    | size=2U undefined size=4U       | pad      | ver=1U wakeup ver=1U |
| Send   w[0]     w[1]     Receive   w[0]     w[1]     w[1]     w[0]     w[1]     w[2] | func=9U  undefined  err  undefined  cc_pad_set_all()  func=5U  config | svc=6U   undefined   svc=1U   undefined          | l<br>l    | size=2U undefined size=4U       | pad      | ver=1U wakeup ver=1U |

## 10.6.90 sc\_pad\_get\_all()

| Send       |             |      |           |       |         |         |            |   |
|------------|-------------|------|-----------|-------|---------|---------|------------|---|
| w[0]       | func=10U    |      | svc=6U    | Ι     | size=2U |         | ver=1U     |   |
|            | undefined   |      | undefined |       |         | pad     |            | I |
| Receive    |             |      |           |       |         |         |            |   |
| w[0]       | err         | -    | svc=1U    | 1     | size=3U |         | ver=1U     |   |
| w[1]       |             |      |           | ctrl  |         |         |            |   |
|            | wakeup      |      |           |       | config  |         |            | I |
| 10.6.91 so | c_pad_set() |      |           |       |         |         |            |   |
| Send       |             |      |           |       |         |         |            |   |
| w[0]       | func=15U    |      |           |       |         |         |            |   |
| w[1]       |             |      |           | val   |         |         |            |   |
|            | undefined   |      |           |       |         | pad     |            | I |
| Receive    |             |      |           |       |         |         |            |   |
| w[0]       | err         |      | svc=1U    | l .   | size=1U |         | ver=1U     |   |
| 10.6.92 so | c_pad_get() |      |           |       |         |         |            |   |
| Send       |             |      |           |       |         |         |            |   |
|            | func=16U    |      |           |       |         |         | ver=1U<br> |   |
| w[1]       | undefined   | <br> | undefined | l<br> |         | pad<br> |            |   |
| Receive    |             |      |           |       |         |         |            |   |
| w[0]       | err         | I    | svc=1U    | 1     | size=2U |         | ver=1U     |   |
|            |             |      |           |       |         |         |            |   |

## 10.6.93 sc\_pad\_config()

| w[1] |

Send
| w[0] | func=17U | svc=6U | size=3U | ver=1U |
| w[1] | val |

| w[2] | undefined | pue

Receive

|                              | undefined                              |        |               |   |         |         |         |
|------------------------------|----------------------------------------|--------|---------------|---|---------|---------|---------|
|                              |                                        |        |               |   |         | pad<br> |         |
| Receive                      |                                        |        |               |   |         |         |         |
| w[0]                         | err                                    |        | svc=1U        | l | size=1U |         | ver=1U  |
| 10.6.94 sc                   | _pad_set_gp_2                          | 28fdso | i()           |   |         |         |         |
| Send                         |                                        |        |               |   |         |         |         |
|                              | func=11U                               |        | svc=6U        |   | size=2U |         | ver=1U  |
|                              | ps                                     |        | dse           |   |         | pad     | <b></b> |
| w[1]  <br>                   |                                        | '      |               |   |         |         |         |
| w[1]  <br><br>Receive        |                                        |        |               |   |         |         |         |
| Receive                      |                                        | <br>I  | svc=1U<br>i() | I | size=1U | I       | ver=1U  |
| Receive   w[0]               | err                                    | <br>I  |               | I | size=1U | I       | ver=1U  |
| Receive   w[0]               | err  pad_get_gp_2  func=12U            | 28fdso | i()<br>svc=6U |   | size=2U |         | ver=1U  |
| Receive   w[0]    10.6.95 sc | err pad_get_gp_2 func=12U              | 28fdso | i()           |   | size=2U |         |         |
| Receive   w[0]    10.6.95 sc | err pad_get_gp_2 func=12U              | 28fdso | i()<br>svc=6U |   | size=2U | i       | ver=1U  |
| Receive   w[0]    10.6.95 sc | err  pad_get_gp_a  func=12U  undefined | 28fdso | i()<br>svc=6U |   | size=2U | i       | ver=1U  |

| w[0] | err | svc=1U | size=1U | ver=1U

| pke |

## 10.6.97 sc\_pad\_get\_gp\_28fdsoi\_hsic()

| Send    |           |   |           |   |           |     |        |  |
|---------|-----------|---|-----------|---|-----------|-----|--------|--|
| w[0]    | func=8U   | ı | svc=6U    |   | size=2U   | I   | ver=1U |  |
| w[1]    | undefined | I | undefined |   |           | pad |        |  |
| Receive |           |   |           |   |           |     |        |  |
| w[0]    | err       | ı | svc=1U    | ı | size=3U   | ı   | ver=1U |  |
| w[1]    | pke       | ı | hys       | l | pus       | ı   | dse    |  |
| w[2]    | undefined | ı | undefined | ı | undefined | ı   | pue    |  |
|         |           |   |           |   |           |     |        |  |

## 10.6.98 sc\_pad\_set\_gp\_28fdsoi\_comp()

| Send    |          |   |           |      |         |     |        |      |
|---------|----------|---|-----------|------|---------|-----|--------|------|
| w[0]    | func=13U | I | svc=6U    | l    | size=3U | l   | ver=1U |      |
| w[1]    | rasrcp   | ı | compen    | ı    |         | pad |        | I    |
| w[2]    | psw_ovr  |   | nasrc_sel |      | fastfrz |     | rasrcn | <br> |
| Receive |          |   |           |      |         |     |        |      |
| w[0]    | err      |   | svc=1U    | <br> | size=1U |     | ver=1U | <br> |

## 10.6.99 sc\_pad\_get\_gp\_28fdsoi\_comp()

| Send    |           |   |           |   |           |     |         |   |
|---------|-----------|---|-----------|---|-----------|-----|---------|---|
| w[0]    | func=14U  | I | svc=6U    | I | size=2U   |     | ver=1U  | I |
| w[1]    | undefined |   | undefined | ı |           | pad |         |   |
| Receive |           |   |           |   |           |     |         |   |
| w[0]    | err       |   | svc=1U    | ı | size=3U   | l   | ver=1U  | I |
| w[1]    | nasrc     | ı | rasrcn    | ı | rasrcp    | ı   | compen  |   |
| w[2]    | psw_ovr   |   | compok    | l | nasrc_sel |     | fastfrz |   |

#### 10.6.100 sc\_misc\_set\_control()

| Send   |         |   |        |   |         |   |        |  |
|--------|---------|---|--------|---|---------|---|--------|--|
|        |         |   |        |   |         |   |        |  |
| w[0] w | func=1U | I | svc=7U | I | size=4U | 1 | ver=1U |  |
|        |         |   |        |   |         |   |        |  |

|                                              |                |           |                   | ctrl |         |           |        |
|----------------------------------------------|----------------|-----------|-------------------|------|---------|-----------|--------|
| <br>  w[2]                                   |                |           |                   | val  |         |           |        |
| w[3]                                         | undefined      |           | undefined         |      |         | esource   |        |
| Receive                                      |                |           |                   |      |         |           |        |
| w[0]                                         | err            | <br> <br> | svc=1U            | <br> | size=1U | <br> <br> | ver=1U |
| 0.6.101                                      | sc_misc_get_co | ontrol()  | )                 |      |         |           |        |
| Send                                         |                |           |                   |      |         |           |        |
|                                              | func=2U        |           |                   |      | size=3U | I         | ver=1U |
| w[1]                                         |                |           |                   | ctrl |         |           |        |
| w[2]                                         | undefined      | <br> <br> | undefined         |      | r       | esource   |        |
|                                              |                |           |                   |      |         |           |        |
| Receive                                      |                |           |                   |      |         |           |        |
| w[0]                                         | err            |           |                   |      |         |           | ver=1U |
| w[1]  <br>                                   |                |           |                   |      | size=2U |           | ver=1U |
| w[0]  <br>  w[1]  <br>  w[1]                 |                |           |                   |      |         |           |        |
| w[0]  <br>  w[1]  <br>  0.6.102              |                | ax_dm     | na_group()        | val  |         |           |        |
| w[0]  <br>  w[1]  <br>  10.6.102  <br>  Send | sc_misc_set_ma | ax_dm     | na_group()        | val  |         |           |        |
| w[0]  <br>  w[1]  <br>  10.6.102  <br>  Send | sc_misc_set_ma | ax_dm     | na_group() svc=7U | val  | size=2U |           | ver=1U |

| w[0] | err | svc=1U | size=1U | ver=1U |

#### 10.6.104 sc\_misc\_debug\_out()

| Send    |           |      |           |     |           |   |        |     |
|---------|-----------|------|-----------|-----|-----------|---|--------|-----|
| w[0]    | func=10U  | <br> | svc=7U    | Ι   | size=2U   |   | ver=1U |     |
| w[1]    | undefined | ı    | undefined | ı   | undefined |   | ch     |     |
| D       |           |      |           |     |           |   |        |     |
| Receive |           |      |           |     |           |   |        |     |
| w[0]w   | undefined | -    | svc=1U    | - 1 | size=1U   | 1 | ver=1U | - 1 |

## 10.6.105 sc\_misc\_waveform\_capture()

| Send    |           |      |           |      |           |      |        |   |
|---------|-----------|------|-----------|------|-----------|------|--------|---|
| w[0]    | func=6U   | ı    | svc=7U    | ı    | size=2U   | ı    | ver=1U |   |
| w[1]    | undefined | <br> | undefined | <br> | undefined | <br> | enable | I |
| Receive |           |      |           |      |           |      |        |   |
| w[0]    | err       | l    | svc=1U    | <br> | size=1U   | l    | ver=1U |   |

# 10.6.106 sc\_misc\_build\_info()

| Send    |           |      |        |        |         |   |        |      |
|---------|-----------|------|--------|--------|---------|---|--------|------|
| w[0]    | func=15U  | <br> | svc=7U |        | size=1U |   | ver=1U | <br> |
| Receive |           |      |        |        |         |   |        |      |
| w[0]    | undefined | I    | svc=1U | I      | size=3U | l | ver=1U |      |
| w[1]    |           |      |        | build  |         |   |        | I    |
| w[2]    |           |      |        | commit |         |   |        |      |

## 10.6.107 sc\_misc\_api\_ver()

| Send    |           |        |        |   |         |        |        |   |
|---------|-----------|--------|--------|---|---------|--------|--------|---|
| w[0] w  | func=35U  |        | svc=7U |   | size=1U | I      | ver=1U |   |
|         |           |        |        |   |         |        |        |   |
| Receive |           |        |        |   |         |        |        |   |
| w[0]w   | undefined |        | svc=1U | I | size=3U | 1      | ver=1U | - |
| w[1]    |           | cl_min |        |   |         | cl_maj |        |   |
| w[2]    |           | sv_min |        |   |         | sv_maj |        |   |
|         |           |        |        |   |         |        |        |   |

## 10.6.108 sc\_misc\_unique\_id()

| Send    |           |   |        |      |         |  |        |  |
|---------|-----------|---|--------|------|---------|--|--------|--|
| w[0]    | func=19U  |   | svc=7U |      | size=1U |  | ver=1U |  |
|         |           |   |        |      |         |  |        |  |
| Receive |           |   |        |      |         |  |        |  |
| w[0]    | undefined | I | svc=1U | ı    | size=3U |  | ver=1U |  |
| w[1]    |           |   |        | id_l |         |  |        |  |
| w[2]    |           |   |        | id_h |         |  |        |  |
|         |           |   |        |      |         |  |        |  |

#### 10.6.109 sc\_misc\_set\_ari()

| Send    |           |         |        |   |         |         |        |           |
|---------|-----------|---------|--------|---|---------|---------|--------|-----------|
| w[0]    | func=3U   | I       | svc=7U | ı | size=3U | ı       | ver=1U |           |
| w[1]    | res       | ource_r | nst    | I | r       | esource |        |           |
| w[2]    | undefined | l       | enable | ı |         | ari     |        | I         |
| Receive |           |         |        |   |         |         |        |           |
| w[0]    | err       | <br>    | svc=1U |   | size=1U | <br>    | ver=1U | <br> <br> |

#### 10.6.110 sc\_misc\_boot\_status()

| Sena |           |  |           |   |           |   |        |  |
|------|-----------|--|-----------|---|-----------|---|--------|--|
| w[0] | func=7U   |  | svc=7U    |   | size=2U   | I | ver=1U |  |
| w[1] | undefined |  | undefined | ı | undefined | ı | status |  |
|      |           |  |           |   |           |   |        |  |

#### 10.6.111 sc\_misc\_boot\_done()

| Send    |           |       |           |   |         |     |        |   |
|---------|-----------|-------|-----------|---|---------|-----|--------|---|
| w[0]    | func=14U  | I     | svc=7U    | ı | size=2U | ı   | ver=1U |   |
| w[1]    | undefined |       | undefined |   |         | cpu |        |   |
|         |           |       |           |   |         |     |        |   |
| Receive |           |       |           |   |         |     |        |   |
| w[0]    | err       | l<br> | svc=1U    | I | size=1U | I   | ver=1U | I |

#### 10.6.112 sc\_misc\_otp\_fuse\_read()

| Send                        |                       |           |             |      |         |           |                  |
|-----------------------------|-----------------------|-----------|-------------|------|---------|-----------|------------------|
|                             | func=11U              |           | svc=7U      |      | size=2U |           | ver=1U           |
| w[1]                        |                       |           |             | word |         |           |                  |
| Receive                     |                       |           |             |      |         |           |                  |
| w[0]                        | err                   |           | svc=1U      | Ι    | size=2U |           | ver=1U           |
| w[1]                        |                       |           |             | val  |         |           |                  |
| 10.6.113                    | sc_misc_otp_f         | use_wri   | te()        |      |         |           |                  |
| Send                        |                       |           |             |      |         |           |                  |
| w[0]                        | func=17U              | ı         | svc=7U      |      | size=3U | ı         | ver=1U           |
| w[1]                        |                       |           |             | word |         |           |                  |
| w[2]                        |                       |           |             | val  |         |           |                  |
|                             |                       |           |             |      |         |           |                  |
| Receive<br>                 |                       |           |             |      |         |           |                  |
| Receive<br><br>  w[0]  <br> | err                   | <br> <br> | svc=1U      | I    | size=1U | <br> <br> | ver=1U           |
| w[0]                        | err<br>sc_misc_set_te | <u>-</u>  | svc=1U      | l    | size=1U | <br> <br> | ver=1U           |
| 10.6.114                    |                       | <u>-</u>  | svc=1U      | I    | size=1U | I         | ver=1U           |
| w[0]  <br>10.6.114          |                       | emp()     |             |      | size=1U |           | ver=1U<br>ver=1U |
| 10.6.114 Send               | sc_misc_set_te        | emp()     | svc=7U<br>s |      | size=3U | esource   | ver=1U           |
| 10.6.114 Send               | sc_misc_set_te        | emp()     | svc=7U<br>s |      | size=3U |           | ver=1U           |
| 10.6.114 Send               | sc_misc_set_te        | emp()     | svc=7U<br>s |      | size=3U | esource   | ver=1U           |

#### 

| w[0] | func=13U | svc=7U | size=2U | ver=1U |

resource

 $\mid$  w[1]  $\mid$  undefined  $\mid$  temp  $\mid$ 

Receive

#### 10.6.116 sc\_misc\_get\_boot\_dev()

| Send    |           |   |           |   |         |     |        |   |
|---------|-----------|---|-----------|---|---------|-----|--------|---|
| w[0]    | func=16U  | I | svc=7U    | ı | size=1U | ı   | ver=1U | I |
|         |           |   |           |   |         |     |        |   |
| Receive |           |   |           |   |         |     |        |   |
| [0]w    | undefined |   | svc=1U    | l | size=2U |     | ver=1U |   |
| w[1]    | undefined | I | undefined | ı |         | dev |        |   |

#### 10.6.117 sc\_misc\_get\_boot\_type()

| Send    |           |      |           |      |           |   |        |   |
|---------|-----------|------|-----------|------|-----------|---|--------|---|
| w[0]    | func=33U  | <br> | svc=7U    |      | size=1U   | ı | ver=1U | I |
| Receive |           |      |           |      |           |   |        |   |
| w[0]    | err       | l    | svc=1U    | I    | size=2U   | ı | ver=1U |   |
| w[1]    | undefined |      | undefined | <br> | undefined |   | type   | I |

# 10.6.118 sc\_misc\_get\_boot\_container()

| Send    |           |      |           |   |           |   |        |     |
|---------|-----------|------|-----------|---|-----------|---|--------|-----|
| w[0]    | func=36U  | <br> | svc=7U    |   | size=1U   | l | ver=1U | I   |
| Receive |           |      |           |   |           |   |        |     |
| w[0]    | err       | I    | svc=1U    | 1 | size=2U   | 1 | ver=1U | - 1 |
| w[1]    | undefined | ı    | undefined | ı | undefined | ı | idx    |     |

## 10.6.119 sc\_misc\_get\_button\_status()

| Send    |           |   |           |   |           |   |        |   |
|---------|-----------|---|-----------|---|-----------|---|--------|---|
| w[0]    | func=18U  | I | svc=7U    | I | size=1U   |   | ver=1U | 1 |
|         |           |   |           |   |           |   |        |   |
| Receive |           |   |           |   |           |   |        |   |
| w[0]    | undefined | I | svc=1U    |   | size=2U   | l | ver=1U | I |
| w[1]    | undefined | I | undefined | ı | undefined | I | status |   |
|         |           |   |           |   |           |   |        |   |

#### 10.6.120 sc\_misc\_rompatch\_checksum()

| Send    |          |      |        |      |         |   |        |      |
|---------|----------|------|--------|------|---------|---|--------|------|
| w[0]    | func=26U | <br> | svc=7U | <br> | size=1U |   | ver=1U | <br> |
| Receive |          |      |        |      |         |   |        |      |
| w[0]    | err      | l    | svc=1U |      | size=2U | I | ver=1U |      |
| w[1]    | checksum |      |        |      |         |   |        |      |
|         |          |      |        |      |         |   |        |      |

#### 10.6.121 sc\_misc\_board\_ioctl()

| Send    |          |   |        |       |         |   |        |      |
|---------|----------|---|--------|-------|---------|---|--------|------|
| w[0]    | func=34U | ı | svc=7U | l     | size=4U | ı | ver=1U |      |
| w[1]    |          |   |        | parm1 |         |   |        |      |
| w[2]    |          |   |        | parm2 |         |   |        |      |
| w[3]    |          |   |        | parm3 |         |   |        | <br> |
| Receive |          |   |        |       |         |   |        |      |
|         | err      |   |        |       |         |   |        |      |
| w[1]    |          |   |        | parm1 |         |   |        |      |
| w[2]    |          |   |        | parm2 |         |   |        |      |
| w[3]    |          |   |        | parm3 |         |   |        |      |

#### 10.6.122 sc\_seco\_image\_load()

Send | w[0] | func=1U | svc=9U | size=7U | ver=1U | w[1] | addr\_src (MSW) addr\_src (LSW) | w[2] | addr\_dst (MSW) | w[3] | | w[4] | addr\_dst (LSW) | w[5] | len | w[6] | undefined | undefined | Receive | w[0] | err | svc=1U | size=1U | ver=1U

## 10.6.123 sc\_seco\_authenticate()

| Send    |           |       |           |      |           |       |        |   |
|---------|-----------|-------|-----------|------|-----------|-------|--------|---|
| w[0]    | func=2U   |       | svc=9U    |      | size=4U   |       | ver=1U |   |
| w[1]    |           |       | addr      | (MSV | √)        |       |        |   |
| w[2]    |           |       | addr      | (LSV | √)        |       |        |   |
| w[3]    | undefined | I     | undefined | I    | undefined | ı     | cmd    | ı |
|         |           |       |           |      |           |       |        |   |
| Receive |           |       |           |      |           |       |        |   |
| w[0]    | err       | l<br> | svc=1U    |      | size=1U   | l<br> | ver=1U |   |

#### 10.6.124 sc\_seco\_enh\_authenticate()

| Send    |           |   |           |        |           |   |        |      |
|---------|-----------|---|-----------|--------|-----------|---|--------|------|
| w[0]    |           |   | svc=9U    |        |           |   | ver=1U | 1    |
| w[1]    |           |   | ado       | dr (MS | W)        |   |        | ١    |
| w[2]    |           |   | ado       | dr (LS | W)        |   |        |      |
| w[3]    | mask1     |   |           |        |           |   |        |      |
| w[4]    | mask2     |   |           |        |           |   |        |      |
| w[5]    | undefined | ı | undefined | ı      | undefined | ı | cmd    | ı    |
| Receive |           |   |           |        |           |   |        |      |
| w[0]    | err       | ı | svc=1U    |        | size=1U   | l | ver=1U | <br> |

## 10.6.125 sc\_seco\_forward\_lifecycle()

| Send        |         |           |        |        |         |           |        |           |
|-------------|---------|-----------|--------|--------|---------|-----------|--------|-----------|
| w[0]        | func=3U |           | svc=9U | I      | size=2U |           | ver=1U | I         |
| w[1]        |         |           |        | change |         |           |        | I         |
|             |         |           |        |        |         |           |        |           |
| Receive     |         |           |        |        |         |           |        |           |
| w[0]        | err     | <br>      | svc=1U | I      | size=1U |           | ver=1U |           |
| Receive<br> | err     | <br> <br> | svc=1U | <br>   | size=1U | <br> <br> | ver=1U | <br> <br> |

## 10.6.126 sc\_seco\_return\_lifecycle()

| Send     |              |      |        |       |         |  |        |         |
|----------|--------------|------|--------|-------|---------|--|--------|---------|
| w[0]     | func=4U      |      | svc=9U |       | size=3U |  | ver=1U |         |
| w[1]     |              |      | addr   | (MSW) |         |  |        |         |
| w[2]     |              |      | addr   | (LSW) |         |  |        |         |
| Receive  |              |      |        |       |         |  |        |         |
| w[0]     | err          |      | svc=1U | I     | size=1U |  | ver=1U |         |
|          |              |      |        |       |         |  |        | <b></b> |
| 10.6.127 | sc_seco_comm | it() |        |       |         |  |        |         |

| Send    |         |   |        |      |         |  |        |   |
|---------|---------|---|--------|------|---------|--|--------|---|
| w[0]    | func=5U | I | svc=9U | ı    | size=2U |  | ver=1U |   |
| w[1]    |         |   |        | info |         |  |        | I |
| Receive |         |   |        |      |         |  |        |   |
| Veceive |         |   |        |      |         |  |        |   |
| w[0]    | err     |   | svc=1U |      | size=2U |  | ver=1U |   |
| w[1]    |         |   |        | info |         |  |        | - |
|         |         |   |        |      |         |  |        |   |

# 10.6.128 sc\_seco\_attest\_mode()

| Send    |         |           |        |      |         |   |        |           |
|---------|---------|-----------|--------|------|---------|---|--------|-----------|
| w[0]    | func=6U | ı         | svc=9U | ı    | size=2U | ı | ver=1U |           |
| w[1]    |         |           |        | mode |         |   |        |           |
| Receive |         |           |        |      |         |   |        |           |
| w[0]    | err     | <br> <br> | svc=1U | l    | size=1U |   | ver=1U | <br> <br> |

# 10.6.129 sc\_seco\_attest()

| Send    |             |       |        |      |         |      |        |  |
|---------|-------------|-------|--------|------|---------|------|--------|--|
| w[0]    | func=7U     | I     | svc=9U | I    | size=3U | I    | ver=1U |  |
| w[1]    | nonce (MSW) |       |        |      |         |      |        |  |
| w[2]    | nonce (LSW) |       |        |      |         |      |        |  |
| Receive |             |       |        |      |         |      |        |  |
| w[0]    | err         | l<br> | svc=1U | <br> | size=1U | <br> | ver=1U |  |

# 10.6.130 sc\_seco\_get\_attest\_pkey()

| Send    |         |   |        |       |         |   |        |   |
|---------|---------|---|--------|-------|---------|---|--------|---|
| w[0]    | func=8U | I | svc=9U | ı     | size=3U | I | ver=1U | I |
| w[1]    |         |   | addr   | (MSW) |         |   |        | I |
| w[2]    |         |   | addr   | (LSW) |         |   |        |   |
| Receive |         |   |        |       |         |   |        |   |
|         |         |   |        |       |         |   |        |   |
| w[0]    | err     |   | svc=1U | <br>  | size=1U |   | ver=1U |   |

# 10.6.131 sc\_seco\_get\_attest\_sign()

| Send    |         |      |        |       |         |   |        |   |
|---------|---------|------|--------|-------|---------|---|--------|---|
| w[0]    | func=9U | <br> | svc=9U | ı     | size=3U | I | ver=1U |   |
| w[1]    |         |      | addr   | (MSW) |         |   |        |   |
| w[2]    |         |      | addr   | (LSW) |         |   |        | I |
| Receive |         |      |        |       |         |   |        |   |
| w[0]w   | err     |      | svc=1U | 1     | size=1U | 1 | ver=1U | - |

# 10.6.132 sc\_seco\_attest\_verify()

| Send    |          |   |        |       |         |   |        |      |
|---------|----------|---|--------|-------|---------|---|--------|------|
| w[0]    | func=10U | I | svc=9U | I     | size=3U |   | ver=1U | 1    |
| w[1]    |          |   | addr   | (MSW) |         |   |        | I    |
| w[2]    |          |   | addr   | (LSW) |         |   |        | I    |
| Receive |          |   |        |       |         |   |        |      |
| w[0]    | err      | l | svc=1U |       | size=1U | I | ver=1U | <br> |

# 10.6.133 sc\_seco\_gen\_key\_blob()

| Send |          |   |        |         |         |  |        |  |
|------|----------|---|--------|---------|---------|--|--------|--|
| w[0] | func=11U | I | svc=9U |         | size=7U |  | ver=1U |  |
| w[1] |          |   | load   | _addr ( | (MSW)   |  |        |  |
| w[2] |          |   | load   | _addr ( | (LSW)   |  |        |  |
|      |          |   |        |         |         |  |        |  |

96 RPC Protocol

| w[3]    |           |  | expor     | t_addr | (MSW)   |          |        |  |
|---------|-----------|--|-----------|--------|---------|----------|--------|--|
| w[4]    |           |  | expor     | t_addr | (LSW)   |          |        |  |
| w[5]    |           |  |           | id     |         |          |        |  |
| w[6]    | undefined |  | undefined | <br>   |         | max_size |        |  |
| Receive |           |  |           |        |         |          |        |  |
| w[0]    | err       |  | svc=1U    | <br>   | size=1U | <br>     | ver=1U |  |

# 10.6.134 sc\_seco\_load\_key()

| w[0] | func=12U | l | svc=9U | I      | size=4U |  | ver=1U |              |
|------|----------|---|--------|--------|---------|--|--------|--------------|
| w[1] |          |   | add:   | r (MSW | )       |  |        |              |
| w[2] |          |   | add    | r (LSW | )       |  |        | <sub> </sub> |
| w[3] |          |   |        | id     |         |  |        |              |
|      |          |   |        |        |         |  |        |              |

#### Receive

|      |     |   |        |     |         | <br>   |   |
|------|-----|---|--------|-----|---------|--------|---|
| [0]w | err | 1 | svc=1U | - 1 | size=1U | ver=1U | - |

# 10.6.135 sc\_seco\_get\_mp\_key()

Send

| w[0]                  | func=13U  | ı    | svc=9U    | I    | size=4U | <br>     | ver=1U |   |
|-----------------------|-----------|------|-----------|------|---------|----------|--------|---|
| w[1]                  |           |      | dst_      | addr | (MSW)   |          |        |   |
| w[2]                  |           |      | dst_      | addr | (LSW)   |          |        |   |
|                       |           |      |           |      |         |          |        |   |
| w[3]                  | undefined | <br> | undefined | <br> |         | dst_size |        |   |
| w[3]  <br><br>Receive | undefined | <br> | undefined | I    |         | dst_size |        | l |

# 10.6.136 sc\_seco\_update\_mpmr()

Send

| w[0] | func=14U | <br>svc=9U | <br>I | size=4U | <br> | <br>ver=1U | <br>I |
|------|----------|------------|-------|---------|------|------------|-------|
|      |          | <br>       |       |         |      |            |       |
| w[1] |          | addr       | (MSW) |         |      |            |       |
| w[2] |          | <br>addr   | (LSW) |         |      |            |       |

| w[3]                            | undefined       | I            | undefined        |           | lock                   | <br>      | size             |              |
|---------------------------------|-----------------|--------------|------------------|-----------|------------------------|-----------|------------------|--------------|
| Receive                         |                 |              |                  |           |                        |           |                  |              |
| w[0]                            | err             | <br>         | svc=1U           |           | size=1U                | I         | ver=1U           | I            |
|                                 |                 |              |                  |           |                        |           |                  |              |
| 10.6.137                        | sc_seco_get_m   | p_sign()     | )                |           |                        |           |                  |              |
| Send                            |                 |              |                  |           |                        |           |                  |              |
| w[0]                            | func=15U        | I            |                  |           | size=6U                | ı         | ver=1U           |              |
| w[1]                            |                 |              | msg_a            | addr (I   |                        |           |                  |              |
| w[2]                            |                 |              | msg_a            | addr (    |                        |           |                  |              |
| w[3]                            |                 |              | dst_a            | addr (I   |                        |           |                  | I            |
| w[4]                            |                 |              | dst_a            | addr (    | LSW)                   |           |                  | I            |
| w[5]                            |                 | st_size      |                  |           |                        | sg_size   |                  |              |
| Receive                         |                 |              |                  |           |                        |           |                  |              |
| w[0]                            | err             |              | svc=1U           |           | size=1U                |           | ver=1U           | <sub>I</sub> |
| Send                            | sc_seco_build_i | ·            |                  |           |                        |           |                  |              |
| <br>  w[0]                      | func=16U        | <br>         | svc=9U           | <br>I     | size=1U                | <br>l     | ver=1U           | I            |
| Receive                         |                 |              |                  |           |                        |           |                  |              |
| <br>  w[0]                      | undefined       |              | svc=1U           | <br>      | size=3U                |           | ver=1U           | <br>         |
| <br>  w[1]                      |                 |              |                  | versio    | <br>n                  |           |                  | <br>I        |
| w[2]                            |                 |              |                  | commit    |                        |           |                  | I            |
|                                 |                 |              |                  |           |                        |           |                  |              |
| 10.6.139                        | sc_seco_chip_i  | nfo()        |                  |           |                        |           |                  |              |
|                                 |                 | v            |                  |           |                        |           |                  |              |
|                                 |                 |              |                  |           |                        |           |                  |              |
| Send                            | £ 177           |              |                  |           |                        |           |                  |              |
| Send                            | func=17U        | <br>I        | svc=9U           | <br> <br> | size=1U                | <br> <br> | ver=1U           | <br> <br>    |
| Send<br><br>  w[0]  <br>        | func=17U        | <br>         | svc=9U           | <br> <br> | size=1U                | <br> <br> | ver=1U           | l            |
| Send<br>  w[0]  <br><br>Receive | err             | <u>-</u><br> | svc=9U<br>svc=1U | <br>      | size=1U<br><br>size=4U | <br> <br> | ver=1U<br>ver=1U |              |

98 RPC Protocol

| w[2] |           | uid_h |    |  |
|------|-----------|-------|----|--|
|      |           |       |    |  |
| w[3] | monotonic | 1     | lc |  |
|      |           |       |    |  |

# 10.6.140 sc\_seco\_enable\_debug()

| Sen | .d   |          |      |        |           |         |      |        |   |
|-----|------|----------|------|--------|-----------|---------|------|--------|---|
| W   | [0]  | func=18U |      | svc=9U | 1         | size=3U |      | ver=1U |   |
| W   | [1]  |          |      | addr   | (MSW)     |         |      |        |   |
| W   | [2]  |          |      | addr   | (LSW)     |         |      |        | I |
| Rec | eive |          |      |        |           |         |      |        |   |
| W   | [0]  | err      | <br> | svc=1U | <br> <br> | size=1U | <br> | ver=1U |   |

# 10.6.141 sc\_seco\_get\_event()

| Send |           |           |           |  |           |           |        |           |
|------|-----------|-----------|-----------|--|-----------|-----------|--------|-----------|
| w[0] | func=19U  | I         | svc=9U    |  | size=2U   |           | ver=1U |           |
| w[1] | undefined | <br> <br> | undefined |  | undefined | <br> <br> | idx    | <br> <br> |

| Re | eceive | 9 |     |        |         |     |
|----|--------|---|-----|--------|---------|-----|
|    |        |   |     | <br>   | <br>    |     |
|    | w[0]   |   | err | svc=1U | size=2U | - 1 |

| w[0] w                                                  | err | 1 | svc=1U |  | size=2U | 1 | ver=1U | 1 |
|---------------------------------------------------------|-----|---|--------|--|---------|---|--------|---|
| w[0]   err   svc=1U   size=2U   ver=1<br>  w[1]   event |     |   |        |  |         |   |        |   |
|                                                         |     |   |        |  |         |   |        |   |

# 10.6.142 sc\_seco\_fuse\_write()

| Send    |          |   |        |        |         |   |        |      |
|---------|----------|---|--------|--------|---------|---|--------|------|
| w[0]    | func=20U | I | svc=9U | I      | size=3U | l | ver=1U |      |
| w[1]    |          |   | add    | r (MSW | )       |   |        |      |
| w[2]    |          |   | add    | r (LSW | )<br>   |   |        | <br> |
| Receive |          |   |        |        |         |   |        |      |
| w[0]    | err      |   | svc=1U |        | size=1U |   | ver=1U |      |

# 10.6.143 sc\_seco\_patch()

| Send    |          |  |        |       |         |  |        |  |
|---------|----------|--|--------|-------|---------|--|--------|--|
| w[0]    | func=21U |  | svc=9U |       | size=3U |  | ver=1U |  |
| w[1]    |          |  | addı   | (MSW) |         |  |        |  |
| w[2]    |          |  | addı   | (LSW) |         |  |        |  |
| Receive |          |  |        |       |         |  |        |  |
| w[0]    | err      |  | svc=1U | I     | size=1U |  | ver=1U |  |
|         |          |  |        |       |         |  |        |  |

# 10.6.144 sc\_seco\_set\_mono\_counter\_partition()

| Send    |           |      |           |   |         |     |        |      |
|---------|-----------|------|-----------|---|---------|-----|--------|------|
| w[0]    | func=28U  | I    | svc=9U    |   | size=2U | l   | ver=1U | I    |
| w[1]    | undefined |      | undefined |   |         | she |        | I    |
| Receive |           |      |           |   |         |     |        |      |
| w[0]    | err       |      | svc=1U    | l | size=2U |     | ver=1U | I    |
| w[1]    | undefined | <br> | undefined |   |         | she |        | <br> |
|         |           |      |           |   |         |     |        |      |

# 10.6.145 sc\_seco\_set\_fips\_mode()

| Send    |           |      |           |        |           |   |        |   |
|---------|-----------|------|-----------|--------|-----------|---|--------|---|
| w[0]    | func=29U  | l    | svc=9U    | I      | size=2U   | ı | ver=1U |   |
| w[1]    | undefined | I    | undefined | I      | undefined |   | mode   | I |
| Receive |           |      |           |        |           |   |        |   |
| w[0]    | err       | <br> | svc=1U    |        | size=2U   |   | ver=1U |   |
| w[1]    |           |      |           | reason |           |   |        | I |

# 10.6.146 sc\_seco\_start\_rng()

| Send    |          |   |        |        |         |   |        |   |
|---------|----------|---|--------|--------|---------|---|--------|---|
| w[0]w   | func=22U | 1 | svc=9U | I      | size=1U | 1 | ver=1U | 1 |
|         |          |   |        |        |         |   |        |   |
| Receive |          |   |        |        |         |   |        |   |
| w[0] w  | err      | ı | svc=1U |        | size=2U | l | ver=1U |   |
| w[1]    |          |   |        | status |         |   |        | - |
|         |          |   |        |        |         |   |        |   |

100 RPC Protocol

# 10.6.147 sc\_seco\_sab\_msg()

| Send    |          |   |        |           |         |   |        |           |
|---------|----------|---|--------|-----------|---------|---|--------|-----------|
| w[0]    | func=23U |   | svc=9U | I         | size=3U | l | ver=1U | 1         |
| w[1]    |          |   | addr   | (MSW)     |         |   |        | I         |
| w[2]    |          |   | addr   | (LSW)     |         |   |        |           |
| Receive |          |   |        |           |         |   |        |           |
| w[0]    | err      | I | svc=1U | <br> <br> | size=1U |   | ver=1U | <br> <br> |

# 10.6.148 sc\_seco\_secvio\_enable()

| Send    |          |      |        |      |         |  |        |   |
|---------|----------|------|--------|------|---------|--|--------|---|
| w[0]    | func=25U | ı    | svc=9U | I    | size=1U |  | ver=1U |   |
|         |          |      |        |      |         |  |        |   |
| Receive |          |      |        |      |         |  |        |   |
| w[0]    | err      | <br> | svc=1U | <br> | size=1U |  | ver=1U | I |

# 10.6.149 sc\_seco\_secvio\_config()

| Send    |           |      |        |       |         |  |        |      |
|---------|-----------|------|--------|-------|---------|--|--------|------|
| w[0]    | func=26U  | l    | svc=9U |       | size=7U |  | ver=1U |      |
| w[1]    |           |      |        | data0 |         |  |        |      |
| w[2]    |           |      |        | data1 |         |  |        |      |
| w[3]    |           |      |        | data2 |         |  |        |      |
| w[4]    |           |      |        | data3 |         |  |        |      |
| w[5]    |           |      |        | data4 |         |  |        |      |
| w[6]    | undefined |      | size   | l     | access  |  | id     | <br> |
| Receive |           |      |        |       |         |  |        |      |
| w[0]    | err       | <br> | svc=1U |       | size=6U |  | ver=1U |      |
| w[1]    |           |      |        | data0 |         |  |        |      |
| w[2]    |           |      |        | data1 |         |  |        |      |
| w[3]    |           |      |        | data2 |         |  |        |      |
| w[4]    |           |      |        | data3 |         |  |        |      |
| w[5]    |           |      |        | data4 |         |  |        | I    |

ver=1U |

# 10.6.150 sc\_seco\_secvio\_dgo\_config()

| Send    |           |   |           |      |         |   |        |      |
|---------|-----------|---|-----------|------|---------|---|--------|------|
| w[0]    | func=27U  | ı | svc=9U    | ı    | size=3U | ı | ver=1U | <br> |
| w[1]    |           |   |           | data |         |   |        | I    |
| w[2]    | undefined |   | undefined | l    | access  |   | id     |      |
| Receive |           |   |           |      |         |   |        |      |
|         |           |   |           |      |         |   |        |      |
| w[0]    | err       | l | svc=1U    | l    | size=2U | l | ver=1U | <br> |
| w[1]    |           |   |           | data |         |   |        | 1    |
|         |           |   |           |      |         |   |        |      |

# 10.6.151 sc\_irq\_enable()

| Send |         |  |        |      |         |  |
|------|---------|--|--------|------|---------|--|
| w[0] | func=1U |  | svc=8U |      | size=3U |  |
| w[1] |         |  |        | mask |         |  |

| M[T] |        |   |       | mask |          | - |
|------|--------|---|-------|------|----------|---|
|      |        |   |       |      |          |   |
| w[2] | enable | 1 | group | 1    | resource |   |
|      |        |   |       |      |          |   |

Receive

| w[0] w | err | 1 | svc=1U | size=1U | ver=1U | - 1 |
|--------|-----|---|--------|---------|--------|-----|
|        |     |   |        | <br>    |        |     |

# 10.6.152 sc\_irq\_status()

Send

| w[0] w | func=2U   | 1   | svc=8U | I | size=2U | I        | ver=1U | - 1 |
|--------|-----------|-----|--------|---|---------|----------|--------|-----|
|        |           |     |        |   |         |          |        |     |
| w[1]   | undefined | - 1 | group  |   | 1       | resource |        | - 1 |
|        |           |     |        |   |         |          |        |     |
|        |           |     |        |   |         |          |        |     |
|        |           |     |        |   |         |          |        |     |

Receive

|       |     |   |        |        |         | <br>   |     |
|-------|-----|---|--------|--------|---------|--------|-----|
| w[0]w | err | 1 | svc=1U |        | size=2U | ver=1U | - 1 |
|       |     |   |        |        |         | <br>   |     |
| w[1]  |     |   |        | status |         |        | - 1 |

| 102 | RPC Protocol |
|-----|--------------|
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |

# **Chapter 11**

# **Module Index**

# 11.1 Modules

## Here is a list of all modules:

| Interrupt Service           | 7 |
|-----------------------------|---|
| C: Miscellaneous Service    | 2 |
| : Pad Service               | 6 |
| Power Management Service    |   |
| Resource Management Service | 8 |
| O: Security Service         | 6 |
| ER: Timer Service           | 2 |

| 104 | Module Index |
|-----|--------------|
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |
|     |              |

# **Chapter 12**

# File Index

# 12.1 File List

Here is a list of all documented files with brief descriptions:

| platform/config/mx8qm/pads.h                                                                             |
|----------------------------------------------------------------------------------------------------------|
| Header file used to configure SoC pad list                                                               |
| platform/main/ipc.h                                                                                      |
| Header file for the IPC implementation                                                                   |
| platform/main/types.h                                                                                    |
| Header file containing types used across multiple service APIs                                           |
| platform/svc/irq/api.h                                                                                   |
| Header file containing the public API for the System Controller (SC) Interrupt (IRQ) function 264        |
| platform/svc/misc/api.h                                                                                  |
| Header file containing the public API for the System Controller (SC) Miscellaneous (MISC) function . 267 |
| platform/svc/pad/api.h                                                                                   |
| Header file containing the public API for the System Controller (SC) Pad Control (PAD) function 269      |
| platform/svc/pm/api.h                                                                                    |
| Header file containing the public API for the System Controller (SC) Power Management (PM) func-         |
| tion                                                                                                     |
| platform/svc/rm/api.h                                                                                    |
| Header file containing the public API for the System Controller (SC) Resource Management (RM)            |
| function                                                                                                 |
| platform/svc/seco/api.h                                                                                  |
| Header file containing the public API for the System Controller (SC) Security (SECO) function 281        |
| platform/svc/timer/api.h                                                                                 |
| Header file containing the public API for the System Controller (SC) Timer function                      |

| 106 | File Index |
|-----|------------|
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |
|     |            |

# **Chapter 13**

# **Module Documentation**

# 13.1 IRQ: Interrupt Service

Module for the Interrupt (IRQ) service.

#### **Macros**

#define SC\_IRQ\_NUM\_GROUP 7U
 Number of groups.

# **Typedefs**

typedef uint8\_t sc\_irq\_group\_t

This type is used to declare an interrupt group.

typedef uint8\_t sc\_irq\_temp\_t

This type is used to declare a bit mask of temp interrupts.

• typedef uint8\_t sc\_irq\_wdog\_t

This type is used to declare a bit mask of watchdog interrupts.

• typedef uint8\_t sc\_irq\_rtc\_t

This type is used to declare a bit mask of RTC interrupts.

typedef uint8\_t sc\_irq\_wake\_t

This type is used to declare a bit mask of wakeup interrupts.

## **Functions**

- sc\_err\_t sc\_irq\_enable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_irq\_group\_t group, uint32\_t mask, sc\_bool\_t enable)

  This function enables/disables interrupts.
- sc\_err\_t sc\_irq\_status (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_irq\_group\_t group, uint32\_t \*status)

This function returns the current interrupt status (regardless if masked).

## Defines for sc\_irq\_group\_t

• #define SC\_IRQ\_GROUP\_TEMP 0U

Temp interrupts.

#define SC IRQ GROUP WDOG 1U

Watchdog interrupts.

#define SC\_IRQ\_GROUP\_RTC 2U

RTC interrupts.

• #define SC\_IRQ\_GROUP\_WAKE 3U

Wakeup interrupts.

#define SC\_IRQ\_GROUP\_SYSCTR 4U

System counter interrupts.

#define SC IRQ GROUP REBOOTED 5U

Partition reboot complete.

#define SC IRQ GROUP REBOOT 6U

Partition reboot starting.

#### Defines for sc irq temp t

#define SC\_IRQ\_TEMP\_HIGH (1UL << 0U)</li>

Temp alarm interrupt.

#define SC\_IRQ\_TEMP\_CPU0\_HIGH (1UL << 1U)</li>

CPU0 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_CPU1\_HIGH (1UL << 2U)</li>

CPU1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_GPU0\_HIGH (1UL << 3U)</li>

GPU0 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_GPU1\_HIGH (1UL << 4U)</li>

GPU1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_DRC0\_HIGH (1UL << 5U)</li>

DRC0 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_DRC1\_HIGH (1UL << 6U)</li>

DRC1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_VPU\_HIGH (1UL << 7U)</li>

DRC1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_PMIC0\_HIGH (1UL << 8U)</li>

PMIC0 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_PMIC1\_HIGH (1UL << 9U)</li>

PMIC1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_LOW (1UL << 10U)</li>

Temp alarm interrupt.

#define SC\_IRQ\_TEMP\_CPU0\_LOW (1UL << 11U)</li>

CPU0 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_CPU1\_LOW (1UL << 12U)</li>

CPU1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_GPU0\_LOW (1UL << 13U)</li>

GPU0 temp alarm interrupt.

- #define SC\_IRQ\_TEMP\_GPU1\_LOW (1UL << 14U)</li>
   GPU1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC0\_LOW (1UL << 15U)</li>
   DRC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC1\_LOW (1UL << 16U)

DRC1 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_VPU\_LOW (1UL << 17U)</li>

DRC1 temp alarm interrupt.

- #define SC\_IRQ\_TEMP\_PMIC0\_LOW (1UL << 18U)</li>
  - PMIC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMIC1\_LOW (1UL << 19U)</li>

PMIC1 temp alarm interrupt.

• #define SC\_IRQ\_TEMP\_PMIC2\_HIGH (1UL << 20U)

PMIC2 temp alarm interrupt.

#define SC\_IRQ\_TEMP\_PMIC2\_LOW (1UL << 21U)</li>

PMIC2 temp alarm interrupt.

## Defines for sc\_irq\_wdog\_t

#define SC\_IRQ\_WDOG (1U << 0U)</li>
 Watchdog interrupt.

#### Defines for sc\_irq\_rtc\_t

#define SC\_IRQ\_RTC (1U << 0U)</li>
 RTC interrupt.

## Defines for sc\_irq\_wake\_t

- #define SC\_IRQ\_BUTTON (1U << 0U)</li>
  - Button interrupt.
- #define SC\_IRQ\_PAD (1U << 1U)</li>

Pad wakeup.

• #define SC\_IRQ\_USR1 (1U << 2U)

User defined 1.

#define SC IRQ USR2 (1U << 3U)</li>

User defined 2.

#define SC\_IRQ\_BC\_PAD (1U << 4U)</li>

Pad wakeup (broadcast to all partitions)

#define SC\_IRQ\_SW\_WAKE (1U << 5U)</li>

Software requested wake.

#define SC\_IRQ\_SECVIO (1U << 6U)</li>

Security violation.

## Defines for sc\_irq\_sysctr\_t

#define SC\_IRQ\_SYSCTR (1U << 0U)</li>
 SYSCTR interrupt.

# 13.1.1 Detailed Description

Module for the Interrupt (IRQ) service.

## 13.1.2 Function Documentation

## 13.1.2.1 sc\_irq\_enable()

This function enables/disables interrupts.

If pending interrupts are unmasked, an interrupt will be triggered.

## Parameters

| in | ipc      | IPC handle                    |
|----|----------|-------------------------------|
| in | resource | MU channel                    |
| in | group    | group the interrupts are in   |
| in | mask     | mask of interrupts to affect  |
| in | enable   | state to change interrupts to |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

• SC\_PARM if group invalid

## 13.1.2.2 sc\_irq\_status()

This function returns the current interrupt status (regardless if masked).

Automatically clears pending interrupts.

#### **Parameters**

| in | ipc      | IPC handle                   |
|----|----------|------------------------------|
| in | resource | MU channel                   |
| in | group    | groups the interrupts are in |
| in | status   | status of interrupts         |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

• SC\_PARM if group invalid

The returned *status* may show interrupts pending that are currently masked.

## 13.2 MISC: Miscellaneous Service

Module for the Miscellaneous (MISC) service.

#### **Macros**

#define SC\_MISC\_DMA\_GRP\_MAX 31U
 Max DMA channel priority group.

## **Typedefs**

typedef uint8\_t sc\_misc\_dma\_group\_t

This type is used to store a DMA channel priority group.

typedef uint8\_t sc\_misc\_boot\_status\_t

This type is used report boot status.

• typedef uint8\_t sc\_misc\_temp\_t

This type is used report boot status.

typedef uint8\_t sc\_misc\_bt\_t

This type is used report the boot type.

## Defines for type widths

#define SC\_MISC\_DMA\_GRP\_W 5U
 Width of sc\_misc\_dma\_group\_t.

#### Defines for sc\_misc\_boot\_status\_t

- #define SC\_MISC\_BOOT\_STATUS\_SUCCESS 0U Success.
- #define SC\_MISC\_BOOT\_STATUS\_SECURITY 1U Security violation.

# Defines for sc\_misc\_temp\_t

#define SC\_MISC\_TEMP 0U
 Temp sensor.

#define SC\_MISC\_TEMP\_HIGH 1U

Temp high alarm.

#define SC\_MISC\_TEMP\_LOW 2U

Temp low alarm.

## Defines for sc\_misc\_bt\_t

- #define SC\_MISC\_BT\_PRIMARY 0U
  - Primary boot.
- #define SC\_MISC\_BT\_SECONDARY 1U
  - Secondary boot.
- #define SC\_MISC\_BT\_RECOVERY 2U
  - Recovery boot.
- #define SC MISC BT MANUFACTURE 3U
  - Manufacture boot.
- #define SC\_MISC\_BT\_SERIAL 4U
  - Serial boot.

#### **Control Functions**

- sc\_err\_t sc\_misc\_set\_control (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_ctrl\_t ctrl, uint32\_t val)
  - This function sets a miscellaneous control value.
- sc\_err\_t sc\_misc\_get\_control (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_ctrl\_t ctrl, uint32\_t \*val)

This function gets a miscellaneous control value.

#### **DMA Functions**

- sc\_err\_t sc\_misc\_set\_max\_dma\_group (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_misc\_dma\_group\_t max)
  - This function configures the max DMA channel priority group for a partition.
- sc\_err\_t sc\_misc\_set\_dma\_group (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_dma\_group\_t group)

This function configures the priority group for a DMA channel.

## **Debug Functions**

- void sc\_misc\_debug\_out (sc\_ipc\_t ipc, uint8\_t ch)
  - This function is used output a debug character from the SCU UART.
- sc\_err\_t sc\_misc\_waveform\_capture (sc\_ipc\_t ipc, sc\_bool\_t enable)
  - This function starts/stops emulation waveform capture.
- void sc\_misc\_build\_info (sc\_ipc\_t ipc, uint32\_t \*build, uint32\_t \*commit)
  - This function is used to return the SCFW build info.
- void sc\_misc\_api\_ver (sc\_ipc\_t ipc, uint16\_t \*cl\_maj, uint16\_t \*cl\_min, uint16\_t \*sv\_maj, uint16\_t \*sv\_min)
  - This function is used to return the SCFW API versions.
- void sc\_misc\_unique\_id (sc\_ipc\_t ipc, uint32\_t \*id\_l, uint32\_t \*id\_h)

This function is used to return the device's unique ID.

#### **Other Functions**

sc\_err\_t sc\_misc\_set\_ari (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rsrc\_t resource\_mst, uint16\_t ari, sc\_bool\_t enable)

This function configures the ARI match value for PCIe/SATA resources.

void sc misc boot status (sc ipc t ipc, sc misc boot status t status)

This function reports boot status.

• sc err t sc misc boot done (sc ipc t ipc, sc rsrc t cpu)

This function tells the SCFW that a CPU is done booting.

sc\_err\_t sc\_misc\_otp\_fuse\_read (sc\_ipc\_t ipc, uint32\_t word, uint32\_t \*val)

This function reads a given fuse word index.

sc\_err\_t sc\_misc\_otp\_fuse\_write (sc\_ipc\_t ipc, uint32\_t word, uint32\_t val)

This function writes a given fuse word index.

• sc\_err\_t sc\_misc\_set\_temp (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_temp\_t temp, int16\_t celsius, int8\_t tenths)

This function sets a temp sensor alarm.

• sc\_err\_t sc\_misc\_get\_temp (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_temp\_t temp, int16\_t \*celsius, int8\_t \*tenths)

This function gets a temp sensor value.

void sc misc get boot dev (sc ipc t ipc, sc rsrc t \*dev)

This function returns the boot device.

• sc err t sc misc get boot type (sc ipc t ipc, sc misc bt t \*type)

This function returns the boot type.

• sc\_err\_t sc\_misc\_get\_boot\_container (sc\_ipc\_t ipc, uint8\_t \*idx)

This function returns the boot container index.

void sc\_misc\_get\_button\_status (sc\_ipc\_t ipc, sc\_bool\_t \*status)

This function returns the current status of the ON/OFF button.

sc\_err\_t sc\_misc\_rompatch\_checksum (sc\_ipc\_t ipc, uint32\_t \*checksum)

This function returns the ROM patch checksum.

sc\_err\_t sc\_misc\_board\_ioctl (sc\_ipc\_t ipc, uint32\_t \*parm1, uint32\_t \*parm2, uint32\_t \*parm3)

This function calls the board IOCTL function.

#### 13.2.1 Detailed Description

Module for the Miscellaneous (MISC) service.

#### 13.2.2 Function Documentation

#### 13.2.2.1 sc\_misc\_set\_control()

This function sets a miscellaneous control value.

#### **Parameters**

| in | ipc      | IPC handle                              |  |
|----|----------|-----------------------------------------|--|
| in | resource | resource the control is associated with |  |
| in | ctrl     | control to change                       |  |
| in | val      | value to apply to the control           |  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner

Refer to the Control List for valid control values.

#### 13.2.2.2 sc\_misc\_get\_control()

This function gets a miscellaneous control value.

#### **Parameters**

| in  | ipc      | IPC handle                              |  |
|-----|----------|-----------------------------------------|--|
| in  | resource | resource the control is associated with |  |
| in  | ctrl     | control to get                          |  |
| out | val      | pointer to return the control value     |  |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

## Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner

Refer to the Control List for valid control values.

#### 13.2.2.3 sc\_misc\_set\_max\_dma\_group()

This function configures the max DMA channel priority group for a partition.

#### **Parameters**

| in | ipc | IPC handle                        |
|----|-----|-----------------------------------|
| in | pt  | handle of partition to assign max |
| in | max | max priority group (0-31)         |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of the affected partition

Valid *max* range is 0-31 with 0 being the lowest and 31 the highest. Default is the max priority group for the parent partition of *pt*.

#### 13.2.2.4 sc\_misc\_set\_dma\_group()

This function configures the priority group for a DMA channel.

## **Parameters**

| in | ipc      | IPC handle            |
|----|----------|-----------------------|
| in | resource | DMA channel resource  |
| in | group    | priority group (0-31) |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the owner or parent of the owner of the DMA channel

Valid *group* range is 0-31 with 0 being the lowest and 31 the highest. The max value of *group* is limited by the partition max set using sc\_misc\_set\_max\_dma\_group().

# 13.2.2.5 sc\_misc\_debug\_out()

This function is used output a debug character from the SCU UART.

#### **Parameters**

| in | ipc | IPC handle          |
|----|-----|---------------------|
| in | ch  | character to output |

#### 13.2.2.6 sc\_misc\_waveform\_capture()

This function starts/stops emulation waveform capture.

#### **Parameters**

|   | in | ipc    | IPC handle                     |
|---|----|--------|--------------------------------|
| I | in | enable | flag to enable/disable capture |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

• SC\_ERR\_UNAVAILABLE if not running on emulation

## 13.2.2.7 sc\_misc\_build\_info()

This function is used to return the SCFW build info.

#### **Parameters**

| in  | ipc IPC handle |                                         |
|-----|----------------|-----------------------------------------|
| out | build          | pointer to return build number          |
| out | commit         | pointer to return commit ID (git SHA-1) |

#### 13.2.2.8 sc\_misc\_api\_ver()

This function is used to return the SCFW API versions.

#### **Parameters**

| in  | ipc    | IPC handle                                     |
|-----|--------|------------------------------------------------|
| out | cl_maj | pointer to return major part of client version |
| out | cl_min | pointer to return minor part of client version |
| out | sv_maj | pointer to return major part of SCFW version   |
| out | sv_min | pointer to return minor part of SCFW version   |

Client version is the version of the API ported to and used by the caller. SCFW version is the version of the SCFW binary running on the CPU.

Note a major version difference indicates a break in compatibility.

## 13.2.2.9 sc\_misc\_unique\_id()

This function is used to return the device's unique ID.

#### **Parameters**

| in  | ipc | IPC handle                                    |
|-----|-----|-----------------------------------------------|
| out | id← | pointer to return lower 32-bit of ID [31:0]   |
|     | _/  |                                               |
| out | id← | pointer to return upper 32-bits of ID [63:32] |
|     | _h  |                                               |

## 13.2.2.10 sc\_misc\_set\_ari()

This function configures the ARI match value for PCIe/SATA resources.

#### **Parameters**

| in | ipc          | IPC handle                |
|----|--------------|---------------------------|
| in | resource     | match resource            |
| in | resource_mst | PCIe/SATA master to match |
| in | ari          | ARI to match              |
| in | enable       | enable match or not       |

#### Returns

Returns an error code (SC ERR NONE = success).

#### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the owner or parent of the owner of the resource and translation

For PCIe, the ARI is the 16-bit value that includes the bus number, device number, and function number. For SATA, this value includes the FISType and PM\_Port.

#### 13.2.2.11 sc\_misc\_boot\_status()

This function reports boot status.

#### **Parameters**

| in | ipc    | IPC handle  |
|----|--------|-------------|
| in | status | boot status |

This is used by SW partitions to report status of boot. This is normally used to report a boot failure.

13.2.2.12 sc\_misc\_boot\_done()

This function tells the SCFW that a CPU is done booting.

#### **Parameters**

| in | ipc | IPC handle               |
|----|-----|--------------------------|
| in | сри | CPU that is done booting |

This is called by early booting CPUs to report they are done with initialization. After starting early CPUs, the SCFW halts the booting process until they are done. During this time, early CPUs can call the SCFW with lower latency as the SCFW is idle.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the CPU owner

13.2.2.13 sc\_misc\_otp\_fuse\_read()

This function reads a given fuse word index.

#### **Parameters**

| in  | ipc  | IPC handle      |
|-----|------|-----------------|
| in  | word | fuse word index |
| out | val  | fuse read value |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if word fuse index param out of range or invalid
- · SC ERR NOACCESS if read operation failed
- · SC\_ERR\_LOCKED if read operation is locked

#### 13.2.2.14 sc\_misc\_otp\_fuse\_write()

This function writes a given fuse word index.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can do this.

#### **Parameters**

| in | ipc  | IPC handle       |
|----|------|------------------|
| in | word | fuse word index  |
| in | val  | fuse write value |

The command is passed as is to SECO. SECO uses part of the *word* parameter to indicate if the fuse should be locked after programming. See the "Write common fuse" section of the SECO API Reference Guide for more info.

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if word fuse index param out of range or invalid
- SC\_ERR\_NOACCESS if caller does not have SC\_R\_SYSTEM access
- SC\_ERR\_NOACCESS if write operation failed
- · SC\_ERR\_LOCKED if write operation is locked

## 13.2.2.15 sc\_misc\_set\_temp()

This function sets a temp sensor alarm.

#### **Parameters**

| in | ipc      | IPC handle                     |
|----|----------|--------------------------------|
| in | resource | resource with sensor           |
| in | temp     | alarm to set                   |
| in | celsius  | whole part of temp to set      |
| in | tenths   | fractional part of temp to set |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

This function will enable the alarm interrupt if the temp requested is not the min/max temp. This enable automatically clears when the alarm occurs and this function has to be called again to re-enable.

Return errors codes:

- · SC\_ERR\_PARM if parameters invalid
- · SC\_ERR\_NOACCESS if caller does not own the resource
- SC\_ERR\_NOPOWER if power domain of resource not powered

#### 13.2.2.16 sc\_misc\_get\_temp()

This function gets a temp sensor value.

#### **Parameters**

| in  | ipc      | IPC handle                     |
|-----|----------|--------------------------------|
| in  | resource | resource with sensor           |
| in  | temp     | value to get (sensor or alarm) |
| out | celsius  | whole part of temp to get      |
| out | tenths   | fractional part of temp to get |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if parameters invalid
- SC\_ERR\_BUSY if temp not ready yet (time delay after power on)
- SC\_ERR\_NOPOWER if power domain of resource not powered

#### 13.2.2.17 sc\_misc\_get\_boot\_dev()

This function returns the boot device.

#### **Parameters**

| in  | ipc | IPC handle                    |
|-----|-----|-------------------------------|
| out | dev | pointer to return boot device |

#### 13.2.2.18 sc\_misc\_get\_boot\_type()

This function returns the boot type.

#### **Parameters**

| in  | ipc  | IPC handle                  |
|-----|------|-----------------------------|
| out | type | pointer to return boot type |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors code:

• SC\_ERR\_UNAVAILABLE if type not passed by ROM

```
13.2.2.19 sc_misc_get_boot_container()
```

This function returns the boot container index.

#### **Parameters**

| in  | ipc | IPC handle              |
|-----|-----|-------------------------|
| out | idx | pointer to return index |

Return idx = 1 for first container, 2 for second.

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors code:

· SC\_ERR\_UNAVAILABLE if index not passed by ROM

## 13.2.2.20 sc\_misc\_get\_button\_status()

This function returns the current status of the ON/OFF button.

#### **Parameters**

| in  | ipc    | IPC handle                      |
|-----|--------|---------------------------------|
| out | status | pointer to return button status |

#### 13.2.2.21 sc\_misc\_rompatch\_checksum()

This function returns the ROM patch checksum.

#### **Parameters**

| in  | ipc      | IPC handle                 |
|-----|----------|----------------------------|
| out | checksum | pointer to return checksum |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

#### 13.2.2.22 sc\_misc\_board\_ioctl()

This function calls the board IOCTL function.

## **Parameters**

| in     | ipc   | IPC handle                  |
|--------|-------|-----------------------------|
| in,out | parm1 | pointer to pass parameter 1 |
| in,out | parm2 | pointer to pass parameter 2 |
| in,out | parm3 | pointer to pass parameter 3 |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

## 13.3 PAD: Pad Service

Module for the Pad Control (PAD) service.

## **Typedefs**

```
• typedef uint8_t sc_pad_config_t
```

This type is used to declare a pad config.

typedef uint8 t sc pad iso t

This type is used to declare a pad low-power isolation config.

• typedef uint8\_t sc\_pad\_28fdsoi\_dse\_t

This type is used to declare a drive strength.

typedef uint8\_t sc\_pad\_28fdsoi\_ps\_t

This type is used to declare a pull select.

typedef uint8\_t sc\_pad\_28fdsoi\_pus\_t

This type is used to declare a pull-up select.

typedef uint8\_t sc\_pad\_wakeup\_t

This type is used to declare a wakeup mode of a pad.

## Defines for type widths

#define SC\_PAD\_MUX\_W 3U
 Width of mux parameter.

## Defines for sc\_pad\_config\_t

```
    #define SC_PAD_CONFIG_NORMAL 0U
Normal.
```

• #define SC\_PAD\_CONFIG\_OD 1U

Open Drain.

• #define SC\_PAD\_CONFIG\_OD\_IN 2U

Open Drain and input.

#define SC\_PAD\_CONFIG\_OUT\_IN 3U

Output and input.

#### Defines for sc\_pad\_iso\_t

#define SC\_PAD\_ISO\_OFF 0U

ISO latch is transparent.

• #define SC\_PAD\_ISO\_EARLY 1U

Follow EARLY\_ISO.

• #define SC\_PAD\_ISO\_LATE 2U

Follow LATE\_ISO.

• #define SC\_PAD\_ISO\_ON 3U

ISO latched data is held.

13.3 PAD: Pad Service 127

## Defines for sc\_pad\_28fdsoi\_dse\_t

- #define SC\_PAD\_28FDSOI\_DSE\_18V\_1MA 0U
   Drive strength of 1mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_2MA 1U
   Drive strength of 2mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_4MA 2U
   Drive strength of 4mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_6MA 3U
   Drive strength of 6mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_8MA 4U
   Drive strength of 8mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_10MA 5U
   Drive strength of 10mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_12MA 6U
   Drive strength of 12mA for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_18V\_HS 7U
   High-speed drive strength for 1.8v.
- #define SC\_PAD\_28FDSOI\_DSE\_33V\_2MA 0U
   Drive strength of 2mA for 3.3v.
- #define SC\_PAD\_28FDSOI\_DSE\_33V\_4MA 1U
   Drive strength of 4mA for 3.3v.
- #define SC\_PAD\_28FDSOI\_DSE\_33V\_8MA 2U
   Drive strength of 8mA for 3.3v.
- #define SC\_PAD\_28FDSOI\_DSE\_33V\_12MA 3U
   Drive strength of 12mA for 3.3v.
- #define SC\_PAD\_28FDSOI\_DSE\_DV\_HIGH 0U
   High drive strength for dual volt.
- #define SC\_PAD\_28FDSOI\_DSE\_DV\_LOW 1U
   Low drive strength for dual volt.

#### Defines for sc\_pad\_28fdsoi\_ps\_t

- #define SC\_PAD\_28FDSOI\_PS\_KEEPER 0U
   Bus-keeper (only valid for 1.8v)
- #define SC\_PAD\_28FDSOI\_PS\_PU 1U
   Pull-up.
- #define SC\_PAD\_28FDSOI\_PS\_PD 2U
   Pull-down.
- #define SC\_PAD\_28FDSOI\_PS\_NONE 3U
   No pull (disabled)

## Defines for sc\_pad\_28fdsoi\_pus\_t

```
    #define SC_PAD_28FDSOI_PUS_30K_PD 0U
30K pull-down
```

#define SC\_PAD\_28FDSOI\_PUS\_100K\_PU 1U

100K pull-up

#define SC\_PAD\_28FDSOI\_PUS\_3K\_PU 2U

3K pull-up

#define SC\_PAD\_28FDSOI\_PUS\_30K\_PU 3U

30K pull-up

#### Defines for sc pad wakeup t

#define SC\_PAD\_WAKEUP\_OFF 0U
 Off.

• #define SC PAD WAKEUP CLEAR 1U

Clears pending flag.

#define SC\_PAD\_WAKEUP\_LOW\_LVL 4U

Low level.

#define SC\_PAD\_WAKEUP\_FALL\_EDGE 5U

Falling edge.

• #define SC\_PAD\_WAKEUP\_RISE\_EDGE 6U

Rising edge.

• #define SC PAD WAKEUP HIGH LVL 7U

High-level.

#### **Generic Functions**

- sc\_err\_t sc\_pad\_set\_mux (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t mux, sc\_pad\_config\_t config, sc\_pad\_iso\_t iso)
   This function configures the mux settings for a pad.
- sc\_err\_t sc\_pad\_get\_mux (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*mux, sc\_pad\_config\_t \*config, sc\_pad\_iso\_t \*iso)

This function gets the mux settings for a pad.

sc\_err\_t sc\_pad\_set\_gp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t ctrl)

This function configures the general purpose pad control.

sc\_err\_t sc\_pad\_get\_gp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t \*ctrl)

This function gets the general purpose pad control.

sc\_err\_t sc\_pad\_set\_wakeup (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_wakeup\_t wakeup)

This function configures the wakeup mode of the pad.

sc\_err\_t sc\_pad\_get\_wakeup (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_wakeup\_t \*wakeup)

This function gets the wakeup mode of a pad.

• sc\_err\_t sc\_pad\_set\_all (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t mux, sc\_pad\_config\_t config, sc\_pad\_iso\_t iso, uint32\_t ctrl, sc\_pad\_wakeup\_t wakeup)

This function configures a pad.

• sc\_err\_t sc\_pad\_get\_all (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*mux, sc\_pad\_config\_t \*config, sc\_pad\_iso\_t \*iso, uint32\_t \*ctrl, sc\_pad\_wakeup\_t \*wakeup)

This function gets a pad's config.

13.3 PAD: Pad Service 129

## **SoC Specific Functions**

sc\_err\_t sc\_pad\_set (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t val)

This function configures the settings for a pad.

sc\_err\_t sc\_pad\_get (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t \*val)

This function gets the settings for a pad.

sc\_err\_t sc\_pad\_config (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t val)

This function writes a configuration register.

#### **Technology Specific Functions**

sc\_err\_t sc\_pad\_set\_gp\_28fdsoi (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t dse, sc\_pad\_28fdsoi\_ps\_t ps)

This function configures the pad control specific to 28FDSOI.

sc\_err\_t sc\_pad\_get\_gp\_28fdsoi (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t \*dse, sc\_pad\_28fdsoi\_ps\_t \*ps)

This function gets the pad control specific to 28FDSOI.

 sc\_err\_t sc\_pad\_set\_gp\_28fdsoi\_hsic (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t dse, sc\_bool\_t hys, sc\_pad\_28fdsoi\_pus\_t pus, sc\_bool\_t pke, sc\_bool\_t pue)

This function configures the pad control specific to 28FDSOI.

• sc\_err\_t sc\_pad\_get\_gp\_28fdsoi\_hsic (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t \*dse, sc\_bool\_t \*hys, sc\_pad\_28fdsoi\_pus\_t \*pus, sc\_bool\_t \*pke, sc\_bool\_t \*pue)

This function gets the pad control specific to 28FDSOI.

• sc\_err\_t sc\_pad\_set\_gp\_28fdsoi\_comp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t compen, sc\_bool\_t fastfrz, uint8\_t rasrcp, uint8\_t

This function configures the compensation control specific to 28FDSOI.

sc\_err\_t sc\_pad\_get\_gp\_28fdsoi\_comp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*compen, sc\_bool\_t \*fastfrz, uint8\_t \*rasrcp, uint8\_t \*rasrcn, sc\_bool\_t \*nasrc\_sel, sc\_bool\_t \*compok, uint8\_t \*nasrc, sc\_bool\_t \*psw\_ovr)

This function gets the compensation control specific to 28FDSOI.

## 13.3.1 Detailed Description

Module for the Pad Control (PAD) service.

Pad configuration is managed by SC firmware. The pad configuration features supported by the SC firmware include:

- Configuring the mux, input/output connection, and low-power isolation mode.
- Configuring the technology-specific pad setting such as drive strength, pullup/pulldown, etc.
- · Configuring compensation for pad groups with dual voltage capability.

Pad functions fall into one of three categories. Generic functions are common to all SoCs and all process technologies. SoC functions are raw low-level functions. Technology-specific functions are specific to the process technology.

The list of pads is SoC specific. Refer to the SoC Pad List for valid pad values. Note that all pads exist on a die but may or may not be brought out by the specific package. Mapping of pads to package pins/balls is documented in the

associated Data Sheet. Some pads may not be brought out because the part (die+package) is defeatured and some pads may connect to the substrate in the package.

Some pads (SC\_P\_COMP\_\*) that can be specified are not individual pads but are in fact pad groups. These groups have additional configuration that can be done using the sc\_pad\_set\_gp\_28fdsoi\_comp() function. More info on these can be found in the associated Reference Manual.

Pads are managed as a resource by the Resource Manager (RM). They have assigned owners and only the owners can configure the pads. Some of the pads are reserved for use by the SCFW itself and this can be overridden with the implementation of board\_config\_sc(). Additionally, pads may be assigned to various other partitions via the implementation of board\_system\_config().

Note muxing two input pads to the same IP functional signal will result in undefined behavior.

The following SCFW pad code is an example of how to configure pads. In this example, two pads are configured for use by the i.MX8QXP I2C 0 (ADMA.I2C0). Another dual-voltge pad is configured as SPI 0 SCK (ADMA.SPI0.SCK).

The ipc parameter most functions take is a handle to the IPC channel opened to communicate to the SC. It is implementation defined. Most API ports include an sc\_ipc\_open() and sc\_ipc\_close() function to manage this. The sc\_ipc\_open() takes an argument to identify the communication channel (usually the MU address) and returns the IPC handle that all API calls should then use.

```
1 /* Configure I2C_0 SCL pad */
2 sc_pad_set_mux(ipc, SC_P_MIPI_CSI0_GPI00_00, 1, SC_PAD_CONFIG_OD_IN, SC_PAD_ISO_OFF);
3 sc_pad_set_gp_28fdsoi(ipc, SC_P_MIPI_CSI0_GPI00_00, SC_PAD_28FDSOI_DSE_18V_1MA, SC_PAD_28FDSOI_PS_PU);
4
5 /* Configure I2C_0 SDA pad */
6 sc_pad_set_mux(ipc, SC_P_MIPI_CSI0_GPI00_01, 1, SC_PAD_CONFIG_OD_IN, SC_PAD_ISO_OFF);
7 sc_pad_set_gp_28fdsoi(ipc, SC_P_MIPI_CSI0_GPI00_01, SC_PAD_28FDSOI_DSE_18V_1MA, SC_PAD_28FDSOI_PS_PU);
8
9 /* Configure SPI0 SCK pad (dual-voltage) */
10 sc_pad_set_mux(ipc, SC_P_SPI0_SCK, 0, SC_PAD_CONFIG_NORMAL, SC_PAD_ISO_OFF);
11 sc_pad_set_gp_28fdsoi(ipc, SC_P_SPI0_SCK, SC_PAD_28FDSOI_DSE_DV_LOW, SC_PAD_28FDSOI_PS_NONE);
```

The first pair of pads in question are MIPI\_CSI0\_GPIO0\_00 (used for SCL) and MIPI\_CSI0\_GPIO0\_01 (used for SDA). I2C 0 is mux select 1 for both pads.

The first two lines configure the SCL pad. The first configures the SCL pad for mux select 1, and as open-drain with with input. The second configures the drive strength and enables the pull-up.

The last two lines do the same for the SDA pad.

For 28FDSIO single voltage pads, SC\_PAD\_28FDSOI\_DSE\_DV\_HIGH and SC\_PAD\_28FDSOI\_DSE\_DV\_LOW are not valid drive strenths.

```
0 /* Configure I2C_0 SCL pad */
1 sc_pad_set_mux(ipc, SC_P_MIPI_CSI0_GPI00_00, 1, SC_PAD_CONFIG_OD_IN, SC_PAD_ISO_OFF);
2 sc_pad_set_gp_28fdsoi(ipc, SC_P_MIPI_CSI0_GPI00_00, SC_PAD_28FDSOI_DSE_18V_1MA, SC_PAD_28FDSOI_PS_PU);
3
4 /* Configure I2C_0 SDA pad */
5 sc_pad_set_mux(ipc, SC_P_MIPI_CSI0_GPI00_01, 1, SC_PAD_CONFIG_OD_IN, SC_PAD_ISO_OFF);
6 sc_pad_set_gp_28fdsoi(ipc, SC_P_MIPI_CSI0_GPI00_01, SC_PAD_28FDSOI_DSE_18V_1MA, SC_PAD_28FDSOI_PS_PU);
```

The next pad configured is SPI0\_SCK. It is configured as mux select 0. the first line configures the mux select as 0 and normal push-pull. The second line configures the drive strength and no pull-up. Note the drive strength setting is different for this dual voltage pad.

```
7 /* Configure SPIO SCK pad (dual-voltage) */
9 sc_pad_set_mux(ipc, SC_P_SPIO_SCK, 0, SC_PAD_CONFIG_NORMAL, SC_PAD_ISO_OFF);
10 sc_pad_set_gp_28fdsoi(ipc, SC_P_SPIO_SCK, SC_PAD_28FDSOI_DSE_DV_LOW, SC_PAD_28FDSOI_PS_NONE);
```

For 28FDSIO dual voltage pads, only SC\_PAD\_28FDSOI\_DSE\_DV\_HIGH and SC\_PAD\_28FDSOI\_DSE\_DV\_LOW are valid drive strenths.

The voltage of the pad is determined by the supply for the pad group (the VDD SPI SAI 1P8 3P3 pad in this case).

13.3 PAD: Pad Service 131

# 13.3.2 Typedef Documentation

```
13.3.2.1 sc_pad_config_t
typedef uint8_t sc_pad_config_t
```

This type is used to declare a pad config.

It determines how the output data is driven, pull-up is controlled, and input signal is connected. Normal and OD are typical and only connect the input when the output is not driven. The IN options are less common and force an input connection even when driving the output.

```
13.3.2.2 sc_pad_iso_t
typedef uint8_t sc_pad_iso_t
```

This type is used to declare a pad low-power isolation config.

ISO\_LATE is the most common setting. ISO\_EARLY is only used when an output pad is directly determined by another input pad. The other two are only used when SW wants to directly control isolation.

```
13.3.2.3 sc_pad_28fdsoi_dse_t
typedef uint8_t sc_pad_28fdsoi_dse_t
```

This type is used to declare a drive strength.

Note it is specific to 28FDSOI. Also note that valid values depend on the pad type.

```
13.3.2.4 sc_pad_28fdsoi_ps_t
typedef uint8_t sc_pad_28fdsoi_ps_t
```

This type is used to declare a pull select.

Note it is specific to 28FDSOI.

```
13.3.2.5 sc_pad_28fdsoi_pus_t
typedef uint8_t sc_pad_28fdsoi_pus_t
```

This type is used to declare a pull-up select.

Note it is specific to 28FDSOI HSIC pads.

# 13.3.3 Function Documentation

This function configures the mux settings for a pad.

This includes the signal mux, pad config, and low-power isolation mode.

#### **Parameters**

| in | ipc    | IPC handle               |
|----|--------|--------------------------|
| in | pad    | pad to configure         |
| in | mux    | mux setting              |
| in | config | pad config               |
| in | iso    | low-power isolation mode |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Note muxing two input pads to the same IP functional signal will result in undefined behavior.

Refer to the SoC Pad List for valid pad values.

# 13.3.3.2 sc\_pad\_get\_mux()

This function gets the mux settings for a pad.

This includes the signal mux, pad config, and low-power isolation mode.

#### **Parameters**

| in  | ipc    | IPC handle                                 |  |
|-----|--------|--------------------------------------------|--|
| in  | pad    | pad to query                               |  |
| out | mux    | pointer to return mux setting              |  |
| out | config | pointer to return pad config               |  |
| out | iso    | pointer to return low-power isolation mode |  |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

13.3 PAD: Pad Service 133

- · SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

```
13.3.3.3 sc_pad_set_gp()
```

This function configures the general purpose pad control.

This is technology dependent and includes things like drive strength, slew rate, pull up/down, etc. Refer to the SoC Reference Manual for bit field details.

#### **Parameters**

| in | ipc  | IPC handle           |
|----|------|----------------------|
| in | pad  | pad to configure     |
| in | ctrl | control value to set |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

```
13.3.3.4 sc_pad_get_gp()
```

This function gets the general purpose pad control.

This is technology dependent and includes things like drive strength, slew rate, pull up/down, etc. Refer to the SoC Reference Manual for bit field details.

#### **Parameters**

| in  | ipc  | IPC handle                      |
|-----|------|---------------------------------|
| in  | pad  | pad to query                    |
| out | ctrl | pointer to return control value |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

# 13.3.3.5 sc\_pad\_set\_wakeup()

This function configures the wakeup mode of the pad.

# **Parameters**

| in | ipc    | IPC handle       |
|----|--------|------------------|
| in | pad    | pad to configure |
| in | wakeup | wakeup to set    |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- · SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

13.3 PAD: Pad Service 135

# 13.3.3.6 sc\_pad\_get\_wakeup()

This function gets the wakeup mode of a pad.

#### **Parameters**

| in  | ipc    | IPC handle               |
|-----|--------|--------------------------|
| in  | pad    | pad to query             |
| out | wakeup | pointer to return wakeup |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

# 13.3.3.7 sc\_pad\_set\_all()

This function configures a pad.

#### **Parameters**

| in | ipc    | IPC handle               |
|----|--------|--------------------------|
| in | pad    | pad to configure         |
| in | mux    | mux setting              |
| in | config | pad config               |
| in | iso    | low-power isolation mode |
| in | ctrl   | control value            |
| in | wakeup | wakeup to set            |

#### See also

```
sc_pad_set_mux().
sc_pad_set_gp().
```

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

#### Returns

```
Returns an error code (SC_ERR_NONE = success).
```

Note muxing two input pads to the same IP functional signal will result in undefined behavior.

Refer to the SoC Pad List for valid pad values.

```
13.3.3.8 sc_pad_get_all()
```

This function gets a pad's config.

#### **Parameters**

| in  | ipc                                            | IPC handle                      |
|-----|------------------------------------------------|---------------------------------|
| in  | pad                                            | pad to query                    |
| out | mux pointer to return mux setting              |                                 |
| out | config                                         | pointer to return pad config    |
| out | iso pointer to return low-power isolation mode |                                 |
| out | ctrl                                           | pointer to return control value |
| out | wakeup                                         | pointer to return wakeup to set |

### See also

```
sc_pad_set_mux().
sc_pad_set_gp().
```

#### Return errors:

13.3 PAD: Pad Service 137

- · SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

# Returns

Returns an error code (SC\_ERR\_NONE = success).

Refer to the SoC Pad List for valid pad values.

```
13.3.3.9 sc_pad_set()
```

This function configures the settings for a pad.

This setting is SoC specific.

#### **Parameters**

| in | ipc | IPC handle       |
|----|-----|------------------|
| in | pad | pad to configure |
| in | val | value to set     |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

- · SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

```
13.3.3.10 sc_pad_get()
```

This function gets the settings for a pad.

This setting is SoC specific.

#### **Parameters**

| in  | ipc | IPC handle                |
|-----|-----|---------------------------|
| in  | pad | pad to query              |
| out | val | pointer to return setting |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

```
13.3.3.11 sc_pad_config()
```

This function writes a configuration register.

This setting is SoC specific.

# **Parameters**

| in | ipc | IPC handle       |
|----|-----|------------------|
| in | pad | pad to configure |
| in | val | value to set     |

Use to configure various HSIC and NAND congiruation settings.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- · SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner

Refer to the SoC Pad List for valid pad values.

13.3 PAD: Pad Service 139

# 13.3.3.12 sc\_pad\_set\_gp\_28fdsoi()

This function configures the pad control specific to 28FDSOI.

#### **Parameters**

| in | ipc | IPC handle       |
|----|-----|------------------|
| in | pad | pad to configure |
| in | dse | drive strength   |
| in | ps  | pull select      |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

# 13.3.3.13 sc\_pad\_get\_gp\_28fdsoi()

This function gets the pad control specific to 28FDSOI.

# **Parameters**

| in  | ipc | IPC handle                       |
|-----|-----|----------------------------------|
| in  | pad | pad to query                     |
| out | dse | pointer to return drive strength |
| out | ps  | pointer to return pull select    |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

# 13.3.3.14 sc\_pad\_set\_gp\_28fdsoi\_hsic()

This function configures the pad control specific to 28FDSOI.

# Parameters

| in | ipc | IPC handle         |
|----|-----|--------------------|
| in | pad | pad to configure   |
| in | dse | drive strength     |
| in | hys | hysteresis         |
| in | pus | pull-up select     |
| in | pke | pull keeper enable |
| in | pue | pull-up enable     |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

13.3 PAD: Pad Service 141

# 13.3.3.15 sc\_pad\_get\_gp\_28fdsoi\_hsic()

This function gets the pad control specific to 28FDSOI.

### **Parameters**

| in  | ipc | IPC handle                           |
|-----|-----|--------------------------------------|
| in  | pad | pad to query                         |
| out | dse | pointer to return drive strength     |
| out | hys | pointer to return hysteresis         |
| out | pus | pointer to return pull-up select     |
| out | pke | pointer to return pull keeper enable |
| out | pue | pointer to return pull-up enable     |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

# 13.3.3.16 sc\_pad\_set\_gp\_28fdsoi\_comp()

This function configures the compensation control specific to 28FDSOI.

#### **Parameters**

| in | ipc       | IPC handle                 |
|----|-----------|----------------------------|
| in | pad       | pad to configure           |
| in | compen    | compensation/freeze mode   |
| in | fastfrz   | fast freeze                |
| in | rasrcp    | compensation code for PMOS |
| in | rasrcn    | compensation code for NMOS |
| in | nasrc_sel | NASRC read select          |
| in | psw_ovr   | 2.5v override              |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

Note *psw\_ovr* is only applicable to pads supporting 2.5 volt operation (e.g. some Ethernet pads).

# 13.3.3.17 sc\_pad\_get\_gp\_28fdsoi\_comp()

This function gets the compensation control specific to 28FDSOI.

#### **Parameters**

| in  | ipc     | IPC handle                                 |
|-----|---------|--------------------------------------------|
| in  | pad     | pad to query                               |
| out | compen  | pointer to return compensation/freeze mode |
| out | fastfrz | pointer to return fast freeze              |

13.3 PAD: Pad Service

# **Parameters**

| out | rasrcp                                             | pointer to return compensation code for PMOS |
|-----|----------------------------------------------------|----------------------------------------------|
| out | rasrcn pointer to return compensation code for NMC |                                              |
| out | nasrc_sel                                          | pointer to return NASRC read select          |
| out | compok                                             | pointer to return compensation status        |
| out | nasrc                                              | pointer to return NASRCP/NASRCN              |
| out | psw_ovr                                            | pointer to return the 2.5v override          |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the pad owner,
- SC\_ERR\_UNAVAILABLE if process not applicable

Refer to the SoC Pad List for valid pad values.

# 13.4 PM: Power Management Service

Module for the Power Management (PM) service.

# **Typedefs**

```
• typedef uint8_t sc_pm_power_mode_t
```

This type is used to declare a power mode.

· typedef uint8\_t sc\_pm\_clk\_t

This type is used to declare a clock.

typedef uint8\_t sc\_pm\_clk\_parent\_t

This type is used to declare the clock parent.

typedef uint32\_t sc\_pm\_clock\_rate\_t

This type is used to declare clock rates.

· typedef uint8\_t sc\_pm\_reset\_type\_t

This type is used to declare a desired reset type.

typedef uint8\_t sc\_pm\_reset\_reason\_t

This type is used to declare a reason for a reset.

typedef uint8\_t sc\_pm\_sys\_if\_t

This type is used to specify a system-level interface to be power managed.

typedef uint8\_t sc\_pm\_wake\_src\_t

This type is used to specify a wake source for CPU resources.

# Defines for type widths

```
• #define SC_PM_POWER_MODE_W 2U
```

Width of sc\_pm\_power\_mode\_t.

• #define SC\_PM\_CLOCK\_MODE\_W 3U

Width of sc\_pm\_clock\_mode\_t.

• #define SC PM RESET TYPE W 2U

Width of sc\_pm\_reset\_type\_t.

• #define SC\_PM\_RESET\_REASON\_W 4U

Width of sc pm reset reason t.

# **Defines for ALL parameters**

#define SC\_PM\_CLK\_ALL ((sc\_pm\_clk\_t) UINT8\_MAX)
 All clocks.

# Defines for sc\_pm\_power\_mode\_t

• #define SC\_PM\_PW\_MODE\_OFF 0U

Power off.

· #define SC PM PW MODE STBY 1U

Power in standby.

• #define SC\_PM\_PW\_MODE\_LP 2U

Power in low-power.

• #define SC\_PM\_PW\_MODE\_ON 3U

Power on.

# Defines for sc\_pm\_clk\_t

- #define SC\_PM\_CLK\_SLV\_BUS 0U Slave bus clock.
- #define SC\_PM\_CLK\_MST\_BUS 1U

Master bus clock.

• #define SC\_PM\_CLK\_PER 2U

Peripheral clock.

#define SC\_PM\_CLK\_PHY 3U

Phy clock.

#define SC\_PM\_CLK\_MISC 4U

Misc clock.

• #define SC\_PM\_CLK\_MISC0 0U

Misc 0 clock.

#define SC\_PM\_CLK\_MISC1 1U

Misc 1 clock.

#define SC\_PM\_CLK\_MISC2 2U

Misc 2 clock.

• #define SC\_PM\_CLK\_MISC3 3U

Misc 3 clock.

• #define SC\_PM\_CLK\_MISC4 4U

Misc 4 clock.

• #define SC\_PM\_CLK\_CPU 2U

CPU clock.

• #define SC\_PM\_CLK\_PLL 4U

PLL.

#define SC\_PM\_CLK\_BYPASS 4U

Bypass clock.

# Defines for sc\_pm\_clk\_parent\_t

#define SC\_PM\_PARENT\_XTAL 0U

Parent is XTAL.

• #define SC\_PM\_PARENT\_PLL0 1U

Parent is PLL0.

• #define SC\_PM\_PARENT\_PLL1 2U

Parent is PLL1 or PLL0/2.

• #define SC\_PM\_PARENT\_PLL2 3U

Parent in PLL2 or PLL0/4.

• #define SC\_PM\_PARENT\_BYPS 4U

Parent is a bypass clock.

# Defines for sc\_pm\_reset\_type\_t

• #define SC\_PM\_RESET\_TYPE\_COLD 0U

Cold reset.

#define SC\_PM\_RESET\_TYPE\_WARM 1U

Warm reset.

• #define SC\_PM\_RESET\_TYPE\_BOARD 2U

Board reset.

# Defines for sc\_pm\_reset\_reason\_t

#define SC\_PM\_RESET\_REASON\_POR 0U
 Power on reset.

#define SC\_PM\_RESET\_REASON\_JTAG 1U

JTAG reset.

• #define SC\_PM\_RESET\_REASON\_SW 2U

Software reset.

#define SC\_PM\_RESET\_REASON\_WDOG 3U

Partition watchdog reset.

#define SC\_PM\_RESET\_REASON\_LOCKUP 4U

SCU lockup reset.

#define SC\_PM\_RESET\_REASON\_SNVS 5U

SNVS reset.

#define SC\_PM\_RESET\_REASON\_TEMP 6U

Temp panic reset.

#define SC\_PM\_RESET\_REASON\_MSI 7U

MSI reset.

• #define SC\_PM\_RESET\_REASON\_UECC 8U

ECC reset.

#define SC PM RESET REASON SCFW WDOG 9U

SCFW watchdog reset.

• #define SC\_PM\_RESET\_REASON\_ROM\_WDOG 10U

SCU ROM watchdog reset.

• #define SC\_PM\_RESET\_REASON\_SECO 11U

SECO reset.

#define SC\_PM\_RESET\_REASON\_SCFW\_FAULT 12U

SCFW fault reset.

#define SC\_PM\_RESET\_REASON\_V2X\_DEBUG 13U

V2X debug switch.

### Defines for sc pm sys if t

#define SC PM SYS IF INTERCONNECT 0U

System interconnect.

• #define SC PM SYS IF MU 1U

AP -> SCU message units.

#define SC PM SYS IF OCMEM 2U

On-chip memory (ROM/OCRAM)

• #define SC\_PM\_SYS\_IF\_DDR 3U

DDR memory.

Defines for sc\_pm\_wake\_src\_t

#define SC PM WAKE SRC NONE 0U

No wake source, used for self-kill.

· #define SC PM WAKE SRC SCU 1U

Wakeup from SCU to resume CPU (IRQSTEER & GIC powered down)

#define SC\_PM\_WAKE\_SRC\_IRQSTEER 2U

Wakeup from IRQSTEER to resume CPU (GIC powered down)

#define SC\_PM\_WAKE\_SRC\_IRQSTEER\_GIC 3U

Wakeup from IRQSTEER+GIC to wake CPU (GIC clock gated)

#define SC\_PM\_WAKE\_SRC\_GIC 4U

Wakeup from GIC to wake CPU.

#### **Power Functions**

sc\_err\_t sc\_pm\_set\_sys\_power\_mode (sc\_ipc\_t ipc, sc\_pm\_power\_mode\_t mode)

This function sets the system power mode.

• sc err t sc pm set partition power mode (sc ipc t ipc, sc rm pt t pt, sc pm power mode t mode)

This function sets the power mode of a partition.

sc\_err\_t sc\_pm\_get\_sys\_power\_mode (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_power\_mode\_t \*mode)

This function gets the power mode of a partition.

sc\_err\_t sc\_pm\_partition\_wake (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function sends a wake interrupt to a partition.

• sc\_err\_t sc\_pm\_set\_resource\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode)

This function sets the power mode of a resource.

 sc\_err\_t sc\_pm\_set\_resource\_power\_mode\_all (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_power\_mode\_t mode, sc\_rsrc\_t exclude)

This function sets the power mode for all the resources owned by a child partition.

sc\_err\_t sc\_pm\_get\_resource\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t \*mode)

This function gets the power mode of a resource.

sc\_err\_t sc\_pm\_req\_low\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode)

This function specifies the low power mode some of the resources can enter based on their state.

 sc\_err\_t sc\_pm\_req\_cpu\_low\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode, sc\_pm\_wake\_src\_t wake\_src)

This function requests low-power mode entry for CPU/cluster resources.

sc\_err\_t sc\_pm\_set\_cpu\_resume\_addr (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_faddr\_t address)

This function is used to set the resume address of a CPU.

sc\_err\_t sc\_pm\_set\_cpu\_resume (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t isPrimary, sc\_faddr\_t address)

This function is used to set parameters for CPU resume from low-power mode.

sc\_err\_t sc\_pm\_req\_sys\_if\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_sys\_if\_t sys\_if, sc\_pm\_power\_mode\_t hpm, sc\_pm\_power\_mode\_t lpm)

This function requests the power mode configuration for system-level interfaces including messaging units, interconnect, and memories.

# **Clock/PLL Functions**

- sc\_err\_t sc\_pm\_set\_clock\_rate (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clock\_rate\_t \*rate)

  This function sets the rate of a resource's clock/PLL.
- sc\_err\_t sc\_pm\_get\_clock\_rate (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clock\_rate\_t \*rate)

  This function gets the rate of a resource's clock/PLL.
- sc\_err\_t sc\_pm\_clock\_enable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_bool\_t enable, sc\_bool\_t autog)

This function enables/disables a resource's clock.

- sc\_err\_t sc\_pm\_set\_clock\_parent (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clk\_parent\_t parent)

  This function sets the parent of a resource's clock.
- sc\_err\_t sc\_pm\_get\_clock\_parent (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clk\_parent\_t \*parent)

This function gets the parent of a resource's clock.

#### **Reset Functions**

sc\_err\_t sc\_pm\_reset (sc\_ipc\_t ipc, sc\_pm\_reset\_type\_t type)

This function is used to reset the system.

• sc err t sc pm reset reason (sc ipc t ipc, sc pm reset reason t \*reason)

This function gets a caller's reset reason.

sc\_err\_t sc\_pm\_get\_reset\_part (sc\_ipc\_t ipc, sc\_rm\_pt\_t \*pt)

This function gets the partition that caused a reset.

• sc\_err\_t sc\_pm\_boot (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rsrc\_t resource\_cpu, sc\_faddr\_t boot\_addr, sc\_rsrc\_t resource\_mu, sc\_rsrc\_t resource\_dev)

This function is used to boot a partition.

sc\_err\_t sc\_pm\_set\_boot\_parm (sc\_ipc\_t ipc, sc\_rsrc\_t resource\_cpu, sc\_faddr\_t boot\_addr, sc\_rsrc\_t resource\_mu, sc\_rsrc\_t resource\_dev)

This function is used to change the boot parameters for a partition.

void sc\_pm\_reboot (sc\_ipc\_t ipc, sc\_pm\_reset\_type\_t type)

This function is used to reboot the caller's partition.

• sc err t sc pm reboot partition (sc ipc t ipc, sc rm pt t pt, sc pm reset type t type)

This function is used to reboot a partition.

sc\_err\_t sc\_pm\_reboot\_continue (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function is used to continue the reboot a partition.

sc\_err\_t sc\_pm\_cpu\_start (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t enable, sc\_faddr\_t address)

This function is used to start/stop a CPU.

• void sc\_pm\_cpu\_reset (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_faddr\_t address)

This function is used to reset a CPU.

• sc\_err\_t sc\_pm\_resource\_reset (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to reset a peripheral.

sc\_bool\_t sc\_pm\_is\_partition\_started (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function returns a bool indicating if a partition was started.

# 13.4.1 Detailed Description

Module for the Power Management (PM) service.

The following SCFW PM code is an example of how to configure the power and clocking of a UART. All resources MUST be powered on before accessing.

The ipc parameter most functions take is a handle to the IPC channel opened to communicate to the SC. It is implementation defined. Most API ports include an sc\_ipc\_open() and sc\_ipc\_close() function to manage this. The sc\_ipc\_open() takes an argument to identify the communication channel (usually the MU address) and returns the IPC handle that all API calls should then use.

Refer to the SoC-specific Resource List for a list of resources. Refer to the SoC-specific Clock List for a list of clocks.

```
1 sc_pm_clock_rate_t rate = SC_160MHZ;
2
3 /* Powerup UART 0 */
4 sc_pm_set_resource_power_mode(ipc, SC_R_UART_0, SC_PM_PW_MODE_ON);
5
6 /* Configure UART 0 baud clock */
7 sc_pm_set_clock_rate(ipc, SC_R_UART_0, SC_PM_CLK_PER, &rate);
8
9 /* Enable UART 0 clock */
10 sc_pm_clock_enable(ipc, SC_R_UART_0, SC_PM_CLK_PER, SC_TRUE, SC_FALSE);
```

First, a variable is declared to hold the rate to request and return for the UART peripheral clock. Note this is the baud clock going into the UART which is then further divided within the UART itself.

```
0 sc_pm_clock_rate_t rate = SC_160MHZ;
```

Then change the power state of the UART to the ON state.

```
1 /* Powerup UART 0 */
3 sc_pm_set_resource_power_mode(ipc, SC_R_UART_0, SC_PM_PW_MODE_ON);
```

Then configure the UART peripheral clock. Note that due to hardware limitation, the exact rate may not be what is requested. The rate is guarenteed to not be greater than the requested rate. The actual rate is returned in the varaible. The actual rate should be used when configuring the UART IP. Note that 160MHz is used as that can be divided by the UART to hit all the common UART rates within required error. Other frequencies may have issues and the caller needs to calculate the baud clock error rate. See the UART section of the SoC RM.

```
4 /* Configure UART 0 baud clock */
6 sc_pm_set_clock_rate(ipc, SC_R_UART_0, SC_PM_CLK_PER, &rate);
```

### Then enable the clock.

```
7 /* Enable UART 0 clock */
9 sc_pm_clock_enable(ipc, SC_R_UART_0, SC_PM_CLK_PER, SC_TRUE, SC_FALSE);
```

At this point, the UART IP can be configured and used.

### 13.4.2 Typedef Documentation

```
13.4.2.1 sc_pm_power_mode_t
```

```
typedef uint8_t sc_pm_power_mode_t
```

This type is used to declare a power mode.

Note resources only use SC\_PM\_PW\_MODE\_OFF and SC\_PM\_PW\_MODE\_ON. The other modes are used only as system power modes.

# 13.4.3 Function Documentation

#### 13.4.3.1 sc\_pm\_set\_sys\_power\_mode()

This function sets the system power mode.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can do this.

#### **Parameters**

| in | ipc  | IPC handle          |
|----|------|---------------------|
| in | mode | power mode to apply |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_ERR\_PARM if invalid mode,
- SC ERR NOACCESS if caller does not have SC R SYSTEM access

# See also

```
sc_pm_set_sys_power_mode().
```

# 13.4.3.2 sc\_pm\_set\_partition\_power\_mode()

This function sets the power mode of a partition.

#### **Parameters**

| in | ipc  | IPC handle          |
|----|------|---------------------|
| in | pt   | handle of partition |
| in | mode | power mode to apply |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_ERR\_PARM if invalid partition or mode != SC\_PM\_PW\_MODE\_OFF,
- SC\_ERR\_NOACCESS if caller's partition is not the owner or parent of pt

This function can only be used to turn off a partition by calling with mode equal to SC\_PM\_PW\_MODE\_OFF. After turning off, the partition can be booted with sc\_pm\_reboot\_partition() or sc\_pm\_boot(). It cannot be used to turn off the calling partition as the MU could not return the an error response.

For dynamic power management of a partition, use sc\_pm\_req\_low\_power\_mode(), sc\_pm\_req\_cpu\_low\_power\_mode(), and sc\_pm\_req\_sys\_if\_power\_mode() with a WFI for controlled power state transitions.

# 13.4.3.3 sc\_pm\_get\_sys\_power\_mode()

This function gets the power mode of a partition.

### **Parameters**

| in  | ipc  | IPC handle                   |
|-----|------|------------------------------|
| in  | pt   | handle of partition          |
| out | mode | pointer to return power mode |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

· SC\_ERR\_PARM if invalid partition

# 13.4.3.4 sc\_pm\_partition\_wake()

This function sends a wake interrupt to a partition.

# **Parameters**

| in | ipc | IPC handle                  |
|----|-----|-----------------------------|
| in | pt  | handle of partition to wake |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

An SC\_IRQ\_SW\_WAKE interrupt is sent to all MUs owned by the partition that have this interrupt enabled. The CPU using an MU will exit a low-power state to service the MU interrupt.

Return errors:

• SC\_ERR\_PARM if invalid partition

# 13.4.3.5 sc\_pm\_set\_resource\_power\_mode()

This function sets the power mode of a resource.

### **Parameters**

| in | ipc      | IPC handle          |
|----|----------|---------------------|
| in | resource | ID of the resource  |
| in | mode     | power mode to apply |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_ERR\_PARM if invalid resource or mode,
- · SC ERR PARM if resource is the MU used to make the call,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner

Resources must be at SC\_PM\_PW\_MODE\_LP mode or higher to access them, otherwise the master will get a bus error or hang.

Note some resources are still not accessible even when powered up if bus transactions go through a fabric not powered up. Examples of this are resources in display and capture subsystems which require the display controller or the imaging subsystem to be powered up first.

Note that resources are grouped into power domains by the underlying hardware. If any resource in the domain is on, the entire power domain will be on. Other power domains required to access the resource will also be turned on. Bus clocks required to access the peripheral will be turned on. Refer to the SoC RM for more info on power domains and access infrastructure (bus fabrics, clock domains, etc.).

When the resource transitions to the SC\_PM\_PW\_MODE\_OFF, all of the settings, including clock rate, will be lost; immaterial of the state of other resources in the same power domain.

#### 13.4.3.6 sc pm set resource power mode all()

This function sets the power mode for all the resources owned by a child partition.

### Parameters

| in | ipc     | IPC handle                |
|----|---------|---------------------------|
| in | pt      | handle of child partition |
| in | mode    | power mode to apply       |
| in | exclude | resource to exclude       |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_ERR\_PARM if invalid partition or mode,
- SC\_ERR\_NOACCESS if caller's partition is not the parent (with grant) of pt

This functions loops through all the resources owned by *pt* and sets the power mode to *mode*. It will skip setting *exclude* (SC\_R\_LAST to skip none).

This function can only be called by the parent. It is used to implement some aspects of virtualization.

#### 13.4.3.7 sc\_pm\_get\_resource\_power\_mode()

This function gets the power mode of a resource.

#### **Parameters**

| in  | ipc      | IPC handle                   |
|-----|----------|------------------------------|
| in  | resource | ID of the resource           |
| out | mode     | pointer to return power mode |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Note only SC\_PM\_PW\_MODE\_OFF and SC\_PM\_PW\_MODE\_ON are valid. The value returned does not reflect the power mode of the partition.

#### 13.4.3.8 sc\_pm\_req\_low\_power\_mode()

This function specifies the low power mode some of the resources can enter based on their state.

This API is only valid for the following resources: SC\_R\_A53, SC\_R\_A53\_0, SC\_R\_A53\_1, SC\_R\_A53\_2, SC\_R ← \_A53\_3, SC\_R\_A72, SC\_R\_A72\_0, SC\_R\_A72\_1, SC\_R\_CC1, SC\_R\_A35, SC\_R\_A35\_0, SC\_R\_A35\_1, SC\_R\_← A35\_2, SC\_R\_A35\_3. For all other resources it will return SC\_ERR\_PARAM. This function will set the low power mode the cores, cluster and cluster associated resources will enter when all the cores in a given cluster execute WFI.

#### **Parameters**

| in | ipc      | IPC handle          |
|----|----------|---------------------|
| in | resource | ID of the resource  |
| in | mode     | power mode to apply |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### 13.4.3.9 sc\_pm\_req\_cpu\_low\_power\_mode()

This function requests low-power mode entry for CPU/cluster resources.

This API is only valid for the following resources: SC\_R\_A53, SC\_R\_A53\_x, SC\_R\_A72, SC\_R\_A72\_x, SC\_R\_A35, SC\_R\_A35\_x, SC\_R\_CCI. For all other resources it will return SC\_ERR\_PARAM. For individual core resources, the specified power mode and wake source will be applied after the core has entered WFI. For cluster resources, the specified power mode is applied after all cores in the cluster have entered low-power mode. For multicluster resources, the specified power mode is applied after all clusters have reached low-power mode.

#### **Parameters**

| in | ipc      | IPC handle                     |
|----|----------|--------------------------------|
| in | resource | ID of the resource             |
| in | mode     | power mode to apply            |
| in | wake_src | wake source for low-power exit |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

### 13.4.3.10 sc\_pm\_set\_cpu\_resume\_addr()

This function is used to set the resume address of a CPU.

#### **Parameters**

| in | ipc      | IPC handle             |
|----|----------|------------------------|
| in | resource | ID of the CPU resource |
| in | address  | 64-bit resume address  |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_ERR\_PARM if invalid resource or address,
- · SC ERR NOACCESS if caller's partition is not the parent of the resource (CPU) owner

Note the address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

### 13.4.3.11 sc\_pm\_set\_cpu\_resume()

This function is used to set parameters for CPU resume from low-power mode.

#### **Parameters**

| in | ipc                           | IPC handle                      |  |
|----|-------------------------------|---------------------------------|--|
| in | resource                      | ID of the CPU resource          |  |
| in | isPrimary                     | set SC_TRUE if primary wake CPU |  |
| in | address 64-bit resume address |                                 |  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC ERR PARM if invalid resource or address,
- · SC ERR NOACCESS if caller's partition is not the parent of the resource (CPU) owner

Note the address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

# 13.4.3.12 sc\_pm\_req\_sys\_if\_power\_mode()

This function requests the power mode configuration for system-level interfaces including messaging units, interconnect, and memories.

This API is only valid for the following resources: SC\_R\_A53, SC\_R\_A72, and SC\_R\_M4\_x\_PID\_y. For all other resources, it will return SC\_ERR\_PARAM. The requested power mode will be captured and applied to system-level resources as system conditions allow.

#### **Parameters**

| in | ipc      | IPC handle                               |  |
|----|----------|------------------------------------------|--|
| in | resource | ID of the resource                       |  |
| in | sys_if   | system-level interface to be configured  |  |
| in | hpm      | high-power mode for the system interface |  |
| in | lpm      | low-power mode for the system interface  |  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.4.3.13 sc\_pm\_set\_clock\_rate()

This function sets the rate of a resource's clock/PLL.

# Parameters

| in     | ipc      | IPC handle          |
|--------|----------|---------------------|
| in     | resource | ID of the resource  |
| in     | clk      | clock/PLL to affect |
| in,out | rate     | pointer to rate     |

Note the actual rate is returned in rate.

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- SC\_ERR\_PARM if invalid resource or clock/PLL,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- SC\_ERR\_UNAVAILABLE if clock/PLL not applicable to this resource,
- SC\_ERR\_LOCKED if rate locked (usually because shared clock/PLL)

Refer to the Clock List for valid clock/PLL values.

# 13.4.3.14 sc\_pm\_get\_clock\_rate()

This function gets the rate of a resource's clock/PLL.

#### **Parameters**

| in  | ipc      | IPC handle             |
|-----|----------|------------------------|
| in  | resource | ID of the resource     |
| in  | clk      | clock/PLL to affect    |
| out | rate     | pointer to return rate |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- SC\_ERR\_PARM if invalid resource or clock/PLL,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- SC\_ERR\_UNAVAILABLE if clock/PLL not applicable to this resource

This function returns the actual clock rate of the hardware. This rate may be different from the original requested clock rate if the resource is set to a low power mode.

Refer to the Clock List for valid clock/PLL values.

# 13.4.3.15 sc\_pm\_clock\_enable()

This function enables/disables a resource's clock.

### **Parameters**

| in | ipc IPC handle                                            |  |
|----|-----------------------------------------------------------|--|
| in | resource ID of the resource                               |  |
| in | clk clock to affect                                       |  |
| in | enable enable if SC_TRUE; otherwise disabled in Rights in |  |
| in | autog HW auto clock gating                                |  |

If resource is SC\_R\_ALL then all resources owned will be affected. No error will be returned.

If clk is SC\_PM\_CLK\_ALL, then an error will be returned if any of the available clocks returns an error.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC ERR PARM if invalid resource or clock,
- · SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent (with grant) of the owner,
- · SC ERR UNAVAILABLE if clock not applicable to this resource

Refer to the Clock List for valid clock values.

# 13.4.3.16 sc\_pm\_set\_clock\_parent()

This function sets the parent of a resource's clock.

This function should only be called when the clock is disabled.

### **Parameters**

| in | ipc      | IPC handle              |
|----|----------|-------------------------|
| in | resource | ID of the resource      |
| in | clk      | clock to affect         |
| in | parent   | New parent of the clock |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- · SC ERR PARM if invalid resource or clock,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent (with grant) of the owner,
- SC ERR UNAVAILABLE if clock not applicable to this resource
- SC\_ERR\_BUSY if clock is currently enabled.
- · SC\_ERR\_NOPOWER if resource not powered

Refer to the Clock List for valid clock values.

# 13.4.3.17 sc\_pm\_get\_clock\_parent()

This function gets the parent of a resource's clock.

### **Parameters**

| in  | ipc      | IPC handle                        |  |
|-----|----------|-----------------------------------|--|
| in  | resource | ID of the resource                |  |
| in  | clk      | clock to affect                   |  |
| out | parent   | pointer to return parent of clock |  |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_ERR\_PARM if invalid resource or clock,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- SC\_ERR\_UNAVAILABLE if clock not applicable to this resource

Refer to the Clock List for valid clock values.

This function is used to reset the system.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can do this.

### **Parameters**

| in | ipc  | IPC handle |
|----|------|------------|
| in | type | reset type |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

- SC\_ERR\_PARM if invalid type,
- · SC ERR NOACCESS if caller cannot access SC R SYSTEM

If this function returns, then the reset did not occur due to an invalid parameter.

# 13.4.3.19 sc\_pm\_reset\_reason()

This function gets a caller's reset reason.

#### **Parameters**

| in  | ipc    | IPC handle                         |  |
|-----|--------|------------------------------------|--|
| out | reason | pointer to return the reset reason |  |

This function returns the reason a partition was reset. If the reason is POR, then the system reset reason will be returned.

Note depending on the connection of the WDOG\_OUT signal and the OTP programming of the PMIC, some resets may trigger a system POR and the original reason will be lost.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.4.3.20 sc\_pm\_get\_reset\_part()

This function gets the partition that caused a reset.

# **Parameters**

|     | in                        | ipc | IPC handle                                |                 |
|-----|---------------------------|-----|-------------------------------------------|-----------------|
| ı   |                           |     |                                           |                 |
| - [ | 011†.                     | pt  | pointer to return the resetting partition |                 |
|     |                           | 1   | NVD AII                                   | Pighto Poporyod |
|     | NXP - All Rights Reserved |     |                                           |                 |

If the reset reason obtained via sc\_pm\_reset\_reason() is POR then the result from this function will be 0. Some SECO causes of reset will also return 0.

Note depending on the connection of the WDOG\_OUT signal and the OTP programming of the PMIC, some resets may trigger a system POR and the partition info will be lost.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.4.3.21 sc\_pm\_boot()

This function is used to boot a partition.

#### **Parameters**

| in | ipc          | IPC handle                                 |  |
|----|--------------|--------------------------------------------|--|
| in | pt           | handle of partition to boot                |  |
| in | resource_cpu | ID of the CPU resource to start            |  |
| in | boot_addr    | 64-bit boot address                        |  |
| in | resource_mu  | ID of the MU that must be powered          |  |
| in | resource_dev | ID of the boot device that must be powered |  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_ERR\_PARM if invalid partition, resource, or addr,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of the partition to boot

This must be used to boot a partition. Only a partition booted this way can be rebooted using the watchdog, sc\_pm\_boot() or sc\_pm\_reboot\_partition().

Note the address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

# 13.4.3.22 sc\_pm\_set\_boot\_parm()

This function is used to change the boot parameters for a partition.

#### **Parameters**

| in | ipc          | IPC handle                                          |
|----|--------------|-----------------------------------------------------|
| in | resource_cpu | ID of the CPU resource to start                     |
| in | boot_addr    | 64-bit boot address                                 |
| in | resource_mu  | ID of the MU that must be powered (0=none)          |
| in | resource_dev | ID of the boot device that must be powered (0=none) |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

· SC\_ERR\_PARM if invalid resource, or addr

This function can be used to change the boot parameters for a partition. This can be useful if a partitions reboots differently from the initial boot done via sc\_pm\_boot() or via ROM.

Note the address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

# 13.4.3.23 sc\_pm\_reboot()

This function is used to reboot the caller's partition.

### **Parameters**

| in | ipc  | IPC handle |
|----|------|------------|
| in | type | reset type |

If type is SC\_PM\_RESET\_TYPE\_COLD, then most peripherals owned by the calling partition will be reset if possible.

SC state (partitions, power, clocks, etc.) is reset. The boot SW of the booting CPU must be able to handle peripherals that that are not reset.

If type is SC\_PM\_RESET\_TYPE\_WARM or SC\_PM\_RESET\_TYPE\_BOARD, then does nothing.

If this function returns, then the reset did not occur due to an invalid parameter.

13.4.3.24 sc\_pm\_reboot\_partition()

This function is used to reboot a partition.

#### **Parameters**

| in | ipc  | IPC handle                    |
|----|------|-------------------------------|
| in | pt   | handle of partition to reboot |
| in | type | reset type                    |

If *type* is SC\_PM\_RESET\_TYPE\_COLD, then most peripherals owned by the calling partition will be reset if possible. SC state (partitions, power, clocks, etc.) is reset. The boot SW of the booting CPU must be able to handle peripherals that that are not reset.

If *type* is SC\_PM\_RESET\_TYPE\_WARM or SC\_PM\_RESET\_TYPE\_BOARD, then returns SC\_ERR\_PARM as these are not supported.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_ERR\_PARM if invalid partition or type
- SC\_ERR\_NOACCESS if caller's partition is not the parent of pt and the caller does not have access to SC\_R\_← SYSTEM

Most peripherals owned by the partition will be reset if possible. SC state (partitions, power, clocks, etc.) is reset. The boot SW of the booting CPU must be able to handle peripherals that that are not reset.

If board\_reboot\_part() returns a non-0 mask, then the reboot will be delayed until all partitions indicated in the mask have called sc\_pm\_reboot\_continue() to continue the boot.

13.4.3.25 sc\_pm\_reboot\_continue()

This function is used to continue the reboot a partition.

#### **Parameters**

| in | ipc | IPC handle                      |  |
|----|-----|---------------------------------|--|
| in | pt  | handle of partition to continue |  |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

· SC\_ERR\_PARM if invalid partition

#### 13.4.3.26 sc pm cpu start()

This function is used to start/stop a CPU.

# Parameters

| in | ipc      | IPC handle                       |
|----|----------|----------------------------------|
| in | resource | ID of the CPU resource           |
| in | enable   | start if SC_TRUE; otherwise stop |
| in | address  | 64-bit boot address              |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- · SC\_ERR\_PARM if invalid resource or address,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of the resource (CPU) owner

This function is usually used to start a secondary CPU in the same partition as the caller. It is not used to start the first CPU in a dedicated partition. That would be started by calling sc\_pm\_boot().

A CPU started with sc\_pm\_cpu\_start() will not restart as a result of a watchdog event or calling sc\_pm\_reboot() or sc\_pm\_reboot\_partition(). Those will reboot that partition which will start the CPU started with sc\_pm\_boot().

Note the address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

### 13.4.3.27 sc\_pm\_cpu\_reset()

This function is used to reset a CPU.

#### **Parameters**

| in | ipc      | IPC handle             |
|----|----------|------------------------|
| in | resource | ID of the CPU resource |
| in | address  | 64-bit boot address    |

This function does not return anything as the calling core may have been reset. It can still fail if the resource or address is invalid. It can also fail if the caller's partition is not the owner of the CPU, not the parent of the CPU resource owner, or has access to SC\_R\_SYSTEM. Will also fail if the resource is not powered on. No indication of failure is returned.

Note this just resets the CPU. None of the peripherals or bus fabric used by the CPU is reset. State configured in the SCFW is not reset. The SW running on the core has to understand and deal with this.

The address is limited by the hardware implementation. See the CPU Start Address section in the Porting Guide.

13.4.3.28 sc\_pm\_resource\_reset()

This function is used to reset a peripheral.

#### **Parameters**

| in | ipc      | IPC handle        |
|----|----------|-------------------|
| in | resource | resource to reset |

This function will reset a resource. Most resources cannot be reset unless the SoC design specifically allows it. In the case on MUs, the IPC/RPC protocol is also reset. Note a caller cannot reset an MU that this API call is sent on.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- SC\_ERR\_PARM if invalid resource,
- SC ERR PARM if resource is the MU used to make the call,

- · SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent (with grant) of the owner,
- SC\_ERR\_BUSY if the resource cannot be reset due to power state of buses,
- SC\_ERR\_UNAVAILABLE if the resource cannot be reset due to hardware limitations

# 13.4.3.29 sc\_pm\_is\_partition\_started()

This function returns a bool indicating if a partition was started.

#### **Parameters**

| in | ipc | IPC handle                   |
|----|-----|------------------------------|
| in | pt  | handle of partition to check |

#### Returns

Returns a bool (SC\_TRUE = started).

Note this indicates if a partition was started. It does not indicate if a partition is currently running or in a low power state.

# 13.5 RM: Resource Management Service

Module for the Resource Management (RM) service.

# **Typedefs**

```
typedef uint8_t sc_rm_pt_t
```

This type is used to declare a resource partition.

typedef uint8\_t sc\_rm\_mr\_t

This type is used to declare a memory region.

typedef uint8\_t sc\_rm\_did\_t

This type is used to declare a resource domain ID used by the isolation HW.

typedef uint16\_t sc\_rm\_sid\_t

This type is used to declare an SMMU StreamID.

typedef uint8\_t sc\_rm\_spa\_t

This type is a used to declare master transaction attributes.

typedef uint8\_t sc\_rm\_perm\_t

This type is used to declare a resource/memory region access permission.

typedef uint8\_t sc\_rm\_det\_t

This type is used to indicate memory region transactions should detour to the IEE.

typedef uint8\_t sc\_rm\_rmsg\_t

This type is used to assign an RMSG value to a memory region.

### Defines for type widths

```
    #define SC RM PARTITION W 5U
```

Width of sc\_rm\_pt\_t.

• #define SC\_RM\_MEMREG\_W 6U

Width of sc\_rm\_mr\_t.

• #define SC RM DID W 4U

Width of sc\_rm\_did\_t.

#define SC\_RM\_SID\_W 6U

Width of sc\_rm\_sid\_t.

#define SC\_RM\_SPA\_W 2U

Width of sc\_rm\_spa\_t.

#define SC\_RM\_PERM\_W 3U

Width of sc\_rm\_perm\_t.

• #define SC\_RM\_DET\_W 1U

Width of sc\_rm\_det\_t.

#define SC\_RM\_RMSG\_W 4U

Width of sc\_rm\_rmsg\_t.

# **Defines for ALL parameters**

```
• #define SC_RM_PT_ALL ((sc_rm_pt_t) UINT8_MAX)
```

All partitions.

#define SC\_RM\_MR\_ALL ((sc\_rm\_mr\_t) UINT8\_MAX)

All memory regions.

# Defines for sc\_rm\_spa\_t

• #define SC RM SPA PASSTHRU 0U

Pass through (attribute driven by master)

#define SC\_RM\_SPA\_PASSSID 1U

Pass through and output on SID.

#define SC\_RM\_SPA\_ASSERT 2U

Assert (force to be secure/privileged)

#define SC\_RM\_SPA\_NEGATE 3U

Negate (force to be non-secure/user)

# Defines for sc\_rm\_perm\_t

• #define SC RM PERM NONE 0U

No access.

#define SC\_RM\_PERM\_SEC\_R 1U

Secure RO.

#define SC\_RM\_PERM\_SECPRIV\_RW 2U

Secure privilege R/W.

#define SC RM PERM SEC RW 3U

Secure R/W.

#define SC RM PERM NSPRIV R 4U

Secure R/W, non-secure privilege RO.

• #define SC\_RM\_PERM\_NS\_R 5U

Secure R/W, non-secure RO.

• #define SC RM PERM NSPRIV RW 6U

Secure R/W, non-secure privilege R/W.

• #define SC RM PERM FULL 7U

Full access.

#### **Partition Functions**

sc\_err\_t sc\_rm\_partition\_alloc (sc\_ipc\_t ipc, sc\_rm\_pt\_t \*pt, sc\_bool\_t secure, sc\_bool\_t isolated, sc\_bool\_t restricted, sc\_bool\_t grant, sc\_bool\_t coherent)

This function requests that the SC create a new resource partition.

• sc\_err\_t sc\_rm\_set\_confidential (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_bool\_t retro)

This function makes a partition confidential.

• sc\_err\_t sc\_rm\_partition\_free (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function frees a partition and assigns all resources to the caller.

sc\_rm\_did\_t sc\_rm\_get\_did (sc\_ipc\_t ipc)

This function returns the DID of a partition.

sc\_err\_t sc\_rm\_partition\_static (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rm\_did\_t did)

This function forces a partition to use a specific static DID.

sc\_err\_t sc\_rm\_partition\_lock (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function locks a partition.

sc\_err\_t sc\_rm\_get\_partition (sc\_ipc\_t ipc, sc\_rm\_pt\_t \*pt)

This function gets the partition handle of the caller.

sc\_err\_t sc\_rm\_set\_parent (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rm\_pt\_t pt\_parent)

This function sets a new parent for a partition.

sc\_err\_t sc\_rm\_move\_all (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt\_src, sc\_rm\_pt\_t pt\_dst, sc\_bool\_t move\_rsrc, sc\_bool\_t move\_pads)

This function moves all movable resources/pads owned by a source partition to a destination partition.

### **Resource Functions**

sc\_err\_t sc\_rm\_assign\_resource (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rsrc\_t resource)

This function assigns ownership of a resource to a partition.

sc\_err\_t sc\_rm\_set\_resource\_movable (sc\_ipc\_t ipc, sc\_rsrc\_t resource\_fst, sc\_rsrc\_t resource\_lst, sc\_bool\_t movable)

This function flags resources as movable or not.

sc\_err\_t sc\_rm\_set\_subsys\_rsrc\_movable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t movable)

This function flags all of a subsystem's resources as movable or not.

• sc\_err\_t sc\_rm\_set\_master\_attributes (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_spa\_t sa, sc\_rm\_spa\_t pa, sc\_bool\_t smmu\_bypass)

This function sets attributes for a resource which is a bus master (i.e.

• sc\_err\_t sc\_rm\_set\_master\_sid (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_sid\_t sid)

This function sets the StreamID for a resource which is a bus master (i.e.

sc\_err\_t sc\_rm\_set\_peripheral\_permissions (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_pt\_t pt, sc\_rm\_perm\_t perm)

This function sets access permissions for a peripheral resource.

sc\_bool\_t sc\_rm\_is\_resource\_owned (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function gets ownership status of a resource.

sc\_err\_t sc\_rm\_get\_resource\_owner (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_pt\_t \*pt)

This function is used to get the owner of a resource.

sc\_bool\_t sc\_rm\_is\_resource\_master (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to test if a resource is a bus master.

sc\_bool\_t sc\_rm\_is\_resource\_peripheral (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to test if a resource is a peripheral.

sc\_err\_t sc\_rm\_get\_resource\_info (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_sid\_t \*sid)

This function is used to obtain info about a resource.

### **Memory Region Functions**

sc\_err\_t sc\_rm\_memreg\_alloc (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

This function requests that the SC create a new memory region.

sc\_err\_t sc\_rm\_memreg\_split (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_mr\_t \*mr\_ret, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

This function requests that the SC split an existing memory region.

sc\_err\_t sc\_rm\_memreg\_frag (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr\_ret, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

This function requests that the SC fragment a memory region.

sc\_err\_t sc\_rm\_memreg\_free (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr)

This function frees a memory region.

- sc\_err\_t sc\_rm\_find\_memreg (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)
   Internal SC function to find a memory region.
- sc err t sc rm assign memreg (sc ipc t ipc, sc rm pt t pt, sc rm mr t mr)

This function assigns ownership of a memory region.

- sc\_err\_t sc\_rm\_set\_memreg\_permissions (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_pt\_t pt, sc\_rm\_perm\_t perm)

  This function sets access permissions for a memory region.
- sc\_err\_t sc\_rm\_set\_memreg\_iee (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_det\_t det, sc\_rm\_rmsg\_t rmsg)
   This function configures the IEE parameters for a memory region.
- sc\_bool\_t sc\_rm\_is\_memreg\_owned (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr)

This function gets ownership status of a memory region.

• sc\_err\_t sc\_rm\_get\_memreg\_info (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_faddr\_t \*addr\_start, sc\_faddr\_t \*addr\_end)

This function is used to obtain info about a memory region.

#### **Pad Functions**

sc\_err\_t sc\_rm\_assign\_pad (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pad\_t pad)

This function assigns ownership of a pad to a partition.

- sc\_err\_t sc\_rm\_set\_pad\_movable (sc\_ipc\_t ipc, sc\_pad\_t pad\_fst, sc\_pad\_t pad\_lst, sc\_bool\_t movable)
   This function flags pads as movable or not.
- sc\_bool\_t sc\_rm\_is\_pad\_owned (sc\_ipc\_t ipc, sc\_pad\_t pad)

This function gets ownership status of a pad.

## **Debug Functions**

void sc\_rm\_dump (sc\_ipc\_t ipc)

This function dumps the RM state for debug.

### 13.5.1 Detailed Description

Module for the Resource Management (RM) service.

The following SCFW resource manager (RM) code is an example of how to create a partition for an M4 core and its resources. This could be run from another core, an SCD, or be embedded into board.c.

The ipc parameter most functions take is a handle to the IPC channel opened to communicate to the SC. It is implementation defined. Most API ports include an sc\_ipc\_open() and sc\_ipc\_close() function to manage this. The sc\_ipc\_open() takes an argument to identify the communication channel (usually the MU address) and returns the IPC handle that all API calls should then use.

Note all this configuration can be done with the M4 subsystem powered off. It will be loaded when the M4 is powered on.

```
1 sc_rm_pt_t pt_m4_0;
2 sc_rm_mr_t mr_ddr1, mr_ddr2, mr_m4_0;
3
4 //sc_rm_dump(ipc);
5
6 /* Mark all resources as not movable */
```

```
7 sc_rm_set_resource_movable(ipc, SC_R_ALL, SC_R_ALL, SC_FALSE);
8 sc_rm_set_pad_movable(ipc, SC_P_ALL, SC_P_ALL, SC_FALSE);
10 /* Allocate M4_0 partition */
11 sc_rm_partition_alloc(ipc, &pt_m4_0, SC_FALSE, SC_TRUE, SC_FALSE, SC_TRUE,
12
      SC FALSE);
14 /* Mark all M4_0 subsystem resources as movable */
15 sc_rm_set_subsys_rsrc_movable(ipc, SC_R_M4_0_PID0, SC_TRUE);
16 sc_rm_set_pad_movable(ipc,SC_P_ADC_IN3,SC_P_ADC_IN2, SC_TRUE);
18 /\star Keep some resources in the parent partition \star/
19 sc_rm_set_resource_movable(ipc, SC_R_M4_0_PID1, SC_R_M4_0_PID4,
21 sc_rm_set_resource_movable(ipc, SC_R_M4_0_MU_0A0, SC_R_M4_0_MU_0A3,
      SC_FALSE);
23
24 /* Move some resource not in the M4_0 subsystem */
25 sc_rm_set_resource_movable(ipc, SC_R_IRQSTR_M4_0, SC_R_IRQSTR_M4_0,
      SC TRUE);
27 sc rm set resource movable (ipc, SC R M4 1 MU 0A0, SC R M4 1 MU 0A0,
28
      SC TRUE);
30 /* Move everything flagged as movable */
31 sc_rm_move_all(ipc, pt, pt_m4_0, SC_TRUE, SC_TRUE);
33 /* Allow all to access the SEMA42 */
34 sc_rm_set_peripheral_permissions(ipc, pt_m4_0, SC_R_M4_0_SEMA42,
      SC_RM_PT_ALL, SC_RM_PERM_FULL);
3.5
36
37 /* Move M4 0 TCM */
38 sc_rm_find_memreg(ipc, &mr_m4_0, 0x034FE0000, 0x034FE0000);
39 sc_rm_assign_memreg(ipc, pt_m4_0, mr_m4_0);
40
41 /* Split DDR space, assign 0x88000000-0x8FFFFFFF to CM4 */
42 sc_rm_find_memreg(ipc, &mr_ddr1, 0x080000000, 0x080000000);
43 sc_rm_memreg_split(ipc, mr_ddr1, &mr_ddr2, 0x090000000, 0x0FFFFFFFF);
45 /* Reserve DDR for M4 0 */
46 sc_rm_memreg_split(ipc, mr_ddr1, &mr_m4_0, 0x088000000, 0x08FFFFFFF);
47 sc_rm_assign_memreg(ipc, pt_m4_0, mr_m4_0);
48
49 //sc_rm_dump(ipc);
```

First, variables are declared to hold return partition and memory region handles.

```
0 sc_rm_pt_t pt_m4_0;
1 sc_rm_mr_t mr_ddr1, mr_ddr2, mr_m4_0;
```

Optionally, call sc\_rm\_dump() to dump the state of the RM to the SCFW debug UART.

```
2 //sc_rm_dump(ipc);
```

Mark resources and pins as movable or not movable to the new partition. By default, all resources are marked as movable. Marking all as movable or not movable first depends on how many resources are to be moved and which is the most efficient. Marking does not move the resource yet. Note, that it is also possible to assign resources individually using sc rm assign resource().

```
4 /* Mark all resources as not movable */
6 sc_rm_set_resource_movable(ipc, SC_R_ALL, SC_R_ALL, SC_FALSE);
7 sc_rm_set_pad_movable(ipc, SC_P_ALL, SC_P_ALL, SC_FALSE);
```

The sc\_rm\_partition\_alloc() function call requests that the SC create a new partition to contain the M4 system. This function does not access the hardware at all. It allocates a new partition and returns a partition handle (pt\_m4\_0). The partition is marked non-secure as secure=SC\_FALSE. Marking as non-secure prevents subsequent functions from configuring masters in this partition to assert the TZPROT signal.

```
8 /* Allocate M4_0 partition */
10 sc_rm_partition_alloc(ipc, &pt_m4_0, SC_FALSE, SC_TRUE, SC_FALSE, SC_TRUE,
11 SC_FALSE);
```

Now mark some resources as movable. sc\_rm\_set\_subsys\_rsrc\_movable() can be used to mark all resources in a HW subsystem. sc\_rm\_set\_pad movable() is used to mark some pads (i.e. pins) as movable.

```
12 /* Mark all M4_0 subsystem resources as movable */
14 sc_rm_set_subsys_rsrc_movable(ipc, SC_R_M4_0_PID0, SC_TRUE);
15 sc_rm_set_pad_movable(ipc, SC_P_ADC_IN3, SC_P_ADC_IN2, SC_TRUE);
```

Then mark some resources in the M4\_0 subsystem (all marked movable above) as not movable using sc\_rm\_set\_resource\_movable() In this case the process IDs used to access memory owned by other partitions as well as the MUs used for others to communicate with the M4 need to be left with the parent partition.

Move some resources in other subsystems. The new partition will require access to the IRQ Steer module which routes interrupts to this M4's NVIC. In this example, it also needs access to one of the M4 1 MUs.

```
22 /* Move some resource not in the M4_0 subsystem */
24 sc_rm_set_resource_movable(ipc, SC_R_IRQSTR_M4_0, SC_R_IRQSTR_M4_0,
```

Now assign (i.e. move) everything marked as movable. At this point, all these resources are in the new partition and HW will enforce isolation.

```
25 /* Move everything flagged as movable */
30 sc_rm_move_all(ipc, pt, pt_m4_0, SC_TRUE, SC_TRUE);
```

Allow others to access some of the new partitions resources. In this case, the SEMA42 IP works by allowing multiple CPUs to access and acquire the semaphore.

```
31 /* Allow all to access the SEMA42 */
33 sc_rm_set_peripheral_permissions(ipc, pt_m4_0, SC_R_M4_0_SEMA42,
34 SC_RM_PT_ALL, SC_RM_PERM_FULL);
```

Now assign the M4\_0 TCM to the M4 partition. Note the M4 can always access its TCM. This action prevents the parent (current owner of the M4 TCM) from accessing. This should only be done after code for the M4 has been loaded into the TCM. Code loading will require the M4 subsystem already be powered on.

```
35 /* Move M4 0 TCM */
37 sc_rm_find_memreg(ipc, &mr_m4_0, 0x034FE0000, 0x034FE0000);
38 sc_rm_assign_memreg(ipc, pt_m4_0, mr_m4_0);
```

Next is to carve out some DDR for the M4. In this case, the memory is in the middle of the DDR so the DDR has to be split into three regions. First is to split off the end portion and keep this with the parent. Next is then to split off the end of the remaining part and assign this to the M4.

```
39 /* Split DDR space, assign 0x88000000-0x8FFFFFFF to CM4 */
41 sc_rm_find_memreg(ipc, &mr_ddr1, 0x080000000, 0x080000000);
42 sc_rm_memreg_split(ipc, mr_ddr1, &mr_ddr2, 0x090000000, 0x0FFFFFFFF);
43
44 /* Reserve DDR for M4_0 */
45 sc_rm_memreg_split(ipc, mr_ddr1, &mr_m4_0, 0x088000000, 0x08FFFFFFF);
46 sc_rm_assign_memreg(ipc, pt_m4_0, mr_m4_0);
```

Optionally, call sc\_rm\_dump() to dump the state of the RM to the SCFW debug UART. 47 //sc\_rm\_dump(ipc);

At this point, the M4 can be powered on (if not already) and the M4 can be started using sc\_pm\_boot(). Do NOT start the CPU using sc\_pm\_cpu\_start() as that function is for starting a secondary CPU in the calling core's partition. In this

case, the core is in another partition that needs to be booted.

Refer to the SoC-specific Resource List for a list of resources.

# 13.5.2 Typedef Documentation

```
13.5.2.1 sc_rm_perm_t

typedef uint8_t sc_rm_perm_t
```

This type is used to declare a resource/memory region access permission.

Refer to the XRDC2 Block Guide for more information.

```
13.5.2.2 sc_rm_rmsg_t
typedef uint8_t sc_rm_rmsg_t
```

This type is used to assign an RMSG value to a memory region.

This value is sent to the IEE.

### 13.5.3 Function Documentation

# 13.5.3.1 sc\_rm\_partition\_alloc()

This function requests that the SC create a new resource partition.

# **Parameters**

| in  | ipc        | IPC handle                                                                                                                                                |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| out | pt         | return handle for partition; used for subsequent function calls associated with this partition                                                            |
| in  | secure     | boolean indicating if this partition should be secure; only valid if caller is secure                                                                     |
| in  | isolated   | boolean indicating if this partition should be HW isolated via XRDC; set SC_TRUE if new DID is desired                                                    |
| in  | restricted | boolean indicating if this partition should be restricted; set SC_TRUE if masters in this partition cannot create new partitions                          |
| in  | grant      | boolean indicating if this partition should always grant access and control to the parent                                                                 |
| in  | coherent   | boolean indicating if this partition is conferent, set SC_TRUE if only this partition will contain both AP clusters and they will be coherent via the CCI |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- · SC ERR PARM if caller's partition is not secure but a new secure partition is requested,
- · SC\_ERR\_LOCKED if caller's partition is locked,
- SC\_ERR\_UNAVAILABLE if partition table is full (no more allocation space)

Marking as non-secure prevents subsequent functions from configuring masters in this partition to assert the secure signal. Basically, if TrustZone SW is used, the Cortex-A cores and peripherals the TZ SW will use should be in a secure partition. Almost all other partitions (for a non-secure OS or M4 cores) should be in non-secure partitions.

Isolated should be true for almost all partitions. The exception is the non-secure partition for a Cortex-A core used to run a non-secure OS. This isn't isolated by domain but is instead isolated by the TZ security hardware.

If restricted then the new partition is limited in what functions it can call, especially those associated with managing partitions.

The grant option is usually used to isolate a bus master's traffic to specific memory without isolating the peripheral interface of the master or the API controls of that master. This is only used when creating a sub-partition with no CPU. It's useful to separate out a master and the memory it uses.

## 13.5.3.2 sc\_rm\_set\_confidential()

This function makes a partition confidential.

#### **Parameters**

| in | ipc   | IPC handle                           |
|----|-------|--------------------------------------|
| in | pt    | handle of partition that is granting |
| in | retro | retroactive                          |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

SC PARM if pt out of range,

- SC\_ERR\_NOACCESS if caller's not allowed to change pt
- SC ERR LOCKED if partition pt is locked

Call to make a partition confidential. Confidential means only this partition should be able to grant access permissions to this partition.

If retroactive, then all resources owned by other partitions will have access rights for this partition removed, even if locked.

### 13.5.3.3 sc\_rm\_partition\_free()

This function frees a partition and assigns all resources to the caller.

#### **Parameters**

| in | ipc | IPC handle                  |
|----|-----|-----------------------------|
| in | pt  | handle of partition to free |

#### Returns

Returns an error code (SC ERR NONE = success).

### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- SC PARM if pt out of range or invalid,
- SC ERR NOACCESS if pt is the SC partition,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of pt,
- SC\_ERR\_LOCKED if pt or caller's partition is locked

All resources, memory regions, and pads are assigned to the caller/parent. The partition watchdog is disabled (even if locked). DID is freed.

# 13.5.3.4 sc\_rm\_get\_did()

This function returns the DID of a partition.

#### **Parameters**

| in <i>ipc</i> IP | C handle |
|------------------|----------|
|------------------|----------|

### Returns

Returns the domain ID (DID) of the caller's partition.

The DID is a SoC-specific internal ID used by the HW resource protection mechanism. It is only required by clients when using the SEMA42 module as the DID is sometimes connected to the master ID.

### 13.5.3.5 sc\_rm\_partition\_static()

This function forces a partition to use a specific static DID.

### **Parameters**

| in | ipc | IPC handle                        |
|----|-----|-----------------------------------|
| in | pt  | handle of partition to assign did |
| in | did | static DID to assign              |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

## Return errors:

- SC\_ERR\_NOACCESS if caller's partition is restricted,
- SC\_PARM if pt or did out of range,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of pt,
- SC\_ERR\_LOCKED if pt is locked

Assumes no assigned resources or memory regions yet! The number of static DID is fixed by the SC at boot.

### 13.5.3.6 sc\_rm\_partition\_lock()

This function locks a partition.

#### **Parameters**

| in | ipc | IPC handle                  |
|----|-----|-----------------------------|
| in | pt  | handle of partition to lock |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- SC\_PARM if pt out of range,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of pt

If a partition is locked it cannot be freed, have resources/pads assigned to/from it, memory regions created/assigned, DID changed, or parent changed.

### 13.5.3.7 sc\_rm\_get\_partition()

This function gets the partition handle of the caller.

#### **Parameters**

| in  | ipc | IPC handle                           |
|-----|-----|--------------------------------------|
| out | pt  | return handle for caller's partition |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

### 13.5.3.8 sc\_rm\_set\_parent()

This function sets a new parent for a partition.

#### **Parameters**

| in | ipc       | IPC handle                                            |
|----|-----------|-------------------------------------------------------|
| in | pt        | handle of partition for which parent is to be changed |
| in | pt_parent | handle of partition to set as parent                  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the parent of pt,
- · SC\_ERR\_LOCKED if either partition is locked

### 13.5.3.9 sc\_rm\_move\_all()

This function moves all movable resources/pads owned by a source partition to a destination partition.

It can be used to more quickly set up a new partition if a majority of the caller's resources are to be moved to a new partition.

# **Parameters**

| in | ipc       | IPC handle                                                    |
|----|-----------|---------------------------------------------------------------|
| in | pt_src    | handle of partition from which resources should be moved from |
| in | pt_dst    | handle of partition to which resources should be moved to     |
| in | move_rsrc | boolean to indicate if resources should be moved              |
| in | move_pads | boolean to indicate if pads should be moved                   |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

By default, all resources are movable. This can be changed using the sc\_rm\_set\_resource\_movable() function. Note all masters defaulted to SMMU bypass.

#### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not pt\_src or the parent of pt\_src,
- SC\_ERR\_LOCKED if either partition is locked

## 13.5.3.10 sc\_rm\_assign\_resource()

This function assigns ownership of a resource to a partition.

### **Parameters**

| in | ipc      | IPC handle                                               |
|----|----------|----------------------------------------------------------|
| in | pt       | handle of partition to which resource should be assigned |
| in | resource | resource to assign                                       |

This function assigned a resource to a partition. This partition is then the owner. All resources always have an owner (one owner). The owner has various rights to make API calls affecting the resource. Ownership does not imply access to the peripheral itself (that is based on access rights).

### Returns

Returns an error code (SC\_ERR\_NONE = success).

This action resets the resource's master and peripheral attributes. Privilege attribute will be PASSTHRU, security attribute will be ASSERT if the partition is secure and NEGATE if it is not, and masters will defaulted to SMMU bypass. Access permissions will reset to SEC\_RW for the owning partition only for secure partitions, FULL for non-secure. Default is no access by other partitions.

### Return errors:

SC ERR NOACCESS if caller's partition is restricted,

- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- SC\_ERR\_LOCKED if the owning partition or pt is locked

### 13.5.3.11 sc\_rm\_set\_resource\_movable()

This function flags resources as movable or not.

#### **Parameters**

| in | ipc          | IPC handle                                  |
|----|--------------|---------------------------------------------|
| in | resource_fst | first resource for which flag should be set |
| in | resource_lst | last resource for which flag should be set  |
| in | movable      | movable flag (SC_TRUE is movable)           |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- · SC\_PARM if resources are out of range,
- SC\_ERR\_NOACCESS if caller's partition is not a parent of a resource owner,
- · SC\_ERR\_LOCKED if the owning partition is locked

This function is used to determine the set of resources that will be moved using the sc\_rm\_move\_all() function. All resources are movable by default so this function is normally used to prevent a set of resources from moving.

### 13.5.3.12 sc\_rm\_set\_subsys\_rsrc\_movable()

This function flags all of a subsystem's resources as movable or not.

#### **Parameters**

| in | ipc      | IPC handle                            |
|----|----------|---------------------------------------|
| in | resource | resource to use to identify subsystem |
| in | movable  | movable flag (SC_TRUE is movable)     |

A subsystem is a physical grouping within the chip of related resources; this is SoC specific. This function is used to optimize moving resource for these groupings, for instance, an M4 core and its associated resources. The list of subsystems and associated resources can be found in the SoC-specific API document Resources chapter.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

· SC\_ERR\_PARM if a function argument is out of range

Note resource is used to find the associated subsystem. Only resources owned by the caller are set.

#### 13.5.3.13 sc\_rm\_set\_master\_attributes()

This function sets attributes for a resource which is a bus master (i.e.

capable of DMA).

### **Parameters**

| in | ipc         | IPC handle                                        |
|----|-------------|---------------------------------------------------|
| in | resource    | master resource for which attributes should apply |
| in | sa          | security attribute                                |
| in | ра          | privilege attribute                               |
| in | smmu_bypass | SMMU bypass mode                                  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not a parent of the resource owner,
- · SC\_ERR\_LOCKED if the owning partition is locked

Masters are IP blocks that generate bus transactions. This function configures how the isolation HW will define these bus transactions from the specified master. Note the security attribute will only be changed if the caller's partition is secure.

Note an IP block can be both a master and peripheral (have both a programming model and generate bus transactions).

#### 13.5.3.14 sc\_rm\_set\_master\_sid()

This function sets the StreamID for a resource which is a bus master (i.e.

capable of DMA).

### **Parameters**

| in | ipc      | IPC handle                                        |
|----|----------|---------------------------------------------------|
| in | resource | master resource for which attributes should apply |
| in | sid      | StreamID                                          |

### Returns

Returns an error code (SC ERR NONE = success).

### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- · SC\_ERR\_LOCKED if the owning partition is locked

This function configures the SID attribute associated with all bus transactions from this master. Note 0 is not a valid SID as it is reserved to indicate bypass.

### 13.5.3.15 sc\_rm\_set\_peripheral\_permissions()

This function sets access permissions for a peripheral resource.

#### **Parameters**

| in | ipc      | IPC handle                                             |
|----|----------|--------------------------------------------------------|
| in | resource | peripheral resource for which permissions should apply |
| in | pt       | handle of partition <i>perm</i> should by applied for  |
| in | perm     | permissions to apply to resource for pt                |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the resource owner or parent of the owner,
- SC\_ERR\_LOCKED if the owning partition is locked
- SC\_ERR\_LOCKED if the pt is confidential and the caller isn't pt

Peripherals are IP blocks that have a programming model that can be accessed.

This function configures how the isolation HW will restrict access to a peripheral based on the attributes of a transaction from bus master. It also allows the access permissions of SC\_R\_SYSTEM to be set.

Note an IP block can be both a master and peripheral (have both a programming model and generate bus transactions).

13.5.3.16 sc\_rm\_is\_resource\_owned()

This function gets ownership status of a resource.

#### **Parameters**

| in | ipc      | IPC handle        |
|----|----------|-------------------|
| in | resource | resource to check |

#### Returns

Returns a boolean (SC\_TRUE if caller's partition owns the resource).

If resource is out of range then SC\_FALSE is returned.

```
13.5.3.17 sc_rm_get_resource_owner()
```

This function is used to get the owner of a resource.

#### **Parameters**

| in  | ipc      | IPC handle                         |
|-----|----------|------------------------------------|
| in  | resource | resource to check                  |
| out | pt       | pointer to return owning partition |

#### Returns

Returns a boolean (SC\_TRUE if the resource is a bus master).

#### Return errors:

· SC\_PARM if arguments out of range or invalid

If resource is out of range then SC\_ERR\_PARM is returned.

### 13.5.3.18 sc\_rm\_is\_resource\_master()

This function is used to test if a resource is a bus master.

#### **Parameters**

| in | ipc      | IPC handle        |
|----|----------|-------------------|
| in | resource | resource to check |

Masters are IP blocks that generate bus transactions. Note an IP block can be both a master and peripheral (have both a programming model and generate bus transactions).

#### Returns

Returns a boolean (SC\_TRUE if the resource is a bus master).

If resource is out of range then SC FALSE is returned.

13.5.3.19 sc\_rm\_is\_resource\_peripheral()

This function is used to test if a resource is a peripheral.

### **Parameters**

| in | ipc      | IPC handle        |
|----|----------|-------------------|
| in | resource | resource to check |

Peripherals are IP blocks that have a programming model that can be accessed. Note an IP block can be both a master and peripheral (have both a programming model and generate bus transactions)

## Returns

Returns a boolean (SC\_TRUE if the resource is a peripheral).

If resource is out of range then SC\_FALSE is returned.

13.5.3.20 sc\_rm\_get\_resource\_info()

This function is used to obtain info about a resource.

#### **Parameters**

| in  | ipc      | IPC handle                 |
|-----|----------|----------------------------|
| in  | resource | resource to inquire about  |
| out | sid      | pointer to return StreamID |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

• SC\_PARM if resource is out of range

## 13.5.3.21 sc\_rm\_memreg\_alloc()

This function requests that the SC create a new memory region.

### **Parameters**

| in  | ipc        | IPC handle                                                                               |  |
|-----|------------|------------------------------------------------------------------------------------------|--|
| out | mr         | return handle for region; used for subsequent function calls associated with this region |  |
| in  | addr_start | start address of region (physical)                                                       |  |
| in  | addr_end   | end address of region (physical)                                                         |  |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- SC\_ERR\_PARM if the new memory region is misaligned,
- SC\_ERR\_LOCKED if caller's partition is locked,
- SC\_ERR\_PARM if the new memory region spans multiple existing regions,
- SC\_ERR\_NOACCESS if caller's partition does not own the memory containing the new region,
- SC\_ERR\_UNAVAILABLE if memory region table is full (no more allocation space)

This function will create a new memory region. The area covered by the new region must already exist in a memory region owned by the caller. The result will be two memory regions, the new one overlapping the existing one. The new region has higher priority. See the XRDC2 MRC documentation for how it resolves access permissions in this case. By default, permissions will mirror the parent region.

### 13.5.3.22 sc\_rm\_memreg\_split()

This function requests that the SC split an existing memory region.

#### **Parameters**

| in  | ipc        | IPC handle                                                                                   |
|-----|------------|----------------------------------------------------------------------------------------------|
| in  | mr         | handle of memory region to split                                                             |
| out | mr_ret     | return handle for new region; used for subsequent function calls associated with this region |
| in  | addr_start | start address of region (physical)                                                           |
| in  | addr_end   | end address of region (physical)                                                             |

### Returns

Returns an error code (SC ERR NONE = success).

### Return errors:

- SC ERR PARM if the new memory region is not start/end part of mr,
- · SC\_ERR\_LOCKED if caller's partition is locked,
- SC\_ERR\_PARM if the new memory region spans multiple existing regions,
- SC ERR NOACCESS if caller's partition does not own the memory containing the new region,
- SC ERR BUSY if the region is coincident with another region,
- SC\_ERR\_UNAVAILABLE if memory region table is full (no more allocation space)

This function will take an existing region and split it into two, non-overlapping regions. Note the new region must start or end on the split region. Permissions will mirror the parent region.

### 13.5.3.23 sc\_rm\_memreg\_frag()

This function requests that the SC fragment a memory region.

#### **Parameters**

|   | in  | ipc        | IPC handle                                                                                   |
|---|-----|------------|----------------------------------------------------------------------------------------------|
| Ī | out | mr_ret     | return handle for new region; used for subsequent function calls associated with this region |
| Ī | in  | addr_start | start address of region (physical)                                                           |
|   | in  | addr_end   | end address of region (physical)                                                             |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_ERR\_LOCKED if caller's partition is locked,
- SC\_ERR\_PARM if the new memory region spans multiple existing regions,
- SC\_ERR\_NOACCESS if caller's partition does not own the memory containing the new region,
- SC\_ERR\_BUSY if the region is coincident with another region,
- SC ERR UNAVAILABLE if memory region table is full (no more allocation space)

This function finds the memory region containing the address range. It then splits it as required and returns the extracted region. The result is 2-3 non-overlapping regions, depending on how the new region aligns with existing regions. Permissions will mirror the parent region.

# 13.5.3.24 sc\_rm\_memreg\_free()

This function frees a memory region.

#### **Parameters**

| in | ipc | IPC handle                      |  |
|----|-----|---------------------------------|--|
| in | mr  | handle of memory region to free |  |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

SC PARM if mr out of range or invalid,

- SC\_ERR\_NOACCESS if caller's partition is not a parent of mr,
- SC\_ERR\_LOCKED if the owning partition of mr is locked

# 13.5.3.25 sc\_rm\_find\_memreg()

Internal SC function to find a memory region.

# See also

```
sc_rm_find_memreg().
```

This function finds a memory region.

#### **Parameters**

| in  | ipc                                                                                             | IPC handle                            |  |
|-----|-------------------------------------------------------------------------------------------------|---------------------------------------|--|
| out | out mr return handle for region; used for subsequent function calls associated with this region |                                       |  |
| in  | addr_start                                                                                      | start address of region to search for |  |
| in  | addr_end end address of region to search for                                                    |                                       |  |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

· SC\_ERR\_NOTFOUND if region not found,

Searches only for regions owned by the caller. Finds first region containing the range specified.

## 13.5.3.26 sc\_rm\_assign\_memreg()

This function assigns ownership of a memory region.

#### **Parameters**

| in | ipc | IPC handle                                                    |  |
|----|-----|---------------------------------------------------------------|--|
| in | pt  | handle of partition to which memory region should be assigned |  |
| in | mr  | handle of memory region to assign                             |  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

This function assigns a memory region to a partition. This partition is then the owner. All regions always have an owner (one owner). The owner has various rights to make API calls affecting the region. Ownership does not imply access to the memory itself (that is based on access rights).

#### Return errors:

- SC\_PARM if arguments out of range or invalid,
- SC ERR NOACCESS if caller's partition is not the mr owner or parent of the owner,
- SC\_ERR\_LOCKED if the owning partition or pt is locked

### 13.5.3.27 sc\_rm\_set\_memreg\_permissions()

This function sets access permissions for a memory region.

#### **Parameters**

| in | ipc  | IPC handle                                                 |  |
|----|------|------------------------------------------------------------|--|
| in | mr   | handle of memory region for which permissions should apply |  |
| in | pt   | handle of partition perm should by applied for             |  |
| in | perm | permissions to apply to <i>mr</i> for <i>pt</i>            |  |

This operates on the memory region specified. If SC\_RM\_PT\_ALL is specified then it operates on all the regions owned by the caller that exist at the time of the call.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

#### Return errors:

- · SC\_PARM if arguments out of range or invalid,
- · SC ERR NOACCESS if caller's partition is not the region owner or parent of the owner,
- · SC\_ERR\_LOCKED if the owning partition is locked
- SC\_ERR\_LOCKED if the pt is confidential and the caller isn't pt

This function configures how the HW isolation will restrict access to a memory region based on the attributes of a transaction from bus master.

13.5.3.28 sc\_rm\_set\_memreg\_iee()

This function configures the IEE parameters for a memory region.

### **Parameters**

| in | ipc  | IPC handle                       |  |
|----|------|----------------------------------|--|
| in | mr   | handle of memory region to check |  |
| in | det  | 0 = normal, 1 = encrypted        |  |
| in | rmsg | IEE region (0-7)                 |  |

Caller must own SC\_R\_IEE\_Rn where n is rmsg.

### Returns

Returns an error code (SC ERR NONE = success).

### Return errors:

- SC\_PARM if arguments out of range or invalid,
- · SC ERR LOCKED if the owning partition is locked
- · SC\_ERR\_NOACCESS if caller's partition is not the region owner or parent of the owner
- SC\_ERR\_UNAVAILABLE if caller's partition is not the IEE region resource owner

# 13.5.3.29 sc\_rm\_is\_memreg\_owned()

This function gets ownership status of a memory region.

### **Parameters**

| in | ipc | IPC handle                       |  |
|----|-----|----------------------------------|--|
| in | mr  | handle of memory region to check |  |

### Returns

Returns a boolean (SC\_TRUE if caller's partition owns the memory region).

If mr is out of range then SC\_FALSE is returned.

### 13.5.3.30 sc\_rm\_get\_memreg\_info()

This function is used to obtain info about a memory region.

### **Parameters**

| in <i>ipc</i> in <i>mr</i> |            | IPC handle                               |
|----------------------------|------------|------------------------------------------|
|                            |            | handle of memory region to inquire about |
| out                        | addr_start | pointer to return start address          |
| out                        | addr_end   | pointer to return end address            |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

• SC\_PARM if mr is out of range

# 13.5.3.31 sc\_rm\_assign\_pad()

This function assigns ownership of a pad to a partition.

#### **Parameters**

| in | ipc | IPC handle                                          |  |
|----|-----|-----------------------------------------------------|--|
| in | pt  | handle of partition to which pad should be assigned |  |
| in | pad | pad to assign                                       |  |

### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is restricted,
- · SC\_PARM if arguments out of range or invalid,
- SC\_ERR\_NOACCESS if caller's partition is not the pad owner or parent of the owner,
- SC\_ERR\_LOCKED if the owning partition or pt is locked

# 13.5.3.32 sc\_rm\_set\_pad\_movable()

This function flags pads as movable or not.

# **Parameters**

|   | in                    | ipc     | IPC handle                             |  |
|---|-----------------------|---------|----------------------------------------|--|
|   | in pad_fst in pad_lst |         | first pad for which flag should be set |  |
| ſ |                       |         | last pad for which flag should be set  |  |
| Ī | in                    | movable | movable flag (SC_TRUE is movable)      |  |

This function assigned a pad to a partition. This partition is then the owner. All pads always have an owner (one owner). The owner has various rights to make API calls affecting the pad.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

### Return errors:

- SC\_PARM if pads are out of range,
- · SC\_ERR\_NOACCESS if caller's partition is not a parent of a pad owner,
- · SC ERR LOCKED if the owning partition is locked

This function is used to determine the set of pads that will be moved using the sc\_rm\_move\_all() function. All pads are movable by default so this function is normally used to prevent a set of pads from moving.

```
13.5.3.33 sc_rm_is_pad_owned()
```

This function gets ownership status of a pad.

### **Parameters**

| in | ipc | IPC handle   |
|----|-----|--------------|
| in | pad | pad to check |

#### Returns

Returns a boolean (SC\_TRUE if caller's partition owns the pad).

If pad is out of range then SC\_FALSE is returned.

```
13.5.3.34 sc_rm_dump()
```

```
void sc_rm_dump (
sc_ipc_t ipc )
```

This function dumps the RM state for debug.

# **Parameters**

| in | ipc | IPC handle |
|----|-----|------------|

# 13.6 SECO: Security Service

Module for the Security (SECO) service.

# **Typedefs**

• typedef uint8\_t sc\_seco\_auth\_cmd\_t

This type is used to issue SECO authenticate commands.

typedef uint32\_t sc\_seco\_rng\_stat\_t

This type is used to return the RNG initialization status.

### Defines for sc\_seco\_auth\_cmd\_t

#define SC\_SECO\_AUTH\_CONTAINER 0U

Authenticate container.

#define SC\_SECO\_VERIFY\_IMAGE 1U

Verify image.

#define SC\_SECO\_REL\_CONTAINER 2U

Release container.

#define SC\_SECO\_AUTH\_SECO\_FW 3U

SECO Firmware.

#define SC\_SECO\_AUTH\_HDMI\_TX\_FW 4U

HDMI TX Firmware.

#define SC\_SECO\_AUTH\_HDMI\_RX\_FW 5U

HDMI RX Firmware.

#define SC\_SECO\_EVERIFY\_IMAGE 6U

Enhanced verify image.

# Defines for seco\_rng\_stat\_t

- #define SC\_SECO\_RNG\_STAT\_UNAVAILABLE 0U
- Unable to initialize the RNG.

  #define SC\_SECO\_RNG\_STAT\_INPROGRESS 1U

Initialization is on-going.

• #define SC\_SECO\_RNG\_STAT\_READY 2U

Initialized.

## **Image Functions**

- sc\_err\_t sc\_seco\_image\_load (sc\_ipc\_t ipc, sc\_faddr\_t addr\_src, sc\_faddr\_t addr\_dst, uint32\_t len, sc\_bool\_t fw)

  This function loads a SECO image.
- sc\_err\_t sc\_seco\_authenticate (sc\_ipc\_t ipc, sc\_seco\_auth\_cmd\_t cmd, sc\_faddr\_t addr)

This function is used to authenticate a SECO image or command.

sc\_err\_t sc\_seco\_enh\_authenticate (sc\_ipc\_t ipc, sc\_seco\_auth\_cmd\_t cmd, sc\_faddr\_t addr, uint32\_t mask1, uint32\_t mask2)

This function is used to authenticate a SECO image or command.

# **Lifecycle Functions**

sc\_err\_t sc\_seco\_forward\_lifecycle (sc\_ipc\_t ipc, uint32\_t change)

This function updates the lifecycle of the device.

sc\_err\_t sc\_seco\_return\_lifecycle (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function updates the lifecycle to one of the return lifecycles.

sc\_err\_t sc\_seco\_commit (sc\_ipc\_t ipc, uint32\_t \*info)

This function is used to commit into the fuses any new SRK revocation and FW version information that have been found in the primary and secondary containers.

#### **Attestation Functions**

sc\_err\_t sc\_seco\_attest\_mode (sc\_ipc\_t ipc, uint32\_t mode)

This function is used to set the attestation mode.

sc\_err\_t sc\_seco\_attest (sc\_ipc\_t ipc, uint64\_t nonce)

This function is used to request attestation.

sc\_err\_t sc\_seco\_get\_attest\_pkey (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to retrieve the attestation public key.

sc\_err\_t sc\_seco\_get\_attest\_sign (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to retrieve attestation signature and parameters.

sc\_err\_t sc\_seco\_attest\_verify (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to verify attestation.

### **Key Functions**

sc\_err\_t sc\_seco\_gen\_key\_blob (sc\_ipc\_t ipc, uint32\_t id, sc\_faddr\_t load\_addr, sc\_faddr\_t export\_addr, uint16\_t max\_size)

This function is used to generate a SECO key blob.

sc\_err\_t sc\_seco\_load\_key (sc\_ipc\_t ipc, uint32\_t id, sc\_faddr\_t addr)

This function is used to load a SECO key.

# **Manufacturing Protection Functions**

sc\_err\_t sc\_seco\_get\_mp\_key (sc\_ipc\_t ipc, sc\_faddr\_t dst\_addr, uint16\_t dst\_size)

This function is used to get the manufacturing protection public key.

• sc\_err\_t sc\_seco\_update\_mpmr (sc\_ipc\_t ipc, sc\_faddr\_t addr, uint8\_t size, uint8\_t lock)

This function is used to update the manufacturing protection message register.

 sc\_err\_t sc\_seco\_get\_mp\_sign (sc\_ipc\_t ipc, sc\_faddr\_t msg\_addr, uint16\_t msg\_size, sc\_faddr\_t dst\_addr, uint16\_t dst\_size)

This function is used to get the manufacturing protection signature.

# **Debug Functions**

```
    void sc_seco_build_info (sc_ipc_t ipc, uint32_t *version, uint32_t *commit)
```

This function is used to return the SECO FW build info.

• sc\_err\_t sc\_seco\_chip\_info (sc\_ipc\_t ipc, uint16\_t \*lc, uint16\_t \*monotonic, uint32\_t \*uid\_l, uint32\_t \*uid\_h)

This function is used to return SECO chip info.

sc\_err\_t sc\_seco\_enable\_debug (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function securely enables debug.

• sc\_err\_t sc\_seco\_get\_event (sc\_ipc\_t ipc, uint8\_t idx, uint32\_t \*event)

This function is used to return an event from the SECO error log.

#### Miscellaneous Functions

sc err t sc seco fuse write (sc ipc t ipc, sc faddr t addr)

This function securely writes a group of fuse words.

sc\_err\_t sc\_seco\_patch (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function applies a patch.

• sc err t sc seco set mono counter partition (sc ipc t ipc, uint16 t \*she)

This function partitions the monotonic counter.

sc err t sc seco set fips mode (sc ipc t ipc, uint8 t mode, uint32 t \*reason)

This function configures the SECO in FIPS mode.

sc\_err\_t sc\_seco\_start\_rng (sc\_ipc\_t ipc, sc\_seco\_rng\_stat\_t \*status)

This function starts the random number generator.

sc\_err\_t sc\_seco\_sab\_msg (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function sends a generic signed message to the SECO SHE/HSM components.

sc\_err\_t sc\_seco\_secvio\_enable (sc\_ipc\_t ipc)

This function is used to enable security violation and tamper interrupts.

sc\_err\_t sc\_seco\_secvio\_config (sc\_ipc\_t ipc, uint8\_t id, uint8\_t access, uint32\_t \*data0, uint32\_t \*data1, uint32\_t \*data2, uint32\_t \*data3, uint32\_t \*data4, uint8\_t size)

This function is used to read/write SNVS security violation and tamper registers.

• sc\_err\_t sc\_seco\_secvio\_dgo\_config (sc\_ipc\_t ipc, uint8\_t id, uint8\_t access, uint32\_t \*data)

This function is used to read/write SNVS security violation and tamper DGO registers.

### 13.6.1 Detailed Description

Module for the Security (SECO) service.

SECO functions in the SCFW API communicate via a messaging protocol to the Security Controller (SECO). This messaging protocol is documented in the SECO API Reference Guide. There is also a Security Reference Manual (SRM) that documents many of the SECO features.

SECO messages contain error codes defined in the SECO API Reference Guide. These have to be mapped to SC FW error codes. sc\_seco\_get\_event() can be used to obtain SECO-specific error codes recorded in the SECO event log.

### **SCFW Error Mapping to SECO Errors**

SC ERR NOACCESS

- AHAB\_INVALID\_LIFECYCLE
- AHAB\_PERMISSION\_DENIED\_IND
- · SC ERR IPC
  - AHAB INVALID MESSAGE IND
  - AHAB\_CRC\_ERROR
  - AHAB\_INVALID\_OPERATION\_IND
- SC\_ERR\_VERSION
  - AHAB BAD VERSION IND
- SC\_ERR\_PARM
  - AHAB BAD HASH IND
  - AHAB BAD VALUE IND
  - AHAB\_BAD\_FUSE\_ID\_IND
  - AHAB\_BAD\_CONTAINER\_IND
  - AHAB\_BAD\_KEY\_HASH\_IND
  - AHAB\_NO\_VALID\_CONTAINER\_IND
  - AHAB\_MUST\_SIGNED\_IND
  - AHAB\_NO\_BID\_MATCHING\_IND
  - AHAB\_UNKNOWN\_BID\_IND
  - AHAB\_UNALIGNED\_PAYLOAD\_IND
  - AHAB\_WRONG\_SIZE\_IND
  - AHAB\_OTP\_INVALID\_IDX\_IND
  - AHAB\_ADM\_WRONG\_LC\_IND
  - AHAB\_OTP\_DED\_IND
  - AHAB\_BAD\_PAYLOAD\_IND
  - AHAB\_WRONG\_ADDRESS\_IND
  - AHAB\_DMA\_FAILURE\_IND
  - AHAB\_BAD\_UID\_IND
  - AHAB\_INCONSISTENT\_PAR\_IND
  - AHAB\_BAD\_MONOTONIC\_COUNTER\_IND
  - AHAB\_BAD\_SRK\_SET\_IND
  - AHAB\_BAD\_ID\_IND
- SC\_ERR\_LOCKED
  - AHAB\_OTP\_LOCKED\_IND
  - AHAB\_LOCKED\_REG\_IND
- SC\_ERR\_UNAVAILABLE
  - AHAB\_BID\_COLLISION\_IND
  - AHAB\_OOM\_FOR\_BLOB\_IND
  - AHAB\_OOM\_FOR\_BLOB\_EXPORT\_IND
  - AHAB\_HDCP\_DISABLED\_IND

- AHAB\_NON\_SECURE\_STATE\_IND
- AHAB\_DISABLED\_FEATURE\_IND
- · SC ERR BUSY
  - AHAB\_ADM\_NOT\_READY\_IND
  - AHAB TIME OUT IND
- SC\_ERR\_FAIL
  - AHAB\_BAD\_BLOB\_IND
  - AHAB ENCRYPTION FAILURE IND
  - AHAB DECRYPTION FAILURE IND
  - AHAB BAD CERTIFICATE IND
  - AHAB\_OTP\_PROGFAIL\_IND
  - AHAB\_KMEK\_GENERATION\_FAIL\_IND
  - AHAB\_BAD\_SIGNATURE\_IND
  - AHAB\_INVALID\_KEY\_IND
  - AHAB\_MUST\_ATTEST\_IND
  - AHAB\_RNG\_NOT\_STARTED\_IND
  - AHAB\_SECO\_FATAL\_FAILURE\_IND
  - AHAB\_RNG\_INST\_FAILURE\_IND
  - AHAB\_NO\_AUTHENTICATION\_IND
  - AHAB\_AUTH\_SKIPPED\_OR\_FAILED\_IND
- If no mapping exists, SC\_ERR\_FAIL will be returned

### 13.6.2 Function Documentation

# 13.6.2.1 sc\_seco\_image\_load()

This function loads a SECO image.

### **Parameters**

| in | ipc      | IPC handle                   |
|----|----------|------------------------------|
| in | addr_src | address of image source      |
| in | addr_dst | address of image destination |
| in | len      | length of image to load      |
| in | fw       | SC TRUE - firmware load      |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This is used to load images via the SECO. Examples include SECO Firmware and IVT/CSF data used for authentication. These are usually loaded into SECO TCM. *addr\_src* is in secure memory.

See the SECO API Reference Guide for more info.

### 13.6.2.2 sc\_seco\_authenticate()

This function is used to authenticate a SECO image or command.

#### **Parameters**

| in | ipc  | IPC handle             |
|----|------|------------------------|
| in | cmd  | authenticate command   |
| in | addr | address of/or metadata |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- · SC\_ERR\_PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC ERR BUSY if SECO is busy with another authentication request,
- SC\_ERR\_FAIL if SECO response is bad,
- SC ERR IPC if SECO response has bad header tag or size,

- · SC\_ERR\_VERSION if SECO response has bad version,
- · Others, see the Security Service Detailed Description section

This is used to authenticate a SECO image or issue a security command. *addr* often points to an container. It is also just data (or even unused) for some commands.

Implementation of this command depends on the underlying security architecture of the device. For example, on devices with SECO FW, the following options apply:

- cmd=SC\_SECO\_AUTH\_CONTAINER, addr=container address (sends AHAB\_AUTH\_CONTAINER\_REQ to S← ECO)
- cmd=SC\_SECO\_VERIFY\_IMAGE, addr=image mask (sends AHAB\_VERIFY\_IMAGE\_REQ to SECO)
- cmd=SC\_SECO\_REL\_CONTAINER, addr unused (sends AHAB\_RELEASE\_CONTAINER\_REQ to SECO)
- cmd=SC\_SECO\_AUTH\_HDMI\_TX\_FW, addr unused (sends AHAB\_ENABLE\_HDMI\_X\_REQ with Subsystem=0 to SECO)
- cmd=SC\_SECO\_AUTH\_HDMI\_RX\_FW, addr unused (sends AHAB\_ENABLE\_HDMI\_X\_REQ with Subsystem=1 to SECO)

See the SECO API Reference Guide for more info.

# 13.6.2.3 sc\_seco\_enh\_authenticate()

This function is used to authenticate a SECO image or command.

This is an enhanced version that has additional mask arguments.

### **Parameters**

| in | ipc   | IPC handle             |
|----|-------|------------------------|
| in | cmd   | authenticate command   |
| in | addr  | address of/or metadata |
| in | mask1 | metadata               |
| in | mask2 | metadata               |

Return errors codes:

SC ERR PARM if word fuse index param out of range or invalid,

- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC\_ERR\_BUSY if SECO is busy with another authentication request,
- · SC\_ERR\_FAIL if SECO response is bad,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This supports all the commands found in sc\_seco\_authenticate(). Those commands should set both masks to 0 (except SC\_SECO\_VERIFY\_IMAGE).

New commands are as follows:

- cmd=SC\_SECO\_VERIFY\_IMAGE, addr unused, mask1=image mask, mask2 unused (sends AHAB\_VERIFY
   — IMAGE\_REQ to SECO)
- cmd=SC\_SECO\_EVERIFY\_IMAGE, addr=container address, mask1=image mask, mask2=move mask (sends AHAB\_EVERIFY\_IMAGE\_REQ to SECO)

See the SECO API Reference Guide for more info.

```
13.6.2.4 sc_seco_forward_lifecycle()
```

This function updates the lifecycle of the device.

# **Parameters**

| in | ipc    | IPC handle                   |
|----|--------|------------------------------|
| in | change | desired lifecycle transition |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This function is used for going from Open to NXP Closed to OEM Closed. Note *change* is NOT the new desired lifecycle. It is a lifecycle transition as documented in the *SECO API Reference Guide*.

If any SECO request fails or only succeeds because the part is in an "OEM open" lifecycle, then a request to transition from "NXP closed" to "OEM closed" will also fail. For example, booting a signed container when the OEM SRK is not fused will succeed, but as it is an abnormal situation, a subsequent request to transition the lifecycle will return an error.

## 13.6.2.5 sc\_seco\_return\_lifecycle()

This function updates the lifecycle to one of the return lifecycles.

#### **Parameters**

| in | ipc  | IPC handle               |
|----|------|--------------------------|
| in | addr | address of message block |

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

# Return errors codes:

- SC ERR UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC ERR VERSION if SECO response has bad version,
- · Others, see the Security Service Detailed Description section

Note addr must be a pointer to a signed message block.

To switch back to NXP states (Full Field Return), message must be signed by NXP SRK. For OEM States (Partial Field Return), must be signed by OEM SRK.

See the SECO API Reference Guide for more info.

# 13.6.2.6 sc\_seco\_commit()

This function is used to commit into the fuses any new SRK revocation and FW version information that have been found in the primary and secondary containers.

## **Parameters**

| in     | ipc  | IPC handle                                  |
|--------|------|---------------------------------------------|
| in,out | info | pointer to information type to be committed |

The return info will contain what was actually committed.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if info is invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

# 13.6.2.7 sc\_seco\_attest\_mode()

This function is used to set the attestation mode.

Only the owner of the SC\_R\_ATTESTATION resource may make this call.

## **Parameters**

| in | ipc  | IPC handle |
|----|------|------------|
| in | mode | mode       |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

- SC\_ERR\_PARM if mode is invalid,
- SC\_ERR\_NOACCESS if SC\_R\_ATTESTATON not owned by caller,

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This is used to set the SECO attestation mode. This can be prover or verifier. See the SECO API Reference Guide for more on the supported modes, mode values, and mode behavior.

## 13.6.2.8 sc\_seco\_attest()

This function is used to request attestation.

Only the owner of the SC\_R\_ATTESTATION resource may make this call.

#### **Parameters**

| in | ipc   | IPC handle   |
|----|-------|--------------|
| in | nonce | unique value |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_NOACCESS if SC\_R\_ATTESTATON not owned by caller,
- · SC ERR UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- · SC ERR VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This is used to ask SECO to perform an attestation. The result depends on the attestation mode. After this call, the signature can be requested or a verify can be requested.

See the SECO API Reference Guide for more info.

## 13.6.2.9 sc\_seco\_get\_attest\_pkey()

This function is used to retrieve the attestation public key.

Mode must be verifier. Only the owner of the SC\_R\_ATTESTATION resource may make this call.

## **Parameters**

| in | ipc  | IPC handle                |
|----|------|---------------------------|
| in | addr | address to write response |

Result will be written to *addr*. The *addr* parameter must point to an address SECO can access. It must be 64-bit aligned. There should be 96 bytes of space.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC ERR PARM if addr bad or attestation has not been requested,
- SC\_ERR\_NOACCESS if SC\_R\_ATTESTATON not owned by caller,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See the SECO API Reference Guide for more info.

13.6.2.10 sc\_seco\_get\_attest\_sign()

This function is used to retrieve attestation signature and parameters.

Mode must be provider. Only the owner of the SC\_R\_ATTESTATION resource may make this call.

# **Parameters**

| in | ipc  | IPC handle                |
|----|------|---------------------------|
| in | addr | address to write response |

Result will be written to *addr*. The *addr* parameter must point to an address SECO can access. It must be 64-bit aligned. There should be 120 bytes of space.

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if addr bad or attestation has not been requested,
- SC\_ERR\_NOACCESS if SC\_R\_ATTESTATON not owned by caller,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See the SECO API Reference Guide for more info.

```
13.6.2.11 sc seco attest verify()
```

This function is used to verify attestation.

Mode must be verifier. Only the owner of the SC R ATTESTATION resource may make this call.

# Parameters

| in | ipc  | IPC handle           |
|----|------|----------------------|
| in | addr | address of signature |

The addr parameter must point to an address SECO can access. It must be 64-bit aligned.

## **Returns**

Returns an error code (SC\_ERR\_NONE = success).

- SC\_ERR\_PARM if addr bad or attestation has not been requested,
- SC\_ERR\_NOACCESS if SC\_R\_ATTESTATON not owned by caller,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC ERR FAIL if signature doesn't match,

- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See the SECO API Reference Guide for more info.

```
13.6.2.12 sc_seco_gen_key_blob()
```

This function is used to generate a SECO key blob.

## **Parameters**

| in | ipc         | IPC handle      |
|----|-------------|-----------------|
| in | id          | key identifier  |
| in | load_addr   | load address    |
| in | export_addr | export address  |
| in | max_size    | max export size |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- · SC\_ERR\_PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- · SC ERR VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This function is used to encapsulate sensitive keys in a specific structure called a blob, which provides both confidentiality and integrity protection.

See the SECO API Reference Guide for more info.

# 13.6.2.13 sc\_seco\_load\_key()

This function is used to load a SECO key.

## **Parameters**

| in | ipc  | IPC handle     |
|----|------|----------------|
| in | id   | key identifier |
| in | addr | key address    |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- · SC ERR PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC ERR IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This function is used to install private cryptographic keys encapsulated in a blob previously generated by SECO. The controller can be either the IEE or the VPU. The blob header carries the controller type and the key size, as provided by the user when generating the key blob.

See the SECO API Reference Guide for more info.

```
13.6.2.14 sc_seco_get_mp_key()
```

This function is used to get the manufacturing protection public key.

# **Parameters**

| in | ipc      | IPC handle          |
|----|----------|---------------------|
| in | dst_addr | destination address |
| in | dst size | destination size    |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This function is supported only in OEM-closed lifecycle. It generates the mfg public key and stores it in a specific location in the secure memory.

See the SECO API Reference Guide for more info.

13.6.2.15 sc\_seco\_update\_mpmr()

This function is used to update the manufacturing protection message register.

# **Parameters**

| in | ipc  | IPC handle   |
|----|------|--------------|
| in | addr | data address |
| in | size | size         |
| in | lock | lock_reg     |

# Returns

Returns an error code (SC ERR NONE = success).

- · SC\_ERR\_PARM if word fuse index param out of range or invalid,
- · SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC ERR VERSION if SECO response has bad version,

• Others, see the Security Service Detailed Description section

This function is supported only in OEM-closed lifecycle. It updates the content of the MPMR (Manufacturing Protection Message register of 256 bits). This register will be appended to the input-data message when generating the signature. Please refer to the CAAM block guide for details.

See the SECO API Reference Guide for more info.

```
13.6.2.16 sc_seco_get_mp_sign()
```

This function is used to get the manufacturing protection signature.

#### **Parameters**

| in | ipc      | IPC handle          |
|----|----------|---------------------|
| in | msg_addr | message address     |
| in | msg_size | message size        |
| in | dst_addr | destination address |
| in | dst_size | destination size    |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_PARM if word fuse index param out of range or invalid,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC ERR IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

This function is used to generate an ECDSA signature for an input-data message and to store it in a specific location in the secure memory. It is only supported in OEM-closed lifecycle. In order to get the ECDSA signature, the RNG must be initialized. In case it has not been started an error will be returned.

See the SECO API Reference Guide for more info.

# 13.6.2.17 sc\_seco\_build\_info()

This function is used to return the SECO FW build info.

# **Parameters**

| in  | ipc     | IPC handle                              |  |
|-----|---------|-----------------------------------------|--|
| out | version | pointer to return build number          |  |
| out | commit  | pointer to return commit ID (git SHA-1) |  |

## 13.6.2.18 sc\_seco\_chip\_info()

This function is used to return SECO chip info.

# **Parameters**

| in  | ipc IPC handle                 |                                       |
|-----|--------------------------------|---------------------------------------|
| out | lc pointer to return lifecycle |                                       |
| out | monotonic                      | pointer to return monotonic counter   |
| out | uid_l                          | pointer to return UID (lower 32 bits) |
| out | uid_h                          | pointer to return UID (upper 32 bits) |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

# 13.6.2.19 sc\_seco\_enable\_debug()

This function securely enables debug.

# **Parameters**

| in | ipc  | IPC handle               |
|----|------|--------------------------|
| in | addr | address of message block |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

Note addr must be a pointer to a signed message block.

See the SECO API Reference Guide for more info.

```
13.6.2.20 sc_seco_get_event()
```

This function is used to return an event from the SECO error log.

## **Parameters**

| in  | ipc   | IPC handle               |
|-----|-------|--------------------------|
| out | idx   | index of event to return |
| out | event | pointer to return event  |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- · SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

Read of idx 0 captures events from SECO. Loop starting with 0 until an error is returned to dump all events.

```
13.6.2.21 sc_seco_fuse_write()
```

This function securely writes a group of fuse words.

## **Parameters**

| in | ipc  | IPC handle               |  |
|----|------|--------------------------|--|
| in | addr | address of message block |  |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- · SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

Note addr must be a pointer to a signed message block.

See the SECO API Reference Guide for more info.

```
13.6.2.22 sc_seco_patch()
```

This function applies a patch.

## **Parameters**

| in | ipc  | IPC handle               |  |
|----|------|--------------------------|--|
| in | addr | address of message block |  |

## Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- · SC ERR UNAVAILABLE if SECO not available,
- · SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

Note *addr* must be a pointer to a signed message block.

See the SECO API Reference Guide for more info.

```
13.6.2.23 sc seco set mono counter partition()
```

This function partitions the monotonic counter.

Only the owner of the SC R SYSTEM resource or a partition with access permissions to SC R SYSTEM can do this.

## **Parameters**

| in     | ipc | IPC handle                    |
|--------|-----|-------------------------------|
| in,out | she | pointer to number of SHE bits |

SECO uses an OTP monotonic counter to protect the SHE and HSM key-stores from roll-back attack. This function is used to define the number of monotonic counter bits allocated to SHE use. Two monotonic counter bits are used to store this information while the remaining bits are allocated to the HSM user. This function must be called before any SHE or HSM key stores are created in the system, otherwise the default configuration is applied. Returns the actual number of SHE bits.

If the partition has been already configured, any attempt to re-configure the SHE partition to a different value will result in a failure response.

#### Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_NOACCESS if caller does not have SC\_R\_SYSTEM access
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See the SECO API Reference Guide for more info.

```
13.6.2.24 sc_seco_set_fips_mode()
```

This function configures the SECO in FIPS mode.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can do this.

## **Parameters**

| in  | ipc IPC handle |                                  |
|-----|----------------|----------------------------------|
| in  | mode           | FIPS mode                        |
| out | reason         | pointer to return failure reason |

This function permanently configures the SECO in FIPS approved mode. When in FIPS approved mode the following services will be disabled and receive a failure response:

- · Encrypted boot is not supported
- · Attestation is not supported
- · Manufacturing protection is not supported
- DTCP load
- · SHE services are not supported
- Assign JR is not supported (all JRs owned by SECO)

- · SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_NOACCESS if caller does not have SC\_R\_SYSTEM access
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See the SECO API Reference Guide for more info.

```
13.6.2.25 sc_seco_start_rng()
sc_err_t sc_seco_start_rng (
```

sc\_ipc\_t ipc,

This function starts the random number generator.

#### **Parameters**

| in  | ipc    | IPC handle                     |
|-----|--------|--------------------------------|
| out | status | pointer to return state of RNG |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

sc\_seco\_rng\_stat\_t \* status )

Return errors codes:

- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

The RNG is started automatically after all CPUs are booted. This function can be used to start earlier and to check the status.

See the SECO API Reference Guide for more info.

This function sends a generic signed message to the SECO SHE/HSM components.

## **Parameters**

| in | ipc  | IPC handle               |
|----|------|--------------------------|
| in | addr | address of message block |

## Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_UNAVAILABLE if SECO not available,
- · SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- · Others, see the Security Service Detailed Description section

Note addr must be a pointer to a signed message block.

See the SECO API Reference Guide for more info.

13.6.2.27 sc\_seco\_secvio\_enable()

This function is used to enable security violation and tamper interrupts.

These are then reported using the IRQ service via the SC\_IRQ\_SECVIO interrupt. Note it is automatically enabled at boot.

## **Parameters**

| in | ipc | IPC handle |
|----|-----|------------|
|----|-----|------------|

## Returns

Returns and error code (SC\_ERR\_NONE = success).

- SC\_ERR\_NOACCESS if caller does not own SC\_R\_SECVIO,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC ERR IPC if SECO response has bad header tag or size,

- · SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

The security violation interrupt is self-masking. Once it is cleared in the SNVS it must be re-enabled using this function.

## 13.6.2.28 sc\_seco\_secvio\_config()

This function is used to read/write SNVS security violation and tamper registers.

## **Parameters**

| in | ipc    | IPC handle                       |
|----|--------|----------------------------------|
| in | id     | register ID                      |
| in | access | 0=read, 1=write                  |
| in | data0  | pointer to data to read or write |
| in | data1  | pointer to data to read or write |
| in | data2  | pointer to data to read or write |
| in | data3  | pointer to data to read or write |
| in | data4  | pointer to data to read or write |
| in | size   | number of valid data words       |

## Returns

Returns and error code (SC\_ERR\_NONE = success).

Return errors codes:

- SC\_ERR\_NOACCESS if caller does not own SC\_R\_SECVIO,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

Unused data words can be passed a NULL pointer.

See AHAB\_MANAGE\_SNVS\_REQ in the SECO API Reference Guide for more info.

# 13.6.2.29 sc\_seco\_secvio\_dgo\_config()

This function is used to read/write SNVS security violation and tamper DGO registers.

#### **Parameters**

| in | ipc    | IPC handle                       |
|----|--------|----------------------------------|
| in | id     | regsiter ID                      |
| in | access | 0=read, 1=write                  |
| in | data   | pointer to data to read or write |

# Returns

Returns and error code (SC\_ERR\_NONE = success).

## Return errors codes:

- SC\_ERR\_NOACCESS if caller does not own SC\_R\_SECVIO,
- SC\_ERR\_UNAVAILABLE if SECO not available,
- SC\_ERR\_IPC if SECO response has bad header tag or size,
- SC\_ERR\_VERSION if SECO response has bad version,
- Others, see the Security Service Detailed Description section

See AHAB\_MANAGE\_SNVS\_DGO\_REQ in the SECO API Reference Guide for more info.

# 13.7 TIMER: Timer Service

Module for the Timer service.

# **Typedefs**

typedef uint8\_t sc\_timer\_wdog\_action\_t

This type is used to configure the watchdog action.

typedef uint32\_t sc\_timer\_wdog\_time\_t

This type is used to declare a watchdog time value in milliseconds.

# Defines for type widths

#define SC\_TIMER\_ACTION\_W 3U
 Width of sc\_timer\_wdog\_action\_t.

# Defines for sc\_timer\_wdog\_action\_t

 #define SC\_TIMER\_WDOG\_ACTION\_PARTITION 0U Reset partition.

• #define SC\_TIMER\_WDOG\_ACTION\_WARM 1U

Warm reset system.

#define SC TIMER WDOG ACTION COLD 2U

Cold reset system.

#define SC\_TIMER\_WDOG\_ACTION\_BOARD 3U

Reset board.

#define SC\_TIMER\_WDOG\_ACTION\_IRQ 4U

Only generate IRQs.

# **Watchdog Functions**

sc\_err\_t sc\_timer\_set\_wdog\_timeout (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t timeout)

This function sets the watchdog timeout in milliseconds.

sc\_err\_t sc\_timer\_set\_wdog\_pre\_timeout (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t pre\_timeout)

This function sets the watchdog pre-timeout in milliseconds.

sc\_err\_t sc\_timer\_set\_wdog\_window (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t window)

This function sets the watchdog window in milliseconds.

• sc\_err\_t sc\_timer\_start\_wdog (sc\_ipc\_t ipc, sc\_bool\_t lock)

This function starts the watchdog.

sc\_err\_t sc\_timer\_stop\_wdog (sc\_ipc\_t ipc)

This function stops the watchdog if it is not locked.

sc\_err\_t sc\_timer\_ping\_wdog (sc\_ipc\_t ipc)

This function pings (services, kicks) the watchdog resetting the time before expiration back to the timeout.

sc\_err\_t sc\_timer\_get\_wdog\_status (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t \*timeout, sc\_timer\_wdog\_time\_t \*max\_timeout, sc\_timer\_wdog\_time\_t \*remaining\_time)

This function gets the status of the watchdog.

sc\_err\_t sc\_timer\_pt\_get\_wdog\_status (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_bool\_t \*enb, sc\_timer\_wdog\_time\_t \*timeout, sc\_timer\_wdog\_time\_t t\*remaining\_time)

This function gets the status of the watchdog of a partition.

sc\_err\_t sc\_timer\_set\_wdog\_action (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_timer\_wdog\_action\_t action)

This function configures the action to be taken when a watchdog expires.

13.7 TIMER: Timer Service 223

# Real-Time Clock (RTC) Functions

sc\_err\_t sc\_timer\_set\_rtc\_time (sc\_ipc\_t ipc, uint16\_t year, uint8\_t mon, uint8\_t day, uint8\_t hour, uint8\_t min, uint8\_t sec)

This function sets the RTC time.

sc\_err\_t sc\_timer\_get\_rtc\_time (sc\_ipc\_t ipc, uint16\_t \*year, uint8\_t \*mon, uint8\_t \*day, uint8\_t \*hour, uint8\_t \*min, uint8\_t \*sec)

This function gets the RTC time.

sc\_err\_t sc\_timer\_get\_rtc\_sec1970 (sc\_ipc\_t ipc, uint32\_t \*sec)

This function gets the RTC time in seconds since 1/1/1970.

sc\_err\_t sc\_timer\_set\_rtc\_alarm (sc\_ipc\_t ipc, uint16\_t year, uint8\_t mon, uint8\_t day, uint8\_t hour, uint8\_t min, uint8\_t sec)

This function sets the RTC alarm.

sc\_err\_t sc\_timer\_set\_rtc\_periodic\_alarm (sc\_ipc\_t ipc, uint32\_t sec)

This function sets the RTC alarm (periodic mode).

sc\_err\_t sc\_timer\_cancel\_rtc\_alarm (sc\_ipc\_t ipc)

This function cancels the RTC alarm.

sc\_err\_t sc\_timer\_set\_rtc\_calb (sc\_ipc\_t ipc, int8\_t count)

This function sets the RTC calibration value.

# **System Counter (SYSCTR) Functions**

• sc\_err\_t sc\_timer\_set\_sysctr\_alarm (sc\_ipc\_t ipc, uint64\_t ticks)

This function sets the SYSCTR alarm.

• sc err t sc timer set sysctr periodic alarm (sc ipc t ipc, uint64 t ticks)

This function sets the SYSCTR alarm (periodic mode).

• sc err t sc timer cancel sysctr alarm (sc ipc t ipc)

This function cancels the SYSCTR alarm.

# 13.7.1 Detailed Description

Module for the Timer service.

This includes support for the watchdog, RTC, and system counter. Note every resource partition has a watchdog it can use.

# 13.7.2 Function Documentation

# 13.7.2.1 sc\_timer\_set\_wdog\_timeout()

This function sets the watchdog timeout in milliseconds.

If not set then the timeout defaults to the max. Once locked this value cannot be changed.

## **Parameters**

| in | ipc     | IPC handle                      |
|----|---------|---------------------------------|
| in | timeout | timeout period for the watchdog |

## Returns

Returns an error code (SC\_ERR\_NONE = success, SC\_ERR\_LOCKED = locked).

# 13.7.2.2 sc\_timer\_set\_wdog\_pre\_timeout()

This function sets the watchdog pre-timeout in milliseconds.

If not set then the pre-timeout defaults to the max. Once locked this value cannot be changed.

## **Parameters**

|   | in | ipc         | IPC handle                          |
|---|----|-------------|-------------------------------------|
| ſ | in | pre_timeout | pre-timeout period for the watchdog |

When the pre-timout expires an IRQ will be generated. Note this timeout clears when the IRQ is triggered. An IRQ is generated for the failing partition and all of its child partitions.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.3 sc\_timer\_set\_wdog\_window()

This function sets the watchdog window in milliseconds.

If not set then the window defaults to the 0. Once locked this value cannot be changed.

13.7 TIMER: Timer Service 225

## **Parameters**

| in | ipc    | IPC handle                     |
|----|--------|--------------------------------|
| in | window | window period for the watchdog |

## Returns

Returns an error code (SC\_ERR\_NONE = success, SC\_ERR\_LOCKED = locked).

Calling sc timer ping wdog() before the window time has expired will result in the watchdog action being taken.

# 13.7.2.4 sc\_timer\_start\_wdog()

This function starts the watchdog.

#### **Parameters**

| ſ | in | ipc  | IPC handle                         |
|---|----|------|------------------------------------|
|   | in | lock | boolean indicating the lock status |

## Returns

Returns an error code (SC ERR NONE = success).

## Return errors:

- · SC\_ERR\_NOACCESS if caller's partition is not isolated,
- · SC\_ERR\_BUSY if already started

If *lock* is set then the watchdog cannot be stopped or the timeout period changed.

If the calling partition is not isolated then the wdog cannot be used. This is always the case if a non-secure partition is running on the same CPU as a secure partition (e.g. Linux under TZ). See sc\_rm\_partition\_alloc().

# 13.7.2.5 sc\_timer\_stop\_wdog()

This function stops the watchdog if it is not locked.

## **Parameters**

| in <i>ipc</i> IP | C handle |
|------------------|----------|
|------------------|----------|

# Returns

Returns an error code (SC\_ERR\_NONE = success, SC\_ERR\_LOCKED = locked).

# 13.7.2.6 sc\_timer\_ping\_wdog()

This function pings (services, kicks) the watchdog resetting the time before expiration back to the timeout.

# **Parameters**

| in <i>ipc</i> | IPC handle |
|---------------|------------|
|---------------|------------|

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.7 sc\_timer\_get\_wdog\_status()

This function gets the status of the watchdog.

All arguments are in milliseconds.

## **Parameters**

| in  | ipc            | IPC handle                                         |
|-----|----------------|----------------------------------------------------|
| out | timeout        | pointer to return the timeout                      |
| out | max_timeout    | pointer to return the max timeout                  |
| out | remaining_time | pointer to return the time remaining until trigger |

13.7 TIMER: Timer Service 227

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.8 sc\_timer\_pt\_get\_wdog\_status()

This function gets the status of the watchdog of a partition.

All arguments are in milliseconds.

# **Parameters**

| in  | ipc            | IPC handle                                         |
|-----|----------------|----------------------------------------------------|
| in  | pt             | partition to query                                 |
| out | enb            | pointer to return enable status                    |
| out | timeout        | pointer to return the timeout                      |
| out | remaining_time | pointer to return the time remaining until trigger |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.9 sc\_timer\_set\_wdog\_action()

This function configures the action to be taken when a watchdog expires.

# **Parameters**

| in | ipc    | IPC handle          |
|----|--------|---------------------|
| in | pt     | partition to affect |
| in | action | action to take      |

Default action is inherited from the parent.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

## Return errors:

- · SC\_ERR\_PARM if invalid parameters,
- SC\_ERR\_NOACCESS if caller's partition is not the SYSTEM owner,
- SC\_ERR\_LOCKED if the watchdog is locked

## 13.7.2.10 sc\_timer\_set\_rtc\_time()

This function sets the RTC time.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can set the time.

## **Parameters**

| in | ipc  | IPC handle              |
|----|------|-------------------------|
| in | year | year (min 1970)         |
| in | mon  | month (1-12)            |
| in | day  | day of the month (1-31) |
| in | hour | hour (0-23)             |
| in | min  | minute (0-59)           |
| in | sec  | second (0-59)           |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

SC\_ERR\_PARM if invalid time/date parameters,

13.7 TIMER: Timer Service 229

• SC\_ERR\_NOACCESS if caller's partition cannot access SC\_R\_SYSTEM

# 13.7.2.11 sc\_timer\_get\_rtc\_time()

This function gets the RTC time.

## **Parameters**

| in  | ipc                                            | IPC handle                                |  |
|-----|------------------------------------------------|-------------------------------------------|--|
| out | year pointer to return year (min 1970)         |                                           |  |
| out | mon                                            | pointer to return month (1-12)            |  |
| out | day                                            | pointer to return day of the month (1-31) |  |
| out | hour pointer to return hour (0-23)             |                                           |  |
| out | out <i>min</i> pointer to return minute (0-59) |                                           |  |
| out | sec                                            | pointer to return second (0-59)           |  |

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.12 sc\_timer\_get\_rtc\_sec1970()

This function gets the RTC time in seconds since 1/1/1970.

# **Parameters**

| in  | ipc | IPC handle                |
|-----|-----|---------------------------|
| out | sec | pointer to return seconds |

#### Returns

Returns an error code (SC\_ERR\_NONE = success).

# 13.7.2.13 sc\_timer\_set\_rtc\_alarm()

This function sets the RTC alarm.

## **Parameters**

| in | ipc  | IPC handle              |
|----|------|-------------------------|
| in | year | year (min 1970)         |
| in | mon  | month (1-12)            |
| in | day  | day of the month (1-31) |
| in | hour | hour (0-23)             |
| in | min  | minute (0-59)           |
| in | sec  | second (0-59)           |

Note this alarm setting clears when the alarm is triggered. This is an absolute time.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

# 13.7.2.14 sc\_timer\_set\_rtc\_periodic\_alarm()

This function sets the RTC alarm (periodic mode).

13.7 TIMER: Timer Service 231

## **Parameters**

| in | ipc | IPC handle        |
|----|-----|-------------------|
| in | sec | period in seconds |

## Returns

Returns an error code (SC\_ERR\_NONE = success).

Note this is a relative time.

Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

```
13.7.2.15 sc_timer_cancel_rtc_alarm()
```

This function cancels the RTC alarm.

## **Parameters**

| in | ipc | IPC handle |
|----|-----|------------|

Note this alarm setting clears when the alarm is triggered.

Returns

Returns an error code (SC\_ERR\_NONE = success).

Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

# 13.7.2.16 sc\_timer\_set\_rtc\_calb()

This function sets the RTC calibration value.

Only the owner of the SC\_R\_SYSTEM resource or a partition with access permissions to SC\_R\_SYSTEM can set the calibration.

## **Parameters**

| in | ipc   | IPC handle                    |
|----|-------|-------------------------------|
| in | count | calibration count (-16 to 15) |

The calibration value is a 5-bit value including the sign bit, which is implemented in 2's complement. It is added or subtracted from the RTC on a periodic basis, once per 32768 cycles of the RTC clock.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

13.7.2.17 sc\_timer\_set\_sysctr\_alarm()

This function sets the SYSCTR alarm.

## **Parameters**

| in | ipc   | IPC handle            |
|----|-------|-----------------------|
| in | ticks | number of 8MHz cycles |

Note the ticks parameter is an absolute time. This alarm setting clears when the alarm is triggered.

## Returns

Returns an error code (SC ERR NONE = success).

# Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

13.7.2.18 sc\_timer\_set\_sysctr\_periodic\_alarm()

This function sets the SYSCTR alarm (periodic mode).

13.7 TIMER: Timer Service 233

# **Parameters**

| in | ipc   | IPC handle            |
|----|-------|-----------------------|
| in | ticks | number of 8MHz cycles |

Note the *ticks* parameter is a relative time.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

# 13.7.2.19 sc\_timer\_cancel\_sysctr\_alarm()

This function cancels the SYSCTR alarm.

# **Parameters**

| in <i>ipc</i> | IPC handle |
|---------------|------------|
|---------------|------------|

Note this alarm setting clears when the alarm is triggered.

# Returns

Returns an error code (SC\_ERR\_NONE = success).

# Return errors:

• SC\_ERR\_PARM if invalid time/date parameters

| 234 | Module Documentation |
|-----|----------------------|
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |
|     |                      |

# **Chapter 14**

# **File Documentation**

# 14.1 platform/config/mx8qm/pads.h File Reference

Header file used to configure SoC pad list.

## **Macros**

## **Pad Definitions**

```
    #define SC_P_SIM0_CLK 0
        DMA.SIM0.CLK, LSIO.GPIO0.IO00.
```

#define SC\_P\_SIM0\_RST 1

DMA.SIMO.RST, LSIO.GPIO0.IO01.

#define SC\_P\_SIM0\_IO 2

DMA.SIMO.IO, LSIO.GPIO0.IO02.

#define SC\_P\_SIM0\_PD 3

DMA.SIMO.PD, DMA.I2C3.SCL, LSIO.GPIO0.IO03.

#define SC\_P\_SIM0\_POWER\_EN 4

DMA.SIMO.POWER EN, DMA.I2C3.SDA, LSIO.GPIO0.IO04.

• #define SC P SIM0 GPIO0 00 5

DMA.SIMO.POWER\_EN, LSIO.GPIOO.IO05.

- #define SC\_P\_COMP\_CTL\_GPIO\_1V8\_3V3\_SIM 6
- #define SC\_P\_M40\_I2C0\_SCL 7

M40.I2C0.SCL, M40.UART0.RX, M40.GPIO0.IO02, LSIO.GPIO0.IO06.

#define SC\_P\_M40\_I2C0\_SDA 8

M40.I2C0.SDA, M40.UART0.TX, M40.GPIO0.IO03, LSIO.GPIO0.IO07.

• #define SC P M40 GPIO0 00 9

M40.GPIO0.IO00, M40.TPM0.CH0, DMA.UART4.RX, LSIO.GPIO0.IO08.

#define SC\_P\_M40\_GPIO0\_01 10

M40.GPIO0.IO01, M40.TPM0.CH1, DMA.UART4.TX, LSIO.GPIO0.IO09.

#define SC\_P\_M41\_I2C0\_SCL 11

M41.I2C0.SCL, M41.UART0.RX, M41.GPIO0.IO02, LSIO.GPIO0.IO10.

#define SC P M41 I2C0 SDA 12

M41.I2C0.SDA, M41.UART0.TX, M41.GPIO0.IO03, LSIO.GPIO0.IO11.

#define SC\_P\_M41\_GPIO0\_00 13

236 File Documentation

```
M41.GPIO0.IO00, M41.TPM0.CH0, DMA.UART3.RX, LSIO.GPIO0.IO12.

    #define SC_P_M41_GPIO0_01 14

    M41.GPIO0.IO01, M41.TPM0.CH1, DMA.UART3.TX, LSIO.GPIO0.IO13.

    #define SC P GPT0 CLK 15

    LSIO.GPT0.CLK, DMA.I2C1.SCL, LSIO.KPP0.COL4, LSIO.GPI00.IO14.

    #define SC P GPT0 CAPTURE 16

    LSIO.GPT0.CAPTURE, DMA.I2C1.SDA, LSIO.KPP0.COL5, LSIO.GPIO0.IO15.

    #define SC_P_GPT0_COMPARE 17

    LSIO.GPT0.COMPARE, LSIO.PWM3.OUT, LSIO.KPP0.COL6, LSIO.GPIO0.IO16.

    #define SC P GPT1 CLK 18

     LSIO.GPT1.CLK, DMA.I2C2.SCL, LSIO.KPP0.COL7, LSIO.GPIO0.IO17.

    #define SC P GPT1 CAPTURE 19

     LSIO.GPT1.CAPTURE, DMA.I2C2.SDA, LSIO.KPP0.ROW4, LSIO.GPIO0.IO18.

    #define SC_P_GPT1_COMPARE 20

    LSIO.GPT1.COMPARE, LSIO.PWM2.OUT, LSIO.KPP0.ROW5, LSIO.GPI00.IO19.

    #define SC P UARTO RX 21

     DMA.UARTO.RX, SCU.UARTO.RX, LSIO.GPIO0.IO20.
• #define SC_P_UART0_TX 22
     DMA.UARTO.TX, SCU.UARTO.TX, LSIO.GPIO0.IO21.

    #define SC_P_UART0_RTS_B 23

     DMA.UARTO.RTS B, LSIO.PWMO.OUT, DMA.UART2.RX, LSIO.GPIO0.IO22.

    #define SC P UART0 CTS B 24

     DMA.UARTO.CTS_B, LSIO.PWM1.OUT, DMA.UART2.TX, LSIO.GPIO0.IO23.

    #define SC_P_UART1_TX 25

     DMA.UART1.TX, DMA.SPI3.SCK, LSIO.GPI00.IO24.

    #define SC_P_UART1_RX 26

     DMA.UART1.RX, DMA.SPI3.SDO, LSIO.GPIO0.IO25.

    #define SC P UART1 RTS B 27

     DMA.UART1.RTS_B, DMA.SPI3.SDI, DMA.UART1.CTS_B, LSIO.GPI00.IO26.

    #define SC P UART1 CTS B 28

     DMA.UART1.CTS_B, DMA.SPI3.CS0, DMA.UART1.RTS_B, LSIO.GPI00.I027.
• #define SC_P_COMP_CTL_GPIO_1V8_3V3_GPIOLH 29

    #define SC P SCU PMIC MEMC ON 30

     SCU.GPIO0.IOXX PMIC MEMC ON.

    #define SC P SCU WDOG OUT 31

     SCU.WDOG0.WDOG OUT.

    #define SC P PMIC I2C SDA 32

     SCU.PMIC_I2C.SDA.

    #define SC_P_PMIC_I2C_SCL 33

     SCU.PMIC I2C.SCL.

    #define SC P PMIC EARLY WARNING 34

     SCU.PMIC_EARLY_WARNING.

    #define SC P PMIC INT B 35

     SCU.DSC.PMIC_INT_B.

    #define SC P SCU GPIO0 00 36

     SCU.GPIO0.IO00, SCU.UARTO.RX, LSIO.GPIO0.IO28.
  #define SC P SCU GPIO0 01 37
     SCU.GPIO0.IO01, SCU.UART0.TX, LSIO.GPIO0.IO29.

    #define SC P SCU GPIO0 02 38

     SCU.GPIO0.IO02, SCU.GPIO0.IOXX_PMIC_GPU0_ON, LSIO.GPIO0.IO30.

    #define SC P SCU GPIO0 03 39

     SCU.GPIO0.IO03, SCU.GPIO0.IOXX_PMIC_GPU1_ON, LSIO.GPIO0.IO31.

    #define SC P SCU GPIO0 04 40

     SCU.GPIO0.IO04, SCU.GPIO0.IOXX PMIC A72 ON, LSIO.GPIO1.IO00.
```

#define SC P SCU GPIO0 05 41

```
SCU.GPIO0.IO05, SCU.GPIO0.IOXX_PMIC_A53_ON, LSIO.GPIO1.IO01.

    #define SC P SCU GPIO0 06 42

     SCU.GPIO0.IO06, SCU.TPM0.CH0, LSIO.GPIO1.IO02.

    #define SC P SCU GPIO0 07 43

     SCU.GPIO0.IO07, SCU.TPM0.CH1, SCU.DSC.RTC_CLOCK_OUTPUT_32K, LSIO.GPIO1.IO03.

    #define SC P SCU BOOT MODE0 44

     SCU.DSC.BOOT_MODE0.
 #define SC_P_SCU_BOOT_MODE1 45
     SCU.DSC.BOOT_MODE1.

    #define SC P SCU BOOT MODE2 46

     SCU.DSC.BOOT_MODE2.

    #define SC_P_SCU_BOOT_MODE3 47

     SCU.DSC.BOOT_MODE3.

    #define SC_P_SCU_BOOT_MODE4 48

     SCU.DSC.BOOT MODE4, SCU.PMIC 12C.SCL.

    #define SC P SCU BOOT MODE5 49

     SCU.DSC.BOOT_MODE5, SCU.PMIC_I2C.SDA.

    #define SC_P_LVDS0_GPIO00 50

     LVDS0.GPIO0.IO00, LVDS0.PWM0.OUT, LSIO.GPIO1.IO04.

    #define SC_P_LVDS0_GPIO01 51

     LVDS0.GPIO0.IO01, LSIO.GPIO1.IO05.
 #define SC P LVDS0 I2C0 SCL 52
     LVDS0.I2C0.SCL, LVDS0.GPIO0.IO02, LSIO.GPIO1.IO06.
 #define SC P LVDS0 I2C0 SDA 53
     LVDS0.I2C0.SDA, LVDS0.GPIO0.IO03, LSIO.GPIO1.IO07.

    #define SC_P_LVDS0_I2C1_SCL 54

     LVDS0.I2C1.SCL, DMA.UART2.TX, LSIO.GPIO1.IO08.

    #define SC P LVDS0 I2C1 SDA 55

     LVDS0.I2C1.SDA, DMA.UART2.RX, LSIO.GPIO1.IO09.

    #define SC P LVDS1 GPIO00 56

     LVDS1.GPIO0.IO00, LVDS1.PWM0.OUT, LSIO.GPIO1.IO10.

    #define SC_P_LVDS1_GPIO01 57

     LVDS1.GPI00.I001, LSIO.GPI01.I011.

    #define SC P LVDS1 I2C0 SCL 58

     LVDS1.I2C0.SCL, LVDS1.GPIO0.IO02, LSIO.GPIO1.IO12.

    #define SC P LVDS1 I2C0 SDA 59

     LVDS1.I2C0.SDA, LVDS1.GPIO0.IO03, LSIO.GPIO1.IO13.

    #define SC_P_LVDS1_I2C1_SCL 60

     LVDS1.I2C1.SCL, DMA.UART3.TX, LSIO.GPIO1.IO14.

    #define SC P LVDS1 I2C1 SDA 61

     LVDS1.I2C1.SDA, DMA.UART3.RX, LSIO.GPIO1.IO15.

    #define SC P COMP CTL GPIO 1V8 3V3 LVDSGPIO 62

    #define SC P MIPI DSI0 I2C0 SCL 63

     MIPI_DSI0.I2C0.SCL, LSIO.GPIO1.IO16.

    #define SC P MIPI DSI0 I2C0 SDA 64

     MIPI DSI0.I2C0.SDA, LSIO.GPIO1.IO17.
 #define SC P MIPI DSI0 GPIO0 00 65
     MIPI DSI0.GPIO0.IO00, MIPI DSI0.PWM0.OUT, LSIO.GPIO1.IO18.

    #define SC P MIPI DSI0 GPIO0 01 66

     MIPI_DSI0.GPIO0.IO01, LSIO.GPIO1.IO19.

    #define SC_P_MIPI_DSI1_I2C0_SCL 67

     MIPI DSI1.I2C0.SCL, LSIO.GPIO1.IO20.

    #define SC P MIPI DSI1 I2C0 SDA 68

     MIPI DSI1.I2C0.SDA, LSIO.GPIO1.IO21.

    #define SC P MIPI DSI1 GPIO0 00 69
```

238 File Documentation

```
MIPI_DSI1.GPIO0.IO00, MIPI_DSI1.PWM0.OUT, LSIO.GPIO1.IO22.

    #define SC P MIPI DSI1 GPIO0 01 70

     MIPI_DSI1.GPIO0.IO01, LSIO.GPIO1.IO23.

    #define SC P COMP CTL GPIO 1V8 3V3 MIPIDSIGPIO 71

    #define SC P MIPI CSI0 MCLK OUT 72

     MIPI_CSI0.ACM.MCLK_OUT, LSIO.GPIO1.IO24.

    #define SC_P_MIPI_CSI0_I2C0_SCL 73

     MIPI_CSI0.I2C0.SCL, LSIO.GPIO1.IO25.

    #define SC_P_MIPI_CSI0_I2C0_SDA 74

     MIPI CSI0.I2C0.SDA, LSIO.GPIO1.IO26.

    #define SC P MIPI CSI0 GPIO0 00 75

     MIPI_CSI0.GPIO0.IO00, DMA.I2C0.SCL, MIPI_CSI1.I2C0.SCL, LSIO.GPIO1.IO27.

    #define SC P MIPI CSI0 GPIO0 01 76

     MIPI_CSI0.GPIO0.IO01, DMA.I2C0.SDA, MIPI_CSI1.I2C0.SDA, LSIO.GPIO1.IO28.

    #define SC_P_MIPI_CSI1_MCLK_OUT 77

     MIPI CSI1.ACM.MCLK OUT, LSIO.GPIO1.IO29.
 #define SC P MIPI CSI1 GPIO0 00 78
     MIPI_CSI1.GPIO0.IO00, DMA.UART4.RX, LSIO.GPIO1.IO30.
#define SC_P_MIPI_CSI1_GPIO0_01 79
     MIPI_CSI1.GPIO0.IO01, DMA.UART4.TX, LSIO.GPIO1.IO31.

    #define SC_P_MIPI_CSI1_I2C0_SCL 80

     MIPI CSI1.I2C0.SCL, LSIO.GPIO2.IO00.

    #define SC P MIPI CSI1 I2C0 SDA 81

     MIPI_CSI1.I2C0.SDA, LSIO.GPIO2.IO01.

    #define SC P HDMI TX0 TS SCL 82

     HDMI_TX0.I2C0.SCL, DMA.I2C0.SCL, LSIO.GPIO2.IO02.

    #define SC_P_HDMI_TX0_TS_SDA 83

     HDMI TX0.I2C0.SDA, DMA.I2C0.SDA, LSIO.GPIO2.IO03.
  #define SC P COMP CTL GPIO 3V3 HDMIGPIO 84
  #define SC P ESAI1 FSR 85
     AUD.ESAI1.FSR, LSIO.GPIO2.IO04.

    #define SC P ESAI1 FST 86

     AUD.ESAI1.FST, AUD.SPDIF0.EXT_CLK, LSIO.GPIO2.IO05.

    #define SC_P_ESAI1_SCKR 87

     AUD.ESAI1.SCKR, LSIO.GPIO2.IO06.

    #define SC_P_ESAI1_SCKT 88

     AUD.ESAI1.SCKT, AUD.SAI2.RXC, AUD.SPDIF0.EXT CLK, LSIO.GPIO2.IO07.

    #define SC P ESAI1 TX0 89

     AUD.ESAI1.TX0, AUD.SAI2.RXD, AUD.SPDIF0.RX, LSIO.GPIO2.IO08.

    #define SC P ESAI1 TX1 90

     AUD.ESAI1.TX1, AUD.SAI2.RXFS, AUD.SPDIF0.TX, LSIO.GPIO2.IO09.
 #define SC_P_ESAI1_TX2_RX3 91
     AUD.ESAI1.TX2 RX3, AUD.SPDIF0.RX, LSIO.GPIO2.IO10.

    #define SC P ESAI1 TX3 RX2 92

     AUD.ESAI1.TX3_RX2, AUD.SPDIF0.TX, LSIO.GPIO2.IO11.

    #define SC_P_ESAI1_TX4_RX1 93

     AUD.ESAI1.TX4_RX1, LSIO.GPIO2.IO12.

    #define SC_P_ESAI1_TX5_RX0 94

     AUD.ESAI1.TX5 RX0, LSIO.GPIO2.IO13.

    #define SC P SPDIF0 RX 95

     AUD.SPDIFO.RX, AUD.MQS.R, AUD.ACM.MCLK_IN1, LSIO.GPIO2.IO14.

    #define SC P SPDIF0 TX 96

     AUD.SPDIF0.TX, AUD.MQS.L, AUD.ACM.MCLK_OUT1, LSIO.GPIO2.IO15.

    #define SC_P_SPDIF0_EXT_CLK 97
```

AUD.SPDIF0.EXT CLK, DMA.DMA0.REQ IN0, LSIO.GPIO2.IO16.

```
    #define SC_P_SPI3_SCK 98

     DMA.SPI3.SCK. LSIO.GPI02.IO17.

    #define SC P SPI3 SDO 99

     DMA.SPI3.SDO, DMA.FTM.CH0, LSIO.GPIO2.IO18.
#define SC_P_SPI3_SDI 100
     DMA.SPI3.SDI, DMA.FTM.CH1, LSIO.GPIO2.IO19.

    #define SC_P_SPI3_CS0 101

     DMA.SPI3.CS0, DMA.FTM.CH2, LSIO.GPI02.IO20.

    #define SC P SPI3 CS1 102

     DMA.SPI3.CS1, LSIO.GPIO2.IO21.
  #define SC P COMP CTL GPIO 1V8 3V3 GPIORHB 103

    #define SC P ESAI0 FSR 104

     AUD.ESAI0.FSR, LSIO.GPIO2.IO22.
• #define SC_P_ESAI0_FST 105
     AUD.ESAI0.FST, LSIO.GPIO2.IO23.

    #define SC P ESAI0 SCKR 106

     AUD.ESAIO.SCKR, LSIO.GPIO2.IO24.

    #define SC_P_ESAI0_SCKT 107

     AUD.ESAIO.SCKT, LSIO.GPIO2.IO25.

    #define SC_P_ESAI0_TX0 108

     AUD.ESAI0.TX0, LSIO.GPIO2.IO26.

    #define SC P ESAI0 TX1 109

     AUD.ESAI0.TX1, LSIO.GPIO2.IO27.
 #define SC_P_ESAI0_TX2_RX3 110
     AUD.ESAI0.TX2_RX3, LSIO.GPIO2.IO28.
#define SC_P_ESAI0_TX3_RX2 111
     AUD.ESAI0.TX3 RX2, LSIO.GPIO2.IO29.

    #define SC P ESAI0 TX4 RX1 112

     AUD.ESAI0.TX4_RX1, LSIO.GPIO2.IO30.

    #define SC P ESAI0 TX5 RX0 113

     AUD.ESAI0.TX5_RX0, LSIO.GPIO2.IO31.

    #define SC_P_MCLK_IN0 114

     AUD.ACM.MCLK_INO, AUD.ESAIO.RX_HF_CLK, AUD.ESAI1.RX_HF_CLK, LSIO.GPIO3.IO00.

    #define SC P MCLK OUT0 115

     AUD.ACM.MCLK OUTO, AUD.ESAI0.TX HF CLK, AUD.ESAI1.TX HF CLK, LSIO.GPIO3.IO01.

    #define SC_P_COMP_CTL_GPIO_1V8_3V3_GPIORHC 116

    #define SC P SPI0 SCK 117

     DMA.SPIO.SCK, AUD.SAIO.RXC, LSIO.GPIO3.IO02.

    #define SC P SPI0 SDO 118

     DMA.SPIO.SDO, AUD.SAIO.TXD, LSIO.GPIO3.IO03.

    #define SC P SPI0 SDI 119

     DMA.SPIO.SDI, AUD.SAIO.RXD, LSIO.GPIO3.IO04.

    #define SC P SPI0 CS0 120

     DMA.SPIO.CSO, AUD.SAIO.RXFS, LSIO.GPIO3.IO05.

    #define SC P SPI0 CS1 121

     DMA.SPIO.CS1, AUD.SAIO.TXC, LSIO.GPIO3.IO06.
 #define SC P SPI2 SCK 122
     DMA.SPI2.SCK, LSIO.GPIO3.IO07.

    #define SC P SPI2 SDO 123

     DMA.SPI2.SDO, LSIO.GPIO3.IO08.

    #define SC P SPI2 SDI 124

     DMA.SPI2.SDI, LSIO.GPIO3.IO09.

    #define SC P SPI2 CS0 125

     DMA.SPI2.CS0, LSIO.GPIO3.IO10.
```

#define SC\_P\_SPI2\_CS1 126

DMA.SPI2.CS1, AUD.SAI0.TXFS, LSIO.GPIO3.IO11. #define SC\_P\_SAI1\_RXC 127 AUD.SAI1.RXC, AUD.SAI0.TXD, LSIO.GPIO3.IO12. #define SC P SAI1 RXD 128 AUD.SAI1.RXD, AUD.SAI0.TXFS, LSIO.GPIO3.IO13. #define SC\_P\_SAI1\_RXFS 129 AUD.SAI1.RXFS, AUD.SAI0.RXD, LSIO.GPIO3.IO14. #define SC\_P\_SAI1\_TXC 130 AUD.SAI1.TXC, AUD.SAI0.TXC, LSIO.GPIO3.IO15. #define SC P SAI1 TXD 131 AUD.SAI1.TXD, AUD.SAI1.RXC, LSIO.GPIO3.IO16. #define SC P SAI1 TXFS 132 AUD.SAI1.TXFS, AUD.SAI1.RXFS, LSIO.GPIO3.IO17. #define SC P COMP CTL GPIO 1V8 3V3 GPIORHT 133 #define SC\_P\_ADC\_IN7 134 DMA.ADC1.IN3, DMA.SPI1.CS1, LSIO.KPP0.ROW3, LSIO.GPIO3.IO25. #define SC P ADC IN6 135 DMA.ADC1.IN2, DMA.SPI1.CS0, LSIO.KPP0.ROW2, LSIO.GPIO3.IO24. #define SC\_P\_ADC\_IN5 136 DMA.ADC1.IN1, DMA.SPI1.SDI, LSIO.KPP0.ROW1, LSIO.GPIO3.IO23. #define SC P ADC IN4 137 DMA.ADC1.INO, DMA.SPI1.SDO, LSIO.KPP0.ROW0, LSIO.GPIO3.IO22. #define SC P ADC IN3 138 DMA.ADC0.IN3, DMA.SPI1.SCK, LSIO.KPP0.COL3, LSIO.GPIO3.IO21. #define SC P ADC IN2 139 DMA.ADC0.IN2, LSIO.KPP0.COL2, LSIO.GPIO3.IO20. #define SC P ADC IN1 140 DMA.ADCO.IN1, LSIO.KPP0.COL1, LSIO.GPIO3.IO19. #define SC P ADC IN0 141 DMA.ADC0.IN0, LSIO.KPP0.COL0, LSIO.GPIO3.IO18. #define SC\_P\_MLB\_SIG 142 CONN.MLB.SIG, AUD.SAI3.RXC, LSIO.GPIO3.IO26. #define SC\_P\_MLB\_CLK 143 CONN.MLB.CLK, AUD.SAI3.RXFS, LSIO.GPIO3.IO27. #define SC\_P\_MLB\_DATA 144 CONN.MLB.DATA, AUD.SAI3.RXD, LSIO.GPIO3.IO28. #define SC\_P\_COMP\_CTL\_GPIO\_1V8\_3V3\_GPIOLHT 145 #define SC\_P\_FLEXCAN0\_RX 146 DMA.FLEXCANO.RX, LSIO.GPIO3.IO29. #define SC\_P\_FLEXCAN0\_TX 147 DMA.FLEXCANO.TX, LSIO.GPIO3.IO30. • #define SC\_P\_FLEXCAN1\_RX 148 DMA.FLEXCAN1.RX, LSIO.GPIO3.IO31. #define SC\_P\_FLEXCAN1\_TX 149 DMA.FLEXCAN1.TX, LSIO.GPIO4.IO00. #define SC P FLEXCAN2 RX 150 DMA.FLEXCAN2.RX, LSIO.GPIO4.IO01. #define SC P FLEXCAN2 TX 151 DMA.FLEXCAN2.TX, LSIO.GPIO4.IO02. #define SC\_P\_COMP\_CTL\_GPIO\_1V8\_3V3\_GPIOTHR 152 #define SC P USB SS3 TC0 153 DMA.I2C1.SCL, CONN.USB OTG1.PWR, LSIO.GPIO4.IO03. #define SC P USB SS3 TC1 154 DMA.I2C1.SCL, CONN.USB OTG2.PWR, LSIO.GPIO4.IO04.

#define SC\_P\_USB\_SS3\_TC2 155

```
DMA.I2C1.SDA, CONN.USB_OTG1.OC, LSIO.GPIO4.IO05.

    #define SC P USB SS3 TC3 156

     DMA.I2C1.SDA, CONN.USB_OTG2.OC, LSIO.GPIO4.IO06.

    #define SC P COMP CTL GPIO 3V3 USB3IO 157

    #define SC P USDHC1 RESET B 158

     CONN.USDHC1.RESET B, LSIO.GPIO4.IO07.

    #define SC P USDHC1 VSELECT 159

     CONN.USDHC1.VSELECT, LSIO.GPIO4.IO08.

    #define SC P USDHC2 RESET B 160

     CONN.USDHC2.RESET B, LSIO.GPIO4.IO09.

    #define SC P USDHC2 VSELECT 161

     CONN.USDHC2.VSELECT, LSIO.GPIO4.IO10.

    #define SC P USDHC2 WP 162

     CONN.USDHC2.WP, LSIO.GPIO4.IO11.

    #define SC P USDHC2 CD B 163

     CONN.USDHC2.CD B, LSIO.GPIO4.IO12.

    #define SC P COMP CTL GPIO 1V8 3V3 VSELSEP 164

    #define SC P ENETO MDIO 165

     CONN.ENETO.MDIO, DMA.I2C4.SDA, LSIO.GPIO4.IO13.

    #define SC_P_ENET0_MDC 166

     CONN.ENETO.MDC, DMA.I2C4.SCL, LSIO.GPIO4.IO14.
#define SC_P_ENET0_REFCLK_125M_25M 167
     CONN.ENET0.REFCLK 125M 25M, CONN.ENET0.PPS, LSIO.GPIO4.IO15.
#define SC_P_ENET1_REFCLK_125M_25M 168
     CONN.ENET1.REFCLK 125M 25M, CONN.ENET1.PPS, LSIO.GPIO4.IO16.

    #define SC_P_ENET1_MDIO 169

     CONN.ENET1.MDIO, DMA.I2C4.SDA, LSIO.GPIO4.IO17.

    #define SC_P_ENET1_MDC 170

     CONN.ENET1.MDC, DMA.I2C4.SCL, LSIO.GPIO4.IO18.

    #define SC P COMP CTL GPIO 1V8 3V3 GPIOCT 171

    #define SC P QSPI1A SS0 B 172

     LSIO.QSPI1A.SS0_B, LSIO.GPIO4.IO19.
#define SC_P_QSPI1A_SS1_B 173
     LSIO.QSPI1A.SS1_B, LSIO.QSPI1A.SCLK2, LSIO.GPIO4.IO20.

    #define SC_P_QSPI1A_SCLK 174

     LSIO.QSPI1A.SCLK, LSIO.GPI04.I021.

    #define SC P QSPI1A DQS 175

     LSIO.QSPI1A.DQS, LSIO.GPIO4.IO22.

    #define SC P QSPI1A DATA3 176

     LSIO.QSPI1A.DATA3, DMA.I2C1.SDA, CONN.USB_OTG1.OC, LSIO.GPIO4.IO23.

    #define SC P QSPI1A DATA2 177

     LSIO.QSPI1A.DATA2, DMA.I2C1.SCL, CONN.USB_OTG2.PWR, LSIO.GPI04.I024.

    #define SC P QSPI1A DATA1 178

     LSIO.QSPI1A.DATA1, DMA.I2C1.SDA, CONN.USB_OTG2.OC, LSIO.GPIO4.IO25.

    #define SC_P_QSPI1A_DATA0 179

     LSIO.QSPI1A.DATA0, LSIO.GPIO4.IO26.
#define SC_P_COMP_CTL_GPIO_1V8_3V3_QSPI1 180
 #define SC P QSPI0A DATA0 181
     LSIO.QSPI0A.DATA0.

    #define SC P QSPI0A DATA1 182

     LSIO.QSPI0A.DATA1.

    #define SC P QSPI0A DATA2 183

     LSIO.QSPI0A.DATA2.

    #define SC P QSPI0A DATA3 184

     LSIO.QSPI0A.DATA3.
```

```
    #define SC_P_QSPI0A_DQS 185

     LSIO.QSPI0A.DQS.

    #define SC P QSPI0A SS0 B 186

     LSIO.QSPIOA.SSO_B.

    #define SC_P_QSPI0A_SS1_B 187

     LSIO.QSPI0A.SS1_B, LSIO.QSPI0A.SCLK2.

    #define SC_P_QSPI0A_SCLK 188

     LSIO.QSPI0A.SCLK.

    #define SC P QSPI0B SCLK 189

     LSIO.QSPI0B.SCLK.

    #define SC_P_QSPI0B_DATA0 190

     LSIO.QSPI0B.DATA0.

    #define SC P QSPI0B DATA1 191

     LSIO.QSPI0B.DATA1.
 #define SC P QSPI0B DATA2 192
     LSIO.QSPI0B.DATA2.

    #define SC P QSPI0B DATA3 193

     LSIO.QSPI0B.DATA3.

    #define SC_P_QSPI0B_DQS 194

     LSIO.QSPI0B.DQS.

    #define SC P QSPI0B SS0 B 195

     LSIO.QSPI0B.SS0 B.

    #define SC P QSPI0B SS1 B 196

     LSIO.QSPI0B.SS1 B, LSIO.QSPI0B.SCLK2.

    #define SC P COMP CTL GPIO 1V8 3V3 QSPI0 197

    #define SC_P_PCIE_CTRL0_CLKREQ_B 198

     HSIO.PCIE0.CLKREQ B, LSIO.GPIO4.IO27.

    #define SC_P_PCIE_CTRL0_WAKE_B 199

     HSIO.PCIE0.WAKE B, LSIO.GPIO4.IO28.

    #define SC_P_PCIE_CTRL0_PERST_B 200

     HSIO.PCIE0.PERST B, LSIO.GPIO4.IO29.

    #define SC P PCIE CTRL1 CLKREQ B 201

     HSIO.PCIE1.CLKREQ B, DMA.I2C1.SDA, CONN.USB OTG2.OC, LSIO.GPIO4.IO30.

    #define SC P PCIE CTRL1 WAKE B 202

     HSIO.PCIE1.WAKE_B, DMA.I2C1.SCL, CONN.USB_OTG2.PWR, LSIO.GPIO4.IO31.

    #define SC_P_PCIE_CTRL1_PERST_B 203

     HSIO.PCIE1.PERST_B, DMA.I2C1.SCL, CONN.USB_OTG1.PWR, LSIO.GPIO5.IO00.

    #define SC_P_COMP_CTL_GPIO_1V8_3V3_PCIESEP 204

 #define SC P USB HSIC0 DATA 205
     CONN.USB_HSICO.DATA, DMA.I2C1.SDA, LSIO.GPIO5.IO01.

    #define SC P USB HSIC0 STROBE 206

     CONN.USB_HSICO.STROBE, DMA.I2C1.SCL, LSIO.GPIO5.IO02.

    #define SC P CALIBRATION 0 HSIC 207

    #define SC_P_CALIBRATION_1_HSIC 208

    #define SC P EMMC0 CLK 209

     CONN.EMMCO.CLK, CONN.NAND.READY_B.
  #define SC_P_EMMC0_CMD 210
     CONN.EMMCO.CMD, CONN.NAND.DQS, AUD.MQS.R, LSIO.GPIO5.IO03.
  #define SC P EMMC0 DATA0 211
     CONN.EMMCO.DATAO, CONN.NAND.DATAOO, LSIO.GPIO5.IO04.
  #define SC P EMMC0 DATA1 212
     CONN.EMMCO.DATA1, CONN.NAND.DATA01, LSIO.GPIO5.IO05.

    #define SC P EMMC0 DATA2 213

     CONN.EMMCO.DATA2, CONN.NAND.DATA02, LSIO.GPIO5.IO06.

    #define SC P EMMC0 DATA3 214
```

```
CONN.EMMC0.DATA3, CONN.NAND.DATA03, LSIO.GPIO5.IO07.

    #define SC P EMMC0 DATA4 215

     CONN.EMMC0.DATA4, CONN.NAND.DATA04, LSIO.GPIO5.IO08.

    #define SC P EMMC0 DATA5 216

     CONN.EMMCO.DATA5, CONN.NAND.DATA05, LSIO.GPIO5.IO09.

    #define SC_P_EMMC0_DATA6 217

     CONN.EMMCO.DATA6, CONN.NAND.DATA06, LSIO.GPIO5.IO10.

    #define SC_P_EMMC0_DATA7 218

     CONN.EMMCO.DATA7, CONN.NAND.DATA07, LSIO.GPIO5.IO11.

    #define SC P EMMC0 STROBE 219

     CONN.EMMC0.STROBE, CONN.NAND.CLE, LSIO.GPIO5.IO12.

    #define SC P EMMC0 RESET B 220

     CONN.EMMCO.RESET B, CONN.NAND.WP B, CONN.USDHC1.VSELECT, LSIO.GPIO5.IO13.
#define SC_P_COMP_CTL_GPIO_1V8_3V3_SD1FIX 221

    #define SC P USDHC1 CLK 222

    CONN.USDHC1.CLK. AUD.MQS.R.
• #define SC_P_USDHC1_CMD 223
     CONN.USDHC1.CMD, AUD.MQS.L, LSIO.GPIO5.IO14.

    #define SC_P_USDHC1_DATA0 224

     CONN.USDHC1.DATA0, CONN.NAND.RE_N, LSIO.GPIO5.IO15.

    #define SC P USDHC1 DATA1 225

     CONN.USDHC1.DATA1, CONN.NAND.RE_P, LSIO.GPIO5.IO16.

    #define SC_P_CTL_NAND_RE_P_N 226

    #define SC P USDHC1 DATA2 227

     CONN.USDHC1.DATA2, CONN.NAND.DQS_N, LSIO.GPIO5.IO17.

    #define SC_P_USDHC1_DATA3 228

     CONN.USDHC1.DATA3, CONN.NAND.DQS P, LSIO.GPIO5.IO18.

    #define SC P CTL NAND DQS P N 229

    #define SC P USDHC1 DATA4 230

     CONN.USDHC1.DATA4, CONN.NAND.CE0_B, AUD.MQS.R, LSIO.GPIO5.IO19.
 #define SC P USDHC1 DATA5 231
     CONN.USDHC1.DATA5, CONN.NAND.RE_B, AUD.MQS.L, LSIO.GPIO5.IO20.

    #define SC_P_USDHC1_DATA6 232

     CONN.USDHC1.DATA6, CONN.NAND.WE B, CONN.USDHC1.WP, LSIO.GPIO5.IO21.

    #define SC P USDHC1 DATA7 233

     CONN.USDHC1.DATA7, CONN.NAND.ALE, CONN.USDHC1.CD_B, LSIO.GPIO5.IO22.

    #define SC_P_USDHC1_STROBE 234

     CONN.USDHC1.STROBE, CONN.NAND.CE1 B, CONN.USDHC1.RESET B, LSIO.GPIO5.IO23.
#define SC_P_COMP_CTL_GPIO_1V8_3V3_VSEL2 235

    #define SC_P_USDHC2_CLK 236

    CONN.USDHC2.CLK, AUD.MQS.R, LSIO.GPIO5.IO24.

    #define SC P USDHC2 CMD 237

     CONN.USDHC2.CMD, AUD.MQS.L, LSIO.GPIO5.IO25.

    #define SC P USDHC2 DATA0 238

     CONN.USDHC2.DATA0, DMA.UART4.RX, LSIO.GPIO5.IO26.

    #define SC_P_USDHC2_DATA1 239

     CONN.USDHC2.DATA1, DMA.UART4.TX, LSIO.GPIO5.IO27.

    #define SC P USDHC2 DATA2 240

     CONN.USDHC2.DATA2, DMA.UART4.CTS_B, LSIO.GPIO5.IO28.
• #define SC_P_USDHC2_DATA3 241
     CONN.USDHC2.DATA3, DMA.UART4.RTS_B, LSIO.GPIO5.IO29.

    #define SC P COMP CTL GPIO 1V8 3V3 VSEL3 242

    #define SC P ENETO RGMII TXC 243

     CONN.ENETO.RGMII TXC, CONN.ENETO.RCLK50M OUT, CONN.ENETO.RCLK50M IN, LSIO.GPIO5.IO30.

    #define SC P ENETO RGMII TX CTL 244
```

```
CONN.ENET0.RGMII_TX_CTL, LSIO.GPIO5.IO31.

    #define SC_P_ENET0_RGMII_TXD0 245

     CONN.ENETO.RGMII_TXD0, LSIO.GPIO6.IO00.

    #define SC P ENETO RGMII TXD1 246

     CONN.ENET0.RGMII TXD1, LSIO.GPIO6.IO01.

    #define SC_P_ENET0_RGMII_TXD2 247

     CONN.ENET0.RGMII_TXD2, DMA.UART3.TX, VPU.TSI_S1.VID, LSIO.GPIO6.IO02.

    #define SC P ENETO RGMII TXD3 248

     CONN.ENETO.RGMII_TXD3, DMA.UART3.RTS_B, VPU.TSI_S1.SYNC, LSIO.GPIO6.IO03.

    #define SC_P_ENET0_RGMII_RXC 249

     CONN.ENETO.RGMII_RXC, DMA.UART3.CTS_B, VPU.TSI_S1.DATA, LSIO.GPIO6.IO04.

    #define SC P ENETO RGMII RX CTL 250

     CONN.ENET0.RGMII_RX_CTL, VPU.TSI_S0.VID, LSIO.GPIO6.IO05.

    #define SC_P_ENET0_RGMII_RXD0 251

     CONN.ENETO.RGMII RXDO, VPU.TSI SO.SYNC, LSIO.GPIO6.IO06.

    #define SC P ENET0 RGMII RXD1 252

     CONN.ENET0.RGMII_RXD1, VPU.TSI_S0.DATA, LSIO.GPIO6.IO07.

    #define SC P ENET0 RGMII RXD2 253

     CONN.ENETO.RGMII_RXD2, CONN.ENETO.RMII_RX_ER, VPU.TSI_SO.CLK, LSIO.GPIO6.IO08.

    #define SC_P_ENET0_RGMII_RXD3 254

     CONN.ENETO.RGMII RXD3, DMA.UART3.RX, VPU.TSI S1.CLK, LSIO.GPIO6.IO09.

    #define SC_P_COMP_CTL_GPIO_1V8_3V3_ENET_ENETB 255

    #define SC P ENET1 RGMII TXC 256

     CONN.ENET1.RGMII_TXC, CONN.ENET1.RCLK50M_OUT, CONN.ENET1.RCLK50M_IN, LSIO.GPIO6.IO10.
 #define SC_P_ENET1_RGMII_TX_CTL 257
     CONN.ENET1.RGMII TX CTL, LSIO.GPIO6.IO11.

    #define SC_P_ENET1_RGMII_TXD0 258

     CONN.ENET1.RGMII_TXD0, LSIO.GPIO6.IO12.

    #define SC_P_ENET1_RGMII_TXD1 259

     CONN.ENET1.RGMII TXD1, LSIO.GPIO6.IO13.

    #define SC P ENET1 RGMII TXD2 260

     CONN.ENET1.RGMII_TXD2, DMA.UART3.TX, VPU.TSI_S1.VID, LSIO.GPIO6.IO14.

    #define SC P ENET1 RGMII TXD3 261

     CONN.ENET1.RGMII TXD3, DMA.UART3.RTS B, VPU.TSI S1.SYNC, LSIO.GPIO6.IO15.

    #define SC P ENET1 RGMII RXC 262

     CONN.ENET1.RGMII_RXC, DMA.UART3.CTS_B, VPU.TSI_S1.DATA, LSIO.GPIO6.IO16.

    #define SC_P_ENET1_RGMII_RX_CTL 263

     CONN.ENET1.RGMII_RX_CTL, VPU.TSI_S0.VID, LSIO.GPIO6.IO17.

    #define SC P ENET1 RGMII RXD0 264

     CONN.ENET1.RGMII RXD0, VPU.TSI S0.SYNC, LSIO.GPIO6.IO18.

    #define SC P ENET1 RGMII RXD1 265

     CONN.ENET1.RGMII_RXD1, VPU.TSI_S0.DATA, LSIO.GPIO6.IO19.

    #define SC_P_ENET1_RGMII_RXD2 266

     CONN.ENET1.RGMII RXD2, CONN.ENET1.RMII RX ER, VPU.TSI S0.CLK, LSIO.GPIO6.IO20.

    #define SC_P_ENET1_RGMII_RXD3 267

     CONN.ENET1.RGMII_RXD3, DMA.UART3.RX, VPU.TSI_S1.CLK, LSIO.GPIO6.IO21.

    #define SC_P_COMP_CTL_GPIO_1V8_3V3_ENET_ENETA 268
```

#### 14.1.1 Detailed Description

Header file used to configure SoC pad list.

## 14.2 platform/main/ipc.h File Reference

Header file for the IPC implementation.

## **Functions**

```
• sc_err_t sc_ipc_open (sc_ipc_t *ipc, sc_ipc_id_t id)
```

This function opens an IPC channel.

void sc\_ipc\_close (sc\_ipc\_t ipc)

This function closes an IPC channel.

• void sc\_ipc\_read (sc\_ipc\_t ipc, void \*data)

This function reads a message from an IPC channel.

void sc\_ipc\_write (sc\_ipc\_t ipc, const void \*data)

This function writes a message to an IPC channel.

## 14.2.1 Detailed Description

Header file for the IPC implementation.

## 14.2.2 Function Documentation

```
14.2.2.1 sc_ipc_open()
```

This function opens an IPC channel.

#### **Parameters**

| out | ipc | return pointer for ipc handle |
|-----|-----|-------------------------------|
| in  | id  | id of channel to open         |

## Returns

Returns an error code (SC ERR NONE = success, SC ERR IPC otherwise).

The id parameter is implementation specific. Could be an MU address, pointer to a driver path, channel index, etc.

```
14.2.2.2 sc_ipc_close()
```

This function closes an IPC channel.

#### **Parameters**

| in | ipc | id of channel to close |
|----|-----|------------------------|
|----|-----|------------------------|

## 14.2.2.3 sc\_ipc\_read()

This function reads a message from an IPC channel.

#### **Parameters**

| in  | ipc  | id of channel read from           |
|-----|------|-----------------------------------|
| out | data | pointer to message buffer to read |

This function will block if no message is available to be read.

## 14.2.2.4 sc\_ipc\_write()

This function writes a message to an IPC channel.

#### **Parameters**

| in | ipc  | id of channel to write to          |
|----|------|------------------------------------|
| in | data | pointer to message buffer to write |

This function will block if the outgoing buffer is full.

# 14.3 platform/main/types.h File Reference

Header file containing types used across multiple service APIs.

## **Macros**

• #define SC\_R\_NONE 0xFFF0U

Define for ATF/Linux.

#define SC\_C\_TEMP 0U

Defines for sc\_ctrl\_t.

- #define SC\_C\_TEMP\_HI 1U
- #define SC\_C\_TEMP\_LOW 2U
- #define SC\_C\_PXL\_LINK\_MST1\_ADDR 3U
- #define SC\_C\_PXL\_LINK\_MST2\_ADDR 4U
- #define SC C PXL LINK MST ENB 5U
- #define SC\_C\_PXL\_LINK\_MST1\_ENB 6U
- #define SC\_C\_PXL\_LINK\_MST2\_ENB 7U
- #define SC C PXL LINK SLV1 ADDR 8U
- #define SC\_C\_PXL\_LINK\_SLV2\_ADDR 9U
- #define SC\_C\_PXL\_LINK\_MST\_VLD 10U
- #define SC C PXL LINK MST1 VLD 11U
- #define SC C PXL LINK MST2 VLD 12U
- #define SC C SINGLE MODE 13U
- #define SC C ID 14U
- #define SC\_C\_PXL\_CLK\_POLARITY 15U
- #define SC\_C\_LINESTATE 16U
- #define SC C PCIE G RST 17U
- #define SC\_C\_PCIE\_BUTTON\_RST 18U
- #define SC\_C\_PCIE\_PERST 19U
- #define SC\_C\_PHY\_RESET 20U
- #define SC\_C\_PXL\_LINK\_RATE\_CORRECTION 21U
- #define SC\_C\_PANIC 22U
- #define SC C PRIORITY GROUP 23U
- #define SC C TXCLK 24U
- #define SC C CLKDIV 25U
- #define SC\_C\_DISABLE\_50 26U
- #define SC\_C\_DISABLE\_125 27U
- #define SC\_C\_SEL\_125 28U
- #define SC\_C\_MODE 29U
- #define SC\_C\_SYNC\_CTRL0 30U
- #define SC C KACHUNK CNT 31U
- #define SC C KACHUNK SEL 32U
- #define SC\_C\_SYNC\_CTRL1 33U
- #define SC\_C\_DPI\_RESET 34U
- #define SC C MIPI RESET 35U
- #define SC\_C\_DUAL\_MODE 36U
- #define SC\_C\_VOLTAGE 37U
- #define SC C PXL LINK SEL 38U
- #define SC C OFS SEL 39U
- #define SC\_C\_OFS\_AUDIO 40U
- #define SC\_C\_OFS\_PERIPH 41U
- #define SC\_C\_OFS\_IRQ 42U
- #define SC\_C\_RST0 43U
- #define SC\_C\_RST1 44U
- #define SC C SEL0 45U
- #define SC\_C\_CALIB0 46U
- #define SC\_C\_CALIB1 47U
- #define SC\_C\_CALIB2 48U
- #define SC\_C\_IPG\_DEBUG 49U
- #define SC C IPG DOZE 50U
- #define SC C IPG WAIT 51U

- #define SC\_C\_IPG\_STOP 52U
- #define SC\_C\_IPG\_STOP\_MODE 53U
- #define SC\_C\_IPG\_STOP\_ACK 54U
- #define SC\_C\_SYNC\_CTRL 55U
- #define SC C OFS AUDIO ALT 56U
- #define SC C DSP BYP 57U
- #define SC C CLK GEN EN 58U
- #define SC\_C\_INTF\_SEL 59U
- #define SC\_C\_RXC\_DLY 60U
- #define SC\_C\_TIMER\_SEL 61U
- #define SC\_C\_MISC0 62U
- #define SC C MISC1 63U
- #define SC C MISC2 64U
- #define SC C MISC3 65U
- #define SC\_C\_LAST 66U
- #define SC\_P\_ALL ((sc\_pad\_t) UINT16\_MAX)

Define for used to specify all pads.

## **Defines for chip IDs**

- #define CHIP\_ID\_QM 0x1U
   i.MX8QM
- #define CHIP\_ID\_QX 0x2U
  - i.MX8QX
- #define CHIP\_ID\_DXL 0xEU
   i.MX8DXL

## **Defines for common frequencies**

- #define SC\_32KHZ 32768U
  - 32KHz
- #define SC\_1MHZ 1000000U
   1MHz
- #define SC\_10MHZ 10000000U
  - 10MHz
- #define SC\_16MHZ 16000000U
  - 16MHz
- #define SC\_20MHZ 20000000U
  - 20MHz
- #define SC\_25MHZ 25000000U
  - 25MHz
- #define SC\_27MHZ 27000000U
  - 27MHz
- #define SC\_40MHZ 40000000U
  - 40MHz
- #define SC\_45MHZ 45000000U
  - 45MHz
- #define SC\_50MHZ 50000000U
  - 50MHz
- #define SC\_60MHZ 60000000U
  - 60MHz

- #define SC\_66MHZ 6666666U
   66MHz
- #define SC\_74MHZ 74250000U 74.25MHz
- #define SC\_80MHZ 80000000U 80MHz
- #define SC\_83MHZ 833333333U
   83MHz
- #define SC\_84MHZ 84375000U 84.37MHz
- #define SC\_100MHZ 100000000U 100MHz
- #define SC\_114MHZ 114000000U
   114MHz
- #define SC\_125MHZ 125000000U
   125MHz
- #define SC\_128MHZ 128000000U
   128MHz
- #define SC\_133MHZ 133333333U
   133MHz
- #define SC\_135MHZ 135000000U 135MHz
- #define SC\_150MHZ 150000000U
   150MHz
- #define SC\_160MHZ 160000000U
   160MHz
- #define SC\_166MHZ 166666666U
   166MHz
- #define SC\_175MHZ 175000000U
   175MHz
- #define SC\_180MHZ 180000000U 180MHz
- #define SC\_200MHZ 200000000U
   200MHz
- #define SC\_250MHZ 250000000U 250MHz
- #define SC\_266MHZ 266666666U
   266MHz
- #define SC\_300MHZ 300000000U 300MHz
- #define SC\_312MHZ 312500000U 312.5MHZ
- #define SC\_320MHZ 320000000U 320MHz
- #define SC\_325MHZ 325000000U 325MHz
- #define SC\_333MHZ 3333333333
- #define SC\_350MHZ 350000000U 350MHz
- #define SC\_372MHZ 372000000U 372MHz
- #define SC\_375MHZ 375000000U 375MHz
- #define SC 400MHZ 400000000U

400MHz • #define SC\_465MHZ 465000000U 465MHz #define SC\_500MHZ 500000000U 500MHz #define SC\_594MHZ 594000000U 594MHz #define SC\_625MHZ 625000000U 625MHz #define SC 640MHZ 640000000U 640MHz #define SC\_648MHZ 648000000U 648MHz #define SC\_650MHZ 650000000U 650MHz #define SC\_667MHZ 66666667U 667MHz #define SC\_675MHZ 675000000U 675MHz #define SC\_700MHZ 700000000U 700MHz • #define SC\_720MHZ 720000000U 720MHz #define SC\_750MHZ 750000000U 750MHz #define SC\_753MHZ 753000000U 753MHz #define SC\_793MHZ 793000000U 793MHz #define SC\_800MHZ 800000000U 800MHz • #define SC\_850MHZ 850000000U 850MHz #define SC\_858MHZ 858000000U 858MHz #define SC\_900MHZ 900000000U 900MHz #define SC\_953MHZ 953000000U 953MHz #define SC\_963MHZ 963000000U 963MHz #define SC\_1000MHZ 1000000000U #define SC\_1060MHZ 1060000000U 1.06GHz • #define SC\_1068MHZ 1068000000U 1.068GHz #define SC\_1121MHZ 1121000000U 1.121GHz #define SC\_1173MHZ 1173000000U 1.173GHz #define SC\_1188MHZ 1188000000U 1.188GHz #define SC 1260MHZ 1260000000U

1.26GHz

- #define SC\_1278MHZ 1278000000U 1.278GHz
- #define SC\_1280MHZ 1280000000U
   1.28GHz
- #define SC\_1300MHZ 130000000U
   1.3GHz
- #define SC\_1313MHZ 1313000000U
   1.313GHz
- #define SC\_1345MHZ 1345000000U
   1.345GHz
- #define SC\_1400MHZ 140000000U
   1.4GHz
- #define SC\_1500MHZ 1500000000U
   1.5GHz
- #define SC\_1600MHZ 1600000000U
   1.6GHz
- #define SC\_1800MHZ 1800000000U
   1.8GHz
- #define SC\_1860MHZ 1860000000U
   1.86GHz
- #define SC\_2000MHZ 2000000000U
   2.0GHz
- #define SC\_2112MHZ 2112000000U
   2.12GHz

#### **Defines for 24M related frequencies**

- #define SC\_8MHZ 8000000U
  - 8MHz
- #define SC\_12MHZ 12000000U
   12MHz
- #define SC\_19MHZ 19800000U
   19.8MHz
- #define SC\_24MHZ 24000000U 24MHz
- #define SC\_48MHZ 48000000U 48MHz
- #define SC\_120MHZ 120000000U 120MHz
- #define SC\_132MHZ 132000000U
- #define SC\_144MHZ 144000000U
   144MHz
- #define SC\_192MHZ 192000000U
   192MHz
- #define SC\_211MHZ 211200000U 211.2MHz
- #define SC\_228MHZ 228000000U
- #define SC\_240MHZ 240000000U 240MHz
- #define SC\_264MHZ 264000000U 264MHz
- #define SC\_352MHZ 352000000U

352MHz #define SC 360MHZ 360000000U 360MHz #define SC\_384MHZ 384000000U 384MHz #define SC\_396MHZ 396000000U 396MHz #define SC\_432MHZ 432000000U 432MHz #define SC 456MHZ 456000000U 466MHz #define SC 480MHZ 480000000U 480MHz #define SC 600MHZ 600000000U 600MHz #define SC\_744MHZ 744000000U #define SC\_792MHZ 792000000U 792MHz #define SC 864MHZ 864000000U 864MHz #define SC\_912MHZ 912000000U #define SC\_960MHZ 960000000U 960MHz #define SC\_1056MHZ 1056000000U 1056MHz #define SC\_1104MHZ 1104000000U 1104MHz #define SC\_1200MHZ 1200000000U 1.2GHz #define SC\_1464MHZ 1464000000U 1.464GHz #define SC\_2400MHZ 2400000000U 2.4GHz

## Defines for A/V related frequencies

#define SC\_62MHZ 62937500U
 62.9375MHz
 #define SC\_755MHZ 755250000U
 755.25MHz

## Defines for type widths

#define SC\_BOOL\_W 1U

Width of sc\_bool\_t.
#define SC\_ERR\_W 4U

Width of sc\_err\_t.
#define SC\_RSRC\_W 10U

Width of sc\_rsrc\_t.
#define SC\_CTRL\_W 7U

Width of sc\_ctrl\_t.

## Defines for sc\_bool\_t

- #define SC\_FALSE ((sc\_bool\_t) 0U)
  - False.
- #define SC TRUE ((sc bool t) 1U) True.

## Defines for sc\_err\_t

- #define SC\_ERR\_NONE 0U
  - Success.
- #define SC ERR VERSION 1U
  - Incompatible API version.
- #define SC ERR CONFIG 2U
  - Configuration error.
- #define SC\_ERR\_PARM 3U
  - Bad parameter.
- #define SC ERR NOACCESS 4U
  - Permission error (no access)
- #define SC ERR LOCKED 5U
  - Permission error (locked)
- #define SC\_ERR\_UNAVAILABLE 6U
  - Unavailable (out of resources)
- #define SC\_ERR\_NOTFOUND 7U
  - Not found.
- #define SC ERR NOPOWER 8U
  - No power.
- #define SC\_ERR\_IPC 9U
  - Generic IPC error.
- #define SC\_ERR\_BUSY 10U
  - Resource is currently busy/active.
- #define SC ERR FAIL 11U
  - General I/O failure.
- #define SC ERR LAST 12U

## Defines for sc\_rsrc\_t

- #define SC R A53 0U
- #define **SC\_R\_A53\_0** 1U
- #define **SC\_R\_A53\_1** 2U
- #define **SC\_R\_A53\_2** 3U
- #define **SC\_R\_A53\_3** 4U
- #define SC\_R\_A72 5U #define **SC\_R\_A72\_0** 6U
- #define **SC\_R\_A72\_1** 7U
- #define SC R A72 28U
- #define SC R A72 3 9U
- #define SC R CCI 10U
- #define SC R DB 11U
- #define SC\_R\_DRC\_0 12U
- #define SC R DRC 1 13U • #define SC\_R\_GIC\_SMMU 14U
- #define SC R IRQSTR M4 0 15U
- #define SC\_R\_IRQSTR\_M4\_1 16U
- #define SC\_R\_SMMU 17U

- #define SC\_R\_GIC 18U
- #define SC\_R\_DC\_0\_BLIT0 19U
- #define SC R DC 0 BLIT1 20U
- #define SC\_R\_DC\_0\_BLIT2 21U
- #define SC R DC 0 BLIT OUT 22U
- #define SC\_R\_PERF 23U
- #define SC\_R\_USB\_1\_PHY 24U
- #define SC\_R\_DC\_0\_WARP 25U
- #define SC\_R\_V2X\_MU\_0 26U
- #define SC\_R\_V2X\_MU\_1 27U
- #define SC\_R\_DC\_0\_VIDEO0 28U
- #define SC\_R\_DC\_0\_VIDEO1 29U
- #define SC\_R\_DC\_0\_FRAC0 30U
- #define SC R V2X MU 2 31U
- #define SC R DC 0 32U
- #define SC R GPU 2 PID0 33U
- #define SC R DC 0 PLL 0 34U
- #define SC\_R\_DC\_0\_PLL\_1 35U
- #define SC\_R\_DC\_1\_BLIT0 36U
- #define SC\_R\_DC\_1\_BLIT1 37U
  #define SC R DC 1 BLIT2 38U
- #define SC R DC 1 BLIT OUT 39U
- #define SC R V2X MU 3 40U
- #define SC R V2X MU 4 41U
- #define SC\_R\_DC\_1\_WARP 42U
- #define SC\_R\_UNUSED1 43U
- #define SC\_R\_SECVIO 44U
- #define SC R DC 1 VIDEO0 45U
- #define SC\_R\_DC\_1\_VIDEO1 46U
- #define SC R DC 1 FRAC0 47U
- #define SC R UNUSED13 48U
- #define SC R DC 1 49U
- #define SC R UNUSED14 50U
- #define SC R DC 1 PLL 0 51U
- #define SC R DC 1 PLL 1 52U
- #define SC\_R\_SPI\_0 53U
- #define SC\_R\_SPI\_1 54U
- #define **SC\_R\_SPI\_2** 55U
- #define SC R SPI 3 56U
- #define SC\_R\_UART\_0 57U
- #define SC\_R\_UART\_1 58U
- #define SC\_R\_UART\_2 59U
- #define SC\_R\_UART\_3 60U
- #define SC\_R\_UART\_4 61U
- #define SC\_R\_EMVSIM\_0 62U
- #define SC\_R\_EMVSIM\_1 63U
- #define SC\_R\_DMA\_0\_CH0 64U
- #define SC\_R\_DMA\_0\_CH1 65U
- #define SC\_R\_DMA\_0\_CH2 66U
  #define SC\_R\_DMA\_0\_CH3 67U
- #define SC R DMA 0 CH4 68U
- #define SC\_R\_DMA\_0\_CH4 680
   #define SC\_R\_DMA\_0\_CH5 69U
- #define SC R DMA 0 CH6 70U
- #define SC R DMA 0 CH7 71U
- #define SC\_R\_DMA\_0\_CH8 72U
- #define SC R DMA 0 CH9 73U
- #define SC R DMA 0 CH10 74U
- #define SC R DMA 0 CH11 75U
- #define SC R DMA 0 CH12 76U
- #define SC R DMA 0 CH13 77U

- #define SC\_R\_DMA\_0\_CH14 78U
- #define SC\_R\_DMA\_0\_CH15 79U
- #define SC R DMA 0 CH16 80U
- #define SC\_R\_DMA\_0\_CH17 81U
- #define SC R DMA 0 CH18 82U
- #define SC\_R\_DMA\_0\_CH19 83U
- #define SC\_R\_DMA\_0\_CH20 84U
- #define SC\_R\_DMA\_0\_CH21 85U
- #define SC\_R\_DMA\_0\_CH22 86U
- #define SC\_R\_DMA\_0\_CH23 87U
- #define SC\_R\_DMA\_0\_CH24 88U
- #define SC\_R\_DMA\_0\_CH25 89U
- #define SC R DMA 0 CH26 90U
- #define SC R DMA 0 CH27 91U
- #define SC R DMA 0 CH28 92U
- #define SC R DMA 0 CH29 93U
- #define SC R DMA 0 CH30 94U
- #define SC R DMA 0 CH31 95U
- #define SC\_R\_I2C\_0 96U
- #define **SC R I2C 1** 97U
- #define SC R I2C 298U
- #define **SC R I2C 3** 99U
- #define SC R I2C 4 100U
- #define SC R ADC 0 101U
- #define SC\_R\_ADC\_1 102U
- #define SC\_R\_FTM\_0 103U
- #define SC\_R\_FTM\_1 104U
- #define SC R CAN 0 105U
- #define SC R CAN 1 106U
- #define SC\_R\_CAN\_2 107U
- #define SC R DMA 1 CH0 108U
- #define SC R DMA 1 CH1 109U
- #define SC R DMA 1 CH2 110U
- #define SC R DMA 1 CH3 111U
- #define SC R DMA 1 CH4 112U
- #define SC\_R\_DMA\_1\_CH5 113U #define SC R DMA 1 CH6 114U
- #define SC\_R\_DMA\_1\_CH7 115U
- #define SC R DMA 1 CH8 116U
- #define SC\_R\_DMA\_1\_CH9 117U
- #define SC R DMA 1 CH10 118U
- #define SC\_R\_DMA\_1\_CH11 119U
- #define SC\_R\_DMA\_1\_CH12 120U
- #define **SC\_R\_DMA\_1\_CH13** 121U
- #define SC\_R\_DMA\_1\_CH14 122U #define SC\_R\_DMA\_1\_CH15 123U
- #define SC\_R\_DMA\_1\_CH16 124U
- #define **SC\_R\_DMA\_1\_CH17** 125U
- #define SC R DMA\_1 CH18 126U
- #define SC R DMA 1 CH19 127U #define SC\_R\_DMA\_1\_CH20 128U
- #define SC R DMA 1 CH21 129U
- #define SC R DMA 1 CH22 130U
- #define SC R DMA\_1 CH23 131U
- #define SC\_R\_DMA\_1\_CH24 132U
- #define SC R DMA\_1 CH25 133U
- #define SC\_R\_DMA\_1\_CH26 134U
- #define SC R DMA\_1 CH27 135U
- #define SC R DMA 1 CH28 136U
- #define SC R DMA\_1 CH29 137U

- #define SC\_R\_DMA\_1\_CH30 138U
- #define SC\_R\_DMA\_1\_CH31 139U
- #define SC R V2X PID0 140U
- #define SC R V2X PID1 141U
- #define SC R V2X PID2 142U
- #define SC\_R\_V2X\_PID3 143U
- #define SC\_R\_GPU\_0\_PID0 144U
- #define SC\_R\_GPU\_0\_PID1 145U
- #define SC\_R\_GPU\_0\_PID2 146U
- #define SC\_R\_GPU\_0\_PID3 147U
- #define SC\_R\_GPU\_1\_PID0 148U
- #define SC\_R\_GPU\_1\_PID1 149U
- #define SC\_R\_GPU\_1\_PID2 150U
- #define SC\_R\_GPU\_1\_PID3 151U
- #define SC R PCIE A 152U
- #define SC\_R\_SERDES\_0 153U
- #define SC\_R\_MATCH\_0 154U
- #define SC\_R\_MATCH\_1 155U
- #define SC R MATCH 2 156U
- #define SC\_R\_MATCH\_3 157U
- #define SC R MATCH 4 158U
- #define SC R MATCH 5 159U
- #define SC R MATCH 6 160U
- #define SC R MATCH 7 161U
- #define SC\_R\_MATCH\_8 162U
- #define SC\_R\_MATCH\_9 163U
- #define SC\_R\_MATCH\_10 164U
- #define SC R MATCH 11 165U
- #define SC\_R\_MATCH\_12 166U
- #define SC R MATCH 13 167U
- #define SC R MATCH 14 168U
- #define SC R PCIE B 169U
- #define SC R SATA 0 170U
- #define SC R SERDES 1 171U
- #define SC\_R\_HSIO\_GPIO 172U
- #define SC\_R\_MATCH\_15 173U
- #define SC\_R\_MATCH\_16 174U
- #define SC\_R\_MATCH\_17 175U#define SC\_R\_MATCH\_18 176U
- #define **SC\_R\_MATCH\_19** 177U
- #define SC R MATCH 20 178U
- #define SC\_R\_MATCH\_21 179U
- #define SC\_R\_MATCH\_22 180U
- #define SC\_R\_MATCH\_23 181U
- #define SC\_R\_MATCH\_24 182U
- #define SC\_R\_MATCH\_25 183U
- #define SC\_R\_MATCH\_26 184U
- #define SC\_R\_MATCH\_27 185U
- #define SC R MATCH 28 186U
- #define SC R LCD 0 187U
- #define SC\_R\_LCD\_0\_PWM\_0 188U
- #define SC R LCD 0 I2C 0 189U
- #define SC R LCD 0 I2C 1 190U
- #define SC R PWM 0 191U
- #define SC\_R\_PWM\_1 192U
- #define SC R PWM 2 193U
- #define SC\_R\_PWM\_3 194U
- #define SC\_R\_PWM\_4 195U#define SC\_R\_PWM\_5 196U
- #define SC R PWM 6 197U

- #define SC\_R\_PWM\_7 198U
- #define SC\_R\_GPIO\_0 199U
- #define SC R GPIO 1 200U
- #define SC\_R\_GPIO\_2 201U
- #define SC R GPIO 3 202U
- #define SC\_R\_GPIO\_4 203U
- #define SC\_R\_GPIO\_5 204U
- #define SC\_R\_GPIO\_6 205U
- #define SC\_R\_GPIO\_7 206U
- #define SC\_R\_GPT\_0 207U
- #define SC\_R\_GPT\_1 208U
- #define SC\_R\_GPT\_2 209U
- #define SC R GPT 3 210U
- #define SC R GPT 4 211U
- #define SC R KPP 212U
- #define SC R MU 0A 213U
- #define SC R MU 1A 214U
- #define SC R MU 2A 215U
- #define SC R MU 3A 216U
- #define SC R MU 4A 217U
- #define SC R MU 5A 218U
- #define SC R MU 6A 219U
- #define SC R MU 7A 220U
- #define SC R MU 8A 221U
- #define SC\_R\_MU\_9A 222U
- #define SC\_R\_MU\_10A 223U
- #define SC\_R\_MU\_11A 224U
- #define SC\_R\_MU\_12A 225U
- #define SC\_R\_MU\_13A 226U
- #define SC R MU 5B 227U
- #define SC R MU 6B 228U
- #define SC R MU 7B 229U
- #define SC R MU 8B 230U
- #define SC R MU 9B 231U
- #define SC R MU 10B 232U
- #define SC\_R\_MU\_11B 233U
- #define SC R MU 12B 234U
- #define SC\_R\_MU\_13B 235U
- #define SC R ROM 0 236U #define SC\_R\_FSPI\_0 237U
- #define SC R FSPI 1 238U
- #define SC\_R\_IEE 239U
- #define SC\_R\_IEE\_R0 240U
- #define SC\_R\_IEE\_R1 241U
- #define SC\_R\_IEE\_R2 242U
- #define SC\_R\_IEE\_R3 243U
- #define SC\_R\_IEE\_R4 244U
- #define SC\_R\_IEE\_R5 245U
- #define SC R IEE R6 246U
- #define SC R IEE R7 247U #define SC R SDHC 0 248U
- #define SC R SDHC 1 249U
- #define SC R SDHC 2 250U #define SC R ENET 0 251U
- #define SC\_R\_ENET\_1 252U
- #define SC R MLB 0 253U
- #define SC\_R\_DMA\_2\_CH0 254U
- #define SC R DMA 2 CH1 255U
- #define SC R DMA 2 CH2 256U
- #define SC R DMA 2 CH3 257U

- #define SC\_R\_DMA\_2\_CH4 258U
- #define SC\_R\_USB\_0 259U
- #define SC R USB 1 260U
- #define SC R USB 0 PHY 261U
- #define SC R USB 2 262U
- #define SC\_R\_USB\_2\_PHY 263U
- #define SC\_R\_DTCP 264U
- #define SC\_R\_NAND 265U
- #define SC\_R\_LVDS\_0 266U
- #define SC\_R\_LVDS\_0\_PWM\_0 267U
- #define SC\_R\_LVDS\_0\_I2C\_0 268U
- #define SC\_R\_LVDS\_0\_I2C\_1 269U
- #define SC R LVDS 1 270U
- #define SC R LVDS 1 PWM 0 271U
- #define SC R LVDS 1 I2C 0 272U
- #define SC R\_LVDS\_1\_I2C\_1 273U
- #define SC R LVDS 2 274U
- #define SC R LVDS 2 PWM 0 275U
- #define SC\_R\_LVDS\_2\_I2C\_0 276U
- #define SC R LVDS 2 I2C 1 277U
- #define SC R M4 0 PID0 278U
- #define SC R M4 0 PID1 279U
- #define SC R M4 0 PID2 280U
- #define SC R M4 0 PID3 281U #define SC\_R\_M4\_0\_PID4 282U
- #define SC R M4 0 RGPIO 283U
- #define SC\_R\_M4\_0\_SEMA42 284U
- #define SC R M4 0 TPM 285U
- #define SC\_R\_M4\_0\_PIT 286U
- #define SC R M4 0 UART 287U
- #define SC R M4 0 I2C 288U
- #define SC R M4 0 INTMUX 289U
- #define SC R ENET 0 A0 290U
- #define SC R ENET 0 A1 291U
- #define SC R M4 0 MU 0B 292U #define SC\_R\_M4\_0\_MU\_0A0 293U
- #define SC R M4 0 MU 0A1 294U
- #define SC\_R\_M4\_0\_MU\_0A2 295U
- #define SC R M4 0 MU 0A3 296U
- #define SC\_R\_M4\_0\_MU\_1A 297U
- #define SC\_R\_M4\_1\_PID0 298U
- #define SC\_R\_M4\_1\_PID1 299U
- #define SC\_R\_M4\_1\_PID2 300U
- #define SC\_R\_M4\_1\_PID3 301U
- #define SC\_R\_M4\_1\_PID4 302U
- #define SC\_R\_M4\_1\_RGPIO 303U
- #define **SC\_R\_M4\_1\_SEMA42** 304U
- #define **SC\_R\_M4\_1\_TPM** 305U
- #define SC\_R\_M4\_1\_PIT 306U
- #define SC R M4 1 UART 307U
- #define SC R M4 1 I2C 308U
- #define SC R M4 1 INTMUX 309U
- #define SC R UNUSED17 310U
- #define SC R UNUSED18 311U
- #define SC\_R\_M4\_1\_MU\_0B 312U
- #define SC\_R\_M4\_1\_MU\_0A0 313U
- #define SC R M4 1 MU 0A1 314U
- #define SC R M4 1 MU 0A2 315U #define SC R M4 1 MU 0A3 316U
- #define SC\_R\_M4\_1\_MU\_1A 317U

- #define SC\_R\_SAI\_0 318U
- #define SC\_R\_SAI\_1 319U
- #define SC R SAI 2 320U
- #define SC\_R\_IRQSTR\_SCU2 321U
- #define SC R IRQSTR DSP 322U
- #define SC\_R\_ELCDIF\_PLL 323U
- #define SC\_R\_OCRAM 324U
- #define SC\_R\_AUDIO\_PLL\_0 325U
- #define SC\_R\_PI\_0 326U
- #define SC\_R\_PI\_0\_PWM\_0 327U
- #define SC\_R\_PI\_0\_PWM\_1 328U
- #define SC\_R\_PI\_0\_I2C\_0 329U
- #define SC R PI 0 PLL 330U
- #define SC R PI 1 331U
- #define SC\_R\_PI\_1\_PWM\_0 332U
- #define SC\_R\_PI\_1\_PWM\_1 333U
- #define SC\_R\_PI\_1\_I2C\_0 334U
- #define SC\_R\_PI\_1\_PLL 335U
- #define SC\_R\_SC\_PID0 336U
- #define SC\_R\_SC\_PID1 337U
- #define SC\_R\_SC\_PID2 338U
- #define SC\_R\_SC\_PID3 339U
- #define SC\_R\_SC\_PID4 340U
   #define SC\_R\_SC\_SEMA42 341U
- #define SC\_R\_SC\_SEMA42 341U
- #define SC\_R\_SC\_TPM 342U
- #define SC\_R\_SC\_PIT 343U
- #define SC\_R\_SC\_UART 344U
- #define SC\_R\_SC\_I2C 345U
- #define SC\_R\_SC\_MU\_0B 346U
- #define SC\_R\_SC\_MU\_0A0 347U
- #define SC\_R\_SC\_MU\_0A1 348U
- #define SC\_R\_SC\_MU\_0A2 349U
- #define SC\_R\_SC\_MU\_0A3 350U
   #define SC\_R\_SC\_MU\_1A 351U
- #define SC R SYSCNT RD 352U
- #define SC R SYSCNT CMP 353U
- #define SC\_R\_DEBUG 354U
- #define SC\_R\_SYSTEM 355U
- #define SC R SNVS 356U
- #define SC\_R\_OTP 357U
- #define SC R VPU PID0 358U
- #define SC\_R\_VPU\_PID1 359U
- #define SC\_R\_VPU\_PID2 360U
- #define SC\_R\_VPU\_PID3 361U
- #define SC\_R\_VPU\_PID4 362U
- #define SC\_R\_VPU\_PID5 363U
- #define SC\_R\_VPU\_PID6 364U#define SC\_R\_VPU\_PID7 365U
- #define SC R ENET 0 A2 366U
- #define SC\_R\_ENET\_0\_A2 3660
   #define SC\_R\_ENET\_1 A0 367U
- #define SC R ENET 1 A1 368U
- #define SC R ENET 1 A2 369U
- #define SC R ENET 1 A3 370U
- #define SC\_R\_ENET\_1\_A4 371U
- #define SC\_R\_DMA\_4\_CH0 372U
   #define SC\_R\_DMA\_4\_CH1 373U
- #define SC R DMA 4 CH2 374U
- #define SC R DMA 4 CH3 375U
- #define SC R DMA 4 CH4 376U
- #define SC\_R\_ISI\_CH0 377U

- #define SC\_R\_ISI\_CH1 378U
- #define SC\_R\_ISI\_CH2 379U
- #define SC R ISI CH3 380U
- #define SC R ISI CH4 381U
- #define SC R ISI CH5 382U
- #define SC\_R\_ISI\_CH6 383U
- #define SC\_R\_ISI\_CH7 384U
- #define SC\_R\_MJPEG\_DEC\_S0 385U
- #define SC\_R\_MJPEG\_DEC\_S1 386U
- #define SC\_R\_MJPEG\_DEC\_S2 387U
- #define SC\_R\_MJPEG\_DEC\_S3 388U
- #define SC\_R\_MJPEG\_ENC\_S0 389U
- #define SC\_R\_MJPEG\_ENC\_S1 390U
- #define SC\_R\_MJPEG\_ENC\_S2 391U
- #define SC\_R\_MJPEG\_ENC\_S3 392U
- #define SC R MIPI 0 393U
- #define SC R MIPI 0 PWM 0 394U
- #define SC\_R\_MIPI\_0\_I2C\_0 395U
- #define SC R MIPI 0 I2C 1 396U
- #define SC R MIPI 1 397U
- #define SC R MIPI 1 PWM 0 398U
- #define SC R MIPI 1 I2C 0 399U
- #define SC R MIPI 1 I2C 1 400U
- #define SC R CSI 0 401U
- #define SC\_R\_CSI\_0\_PWM\_0 402U
- #define SC\_R\_CSI\_0\_I2C\_0 403U
- #define SC\_R\_CSI\_1 404U
- #define SC\_R\_CSI\_1\_PWM\_0 405U
- #define SC\_R\_CSI\_1\_I2C\_0 406U
- #define SC R HDMI 407U
- #define SC R HDMI I2S 408U
- #define SC R HDMI I2C 0 409U
- #define SC R HDMI PLL 0 410U
- #define SC R HDMI RX 411U
- #define SC R HDMI RX BYPASS 412U
- #define SC\_R\_HDMI\_RX\_I2C\_0 413U
- #define SC R ASRC 0 414U
- #define SC\_R\_ESAI\_0 415U
- #define SC\_R\_SPDIF\_0 416U
- #define SC\_R\_SPDIF\_1 417U
- #define SC\_R\_SAI\_3 418U
- #define SC\_R\_SAI\_4 419U
- #define SC\_R\_SAI\_5 420U
- #define SC\_R\_GPT\_5 421U
- #define SC\_R\_GPT\_6 422U
- #define SC\_R\_GPT\_7 423U
- #define SC\_R\_GPT\_8 424U
- #define SC\_R\_GPT\_9 425U
- #define SC\_R\_GPT\_10 426U
- #define SC R DMA 2 CH5 427U
- #define SC\_R\_DMA\_2\_CH6 428U
- #define SC\_R\_DMA\_2\_CH7 429U
- #define SC\_R\_DMA\_2\_CH8 430U
   #define SC\_R\_DMA\_2\_CH9 431U
- #define SC\_R\_DMA\_2\_CH10 432U
- #define SC R DMA 2 CH11 433U
- #define SC R DMA 2 CH12 434U
- #define SC R DMA 2 CH13 435U
- #define SC\_R\_DMA\_2\_CH14 436U
- #define SC R DMA 2 CH15 437U

- #define SC\_R\_DMA\_2\_CH16 438U
- #define SC\_R\_DMA\_2\_CH17 439U
- #define SC R DMA 2 CH18 440U
- #define SC\_R\_DMA\_2\_CH19 441U
- #define SC R DMA 2 CH20 442U
- #define SC\_R\_DMA\_2\_CH21 443U
- #define SC\_R\_DMA\_2\_CH22 444U
- #define SC\_R\_DMA\_2\_CH23 445U
- #define SC\_R\_DMA\_2\_CH24 446U
- #define SC\_R\_DMA\_2\_CH25 447U
- #define SC\_R\_DMA\_2\_CH26 448U
- #define SC\_R\_DMA\_2\_CH27 449U
- #define SC\_R\_DMA\_2\_CH28 450U
- #define SC\_R\_DMA\_2\_CH29 451U
- #define SC\_R\_DMA\_2\_CH30 452U
- #define SC\_R\_DMA\_2\_CH31 453U
- #define SC R ASRC 1 454U
- #define SC R ESAI 1 455U
- #define SC\_R\_SAI\_6 456U
- #define SC\_R\_SAI\_7 457U
- #define SC R AMIX 458U
- #define SC\_R\_MQS\_0 459U
- #define SC R DMA 3 CH0 460U
- #define SC\_R\_DMA\_3\_CH1 461U
- #define SC\_R\_DMA\_3\_CH2 462U
- #define SC\_R\_DMA\_3\_CH3 463U
- #define SC\_R\_DMA\_3\_CH4 464U
- #define SC\_R\_DMA\_3\_CH5 465U
- #define SC R DMA 3 CH6 466U
- #define SC\_R\_DMA\_3\_CH7 467U
- #define SC\_R\_DMA\_3\_CH8 468U
- #define SC\_R\_DMA\_3\_CH9 469U
- #define SC\_R\_DMA\_3\_CH10 470U
- #define SC\_R\_DMA\_3\_CH11 471U
- #define SC\_R\_DMA\_3\_CH12 472U
   #define SC\_R\_DMA\_3\_CH13 473U
- #define SC R DMA 3 CH14 474U
- #define SC\_R\_DMA\_3\_CH15 475U
- #define SC R DMA 3 CH16 476U
- #define SC\_R\_DMA\_3\_CH17 477U
- #define SC R DMA 3 CH18 478U
- #define SC\_R\_DMA\_3\_CH19 479U
- #define SC\_R\_DMA\_3\_CH20 480U
- #define SC\_R\_DMA\_3\_CH21 481U
- #define SC\_R\_DMA\_3\_CH22 482U
- #define SC\_R\_DMA\_3\_CH23 483U
- #define SC\_R\_DMA\_3\_CH24 484U
- #define SC\_R\_DMA\_3\_CH25 485U
- #define SC\_R\_DMA\_3\_CH26 486U
   #define SC R DMA 3 CH27 487U
- #define SC R DMA 3 CH28 488U
- #define SC R DMA 3 CH29 489U
- #define SC R DMA 3 CH30 490U
- #define SC R DMA 3 CH31 491U
- #define SC\_R\_AUDIO\_PLL\_1 492U
- #define SC R AUDIO CLK 0 493U
- #define SC\_R\_AUDIO\_CLK\_1 494U
- #define SC R MCLK OUT 0 495U
- #define SC\_R\_MCLK\_OUT\_1 496U
  #define SC\_R\_PMIC\_0 497U

- #define SC\_R\_PMIC\_1 498U
- #define SC R SECO 499U
- #define SC\_R\_CAAM\_JR1 500U
- #define SC R CAAM JR2 501U
- #define SC\_R\_CAAM\_JR3 502U
- #define SC\_R\_SECO\_MU\_2 503U
- #define SC\_R\_SECO\_MU\_3 504U
- #define SC\_R\_SECO\_MU\_4 505U
- #define SC\_R\_HDMI\_RX\_PWM\_0 506U
- #define SC\_R\_A35 507U
- #define SC\_R\_A35\_0 508U
- #define SC R A35 1 509U
- #define SC R A35 2 510U
- #define SC R A35 3 511U
- #define SC R DSP 512U
- #define SC R DSP RAM 513U
- #define SC\_R\_CAAM\_JR1\_OUT 514U
- #define SC\_R\_CAAM\_JR2\_OUT 515U
- #define SC R CAAM JR3 OUT 516U
- #define SC\_R\_VPU\_DEC\_0 517U
- #define SC R VPU ENC 0 518U
- #define SC\_R\_CAAM\_JR0 519U
- #define SC\_R\_CAAM\_JR0\_OUT 520U
- #define SC\_R\_PMIC\_2 521U
- #define SC\_R\_DBLOGIC 522U
- #define SC\_R\_HDMI\_PLL\_1 523U
- #define SC R BOARD R0 524U
- #define SC R BOARD R1 525U
- #define SC R BOARD R2 526U
- #define SC R BOARD R3 527U
- #define SC R BOARD R4 528U
- #define SC R BOARD R5 529U
- #define SC R BOARD R6 530U
- #define SC R BOARD R7 531U
- #define SC\_R\_MJPEG\_DEC\_MP 532U
- #define SC R MJPEG ENC MP 533U
- #define SC\_R\_VPU\_TS\_0 534U
- #define SC\_R\_VPU\_MU\_0 535U
- #define SC\_R\_VPU\_MU\_1 536U
- #define SC\_R\_VPU\_MU\_2 537U
- #define SC\_R\_VPU\_MU\_3 538U
- #define SC R VPU ENC 1 539U
- #define SC R VPU 540U
- #define SC R DMA 5 CH0 541U
- #define SC R DMA 5 CH1 542U
- #define SC R DMA 5 CH2 543U
- #define SC R DMA 5 CH3 544U
- #define SC R ATTESTATION 545U
- #define SC R LAST 546U
- #define SC\_R\_ALL ((sc\_rsrc\_t) UINT16\_MAX)

All resources.

## **Typedefs**

typedef uint8 t sc bool t

This type is used to store a boolean.

typedef uint64 t sc faddr t

This type is used to store a system (full-size) address.

typedef uint8\_t sc\_err\_t

This type is used to indicate error response for most functions.

typedef uint16 t sc rsrc t

This type is used to indicate a resource.

typedef uint32\_t sc\_ctrl\_t

This type is used to indicate a control.

typedef uint16\_t sc\_pad\_t

This type is used to indicate a pad.

typedef \_\_INT8\_TYPE\_\_ int8\_t

Type used to declare an 8-bit integer.

typedef \_\_INT16\_TYPE\_\_ int16\_t

Type used to declare a 16-bit integer.

• typedef \_\_INT32\_TYPE\_\_ int32\_t

Type used to declare a 32-bit integer.

typedef \_\_INT64\_TYPE\_\_ int64\_t

Type used to declare a 64-bit integer.

typedef \_\_UINT8\_TYPE\_\_ uint8\_t

Type used to declare an 8-bit unsigned integer.

typedef \_\_UINT16\_TYPE\_\_ uint16\_t

Type used to declare a 16-bit unsigned integer.

typedef \_\_UINT32\_TYPE\_\_ uint32\_t

Type used to declare a 32-bit unsigned integer.

typedef \_\_UINT64\_TYPE\_\_ uint64\_t

Type used to declare a 64-bit unsigned integer.

## 14.3.1 Detailed Description

Header file containing types used across multiple service APIs.

## 14.3.2 Macro Definition Documentation

```
14.3.2.1 SC_R_NONE
```

#define SC\_R\_NONE 0xFFF0U

Define for ATF/Linux.

Not used by SCFW. Not a valid parameter for any SCFW API calls!

14.3.2.2 SC\_P\_ALL

```
#define SC_P_ALL ((sc_pad_t) UINT16_MAX)
```

Define for used to specify all pads.

All pads

## 14.3.3 Typedef Documentation

```
14.3.3.1 sc_rsrc_t

typedef uint16_t sc_rsrc_t
```

This type is used to indicate a resource.

Resources include peripherals and bus masters (but not memory regions). Note items from list should never be changed or removed (only added to at the end of the list).

```
14.3.3.2 sc_pad_t

typedef uint16_t sc_pad_t
```

This type is used to indicate a pad.

Valid values are SoC specific.

Refer to the SoC Pad List for valid pad values.

## 14.4 platform/svc/irq/api.h File Reference

Header file containing the public API for the System Controller (SC) Interrupt (IRQ) function.

## **Macros**

#define SC\_IRQ\_NUM\_GROUP 7U
 Number of groups.

## Defines for sc\_irq\_group\_t

- #define SC\_IRQ\_GROUP\_TEMP 0U
  - Temp interrupts.
- #define SC\_IRQ\_GROUP\_WDOG 1U

Watchdog interrupts.

• #define SC\_IRQ\_GROUP\_RTC 2U

RTC interrupts.

• #define SC\_IRQ\_GROUP\_WAKE 3U

Wakeup interrupts.

• #define SC\_IRQ\_GROUP\_SYSCTR 4U

System counter interrupts.

• #define SC\_IRQ\_GROUP\_REBOOTED 5U

Partition reboot complete.

#define SC\_IRQ\_GROUP\_REBOOT 6U

Partition reboot starting.

## Defines for sc\_irq\_temp\_t

```
• #define SC_IRQ_TEMP_HIGH (1UL << 0U)
```

Temp alarm interrupt.

- #define SC\_IRQ\_TEMP\_CPU0\_HIGH (1UL << 1U)</li>
   CPU0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_CPU1\_HIGH (1UL << 2U)</li>
   CPU1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_GPU0\_HIGH (1UL << 3U)</li>
   GPU0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_GPU1\_HIGH (1UL << 4U)</li>
   GPU1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC0\_HIGH (1UL << 5U)</li>
   DRC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC1\_HIGH (1UL << 6U)</li>
   DRC1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_VPU\_HIGH (1UL << 7U)</li>
   DRC1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMICO\_HIGH (1UL << 8U)</li>
   PMIC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMIC1\_HIGH (1UL << 9U)</li>
   PMIC1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_LOW (1UL << 10U)</li>
- Temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_CPU0\_LOW (1UL << 11U)</li>
   CPU0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_CPU1\_LOW (1UL << 12U)</li>
   CPU1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_GPU0\_LOW (1UL << 13U)</li>
   GPU0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_GPU1\_LOW (1UL << 14U)</li>
   GPU1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC0\_LOW (1UL << 15U)</li>
   DRC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_DRC1\_LOW (1UL << 16U)</li>
   DRC1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_VPU\_LOW (1UL << 17U)
  - DRC1 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMIC0\_LOW (1UL << 18U)</li>
   PMIC0 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMIC1\_LOW (1UL << 19U)
- PMIC1 temp alarm interrupt.
   #define SC\_IRQ\_TEMP\_PMIC2\_HIGH (1UL << 20U)</li>
   PMIC2 temp alarm interrupt.
- #define SC\_IRQ\_TEMP\_PMIC2\_LOW (1UL << 21U)</li>
   PMIC2 temp alarm interrupt.

## Defines for sc\_irq\_wdog\_t

#define SC\_IRQ\_WDOG (1U << 0U)</li>
 Watchdog interrupt.

#### Defines for sc irq rtc t

#define SC\_IRQ\_RTC (1U << 0U)</li>
 RTC interrupt.

## Defines for sc\_irq\_wake\_t

• #define SC\_IRQ\_BUTTON (1U << 0U)

Button interrupt.

#define SC\_IRQ\_PAD (1U << 1U)</li>

Pad wakeup.

#define SC IRQ USR1 (1U << 2U)</li>

User defined 1.

#define SC IRQ USR2 (1U << 3U)</li>

User defined 2.

#define SC\_IRQ\_BC\_PAD (1U << 4U)</li>

Pad wakeup (broadcast to all partitions)

#define SC IRQ SW WAKE (1U << 5U)</li>

Software requested wake.

#define SC\_IRQ\_SECVIO (1U << 6U)</li>

Security violation.

#### Defines for sc irq sysctr t

#define SC\_IRQ\_SYSCTR (1U << 0U)</li>
 SYSCTR interrupt.

## **Typedefs**

• typedef uint8\_t sc\_irq\_group\_t

This type is used to declare an interrupt group.

typedef uint8\_t sc\_irq\_temp\_t

This type is used to declare a bit mask of temp interrupts.

typedef uint8\_t sc\_irq\_wdog\_t

This type is used to declare a bit mask of watchdog interrupts.

typedef uint8\_t sc\_irq\_rtc\_t

This type is used to declare a bit mask of RTC interrupts.

typedef uint8\_t sc\_irq\_wake\_t

This type is used to declare a bit mask of wakeup interrupts.

## **Functions**

- sc\_err\_t sc\_irq\_enable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_irq\_group\_t group, uint32\_t mask, sc\_bool\_t enable)

  This function enables/disables interrupts.
- sc\_err\_t sc\_irq\_status (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_irq\_group\_t group, uint32\_t \*status)

This function returns the current interrupt status (regardless if masked).

## 14.4.1 Detailed Description

Header file containing the public API for the System Controller (SC) Interrupt (IRQ) function.

## 14.5 platform/svc/misc/api.h File Reference

Header file containing the public API for the System Controller (SC) Miscellaneous (MISC) function.

#### **Macros**

#define SC\_MISC\_DMA\_GRP\_MAX 31U
 Max DMA channel priority group.

## Defines for type widths

#define SC\_MISC\_DMA\_GRP\_W 5U
 Width of sc\_misc\_dma\_group\_t.

#### Defines for sc misc boot status t

 #define SC\_MISC\_BOOT\_STATUS\_SUCCESS 0U Success.
 #define SC\_MISC\_BOOT\_STATUS\_SECURITY 1U

## Defines for sc\_misc\_temp\_t

Security violation.

- #define SC\_MISC\_TEMP 0U
   Temp sensor.
- #define SC\_MISC\_TEMP\_HIGH 1U

Temp high alarm.

#define SC\_MISC\_TEMP\_LOW 2U

Temp low alarm.

## Defines for sc\_misc\_bt\_t

#define SC\_MISC\_BT\_PRIMARY 0U

Primary boot.

• #define SC\_MISC\_BT\_SECONDARY 1U

Secondary boot.

#define SC\_MISC\_BT\_RECOVERY 2U

Recovery boot.

• #define SC\_MISC\_BT\_MANUFACTURE 3U

Manufacture boot.

#define SC\_MISC\_BT\_SERIAL 4U

Serial boot.

## **Typedefs**

typedef uint8\_t sc\_misc\_dma\_group\_t

This type is used to store a DMA channel priority group.

typedef uint8\_t sc\_misc\_boot\_status\_t

This type is used report boot status.

typedef uint8\_t sc\_misc\_temp\_t

This type is used report boot status.

typedef uint8\_t sc\_misc\_bt\_t

This type is used report the boot type.

#### **Functions**

#### **Control Functions**

- sc\_err\_t sc\_misc\_set\_control (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_ctrl\_t ctrl, uint32\_t val)
  - This function sets a miscellaneous control value.
- sc\_err\_t sc\_misc\_get\_control (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_ctrl\_t ctrl, uint32\_t \*val)

This function gets a miscellaneous control value.

#### **DMA Functions**

- $\bullet \ \ sc\_err\_t \ sc\_misc\_set\_max\_dma\_group \ (sc\_ipc\_t \ ipc, \ sc\_rm\_pt\_t \ pt, \ sc\_misc\_dma\_group\_t \ max)$ 
  - This function configures the max DMA channel priority group for a partition.
- sc\_err\_t sc\_misc\_set\_dma\_group (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_dma\_group\_t group)

This function configures the priority group for a DMA channel.

## **Debug Functions**

- void sc\_misc\_debug\_out (sc\_ipc\_t ipc, uint8\_t ch)
  - This function is used output a debug character from the SCU UART.
- sc\_err\_t sc\_misc\_waveform\_capture (sc\_ipc\_t ipc, sc\_bool\_t enable)

This function starts/stops emulation waveform capture.

void sc\_misc\_build\_info (sc\_ipc\_t ipc, uint32\_t \*build, uint32\_t \*commit)

This function is used to return the SCFW build info.

• void sc\_misc\_api\_ver (sc\_ipc\_t ipc, uint16\_t \*cl\_maj, uint16\_t \*cl\_min, uint16\_t \*sv\_maj, uint16\_t \*sv\_min)

This function is used to return the SCFW API versions.

void sc\_misc\_unique\_id (sc\_ipc\_t ipc, uint32\_t \*id\_l, uint32\_t \*id\_h)

This function is used to return the device's unique ID.

#### **Other Functions**

sc\_err\_t sc\_misc\_set\_ari (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rsrc\_t resource\_mst, uint16\_t ari, sc\_bool\_t enable)

This function configures the ARI match value for PCIe/SATA resources.

void sc\_misc\_boot\_status (sc\_ipc\_t ipc, sc\_misc\_boot\_status\_t status)

This function reports boot status.

- sc\_err\_t sc\_misc\_boot\_done (sc\_ipc\_t ipc, sc\_rsrc\_t cpu)
  - This function tells the SCFW that a CPU is done booting.
- sc\_err\_t sc\_misc\_otp\_fuse\_read (sc\_ipc\_t ipc, uint32\_t word, uint32\_t \*val)

This function reads a given fuse word index.

sc err t sc misc otp fuse write (sc ipc t ipc, uint32 t word, uint32 t val)

This function writes a given fuse word index.

sc\_err\_t sc\_misc\_set\_temp (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_temp\_t temp, int16\_t celsius, int8\_t tenths)

This function sets a temp sensor alarm.

sc\_err\_t sc\_misc\_get\_temp (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_misc\_temp\_t temp, int16\_t \*celsius, int8\_t \*tenths)

This function gets a temp sensor value.

void sc\_misc\_get\_boot\_dev (sc\_ipc\_t ipc, sc\_rsrc\_t \*dev)

This function returns the boot device.

sc\_err\_t sc\_misc\_get\_boot\_type (sc\_ipc\_t ipc, sc\_misc\_bt\_t \*type)

This function returns the boot type.

sc err t sc misc get boot container (sc ipc t ipc, uint8 t \*idx)

This function returns the boot container index.

void sc\_misc\_get\_button\_status (sc\_ipc\_t ipc, sc\_bool\_t \*status)

This function returns the current status of the ON/OFF button.

• sc\_err\_t sc\_misc\_rompatch\_checksum (sc\_ipc\_t ipc, uint32\_t \*checksum)

This function returns the ROM patch checksum.

sc\_err\_t sc\_misc\_board\_ioctl (sc\_ipc\_t ipc, uint32\_t \*parm1, uint32\_t \*parm2, uint32\_t \*parm3)

This function calls the board IOCTL function.

## 14.5.1 Detailed Description

Header file containing the public API for the System Controller (SC) Miscellaneous (MISC) function.

## 14.6 platform/svc/pad/api.h File Reference

Header file containing the public API for the System Controller (SC) Pad Control (PAD) function.

## Macros

#### Defines for type widths

• #define SC PAD MUX W 3U

Width of mux parameter.

## Defines for sc\_pad\_config\_t

#define SC\_PAD\_CONFIG\_NORMAL 0U

Normal.

• #define SC PAD CONFIG OD 1U

Open Drain.

#define SC PAD CONFIG OD IN 2U

Open Drain and input.

#define SC\_PAD\_CONFIG\_OUT\_IN 3U

Output and input.

#### Defines for sc pad iso t

• #define SC\_PAD\_ISO\_OFF 0U

ISO latch is transparent.

#define SC PAD ISO EARLY 1U

Follow EARLY\_ISO.

• #define SC\_PAD\_ISO\_LATE 2U

Follow LATE\_ISO.

#define SC PAD ISO ON 3U

ISO latched data is held.

## Defines for sc\_pad\_28fdsoi\_dse\_t

#define SC\_PAD\_28FDSOI\_DSE\_18V\_1MA 0U

Drive strength of 1mA for 1.8v.

#define SC\_PAD\_28FDSOI\_DSE\_18V\_2MA 1U

Drive strength of 2mA for 1.8v.

#define SC\_PAD\_28FDSOI\_DSE\_18V\_4MA 2U

Drive strength of 4mA for 1.8v.

#define SC\_PAD\_28FDSOI\_DSE\_18V\_6MA 3U

Drive strength of 6mA for 1.8v.

#define SC PAD 28FDSOI DSE 18V 8MA 4U

Drive strength of 8mA for 1.8v.

#define SC PAD 28FDSOI DSE 18V 10MA 5U

Drive strength of 10mA for 1.8v.

#define SC\_PAD\_28FDSOI\_DSE\_18V\_12MA 6U

Drive strength of 12mA for 1.8v.

• #define SC PAD 28FDSOI DSE 18V HS 7U

High-speed drive strength for 1.8v.

• #define SC\_PAD\_28FDSOI\_DSE\_33V\_2MA 0U

Drive strength of 2mA for 3.3v.

#define SC\_PAD\_28FDSOI\_DSE\_33V\_4MA 1U

Drive strength of 4mA for 3.3v.

#define SC\_PAD\_28FDSOI\_DSE\_33V\_8MA 2U

Drive strength of 8mA for 3.3v.

#define SC\_PAD\_28FDSOI\_DSE\_33V\_12MA 3U

Drive strength of 12mA for 3.3v.

#define SC\_PAD\_28FDSOI\_DSE\_DV\_HIGH 0U

High drive strength for dual volt.

#define SC PAD 28FDSOI DSE DV LOW 1U

Low drive strength for dual volt.

## Defines for sc\_pad\_28fdsoi\_ps\_t

• #define SC PAD 28FDSOI PS KEEPER 0U

Bus-keeper (only valid for 1.8v)

• #define SC PAD 28FDSOI PS PU 1U

Pull-up.

#define SC PAD 28FDSOI PS PD 2U

Pull-down

• #define SC\_PAD\_28FDSOI\_PS\_NONE 3U

No pull (disabled)

#### Defines for sc pad 28fdsoi pus t

- #define SC\_PAD\_28FDSOI\_PUS\_30K\_PD 0U
  - 30K pull-down
- #define SC\_PAD\_28FDSOI\_PUS\_100K\_PU 1U
  - 100K pull-up
- #define SC\_PAD\_28FDSOI\_PUS\_3K\_PU 2U
  - 3K pull-up
- #define SC\_PAD\_28FDSOI\_PUS\_30K\_PU 3U
  - 30K pull-up

## Defines for sc\_pad\_wakeup\_t

- #define SC\_PAD\_WAKEUP\_OFF 0U
  - Off.
- #define SC\_PAD\_WAKEUP\_CLEAR 1U
  - Clears pending flag.
- #define SC\_PAD\_WAKEUP\_LOW\_LVL 4U
  - Low level.
- #define SC PAD WAKEUP FALL EDGE 5U
  - Falling edge.
- #define SC\_PAD\_WAKEUP\_RISE\_EDGE 6U
  - Rising edge.
- #define SC\_PAD\_WAKEUP\_HIGH\_LVL 7U
   High-level.

## **Typedefs**

- typedef uint8\_t sc\_pad\_config\_t
  - This type is used to declare a pad config.
- typedef uint8\_t sc\_pad\_iso\_t
  - This type is used to declare a pad low-power isolation config.
- typedef uint8\_t sc\_pad\_28fdsoi\_dse\_t
  - This type is used to declare a drive strength.
- typedef uint8\_t sc\_pad\_28fdsoi\_ps\_t
  - This type is used to declare a pull select.
- typedef uint8\_t sc\_pad\_28fdsoi\_pus\_t
  - This type is used to declare a pull-up select.
- typedef uint8\_t sc\_pad\_wakeup\_t
  - This type is used to declare a wakeup mode of a pad.

## **Functions**

## **Generic Functions**

- sc\_err\_t sc\_pad\_set\_mux (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t mux, sc\_pad\_config\_t config, sc\_pad\_iso\_t iso)

  This function configures the mux settings for a pad.
- sc\_err\_t sc\_pad\_get\_mux (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*mux, sc\_pad\_config\_t \*config, sc\_pad\_iso\_t \*iso)
  - This function gets the mux settings for a pad.
- sc\_err\_t sc\_pad\_set\_gp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t ctrl)

This function configures the general purpose pad control.

sc\_err\_t sc\_pad\_get\_gp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t \*ctrl)

This function gets the general purpose pad control.

sc\_err\_t sc\_pad\_set\_wakeup (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_wakeup\_t wakeup)

This function configures the wakeup mode of the pad.

sc\_err\_t sc\_pad\_get\_wakeup (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_wakeup\_t \*wakeup)

This function gets the wakeup mode of a pad.

sc\_err\_t sc\_pad\_set\_all (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t mux, sc\_pad\_config\_t config, sc\_pad\_iso\_t iso, uint32\_t ctrl, sc\_pad\_wakeup\_t wakeup)

This function configures a pad.

sc\_err\_t sc\_pad\_get\_all (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*mux, sc\_pad\_config\_t \*config, sc\_pad\_iso\_t \*iso, uint32 t \*ctrl, sc\_pad\_wakeup t \*wakeup)

This function gets a pad's config.

#### SoC Specific Functions

sc\_err\_t sc\_pad\_set (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t val)

This function configures the settings for a pad.

sc\_err\_t sc\_pad\_get (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t \*val)

This function gets the settings for a pad.

sc\_err\_t sc\_pad\_config (sc\_ipc\_t ipc, sc\_pad\_t pad, uint32\_t val)

This function writes a configuration register.

#### **Technology Specific Functions**

sc\_err\_t sc\_pad\_set\_gp\_28fdsoi (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t dse, sc\_pad\_28fdsoi\_ps\_t ps)

This function configures the pad control specific to 28FDSOI.

sc\_err\_t sc\_pad\_get\_gp\_28fdsoi (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t \*dse, sc\_pad\_28fdsoi\_ps\_t \*ps)

This function gets the pad control specific to 28FDSOI.

sc\_err\_t sc\_pad\_set\_gp\_28fdsoi\_hsic (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t dse, sc\_bool\_t hys, sc\_pad\_28fdsoi\_pus\_t pus, sc\_bool\_t pke, sc\_bool\_t pue)

This function configures the pad control specific to 28FDSOI.

• sc\_err\_t sc\_pad\_get\_gp\_28fdsoi\_hsic (sc\_ipc\_t ipc, sc\_pad\_t pad, sc\_pad\_28fdsoi\_dse\_t \*dse, sc\_bool\_t \*hys, sc\_pad\_28fdsoi\_pus\_t \*pus, sc\_bool\_t \*pke, sc\_bool\_t \*pue)

This function gets the pad control specific to 28FDSOI.

sc\_err\_t sc\_pad\_set\_gp\_28fdsoi\_comp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t compen, sc\_bool\_t fastfrz, uint8\_t rasrcp, uint8\_t rasrc

This function configures the compensation control specific to 28FDSOI.

sc\_err\_t sc\_pad\_get\_gp\_28fdsoi\_comp (sc\_ipc\_t ipc, sc\_pad\_t pad, uint8\_t \*compen, sc\_bool\_t \*fastfrz, uint8\_t \*rasrcp, uint8\_t \*r

This function gets the compensation control specific to 28FDSOI.

#### 14.6.1 Detailed Description

Header file containing the public API for the System Controller (SC) Pad Control (PAD) function.

## 14.7 platform/svc/pm/api.h File Reference

Header file containing the public API for the System Controller (SC) Power Management (PM) function.

## Macros

#### Defines for type widths

#define SC\_PM\_POWER\_MODE\_W 2U
 Width of sc\_pm\_power\_mode\_t.
 #define SC\_PM\_CLOCK\_MODE\_W 3U
 Width of sc\_pm\_clock\_mode\_t.
 #define SC\_PM\_RESET\_TYPE\_W 2U
 Width of sc\_pm\_reset\_type\_t.
 #define SC\_PM\_RESET\_REASON\_W 4U

Width of sc\_pm\_reset\_reason\_t.

# Defines for ALL parameters

#define SC\_PM\_CLK\_ALL ((sc\_pm\_clk\_t) UINT8\_MAX)
 All clocks.

## Defines for sc\_pm\_power\_mode\_t

• #define SC\_PM\_PW\_MODE\_OFF 0U

Power off.

• #define SC\_PM\_PW\_MODE\_STBY 1U

Power in standby.

#define SC\_PM\_PW\_MODE\_LP 2U

Power in low-power.

#define SC\_PM\_PW\_MODE\_ON 3U

Power on.

## Defines for sc\_pm\_clk\_t

#define SC\_PM\_CLK\_SLV\_BUS 0U

Slave bus clock.

#define SC\_PM\_CLK\_MST\_BUS 1U

Master bus clock.

• #define SC\_PM\_CLK\_PER 2U

Peripheral clock.

#define SC\_PM\_CLK\_PHY 3U

Phy clock.

• #define SC\_PM\_CLK\_MISC 4U

Misc clock.

• #define SC\_PM\_CLK\_MISC0 0U

Misc 0 clock.

#define SC\_PM\_CLK\_MISC1 1U

Misc 1 clock.

#define SC\_PM\_CLK\_MISC2 2U

Misc 2 clock.

#define SC\_PM\_CLK\_MISC3 3U

Misc 3 clock.

#define SC\_PM\_CLK\_MISC4 4U

Misc 4 clock.

#define SC\_PM\_CLK\_CPU 2U

CPU clock.

• #define SC\_PM\_CLK\_PLL 4U

PLL.

• #define SC\_PM\_CLK\_BYPASS 4U

Bypass clock.

## Defines for sc\_pm\_clk\_parent\_t

#define SC\_PM\_PARENT\_XTAL 0U
 Parent is XTAL.

• #define SC\_PM\_PARENT\_PLL0 1U

Parent is PLL0.

#define SC\_PM\_PARENT\_PLL1 2U

Parent is PLL1 or PLL0/2.

#define SC\_PM\_PARENT\_PLL2 3U

Parent in PLL2 or PLL0/4.

#define SC\_PM\_PARENT\_BYPS 4U

Parent is a bypass clock.

## Defines for sc\_pm\_reset\_type\_t

• #define SC\_PM\_RESET\_TYPE\_COLD 0U

Cold reset.

#define SC\_PM\_RESET\_TYPE\_WARM 1U

Warm reset.

#define SC\_PM\_RESET\_TYPE\_BOARD 2U

Board reset.

## Defines for sc\_pm\_reset\_reason\_t

• #define SC PM RESET REASON POR 0U

Power on reset.

#define SC PM RESET REASON JTAG 1U

JTAG reset

• #define SC\_PM\_RESET\_REASON\_SW 2U

Software reset.

• #define SC PM RESET REASON WDOG 3U

Partition watchdog reset.

• #define SC\_PM\_RESET\_REASON\_LOCKUP 4U

SCU lockup reset.

#define SC\_PM\_RESET\_REASON\_SNVS 5U

SNVS reset.

#define SC PM RESET REASON TEMP 6U

Temp panic reset.

• #define SC\_PM\_RESET\_REASON\_MSI 7U

MSI reset.

• #define SC PM RESET REASON UECC 8U

ECC reset.

• #define SC\_PM\_RESET\_REASON\_SCFW\_WDOG 9U

SCFW watchdog reset.

#define SC\_PM\_RESET\_REASON\_ROM\_WDOG 10U

SCU ROM watchdog reset.

#define SC PM RESET REASON SECO 11U

SECO reset.

#define SC\_PM\_RESET\_REASON\_SCFW\_FAULT 12U

SCFW fault reset.

#define SC\_PM\_RESET\_REASON\_V2X\_DEBUG 13U

V2X debug switch.

#### Defines for sc\_pm\_sys\_if\_t

#define SC\_PM\_SYS\_IF\_INTERCONNECT 0U

System interconnect.

• #define SC\_PM\_SYS\_IF\_MU 1U

AP -> SCU message units.

#define SC\_PM\_SYS\_IF\_OCMEM 2U

On-chip memory (ROM/OCRAM)

• #define SC PM SYS IF DDR 3U

DDR memory.

#### Defines for sc pm wake src t

• #define SC PM WAKE SRC NONE 0U

No wake source, used for self-kill.

#define SC\_PM\_WAKE\_SRC\_SCU 1U

Wakeup from SCU to resume CPU (IRQSTEER & GIC powered down)

#define SC\_PM\_WAKE\_SRC\_IRQSTEER 2U

Wakeup from IRQSTEER to resume CPU (GIC powered down)

#define SC PM WAKE SRC IRQSTEER GIC 3U

Wakeup from IRQSTEER+GIC to wake CPU (GIC clock gated)

#define SC\_PM\_WAKE\_SRC\_GIC 4U

Wakeup from GIC to wake CPU.

#### **Typedefs**

typedef uint8\_t sc\_pm\_power\_mode\_t

This type is used to declare a power mode.

typedef uint8\_t sc\_pm\_clk\_t

This type is used to declare a clock.

typedef uint8\_t sc\_pm\_clk\_parent\_t

This type is used to declare the clock parent.

typedef uint32\_t sc\_pm\_clock\_rate\_t

This type is used to declare clock rates.

typedef uint8\_t sc\_pm\_reset\_type\_t

This type is used to declare a desired reset type.

typedef uint8\_t sc\_pm\_reset\_reason\_t

This type is used to declare a reason for a reset.

typedef uint8\_t sc\_pm\_sys\_if\_t

This type is used to specify a system-level interface to be power managed.

typedef uint8\_t sc\_pm\_wake\_src\_t

This type is used to specify a wake source for CPU resources.

#### **Functions**

#### **Power Functions**

• sc\_err\_t sc\_pm\_set\_sys\_power\_mode (sc\_ipc\_t ipc, sc\_pm\_power\_mode\_t mode)

This function sets the system power mode.

• sc\_err\_t sc\_pm\_set\_partition\_power\_mode (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_power\_mode\_t mode)

This function sets the power mode of a partition.

sc\_err\_t sc\_pm\_get\_sys\_power\_mode (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_power\_mode\_t \*mode)
 This function gets the power mode of a partition.

sc\_err\_t sc\_pm\_partition\_wake (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function sends a wake interrupt to a partition.

- sc\_err\_t sc\_pm\_set\_resource\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode)

  This function sets the power mode of a resource.
- sc\_err\_t sc\_pm\_set\_resource\_power\_mode\_all (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_power\_mode\_t mode, sc\_rsrc\_t exclude)

This function sets the power mode for all the resources owned by a child partition.

- sc\_err\_t sc\_pm\_get\_resource\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t \*mode)
   This function gets the power mode of a resource.
- sc\_err\_t sc\_pm\_req\_low\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode)

This function specifies the low power mode some of the resources can enter based on their state.

 sc\_err\_t sc\_pm\_req\_cpu\_low\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_power\_mode\_t mode, sc\_pm\_wake\_src\_t wake\_src)

This function requests low-power mode entry for CPU/cluster resources.

sc\_err\_t sc\_pm\_set\_cpu\_resume\_addr (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_faddr\_t address)

This function is used to set the resume address of a CPU.

- sc\_err\_t sc\_pm\_set\_cpu\_resume (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t isPrimary, sc\_faddr\_t address)

  This function is used to set parameters for CPU resume from low-power mode.
- sc\_err\_t sc\_pm\_req\_sys\_if\_power\_mode (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_sys\_if\_t sys\_
   if, sc\_pm\_power\_mode\_t lpm)

This function requests the power mode configuration for system-level interfaces including messaging units, interconnect, and memories.

#### **Clock/PLL Functions**

- sc\_err\_t sc\_pm\_set\_clock\_rate (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clock\_rate\_t \*rate)

  This function sets the rate of a resource's clock/PLL.
- sc\_err\_t sc\_pm\_get\_clock\_rate (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clock\_rate\_t \*rate)

  This function gets the rate of a resource's clock/PLL.
- sc\_err\_t sc\_pm\_clock\_enable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_bool\_t enable, sc\_bool\_t autog)

This function enables/disables a resource's clock.

sc\_err\_t sc\_pm\_set\_clock\_parent (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clk\_parent\_t parent)

This function sets the parent of a resource's clock.

sc\_err\_t sc\_pm\_get\_clock\_parent (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_pm\_clk\_t clk, sc\_pm\_clk\_parent\_t \*parent)

This function gets the parent of a resource's clock.

#### **Reset Functions**

- sc\_err\_t sc\_pm\_reset (sc\_ipc\_t ipc, sc\_pm\_reset\_type\_t type)
  - This function is used to reset the system.
- sc err t sc pm reset reason (sc ipc t ipc, sc pm reset reason t \*reason)

```
This function gets a caller's reset reason.
```

sc err t sc pm get reset part (sc ipc t ipc, sc rm pt t \*pt)

This function gets the partition that caused a reset.

sc\_err\_t sc\_pm\_boot (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rsrc\_t resource\_cpu, sc\_faddr\_t boot\_addr, sc\_rsrc\_t resource\_mu, sc\_rsrc\_t resource\_dev)

This function is used to boot a partition.

• sc\_err\_t sc\_pm\_set\_boot\_parm (sc\_ipc\_t ipc, sc\_rsrc\_t resource\_cpu, sc\_faddr\_t boot\_addr, sc\_rsrc\_t resource\_mu, sc\_rsrc\_t resource\_dev)

This function is used to change the boot parameters for a partition.

void sc\_pm\_reboot (sc\_ipc\_t ipc, sc\_pm\_reset\_type\_t type)

This function is used to reboot the caller's partition.

sc\_err\_t sc\_pm\_reboot\_partition (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pm\_reset\_type\_t type)

This function is used to reboot a partition.

sc\_err\_t sc\_pm\_reboot\_continue (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function is used to continue the reboot a partition.

• sc\_err\_t sc\_pm\_cpu\_start (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t enable, sc\_faddr\_t address)

This function is used to start/stop a CPU.

void sc\_pm\_cpu\_reset (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_faddr\_t address)

This function is used to reset a CPU.

sc\_err\_t sc\_pm\_resource\_reset (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to reset a peripheral.

sc\_bool\_t sc\_pm\_is\_partition\_started (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function returns a bool indicating if a partition was started.

#### 14.7.1 Detailed Description

Header file containing the public API for the System Controller (SC) Power Management (PM) function.

This includes functions for power state control, clock control, reset control, and wake-up event control.

# 14.8 platform/svc/rm/api.h File Reference

Header file containing the public API for the System Controller (SC) Resource Management (RM) function.

### **Macros**

#### Defines for type widths

```
    #define SC RM PARTITION W 5U
```

Width of sc\_rm\_pt\_t.

#define SC\_RM\_MEMREG\_W 6U

Width of sc\_rm\_mr\_t.

• #define SC RM DID W 4U

Width of sc\_rm\_did\_t.

#define SC RM SID W 6U

Width of sc\_rm\_sid\_t.

#define SC\_RM\_SPA\_W 2U

Width of sc\_rm\_spa\_t.

• #define SC RM PERM W 3U

Width of sc rm perm t.

#define SC RM DET W 1U

```
Width of sc_rm_det_t.
• #define SC_RM_RMSG_W 4U
Width of sc_rm_rmsg_t.
```

#### **Defines for ALL parameters**

#define SC\_RM\_PT\_ALL ((sc\_rm\_pt\_t) UINT8\_MAX)
 All partitions.

 #define SC\_RM\_MR\_ALL ((sc\_rm\_mr\_t) UINT8\_MAX)

All memory regions.

Defines for sc\_rm\_spa\_t

• #define SC RM SPA PASSTHRU 0U

Pass through (attribute driven by master)

• #define SC\_RM\_SPA\_PASSSID 1U

Pass through and output on SID.

#define SC\_RM\_SPA\_ASSERT 2U

Assert (force to be secure/privileged)

#define SC\_RM\_SPA\_NEGATE 3U

Negate (force to be non-secure/user)

#### Defines for sc\_rm\_perm\_t

• #define SC\_RM\_PERM\_NONE 0U

No access.

#define SC\_RM\_PERM\_SEC\_R 1U

Secure RO.

• #define SC\_RM\_PERM\_SECPRIV\_RW 2U

Secure privilege R/W.

• #define SC\_RM\_PERM\_SEC\_RW 3U

Secure R/W.

• #define SC RM PERM NSPRIV R 4U

Secure R/W, non-secure privilege RO.

• #define SC\_RM\_PERM\_NS\_R 5U

Secure R/W, non-secure RO.

#define SC\_RM\_PERM\_NSPRIV\_RW 6U

Secure R/W, non-secure privilege R/W.

#define SC\_RM\_PERM\_FULL 7U

Full access.

#### **Typedefs**

typedef uint8\_t sc\_rm\_pt\_t

This type is used to declare a resource partition.

typedef uint8\_t sc\_rm\_mr\_t

This type is used to declare a memory region.

typedef uint8\_t sc\_rm\_did\_t

This type is used to declare a resource domain ID used by the isolation HW.

typedef uint16 t sc rm sid t

This type is used to declare an SMMU StreamID.

typedef uint8\_t sc\_rm\_spa\_t

This type is a used to declare master transaction attributes.

typedef uint8 t sc rm perm t

This type is used to declare a resource/memory region access permission.

typedef uint8 t sc rm det t

This type is used to indicate memory region transactions should detour to the IEE.

typedef uint8 t sc rm rmsg t

This type is used to assign an RMSG value to a memory region.

#### **Functions**

#### **Partition Functions**

sc\_err\_t sc\_rm\_partition\_alloc (sc\_ipc\_t ipc, sc\_rm\_pt\_t \*pt, sc\_bool\_t secure, sc\_bool\_t isolated, sc\_bool\_t restricted, sc\_bool\_t grant, sc\_bool\_t coherent)

This function requests that the SC create a new resource partition.

sc\_err\_t sc\_rm\_set\_confidential (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_bool\_t retro)

This function makes a partition confidential.

sc\_err\_t sc\_rm\_partition\_free (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function frees a partition and assigns all resources to the caller.

sc\_rm\_did\_t sc\_rm\_get\_did (sc\_ipc\_t ipc)

This function returns the DID of a partition.

sc\_err\_t sc\_rm\_partition\_static (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rm\_did\_t did)

This function forces a partition to use a specific static DID.

sc\_err\_t sc\_rm\_partition\_lock (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt)

This function locks a partition.

sc\_err\_t sc\_rm\_get\_partition (sc\_ipc\_t ipc, sc\_rm\_pt\_t \*pt)

This function gets the partition handle of the caller.

sc\_err\_t sc\_rm\_set\_parent (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rm\_pt\_t pt\_parent)

This function sets a new parent for a partition.

sc\_err\_t sc\_rm\_move\_all (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt\_src, sc\_rm\_pt\_t pt\_dst, sc\_bool\_t move\_rsrc, sc\_bool\_t move pads)

This function moves all movable resources/pads owned by a source partition to a destination partition.

#### **Resource Functions**

sc\_err\_t sc\_rm\_assign\_resource (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rsrc\_t resource)

This function assigns ownership of a resource to a partition.

sc\_err\_t sc\_rm\_set\_resource\_movable (sc\_ipc\_t ipc, sc\_rsrc\_t resource\_fst, sc\_rsrc\_t resource\_lst, sc\_bool\_t movable)

This function flags resources as movable or not.

• sc\_err\_t sc\_rm\_set\_subsys\_rsrc\_movable (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_bool\_t movable)

This function flags all of a subsystem's resources as movable or not.

sc\_err\_t sc\_rm\_set\_master\_attributes (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_spa\_t sa, sc\_rm\_spa\_t pa, sc\_bool\_t smmu\_bypass)

This function sets attributes for a resource which is a bus master (i.e.

• sc\_err\_t sc\_rm\_set\_master\_sid (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_sid\_t sid)

This function sets the StreamID for a resource which is a bus master (i.e.

sc\_err\_t sc\_rm\_set\_peripheral\_permissions (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_pt\_t pt, sc\_rm\_perm\_t perm)

This function sets access permissions for a peripheral resource.

• sc bool t sc rm is resource owned (sc ipc t ipc, sc rsrc t resource)

This function gets ownership status of a resource.

sc\_err\_t sc\_rm\_get\_resource\_owner (sc\_ipc\_t ipc, sc\_rsrc\_t resource, sc\_rm\_pt\_t \*pt)

This function is used to get the owner of a resource.

sc\_bool\_t sc\_rm\_is\_resource\_master (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to test if a resource is a bus master.

sc\_bool\_t sc\_rm\_is\_resource\_peripheral (sc\_ipc\_t ipc, sc\_rsrc\_t resource)

This function is used to test if a resource is a peripheral.

sc err t sc rm get resource info (sc ipc t ipc, sc rsrc t resource, sc rm sid t \*sid)

This function is used to obtain info about a resource.

#### **Memory Region Functions**

- sc\_err\_t sc\_rm\_memreg\_alloc (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

  This function requests that the SC create a new memory region.
- sc\_err\_t sc\_rm\_memreg\_split (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_mr\_t \*mr\_ret, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

This function requests that the SC split an existing memory region.

- sc\_err\_t sc\_rm\_memreg\_frag (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr\_ret, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

  This function requests that the SC fragment a memory region.
- sc\_err\_t sc\_rm\_memreg\_free (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr)

This function frees a memory region.

- sc\_err\_t sc\_rm\_find\_memreg (sc\_ipc\_t ipc, sc\_rm\_mr\_t \*mr, sc\_faddr\_t addr\_start, sc\_faddr\_t addr\_end)

  Internal SC function to find a memory region.
- sc\_err\_t sc\_rm\_assign\_memreg (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_rm\_mr\_t mr)

This function assigns ownership of a memory region.

- sc\_err\_t sc\_rm\_set\_memreg\_permissions (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_pt\_t pt, sc\_rm\_perm\_t perm)

  This function sets access permissions for a memory region.
- sc\_err\_t sc\_rm\_set\_memreg\_iee (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_rm\_det\_t det, sc\_rm\_rmsg\_t rmsg)

This function configures the IEE parameters for a memory region.

sc\_bool\_t sc\_rm\_is\_memreg\_owned (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr)

This function gets ownership status of a memory region.

• sc\_err\_t sc\_rm\_get\_memreg\_info (sc\_ipc\_t ipc, sc\_rm\_mr\_t mr, sc\_faddr\_t \*addr\_start, sc\_faddr\_t \*addr\_← end)

This function is used to obtain info about a memory region.

#### **Pad Functions**

sc\_err\_t sc\_rm\_assign\_pad (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_pad\_t pad)

This function assigns ownership of a pad to a partition.

• sc\_err\_t sc\_rm\_set\_pad\_movable (sc\_ipc\_t ipc, sc\_pad\_t pad\_fst, sc\_pad\_t pad\_lst, sc\_bool\_t movable)

This function flags pads as movable or not.

• sc\_bool\_t sc\_rm\_is\_pad\_owned (sc\_ipc\_t ipc, sc\_pad\_t pad)

This function gets ownership status of a pad.

#### **Debug Functions**

void sc\_rm\_dump (sc\_ipc\_t ipc)

This function dumps the RM state for debug.

#### 14.8.1 Detailed Description

Header file containing the public API for the System Controller (SC) Resource Management (RM) function.

This includes functions for partitioning resources, pads, and memory regions.

# 14.9 platform/svc/seco/api.h File Reference

Header file containing the public API for the System Controller (SC) Security (SECO) function.

#### **Macros**

#### Defines for sc\_seco\_auth\_cmd\_t

- #define SC SECO AUTH CONTAINER 0U
  - Authenticate container.
- #define SC\_SECO\_VERIFY\_IMAGE 1U
  - Verify image.
- #define SC SECO REL CONTAINER 2U
  - Release container.
- #define SC\_SECO\_AUTH\_SECO\_FW 3U
  - SECO Firmware.
- #define SC SECO AUTH HDMI TX FW 4U
  - HDMI TX Firmware.
- #define SC\_SECO\_AUTH\_HDMI\_RX\_FW 5U
  - HDMI RX Firmware.
- #define SC\_SECO\_EVERIFY\_IMAGE 6U

Enhanced verify image.

#### Defines for seco\_rng\_stat\_t

- #define SC\_SECO\_RNG\_STAT\_UNAVAILABLE 0U
  - Unable to initialize the RNG.
- #define SC\_SECO\_RNG\_STAT\_INPROGRESS 1U
  - Initialization is on-going.
- #define SC\_SECO\_RNG\_STAT\_READY 2U

Initialized.

## **Typedefs**

- · typedef uint8 t sc seco auth cmd t
  - This type is used to issue SECO authenticate commands.
- typedef uint32\_t sc\_seco\_rng\_stat\_t

This type is used to return the RNG initialization status.

#### **Functions**

#### Image Functions

sc\_err\_t sc\_seco\_image\_load (sc\_ipc\_t ipc, sc\_faddr\_t addr\_src, sc\_faddr\_t addr\_dst, uint32\_t len, sc\_bool\_t fw)

This function loads a SECO image.

• sc\_err\_t sc\_seco\_authenticate (sc\_ipc\_t ipc, sc\_seco\_auth\_cmd\_t cmd, sc\_faddr\_t addr)

This function is used to authenticate a SECO image or command.

• sc\_err\_t sc\_seco\_enh\_authenticate (sc\_ipc\_t ipc, sc\_seco\_auth\_cmd\_t cmd, sc\_faddr\_t addr, uint32\_t mask1, uint32\_t mask2)

This function is used to authenticate a SECO image or command.

#### **Lifecycle Functions**

• sc err t sc seco forward lifecycle (sc ipc t ipc, uint32 t change)

This function updates the lifecycle of the device.

sc err t sc seco return lifecycle (sc ipc t ipc, sc faddr t addr)

This function updates the lifecycle to one of the return lifecycles.

sc\_err\_t sc\_seco\_commit (sc\_ipc\_t ipc, uint32\_t \*info)

This function is used to commit into the fuses any new SRK revocation and FW version information that have been found in the primary and secondary containers.

#### **Attestation Functions**

sc\_err\_t sc\_seco\_attest\_mode (sc\_ipc\_t ipc, uint32\_t mode)

This function is used to set the attestation mode.

sc\_err\_t sc\_seco\_attest (sc\_ipc\_t ipc, uint64\_t nonce)

This function is used to request attestation.

sc\_err\_t sc\_seco\_get\_attest\_pkey (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to retrieve the attestation public key.

sc\_err\_t sc\_seco\_get\_attest\_sign (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to retrieve attestation signature and parameters.

sc\_err\_t sc\_seco\_attest\_verify (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function is used to verify attestation.

#### **Key Functions**

sc\_err\_t sc\_seco\_gen\_key\_blob (sc\_ipc\_t ipc, uint32\_t id, sc\_faddr\_t load\_addr, sc\_faddr\_t export\_addr, uint16\_t max\_size)

This function is used to generate a SECO key blob.

sc\_err\_t sc\_seco\_load\_key (sc\_ipc\_t ipc, uint32\_t id, sc\_faddr\_t addr)

This function is used to load a SECO key.

#### **Manufacturing Protection Functions**

sc\_err\_t sc\_seco\_get\_mp\_key (sc\_ipc\_t ipc, sc\_faddr\_t dst\_addr, uint16\_t dst\_size)

This function is used to get the manufacturing protection public key.

sc\_err\_t sc\_seco\_update\_mpmr (sc\_ipc\_t ipc, sc\_faddr\_t addr, uint8\_t size, uint8\_t lock)

This function is used to update the manufacturing protection message register.

 sc\_err\_t sc\_seco\_get\_mp\_sign (sc\_ipc\_t ipc, sc\_faddr\_t msg\_addr, uint16\_t msg\_size, sc\_faddr\_t dst\_addr, uint16 t dst size) This function is used to get the manufacturing protection signature.

#### **Debug Functions**

```
    void sc seco build info (sc ipc t ipc, uint32 t *version, uint32 t *commit)
```

This function is used to return the SECO FW build info.

- sc\_err\_t sc\_seco\_chip\_info (sc\_ipc\_t ipc, uint16\_t \*lc, uint16\_t \*monotonic, uint32\_t \*uid\_l, uint32\_t \*uid\_h)

  This function is used to return SECO chip info.
- sc\_err\_t sc\_seco\_enable\_debug (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function securely enables debug.

sc\_err\_t sc\_seco\_get\_event (sc\_ipc\_t ipc, uint8\_t idx, uint32\_t \*event)

This function is used to return an event from the SECO error log.

#### **Miscellaneous Functions**

sc\_err\_t sc\_seco\_fuse\_write (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function securely writes a group of fuse words.

sc\_err\_t sc\_seco\_patch (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function applies a patch.

sc\_err\_t sc\_seco\_set\_mono\_counter\_partition (sc\_ipc\_t ipc, uint16\_t \*she)

This function partitions the monotonic counter.

• sc\_err\_t sc\_seco\_set\_fips\_mode (sc\_ipc\_t ipc, uint8\_t mode, uint32\_t \*reason)

This function configures the SECO in FIPS mode.

sc\_err\_t sc\_seco\_start\_rng (sc\_ipc\_t ipc, sc\_seco\_rng\_stat\_t \*status)

This function starts the random number generator.

sc\_err\_t sc\_seco\_sab\_msg (sc\_ipc\_t ipc, sc\_faddr\_t addr)

This function sends a generic signed message to the SECO SHE/HSM components.

sc\_err\_t sc\_seco\_secvio\_enable (sc\_ipc\_t ipc)

This function is used to enable security violation and tamper interrupts.

sc\_err\_t sc\_seco\_secvio\_config (sc\_ipc\_t ipc, uint8\_t id, uint8\_t access, uint32\_t \*data0, uint32\_t \*data1, uint32\_t \*data2, uint32\_t \*data3, uint32\_t \*data4, uint8\_t size)

This function is used to read/write SNVS security violation and tamper registers.

sc\_err\_t sc\_seco\_secvio\_dgo\_config (sc\_ipc\_t ipc, uint8\_t id, uint8\_t access, uint32\_t \*data)

This function is used to read/write SNVS security violation and tamper DGO registers.

#### 14.9.1 Detailed Description

Header file containing the public API for the System Controller (SC) Security (SECO) function.

# 14.10 platform/svc/timer/api.h File Reference

Header file containing the public API for the System Controller (SC) Timer function.

#### Macros

#### Defines for type widths

#define SC\_TIMER\_ACTION\_W 3U
 Width of sc\_timer\_wdog\_action\_t.

#### Defines for sc\_timer\_wdog\_action\_t

 #define SC\_TIMER\_WDOG\_ACTION\_PARTITION 0U Reset partition.

#define SC TIMER WDOG ACTION WARM 1U

Warm reset system.

#define SC\_TIMER\_WDOG\_ACTION\_COLD 2U

Cold reset system.

#define SC\_TIMER\_WDOG\_ACTION\_BOARD 3U

Reset hoard

#define SC TIMER WDOG ACTION IRQ 4U

Only generate IRQs.

#### **Typedefs**

typedef uint8\_t sc\_timer\_wdog\_action\_t

This type is used to configure the watchdog action.

typedef uint32\_t sc\_timer\_wdog\_time\_t

This type is used to declare a watchdog time value in milliseconds.

#### **Functions**

#### **Watchdog Functions**

sc\_err\_t sc\_timer\_set\_wdog\_timeout (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t timeout)

This function sets the watchdog timeout in milliseconds.

sc\_err\_t sc\_timer\_set\_wdog\_pre\_timeout (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t pre\_timeout)

This function sets the watchdog pre-timeout in milliseconds.

sc\_err\_t sc\_timer\_set\_wdog\_window (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t window)

This function sets the watchdog window in milliseconds.

sc err t sc timer start wdog (sc ipc t ipc, sc bool t lock)

This function starts the watchdog.

sc\_err\_t sc\_timer\_stop\_wdog (sc\_ipc\_t ipc)

This function stops the watchdog if it is not locked.

sc\_err\_t sc\_timer\_ping\_wdog (sc\_ipc\_t ipc)

This function pings (services, kicks) the watchdog resetting the time before expiration back to the timeout.

sc\_err\_t sc\_timer\_get\_wdog\_status (sc\_ipc\_t ipc, sc\_timer\_wdog\_time\_t \*timeout, sc\_timer\_wdog\_time\_t \*max\_timeout, sc\_timer\_wdog\_time\_t \*remaining\_time)

This function gets the status of the watchdog.

sc\_err\_t sc\_timer\_pt\_get\_wdog\_status (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_bool\_t \*enb, sc\_timer\_wdog\_time\_t \*timeout, sc\_timer\_wdog\_time\_t \*remaining\_time)

This function gets the status of the watchdog of a partition.

• sc\_err\_t sc\_timer\_set\_wdog\_action (sc\_ipc\_t ipc, sc\_rm\_pt\_t pt, sc\_timer\_wdog\_action\_t action)

This function configures the action to be taken when a watchdog expires.

#### Real-Time Clock (RTC) Functions

sc\_err\_t sc\_timer\_set\_rtc\_time (sc\_ipc\_t ipc, uint16\_t year, uint8\_t mon, uint8\_t day, uint8\_t hour, uint8\_t min, uint8\_t sec)

This function sets the RTC time.

• sc\_err\_t sc\_timer\_get\_rtc\_time (sc\_ipc\_t ipc, uint16\_t \*year, uint8\_t \*mon, uint8\_t \*day, uint8\_t \*hour, uint8\_t \*min, uint8\_t \*sec)

This function gets the RTC time.

• sc\_err\_t sc\_timer\_get\_rtc\_sec1970 (sc\_ipc\_t ipc, uint32\_t \*sec)

This function gets the RTC time in seconds since 1/1/1970.

• sc\_err\_t sc\_timer\_set\_rtc\_alarm (sc\_ipc\_t ipc, uint16\_t year, uint8\_t mon, uint8\_t day, uint8\_t hour, uint8\_t min, uint8\_t sec)

This function sets the RTC alarm.

• sc err t sc timer set rtc periodic alarm (sc ipc t ipc, uint32 t sec)

This function sets the RTC alarm (periodic mode).

sc\_err\_t sc\_timer\_cancel\_rtc\_alarm (sc\_ipc\_t ipc)

This function cancels the RTC alarm.

sc\_err\_t sc\_timer\_set\_rtc\_calb (sc\_ipc\_t ipc, int8\_t count)

This function sets the RTC calibration value.

#### System Counter (SYSCTR) Functions

• sc\_err\_t sc\_timer\_set\_sysctr\_alarm (sc\_ipc\_t ipc, uint64\_t ticks)

This function sets the SYSCTR alarm.

sc\_err\_t sc\_timer\_set\_sysctr\_periodic\_alarm (sc\_ipc\_t ipc, uint64\_t ticks)

This function sets the SYSCTR alarm (periodic mode).

sc\_err\_t sc\_timer\_cancel\_sysctr\_alarm (sc\_ipc\_t ipc)

This function cancels the SYSCTR alarm.

#### 14.10.1 Detailed Description

Header file containing the public API for the System Controller (SC) Timer function.

| 286 | File Documentation |
|-----|--------------------|
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |
|     |                    |

# Index

| ipc.h                            | sc_pad_get_wakeup, 134             |
|----------------------------------|------------------------------------|
| sc_ipc_close, 245                | sc_pad_iso_t, 131                  |
| sc_ipc_open, 245                 | sc_pad_set, 137                    |
| sc_ipc_read, 246                 | sc_pad_set_all, 135                |
| sc_ipc_write, 246                | sc_pad_set_gp, 133                 |
| IRQ: Interrupt Service, 107      | sc_pad_set_gp_28fdsoi, 138         |
| sc_irq_enable, 110               | sc_pad_set_gp_28fdsoi_comp, 141    |
| sc_irq_status, 110               | sc_pad_set_gp_28fdsoi_hsic, 140    |
|                                  | sc_pad_set_mux, 131                |
| MISC: Miscellaneous Service, 112 | sc_pad_set_wakeup, 134             |
| sc_misc_api_ver, 118             | platform/config/mx8qm/pads.h, 235  |
| sc_misc_board_ioctl, 125         | platform/main/ipc.h, 245           |
| sc_misc_boot_done, 120           | platform/main/types.h, 246         |
| sc_misc_boot_status, 119         | platform/svc/irq/api.h, 264        |
| sc_misc_build_info, 117          | platform/svc/misc/api.h, 267       |
| sc_misc_debug_out, 117           | platform/svc/pad/api.h, 269        |
| sc_misc_get_boot_container, 124  | platform/svc/pm/api.h, 272         |
| sc_misc_get_boot_dev, 123        | platform/svc/rm/api.h, 277         |
| sc_misc_get_boot_type, 123       | platform/svc/seco/api.h, 281       |
| sc_misc_get_button_status, 124   | platform/svc/timer/api.h, 283      |
| sc_misc_get_control, 115         | PM: Power Management Service, 144  |
| sc_misc_get_temp, 122            | sc_pm_boot, 162                    |
| sc_misc_otp_fuse_read, 120       | sc_pm_clock_enable, 158            |
| sc_misc_otp_fuse_write, 121      | sc_pm_cpu_reset, 165               |
| sc_misc_rompatch_checksum, 125   | sc_pm_cpu_start, 165               |
| sc_misc_set_ari, 119             | sc_pm_get_clock_parent, 159        |
| sc_misc_set_control, 114         | sc_pm_get_clock_rate, 157          |
| sc_misc_set_dma_group, 116       | sc_pm_get_reset_part, 161          |
| sc_misc_set_max_dma_group, 115   | sc_pm_get_resource_power_mode, 153 |
| sc_misc_set_temp, 121            | sc_pm_get_sys_power_mode, 151      |
| sc_misc_unique_id, 118           | sc_pm_is_partition_started, 167    |
| sc_misc_waveform_capture, 117    | sc_pm_partition_wake, 151          |
| PAD: Pad Service, 126            | sc_pm_power_mode_t, 149            |
| sc_pad_28fdsoi_dse_t, 131        | sc_pm_reboot, 163                  |
| sc_pad_28fdsoi_ps_t, 131         | sc_pm_reboot_continue, 164         |
| sc_pad_28fdsoi_pus_t, 131        | sc pm reboot partition, 164        |
| sc_pad_config, 138               | sc_pm_req_cpu_low_power_mode, 154  |
| sc_pad_config_t, 131             | sc_pm_req_low_power_mode, 154      |
| sc_pad_get, 137                  | sc_pm_req_sys_if_power_mode, 156   |
| sc_pad_get_all, 136              | sc_pm_reset, 160                   |
| sc_pad_get_gp, 133               | sc_pm_reset_reason, 161            |
| sc_pad_get_gp_28fdsoi, 139       | sc pm resource reset, 166          |
| sc_pad_get_gp_28fdsoi_comp, 142  | sc_pm_set_boot_parm, 162           |
| sc_pad_get_gp_28fdsoi_hsic, 140  | sc_pm_set_clock_parent, 159        |
| sc_pad_get_mux, 132              | sc_pm_set_clock_rate, 157          |
| <b>→ →</b> - ,                   | <u> </u>                           |

| sc_pm_set_cpu_resume, 156              | sc_irq_status                                              |
|----------------------------------------|------------------------------------------------------------|
| sc_pm_set_cpu_resume_addr, 155         | IRQ: Interrupt Service, 110                                |
| sc_pm_set_partition_power_mode, 150    | sc_misc_api_ver                                            |
| sc_pm_set_resource_power_mode, 152     | MISC: Miscellaneous Service, 118                           |
| sc_pm_set_resource_power_mode_all, 153 | sc_misc_board_ioctl                                        |
| sc_pm_set_sys_power_mode, 150          | MISC: Miscellaneous Service, 125                           |
| RM: Resource Management Service, 168   | sc_misc_boot_done                                          |
| sc_rm_assign_memreg, 190               | MISC: Miscellaneous Service, 120                           |
| sc_rm_assign_pad, 193                  | sc_misc_boot_status                                        |
| sc_rm_assign_resource, 180             | MISC: Miscellaneous Service, 119                           |
| sc_rm_dump, 195                        | sc_misc_build_info                                         |
| sc_rm_find_memreg, 190                 | MISC: Miscellaneous Service, 117                           |
| sc_rm_get_did, 176                     | sc_misc_debug_out                                          |
| sc_rm_get_memreg_info, 193             | MISC: Miscellaneous Service, 117                           |
| sc_rm_get_partition, 178               | sc_misc_get_boot_container                                 |
| sc_rm_get_resource_info, 186           | MISC: Miscellaneous Service, 124                           |
| sc_rm_get_resource_owner, 185          | sc_misc_get_boot_dev                                       |
| sc_rm_is_memreg_owned, 192             | MISC: Miscellaneous Service, 123                           |
| sc_rm_is_pad_owned, 195                | sc_misc_get_boot_type                                      |
| sc rm is resource master, 185          | MISC: Miscellaneous Service, 123                           |
| sc_rm_is_resource_owned, 184           | sc_misc_get_button_status                                  |
| sc_rm_is_resource_peripheral, 186      | MISC: Miscellaneous Service, 124                           |
| sc_rm_memreg_alloc, 187                | sc_misc_get_control                                        |
| sc_rm_memreg_frag, 188                 | MISC: Miscellaneous Service, 115                           |
| sc_rm_memreg_free, 189                 | sc_misc_get_temp                                           |
| sc_rm_memreg_split, 188                | MISC: Miscellaneous Service, 122                           |
| sc_rm_move_all, 179                    | sc_misc_otp_fuse_read                                      |
| sc_rm_partition_alloc, 174             | MISC: Miscellaneous Service, 120                           |
| sc_rm_partition_free, 176              | sc_misc_otp_fuse_write                                     |
| sc_rm_partition_lock, 177              | MISC: Miscellaneous Service, 121 sc_misc_rompatch_checksum |
| sc_rm_partition_static, 177            | MISC: Miscellaneous Service, 125                           |
| sc_rm_perm_t, 174                      | sc misc set ari                                            |
| sc_rm_rmsg_t, 174                      | MISC: Miscellaneous Service, 119                           |
| sc_rm_set_confidential, 175            | sc misc set control                                        |
| sc_rm_set_master_attributes, 182       | MISC: Miscellaneous Service, 114                           |
| sc_rm_set_master_sid, 183              | sc misc set dma group                                      |
| sc_rm_set_memreg_iee, 192              | MISC: Miscellaneous Service, 116                           |
| sc_rm_set_memreg_permissions, 191      | sc_misc_set_max_dma_group                                  |
| sc_rm_set_pad_movable, 194             | MISC: Miscellaneous Service, 115                           |
| sc_rm_set_parent, 178                  | sc_misc_set_temp                                           |
| sc_rm_set_peripheral_permissions, 183  | MISC: Miscellaneous Service, 121                           |
| sc_rm_set_resource_movable, 181        | sc_misc_unique_id                                          |
| sc_rm_set_subsys_rsrc_movable, 181     | MISC: Miscellaneous Service, 118                           |
| sc_ipc_close                           | sc_misc_waveform_capture                                   |
| ipc.h, 245                             | MISC: Miscellaneous Service, 117                           |
| sc_ipc_open                            | SC_P_ALL                                                   |
| ipc.h, 245                             | types.h, 263                                               |
| sc_ipc_read                            | sc_pad_28fdsoi_dse_t                                       |
| ipc.h, 246                             | PAD: Pad Service, 131                                      |
| sc_ipc_write                           | sc_pad_28fdsoi_ps_t                                        |
| ipc.h, 246                             | PAD: Pad Service, 131                                      |
| sc_irq_enable                          | sc_pad_28fdsoi_pus_t                                       |
| IRQ: Interrupt Service, 110            | PAD: Pad Service, 131                                      |

| sc_pad_config                     | sc_pm_get_resource_power_mode                        |
|-----------------------------------|------------------------------------------------------|
| PAD: Pad Service, 138             | PM: Power Management Service, 153                    |
| sc_pad_config_t                   | sc_pm_get_sys_power_mode                             |
| PAD: Pad Service, 131             | PM: Power Management Service, 151                    |
| sc_pad_get                        | sc_pm_is_partition_started                           |
| PAD: Pad Service, 137             | PM: Power Management Service, 167                    |
| sc_pad_get_all                    | sc_pm_partition_wake                                 |
| PAD: Pad Service, 136             | PM: Power Management Service, 151                    |
| sc_pad_get_gp                     | sc_pm_power_mode_t                                   |
| PAD: Pad Service, 133             | PM: Power Management Service, 149                    |
| sc_pad_get_gp_28fdsoi             | sc_pm_reboot                                         |
| PAD: Pad Service, 139             | PM: Power Management Service, 163                    |
| sc_pad_get_gp_28fdsoi_comp        | sc_pm_reboot_continue                                |
| PAD: Pad Service, 142             | PM: Power Management Service, 164                    |
| sc_pad_get_gp_28fdsoi_hsic        | sc_pm_reboot_partition                               |
| PAD: Pad Service, 140             | PM: Power Management Service, 164                    |
| sc_pad_get_mux                    | sc_pm_req_cpu_low_power_mode                         |
| PAD: Pad Service, 132             | PM: Power Management Service, 154                    |
| sc_pad_get_wakeup                 | sc_pm_req_low_power_mode                             |
| PAD: Pad Service, 134             | PM: Power Management Service, 154                    |
| sc_pad_iso_t                      | sc_pm_req_sys_if_power_mode                          |
| PAD: Pad Service, 131             | PM: Power Management Service, 156                    |
| sc_pad_set PAD: Pad Service, 137  | sc_pm_reset PM: Power Management Service, 160        |
| sc_pad_set_all                    | •                                                    |
| PAD: Pad Service, 135             | sc_pm_reset_reason PM: Power Management Service, 161 |
| sc_pad_set_gp                     | sc_pm_resource_reset                                 |
| PAD: Pad Service, 133             | PM: Power Management Service, 166                    |
| sc_pad_set_gp_28fdsoi             | sc_pm_set_boot_parm                                  |
| PAD: Pad Service, 138             | PM: Power Management Service, 162                    |
| sc_pad_set_gp_28fdsoi_comp        | sc_pm_set_clock_parent                               |
| PAD: Pad Service, 141             | PM: Power Management Service, 159                    |
| sc_pad_set_gp_28fdsoi_hsic        | sc_pm_set_clock_rate                                 |
| PAD: Pad Service, 140             | PM: Power Management Service, 157                    |
| sc_pad_set_mux                    | sc_pm_set_cpu_resume                                 |
| PAD: Pad Service, 131             | PM: Power Management Service, 156                    |
| sc_pad_set_wakeup                 | sc_pm_set_cpu_resume_addr                            |
| PAD: Pad Service, 134             | PM: Power Management Service, 155                    |
| sc_pad_t                          | sc_pm_set_partition_power_mode                       |
| types.h, 264                      | PM: Power Management Service, 150                    |
| sc_pm_boot                        | sc_pm_set_resource_power_mode                        |
| PM: Power Management Service, 162 | PM: Power Management Service, 152                    |
| sc_pm_clock_enable                | sc_pm_set_resource_power_mode_all                    |
| PM: Power Management Service, 158 | PM: Power Management Service, 153                    |
| sc_pm_cpu_reset                   | sc_pm_set_sys_power_mode                             |
| PM: Power Management Service, 165 | PM: Power Management Service, 150                    |
| sc_pm_cpu_start                   | SC_R_NONE                                            |
| PM: Power Management Service, 165 | types.h, 263                                         |
| sc_pm_get_clock_parent            | sc_rm_assign_memreg                                  |
| PM: Power Management Service, 159 | RM: Resource Management Service, 190                 |
| sc_pm_get_clock_rate              | sc_rm_assign_pad                                     |
| PM: Power Management Service, 157 | RM: Resource Management Service, 193                 |
| sc_pm_get_reset_part              | sc_rm_assign_resource                                |
| PM: Power Management Service, 161 | RM: Resource Management Service, 180                 |

| sc_rm_dump                           | sc_rm_set_memreg_permissions         |
|--------------------------------------|--------------------------------------|
| RM: Resource Management Service, 195 | RM: Resource Management Service, 191 |
| sc_rm_find_memreg                    | sc_rm_set_pad_movable                |
| RM: Resource Management Service, 190 | RM: Resource Management Service, 194 |
| sc_rm_get_did                        | sc_rm_set_parent                     |
| RM: Resource Management Service, 176 | RM: Resource Management Service, 178 |
| sc_rm_get_memreg_info                | sc_rm_set_peripheral_permissions     |
| RM: Resource Management Service, 193 | RM: Resource Management Service, 183 |
| sc_rm_get_partition                  | sc_rm_set_resource_movable           |
| RM: Resource Management Service, 178 | RM: Resource Management Service, 181 |
| sc_rm_get_resource_info              | sc rm set subsys rsrc movable        |
| RM: Resource Management Service, 186 | RM: Resource Management Service, 181 |
| sc_rm_get_resource_owner             | sc_rsrc_t                            |
| RM: Resource Management Service, 185 | types.h, 264                         |
| sc_rm_is_memreg_owned                | sc_seco_attest                       |
| RM: Resource Management Service, 192 | SECO: Security Service, 206          |
| sc_rm_is_pad_owned                   | sc_seco_attest_mode                  |
| RM: Resource Management Service, 195 | SECO: Security Service, 205          |
| sc_rm_is_resource_master             | sc_seco_attest_verify                |
| RM: Resource Management Service, 185 | SECO: Security Service, 208          |
| sc_rm_is_resource_owned              | sc_seco_authenticate                 |
| RM: Resource Management Service, 184 | SECO: Security Service, 201          |
|                                      | sc_seco_build_info                   |
| sc_rm_is_resource_peripheral         |                                      |
| RM: Resource Management Service, 186 | SECO: Security Service, 212          |
| sc_rm_memreg_alloc                   | sc_seco_chip_info                    |
| RM: Resource Management Service, 187 | SECO: Security Service, 213          |
| sc_rm_memreg_frag                    | sc_seco_commit                       |
| RM: Resource Management Service, 188 | SECO: Security Service, 204          |
| sc_rm_memreg_free                    | sc_seco_enable_debug                 |
| RM: Resource Management Service, 189 | SECO: Security Service, 213          |
| sc_rm_memreg_split                   | sc_seco_enh_authenticate             |
| RM: Resource Management Service, 188 | SECO: Security Service, 202          |
| sc_rm_move_all                       | sc_seco_forward_lifecycle            |
| RM: Resource Management Service, 179 | SECO: Security Service, 203          |
| sc_rm_partition_alloc                | sc_seco_fuse_write                   |
| RM: Resource Management Service, 174 | SECO: Security Service, 215          |
| sc_rm_partition_free                 | sc_seco_gen_key_blob                 |
| RM: Resource Management Service, 176 | SECO: Security Service, 209          |
| sc_rm_partition_lock                 | sc_seco_get_attest_pkey              |
| RM: Resource Management Service, 177 | SECO: Security Service, 206          |
| sc_rm_partition_static               | sc_seco_get_attest_sign              |
| RM: Resource Management Service, 177 | SECO: Security Service, 207          |
| sc_rm_perm_t                         | sc_seco_get_event                    |
| RM: Resource Management Service, 174 | SECO: Security Service, 214          |
| sc_rm_rmsg_t                         | sc_seco_get_mp_key                   |
| RM: Resource Management Service, 174 | SECO: Security Service, 210          |
| sc_rm_set_confidential               | sc_seco_get_mp_sign                  |
| RM: Resource Management Service, 175 | SECO: Security Service, 212          |
| sc_rm_set_master_attributes          | sc_seco_image_load                   |
| RM: Resource Management Service, 182 | SECO: Security Service, 200          |
| sc_rm_set_master_sid                 | sc_seco_load_key                     |
| RM: Resource Management Service, 183 | SECO: Security Service, 209          |
| sc_rm_set_memreg_iee                 | sc_seco_patch                        |
| RM: Resource Management Service, 192 | SECO: Security Service, 215          |

| an annu watuwa lifa ayala          | an timen atom under                     |
|------------------------------------|-----------------------------------------|
| sc_seco_return_lifecycle           | sc_timer_stop_wdog                      |
| SECO: Security Service, 204        | TIMER: Timer Service, 225               |
| sc_seco_sab_msg                    | SECO: Security Service, 196             |
| SECO: Security Service, 218        | sc_seco_attest, 206                     |
| sc_seco_secvio_config              | sc_seco_attest_mode, 205                |
| SECO: Security Service, 220        | sc_seco_attest_verify, 208              |
| sc_seco_secvio_dgo_config          | sc_seco_authenticate, 201               |
| SECO: Security Service, 220        | sc_seco_build_info, 212                 |
| sc_seco_secvio_enable              | sc_seco_chip_info, 213                  |
| SECO: Security Service, 219        | sc_seco_commit, 204                     |
| sc_seco_set_fips_mode              | sc_seco_enable_debug, 213               |
| SECO: Security Service, 217        | sc_seco_enh_authenticate, 202           |
| sc_seco_set_mono_counter_partition | sc_seco_forward_lifecycle, 203          |
| SECO: Security Service, 216        | sc_seco_fuse_write, 215                 |
| sc_seco_start_rng                  | sc_seco_gen_key_blob, 209               |
| SECO: Security Service, 218        | sc_seco_get_attest_pkey, 206            |
| sc_seco_update_mpmr                | sc_seco_get_attest_sign, 207            |
| SECO: Security Service, 211        | sc_seco_get_event, 214                  |
| sc_timer_cancel_rtc_alarm          | sc_seco_get_mp_key, 210                 |
| TIMER: Timer Service, 231          | sc_seco_get_mp_sign, 212                |
| sc_timer_cancel_sysctr_alarm       | sc_seco_image_load, 200                 |
| TIMER: Timer Service, 233          | sc_seco_load_key, 209                   |
| sc_timer_get_rtc_sec1970           | sc_seco_patch, 215                      |
| TIMER: Timer Service, 229          | sc seco return lifecycle, 204           |
| sc_timer_get_rtc_time              | sc_seco_sab_msg, 218                    |
| TIMER: Timer Service, 229          | sc_seco_secvio_config, 220              |
| sc_timer_get_wdog_status           | sc_seco_secvio_dgo_config, 220          |
| TIMER: Timer Service, 226          | sc_seco_secvio_enable, 219              |
| sc_timer_ping_wdog                 | sc_seco_set_fips_mode, 217              |
| TIMER: Timer Service, 226          | sc_seco_set_mono_counter_partition, 216 |
| sc_timer_pt_get_wdog_status        | sc_seco_start_rng, 218                  |
| TIMER: Timer Service, 227          | sc_seco_update_mpmr, 211                |
| sc_timer_set_rtc_alarm             | 00_0000_upuato_mp, 211                  |
| TIMER: Timer Service, 230          | TIMER: Timer Service, 222               |
| sc timer set rtc calb              | sc_timer_cancel_rtc_alarm, 231          |
| TIMER: Timer Service, 231          | sc_timer_cancel_sysctr_alarm, 233       |
|                                    | sc_timer_get_rtc_sec1970, 229           |
| sc_timer_set_rtc_periodic_alarm    |                                         |
| TIMER: Timer Service, 230          | sc_timer_get_rtc_time, 229              |
| sc_timer_set_rtc_time              | sc_timer_get_wdog_status, 226           |
| TIMER: Timer Service, 228          | sc_timer_ping_wdog, 226                 |
| sc_timer_set_sysctr_alarm          | sc_timer_pt_get_wdog_status, 227        |
| TIMER: Timer Service, 232          | sc_timer_set_rtc_alarm, 230             |
| sc_timer_set_sysctr_periodic_alarm | sc_timer_set_rtc_calb, 231              |
| TIMER: Timer Service, 232          | sc_timer_set_rtc_periodic_alarm, 230    |
| sc_timer_set_wdog_action           | sc_timer_set_rtc_time, 228              |
| TIMER: Timer Service, 227          | sc_timer_set_sysctr_alarm, 232          |
| sc_timer_set_wdog_pre_timeout      | sc_timer_set_sysctr_periodic_alarm, 232 |
| TIMER: Timer Service, 224          | sc_timer_set_wdog_action, 227           |
| sc_timer_set_wdog_timeout          | sc_timer_set_wdog_pre_timeout, 224      |
| TIMER: Timer Service, 223          | sc_timer_set_wdog_timeout, 223          |
| sc_timer_set_wdog_window           | sc_timer_set_wdog_window, 224           |
| TIMER: Timer Service, 224          | sc_timer_start_wdog, 225                |
| sc_timer_start_wdog                | sc_timer_stop_wdog, 225                 |
| TIMER: Timer Service, 225          | types.h                                 |
|                                    |                                         |

SC\_P\_ALL, 263 sc\_pad\_t, 264 SC\_R\_NONE, 263 sc\_rsrc\_t, 264