imx: imx_caam: Add code to initialize the CAAM job-rings to NS-world
authorBryan O'Donoghue <bryan.odonoghue@linaro.org>
Wed, 11 Jul 2018 15:35:17 +0000 (16:35 +0100)
committerBryan O'Donoghue <bryan.odonoghue@linaro.org>
Tue, 4 Sep 2018 13:18:30 +0000 (14:18 +0100)
commitca52cbe65b1453f4a2811249847d3387b6888fd3
treed900a79d77d5362ff9c6e948213712ea4d089175
parentdb05fb77dcdce2259876543aacade3f9b1346b4c
imx: imx_caam: Add code to initialize the CAAM job-rings to NS-world

This patch defines the most basic part of the CAAM and the only piece of
the CAAM silicon we are really interested in, in ATF, the CAAM control
structure.

The CAAM itself is a huge address space of some 32k, way out of scope for
the purpose we have in ATF.

This patch adds a simple CAAM init function that assigns ownership of the
CAAM job-rings to the non-secure MID with the ownership bit set to
non-secure.

This will allow later logic in the boot process such as OPTEE, u-boot and
Linux to assign job-rings as appropriate, restricting if necessary but
leaving open the main functionality of the CAAM to the Linux NS runtime.

Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org>
plat/imx/common/imx_caam.c [new file with mode: 0644]
plat/imx/common/include/imx_caam.h [new file with mode: 0644]