misc: scu_api: Add SCFW API to get the index of boot container set
authorYe Li <ye.li@nxp.com>
Tue, 9 Jun 2020 10:34:42 +0000 (03:34 -0700)
committerStefano Babic <sbabic@denx.de>
Thu, 16 Jul 2020 09:19:50 +0000 (11:19 +0200)
Add SCFW API sc_misc_get_boot_container to get current boot container
set index.
The index value returns 1 for primary container set, 2 for secondary
container set.

Signed-off-by: Ye Li <ye.li@nxp.com>
Reviewed-by: Peng Fan <peng.fan@nxp.com>
arch/arm/include/asm/arch-imx8/sci/rpc.h
arch/arm/include/asm/arch-imx8/sci/sci.h
drivers/misc/imx8/scu_api.c

index c1a9c353ba0fc62cb07b9c7d273fa93592457e7b..9f55904f4422acf49d8ac2827b62f1bb3832516a 100644 (file)
@@ -115,6 +115,7 @@ struct sc_rpc_msg_s {
 #define MISC_FUNC_GET_TEMP                     13U
 #define MISC_FUNC_GET_BOOT_DEV                 16U
 #define MISC_FUNC_GET_BUTTON_STATUS            18U
+#define MISC_FUNC_GET_BOOT_CONTAINER   36U
 
 /* PAD RPC */
 #define PAD_FUNC_UNKNOWN                       0
index f91f7cc58760b9c76111df14e3e411104f31a91c..1c29209b3990645abff62beec73d3d4dc7ec16d0 100644 (file)
@@ -82,6 +82,7 @@ int sc_misc_get_control(sc_ipc_t ipc, sc_rsrc_t resource, sc_ctrl_t ctrl,
                        u32 *val);
 void sc_misc_get_boot_dev(sc_ipc_t ipc, sc_rsrc_t *boot_dev);
 void sc_misc_boot_status(sc_ipc_t ipc, sc_misc_boot_status_t status);
+int sc_misc_get_boot_container(sc_ipc_t ipc, u8 *idx);
 void sc_misc_build_info(sc_ipc_t ipc, u32 *build, u32 *commit);
 int sc_misc_otp_fuse_read(sc_ipc_t ipc, u32 word, u32 *val);
 int sc_misc_get_temp(sc_ipc_t ipc, sc_rsrc_t resource, sc_misc_temp_t temp,
index 3e38edbf5dc3499a6db2c1928304e0af9259f94d..20b74fbb18d1906876df12d4343649cd9ef2f719 100644 (file)
@@ -374,6 +374,31 @@ void sc_misc_boot_status(sc_ipc_t ipc, sc_misc_boot_status_t status)
                       __func__, status, RPC_R8(&msg));
 }
 
+int sc_misc_get_boot_container(sc_ipc_t ipc, u8 *idx)
+{
+       struct udevice *dev = gd->arch.scu_dev;
+       int size = sizeof(struct sc_rpc_msg_s);
+       struct sc_rpc_msg_s msg;
+       int ret;
+
+       if (!dev)
+               hang();
+
+       RPC_VER(&msg) = SC_RPC_VERSION;
+       RPC_SIZE(&msg) = 1U;
+       RPC_SVC(&msg) = (u8)SC_RPC_SVC_MISC;
+       RPC_FUNC(&msg) = (u8)MISC_FUNC_GET_BOOT_CONTAINER;
+
+       ret = misc_call(dev, SC_FALSE, &msg, size, &msg, size);
+       if (ret < 0)
+               return ret;
+
+       if (idx)
+               *idx = (u8)RPC_U8(&msg, 0U);
+
+       return 0;
+}
+
 void sc_misc_build_info(sc_ipc_t ipc, u32 *build, u32 *commit)
 {
        struct udevice *dev = gd->arch.scu_dev;