[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1595235977-106241-1-git-send-email-franck.lenormand@oss.nxp.com>
Date: Mon, 20 Jul 2020 11:06:10 +0200
From: franck.lenormand@....nxp.com
To: shawnguo@...nel.org, s.hauer@...gutronix.de, festevam@...il.com
Cc: franck.lenormand@....nxp.com, kernel@...gutronix.de,
linux-kernel@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
linux-imx@....com, aisheng.dong@....com, abel.vesa@....com,
Anson.Huang@....com, linux@...pel-privat.de,
leonard.crestez@....com, daniel.baluta@....com,
qiangqing.zhang@....com, peng.fan@....com
Subject: [PATCH 0/7] Add support of SECVIO from SNVS on iMX8q/x
From: Franck LENORMAND <franck.lenormand@....com>
This patchset aims to add support for the SECurity VIOlation (SECVIO) of the
SNVS. A secvio is a signal emitted by the SNVS when a hardware attack
is detected. On imx8x and imx8q SoC, the SNVS is controlled by the
SECO and it is possible to interact with it using the SCU using the SC APIs.
For the driver to communicate with the SNVS via the SCU and the SECO, I had to:
- Add support for exchange of big message with the SCU (needed for
imx_scu_irq_get_status)
- Add API to check linux can control the SECVIO (imx_sc_rm_is_resource_owned)
- Add APIs for the driver to read the state of the SECVIO registers of the
SNVS and DGO (imx_sc_seco_secvio_enable and imx_sc_seco_secvio_enable).
To check the state of the SECVIO IRQ in the SCU, I added the
imx_scu_irq_get_status API.
The secvio driver is designed to receive the IRQ produced by the
SNVS in case of hardware attack and notify the status to the
audit framework which can be used by the user.
The goal of the driver is to be self suficient but can be extended by the
user to perform custom operations on values read (imx_sc_seco_secvio_enable)
Franck LENORMAND (7):
firmware: imx: scu-rm: Add Resource Management APIs
firmware: imx: scu: Support reception of messages of any size
firmware: imx: scu-seco: Add SEcure Controller APIS
firmware: imx: scu-irq: Add API to retrieve status of IRQ
dt-bindings: firmware: imx-scu: Add SECVIO resource
dt-bindings: arm: imx: Documentation of the SC secvio driver
soc: imx8: Add the SC SECVIO driver
.../bindings/arm/freescale/fsl,imx-sc-secvio.yaml | 34 +
drivers/firmware/imx/Makefile | 2 +-
drivers/firmware/imx/imx-scu-irq.c | 37 +-
drivers/firmware/imx/imx-scu.c | 24 +-
drivers/firmware/imx/rm.c | 44 ++
drivers/firmware/imx/seco.c | 275 +++++++
drivers/soc/imx/Kconfig | 10 +
drivers/soc/imx/Makefile | 1 +
drivers/soc/imx/secvio/Kconfig | 10 +
drivers/soc/imx/secvio/Makefile | 3 +
drivers/soc/imx/secvio/imx-secvio-audit.c | 39 +
drivers/soc/imx/secvio/imx-secvio-debugfs.c | 379 +++++++++
drivers/soc/imx/secvio/imx-secvio-sc-int.h | 83 ++
drivers/soc/imx/secvio/imx-secvio-sc.c | 873 +++++++++++++++++++++
include/dt-bindings/firmware/imx/rsrc.h | 3 +-
include/linux/firmware/imx/ipc.h | 1 +
include/linux/firmware/imx/sci.h | 6 +
include/linux/firmware/imx/svc/rm.h | 69 ++
include/linux/firmware/imx/svc/seco.h | 73 ++
include/soc/imx/imx-secvio-sc.h | 177 +++++
20 files changed, 2134 insertions(+), 9 deletions(-)
create mode 100644 Documentation/devicetree/bindings/arm/freescale/fsl,imx-sc-secvio.yaml
create mode 100644 drivers/firmware/imx/rm.c
create mode 100644 drivers/firmware/imx/seco.c
create mode 100644 drivers/soc/imx/secvio/Kconfig
create mode 100644 drivers/soc/imx/secvio/Makefile
create mode 100644 drivers/soc/imx/secvio/imx-secvio-audit.c
create mode 100644 drivers/soc/imx/secvio/imx-secvio-debugfs.c
create mode 100644 drivers/soc/imx/secvio/imx-secvio-sc-int.h
create mode 100644 drivers/soc/imx/secvio/imx-secvio-sc.c
create mode 100644 include/linux/firmware/imx/svc/rm.h
create mode 100644 include/linux/firmware/imx/svc/seco.h
create mode 100644 include/soc/imx/imx-secvio-sc.h
--
2.7.4
Powered by blists - more mailing lists