]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
misc: imx8: add sc_misc_get_temp
authorPeng Fan <peng.fan@nxp.com>
Sun, 5 May 2019 13:23:51 +0000 (13:23 +0000)
committerStefano Babic <sbabic@denx.de>
Fri, 19 Jul 2019 13:16:54 +0000 (15:16 +0200)
Add sc_misc_get_temp to support get temperature

Signed-off-by: Peng Fan <peng.fan@nxp.com>
arch/arm/include/asm/arch-imx8/sci/sci.h
arch/arm/include/asm/arch-imx8/sci/svc/misc/api.h
drivers/misc/imx8/scu_api.c

index 97377697f097fdfc0d54b424cddd387e3117f995..901b90d705f08d453e9738c934fbd7902e5b85a6 100644 (file)
@@ -72,6 +72,8 @@ 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);
 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,
+                    s16 *celsius, s8 *tenths);
 
 /* RM API */
 sc_bool_t sc_rm_is_memreg_owned(sc_ipc_t ipc, sc_rm_mr_t mr);
index 5d17b553d7f6050275cd64e4444133140d69e23c..3629eb68d7ab78ac3936939358b8a6f4fc98c2e2 100644 (file)
@@ -26,5 +26,6 @@
 #define SC_MISC_REL_CONTAINER  2U      /* Release container */
 
 typedef u8 sc_misc_boot_status_t;
+typedef u8 sc_misc_temp_t;
 
 #endif /* SC_MISC_API_H */
index d9c4d5d78406fc79281b641fc7ee0f371d985f4d..031bc0048b6ff266d45e4efd1d8e43e4ad46cfd5 100644 (file)
@@ -273,6 +273,34 @@ int sc_misc_otp_fuse_read(sc_ipc_t ipc, u32 word, u32 *val)
        return 0;
 }
 
+int sc_misc_get_temp(sc_ipc_t ipc, sc_rsrc_t resource, sc_misc_temp_t temp,
+                    s16 *celsius, s8 *tenths)
+{
+       struct udevice *dev = gd->arch.scu_dev;
+       int size = sizeof(struct sc_rpc_msg_s);
+       struct sc_rpc_msg_s msg;
+       int ret;
+
+       RPC_VER(&msg) = SC_RPC_VERSION;
+       RPC_SVC(&msg) = (u8)SC_RPC_SVC_MISC;
+       RPC_FUNC(&msg) = (u8)MISC_FUNC_GET_TEMP;
+       RPC_U16(&msg, 0U) = (u16)resource;
+       RPC_U8(&msg, 2U) = (u8)temp;
+       RPC_SIZE(&msg) = 2U;
+
+       ret = misc_call(dev, SC_FALSE, &msg, size, &msg, size);
+       if (ret < 0)
+               return ret;
+
+       if (celsius)
+               *celsius = RPC_I16(&msg, 0U);
+
+       if (tenths)
+               *tenths = RPC_I8(&msg, 2U);
+
+       return 0;
+}
+
 /* RM */
 sc_bool_t sc_rm_is_memreg_owned(sc_ipc_t ipc, sc_rm_mr_t mr)
 {