1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3 * Copyright (C) 2016 Freescale Semiconductor, Inc.
4 * Copyright 2017~2018 NXP
5 *
6 * Header file containing the public API for the System Controller (SC)
7 * Miscellaneous (MISC) function.
8 *
9 * MISC_SVC (SVC) Miscellaneous Service
10 *
11 * Module for the Miscellaneous (MISC) service.
12 */
13
14 #ifndef _SC_MISC_API_H
15 #define _SC_MISC_API_H
16
17 #include <linux/firmware/imx/sci.h>
18
19 /*
20 * This type is used to indicate RPC MISC function calls.
21 */
22 enum imx_misc_func {
23 IMX_SC_MISC_FUNC_UNKNOWN = 0,
24 IMX_SC_MISC_FUNC_SET_CONTROL = 1,
25 IMX_SC_MISC_FUNC_GET_CONTROL = 2,
26 IMX_SC_MISC_FUNC_SET_MAX_DMA_GROUP = 4,
27 IMX_SC_MISC_FUNC_SET_DMA_GROUP = 5,
28 IMX_SC_MISC_FUNC_SECO_IMAGE_LOAD = 8,
29 IMX_SC_MISC_FUNC_SECO_AUTHENTICATE = 9,
30 IMX_SC_MISC_FUNC_DEBUG_OUT = 10,
31 IMX_SC_MISC_FUNC_WAVEFORM_CAPTURE = 6,
32 IMX_SC_MISC_FUNC_BUILD_INFO = 15,
33 IMX_SC_MISC_FUNC_UNIQUE_ID = 19,
34 IMX_SC_MISC_FUNC_SET_ARI = 3,
35 IMX_SC_MISC_FUNC_BOOT_STATUS = 7,
36 IMX_SC_MISC_FUNC_BOOT_DONE = 14,
37 IMX_SC_MISC_FUNC_OTP_FUSE_READ = 11,
38 IMX_SC_MISC_FUNC_OTP_FUSE_WRITE = 17,
39 IMX_SC_MISC_FUNC_SET_TEMP = 12,
40 IMX_SC_MISC_FUNC_GET_TEMP = 13,
41 IMX_SC_MISC_FUNC_GET_BOOT_DEV = 16,
42 IMX_SC_MISC_FUNC_GET_BUTTON_STATUS = 18,
43 };
44
45 /*
46 * Control Functions
47 */
48
49 #ifdef CONFIG_IMX_SCU
50 int imx_sc_misc_set_control(struct imx_sc_ipc *ipc, u32 resource,
51 u8 ctrl, u32 val);
52
53 int imx_sc_misc_get_control(struct imx_sc_ipc *ipc, u32 resource,
54 u8 ctrl, u32 *val);
55
56 int imx_sc_pm_cpu_start(struct imx_sc_ipc *ipc, u32 resource,
57 bool enable, u64 phys_addr);
58 #else
imx_sc_misc_set_control(struct imx_sc_ipc * ipc,u32 resource,u8 ctrl,u32 val)59 static inline int imx_sc_misc_set_control(struct imx_sc_ipc *ipc,
60 u32 resource, u8 ctrl, u32 val)
61 {
62 return -ENOTSUPP;
63 }
64
imx_sc_misc_get_control(struct imx_sc_ipc * ipc,u32 resource,u8 ctrl,u32 * val)65 static inline int imx_sc_misc_get_control(struct imx_sc_ipc *ipc,
66 u32 resource, u8 ctrl, u32 *val)
67 {
68 return -ENOTSUPP;
69 }
70
imx_sc_pm_cpu_start(struct imx_sc_ipc * ipc,u32 resource,bool enable,u64 phys_addr)71 static inline int imx_sc_pm_cpu_start(struct imx_sc_ipc *ipc, u32 resource,
72 bool enable, u64 phys_addr)
73 {
74 return -ENOTSUPP;
75 }
76 #endif
77 #endif /* _SC_MISC_API_H */
78