From: aisheng.dong@nxp.com (Dong Aisheng)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH V5 5/5] soc: imx: sc: add misc svc support
Date: Tue, 21 Aug 2018 00:08:25 +0800 [thread overview]
Message-ID: <1534781305-4770-6-git-send-email-aisheng.dong@nxp.com> (raw)
In-Reply-To: <1534781305-4770-1-git-send-email-aisheng.dong@nxp.com>
Add SCU MISC SVC support which provides misc control get/set functions.
Cc: Shawn Guo <shawnguo@kernel.org>
Cc: Sascha Hauer <kernel@pengutronix.de>
Signed-off-by: Dong Aisheng <aisheng.dong@nxp.com>
---
drivers/soc/imx/sc/Makefile | 1 +
drivers/soc/imx/sc/svc/misc/rpc_clnt.c | 106 +++++++++++++++++++++++++++++++++
include/soc/imx/sc/sci.h | 1 +
include/soc/imx/sc/svc/misc/api.h | 60 +++++++++++++++++++
4 files changed, 168 insertions(+)
create mode 100644 drivers/soc/imx/sc/svc/misc/rpc_clnt.c
create mode 100644 include/soc/imx/sc/svc/misc/api.h
diff --git a/drivers/soc/imx/sc/Makefile b/drivers/soc/imx/sc/Makefile
index 3a709b2..6a3159f 100644
--- a/drivers/soc/imx/sc/Makefile
+++ b/drivers/soc/imx/sc/Makefile
@@ -1,4 +1,5 @@
# SPDX-License-Identifier: GPL-2.0
obj-y += main/ipc.o
+obj-y += svc/misc/rpc_clnt.o
obj-y += svc/pad/rpc_clnt.o
obj-y += svc/pm/rpc_clnt.o
diff --git a/drivers/soc/imx/sc/svc/misc/rpc_clnt.c b/drivers/soc/imx/sc/svc/misc/rpc_clnt.c
new file mode 100644
index 0000000..810a0ad
--- /dev/null
+++ b/drivers/soc/imx/sc/svc/misc/rpc_clnt.c
@@ -0,0 +1,106 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2016 Freescale Semiconductor, Inc.
+ * Copyright 2017~2018 NXP
+ *
+ * File containing client-side RPC functions for the MISC service. These
+ * function are ported to clients that communicate to the SC.
+ *
+ */
+
+#include <soc/imx/sc/svc/misc/api.h>
+#include "../../main/rpc.h"
+
+/*
+ * This type is used to indicate RPC MISC function calls.
+ */
+enum misc_func_e {
+ MISC_FUNC_UNKNOWN = 0,
+ MISC_FUNC_SET_CONTROL = 1,
+ MISC_FUNC_GET_CONTROL = 2,
+ MISC_FUNC_SET_MAX_DMA_GROUP = 4,
+ MISC_FUNC_SET_DMA_GROUP = 5,
+ MISC_FUNC_SECO_IMAGE_LOAD = 8,
+ MISC_FUNC_SECO_AUTHENTICATE = 9,
+ MISC_FUNC_DEBUG_OUT = 10,
+ MISC_FUNC_WAVEFORM_CAPTURE = 6,
+ MISC_FUNC_BUILD_INFO = 15,
+ MISC_FUNC_UNIQUE_ID = 19,
+ MISC_FUNC_SET_ARI = 3,
+ MISC_FUNC_BOOT_STATUS = 7,
+ MISC_FUNC_BOOT_DONE = 14,
+ MISC_FUNC_OTP_FUSE_READ = 11,
+ MISC_FUNC_OTP_FUSE_WRITE = 17,
+ MISC_FUNC_SET_TEMP = 12,
+ MISC_FUNC_GET_TEMP = 13,
+ MISC_FUNC_GET_BOOT_DEV = 16,
+ MISC_FUNC_GET_BUTTON_STATUS = 18,
+};
+
+struct imx_sc_msg_req_misc_set_ctrl {
+ struct sc_rpc_msg hdr;
+ u32 ctrl;
+ u32 val;
+ u16 resource;
+} __packed;
+
+struct imx_sc_msg_req_misc_get_ctrl {
+ struct sc_rpc_msg hdr;
+ u32 ctrl;
+ u16 resource;
+} __packed;
+
+struct imx_sc_msg_resp_misc_get_ctrl {
+ struct sc_rpc_msg hdr;
+ u32 val;
+} __packed;
+
+sc_err_t sc_misc_set_control(sc_ipc_t ipc, sc_rsrc_t resource,
+ sc_ctrl_t ctrl, uint32_t val)
+{
+ struct imx_sc_msg_req_misc_set_ctrl msg;
+ struct sc_rpc_msg *hdr = &msg.hdr;
+ int ret;
+
+ hdr->ver = SC_RPC_VERSION;
+ hdr->svc = (uint8_t)SC_RPC_SVC_MISC;
+ hdr->func = (uint8_t)MISC_FUNC_SET_CONTROL;
+ hdr->size = 4;
+
+ msg.ctrl = ctrl;
+ msg.val = val;
+ msg.resource = resource;
+
+ ret = sc_call_rpc(ipc, (void *)&msg, false);
+ if (ret)
+ return SC_ERR_FAIL;
+
+ return (sc_err_t)hdr->func;
+}
+
+sc_err_t sc_misc_get_control(sc_ipc_t ipc, sc_rsrc_t resource,
+ sc_ctrl_t ctrl, uint32_t *val)
+{
+ struct imx_sc_msg_req_misc_get_ctrl msg;
+ struct imx_sc_msg_resp_misc_get_ctrl *resp;
+ struct sc_rpc_msg *hdr = &msg.hdr;
+ int ret;
+
+ hdr->ver = SC_RPC_VERSION;
+ hdr->svc = (uint8_t)SC_RPC_SVC_MISC;
+ hdr->func = (uint8_t)MISC_FUNC_GET_CONTROL;
+ hdr->size = 3;
+
+ msg.ctrl = ctrl;
+ msg.resource = resource;
+
+ ret = sc_call_rpc(ipc, (void *)&msg, false);
+ if (ret)
+ return SC_ERR_FAIL;
+
+ resp = (struct imx_sc_msg_resp_misc_get_ctrl *)&msg;
+ if (val != NULL)
+ *val = resp->val;
+
+ return (sc_err_t)resp->hdr.func;
+}
diff --git a/include/soc/imx/sc/sci.h b/include/soc/imx/sc/sci.h
index 2407890..867b9c5 100644
--- a/include/soc/imx/sc/sci.h
+++ b/include/soc/imx/sc/sci.h
@@ -13,6 +13,7 @@
#include <soc/imx/sc/ipc.h>
#include <soc/imx/sc/types.h>
+#include <soc/imx/sc/svc/misc/api.h>
#include <soc/imx/sc/svc/pad/api.h>
#include <soc/imx/sc/svc/pm/api.h>
diff --git a/include/soc/imx/sc/svc/misc/api.h b/include/soc/imx/sc/svc/misc/api.h
new file mode 100644
index 0000000..e217f4c
--- /dev/null
+++ b/include/soc/imx/sc/svc/misc/api.h
@@ -0,0 +1,60 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * Copyright (C) 2016 Freescale Semiconductor, Inc.
+ * Copyright 2017~2018 NXP
+ *
+ * Header file containing the public API for the System Controller (SC)
+ * Miscellaneous (MISC) function.
+ *
+ * MISC_SVC (SVC) Miscellaneous Service
+ *
+ * Module for the Miscellaneous (MISC) service.
+ */
+
+#ifndef _SC_MISC_API_H
+#define _SC_MISC_API_H
+
+#include <soc/imx/sc/ipc.h>
+#include <soc/imx/sc/types.h>
+
+/*
+ * Control Functions
+ */
+
+/*
+ * This function sets a miscellaneous control value.
+ *
+ * @param[in] ipc IPC handle
+ * @param[in] resource resource the control is associated with
+ * @param[in] ctrl control to change
+ * @param[in] val value to apply to the control
+ *
+ * @return 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_t sc_misc_set_control(sc_ipc_t ipc, sc_rsrc_t resource,
+ sc_ctrl_t ctrl, uint32_t val);
+
+/*
+ * This function gets a miscellaneous control value.
+ *
+ * @param[in] ipc IPC handle
+ * @param[in] resource resource the control is associated with
+ * @param[in] ctrl control to get
+ * @param[out] val pointer to return the control value
+ *
+ * @return 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_t sc_misc_get_control(sc_ipc_t ipc, sc_rsrc_t resource,
+ sc_ctrl_t ctrl, uint32_t *val);
+
+#endif /* _SC_MISC_API_H */
--
2.7.4
next prev parent reply other threads:[~2018-08-20 16:08 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-08-20 16:08 [PATCH V5 0/5] soc: imx: add scu firmware api support Dong Aisheng
2018-08-20 16:08 ` [PATCH V5 1/5] dt-bindings: arm: fsl: add scu binding doc Dong Aisheng
2018-08-20 18:11 ` Rob Herring
2018-08-21 3:00 ` A.s. Dong
2018-08-21 11:51 ` A.s. Dong
2018-08-24 9:36 ` Jassi Brar
2018-08-24 9:51 ` A.s. Dong
2018-08-20 16:08 ` [PATCH V5 2/5] soc: imx: add SC firmware IPC and APIs Dong Aisheng
2018-09-10 8:40 ` Sascha Hauer
2018-09-10 9:44 ` A.s. Dong
2018-09-10 12:11 ` Sascha Hauer
2018-09-11 10:38 ` A.s. Dong
2018-09-16 13:23 ` A.s. Dong
2018-09-18 6:22 ` Sascha Hauer
2018-09-18 7:54 ` A.s. Dong
2018-08-20 16:08 ` [PATCH V5 3/5] soc: imx: sc: add pm svc support Dong Aisheng
2018-08-20 16:08 ` [PATCH V5 4/5] soc: imx: sc: add pad " Dong Aisheng
2018-08-20 16:08 ` Dong Aisheng [this message]
2018-08-20 16:31 ` [PATCH V5 0/5] soc: imx: add scu firmware api support A.s. Dong
2018-08-24 7:36 ` A.s. Dong
2018-08-24 9:54 ` Jassi Brar
2018-08-24 11:02 ` A.s. Dong
2018-08-27 8:33 ` Sascha Hauer
2018-08-27 9:59 ` A.s. Dong
2018-08-27 10:21 ` A.s. Dong
2018-08-28 6:21 ` Sascha Hauer
2018-08-28 8:53 ` A.s. Dong
2018-08-29 6:53 ` Sascha Hauer
2018-08-29 8:35 ` A.s. Dong
2018-09-03 8:57 ` A.s. Dong
2018-09-03 11:44 ` Sascha Hauer
2018-09-06 3:21 ` A.s. Dong
2018-09-10 7:03 ` Sascha Hauer
2018-09-10 7:53 ` A.s. Dong
2018-08-28 6:15 ` Sascha Hauer
2018-08-28 9:02 ` A.s. Dong
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1534781305-4770-6-git-send-email-aisheng.dong@nxp.com \
--to=aisheng.dong@nxp.com \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).