Go to file
Marc Bonnici 9e245348c6 fixup: spmc/mem: Fix mailbox spinlock error paths
Ensure that we unlock the mailbox as appropriate if an
error occurs during a memory transaction validation.

Signed-off-by: Marc Bonnici <marc.bonnici@arm.com>
2021-11-26 09:44:13 +00:00
.husky build(hooks): add commitlint hook 2021-04-19 14:06:25 +01:00
bl1 Add PIE support for AARCH32 2021-04-21 15:05:57 +02:00
bl2 feat(fwu): initialize FWU driver in BL2 2021-08-02 17:15:40 +01:00
bl2u Avoid the use of linker *_SIZE__ macros 2021-04-21 15:05:57 +02:00
bl31 lsp: Add initial Logical Partition Skeleton Framework 2021-10-06 16:00:34 +01:00
bl32 TSP: Enable test cases 2021-10-07 15:48:34 +01:00
common lsp: Add initial Logical Partition Skeleton Framework 2021-10-06 16:00:34 +01:00
docs Merge changes from topic "erratas" into integration 2021-09-03 23:58:01 +02:00
drivers refactor(plat/nxp): refine api to read SVR register 2021-08-26 10:08:57 +08:00
fdts feat(plat/arm): Introduce TC1 platform 2021-08-11 11:36:50 +01:00
include ffa_svc: Add FFA memory management #defines 2021-10-07 15:48:34 +01:00
lib feat(lib/xlat_tables_v2): allow memory region attribute change 2021-10-05 14:52:48 +01:00
licenses docs(license): rectify `arm-gic.h` license 2021-04-26 12:36:00 +01:00
make_helpers feat(spmc): add secure partition manager core for handling FF-A interfaces 2021-09-06 16:27:06 +05:30
plat fvp/plat_def: Set SPMC_SHARED_MEMORY_OBJ_SIZE 2021-10-07 15:48:34 +01:00
services fixup: spmc/mem: Fix mailbox spinlock error paths 2021-11-26 09:44:13 +00:00
tools fix(tools/stm32image): improve the tool 2021-06-22 14:10:27 +02:00
.checkpatch.conf Re-apply GIT_COMMIT_ID check for checkpatch 2019-07-12 11:06:24 +01:00
.cz.json build(hooks): add Commitizen hook 2021-04-19 14:06:25 +01:00
.editorconfig .editorconfig: set max line length to 100 2020-12-03 15:39:23 +00:00
.gitignore build(hooks): add Husky configuration 2021-04-19 14:06:25 +01:00
.gitreview Specify integration as the default branch for git-review 2020-04-02 07:57:17 +00:00
Makefile feat(spmc): add secure partition manager core for handling FF-A interfaces 2021-09-06 16:27:06 +05:30
PROTOTYPE_README Add README to build and run EL3 SPMC Prototype 2021-10-08 13:52:56 +01:00
commitlint.config.js revert(commitlint): disable `signed-off-by` rule 2021-04-27 16:12:10 +01:00
dco.txt Drop requirement for CLA in contribution.md 2016-09-27 21:52:03 +01:00
ioctl ioctl: Add userspace test binary 2021-10-07 15:48:34 +01:00
license.rst doc: De-duplicate readme and license files 2019-10-08 16:36:15 +00:00
package-lock.json build(deps): bump path-parse from 1.0.6 to 1.0.7 2021-08-13 10:12:00 +01:00
package.json build(hooks): update Commitizen to ^4.2.4 2021-05-12 15:43:56 +01:00
readme.rst doc: Formatting fixes for readme.rst 2019-10-09 15:37:59 +00:00

readme.rst

Trusted Firmware-A
==================

Trusted Firmware-A (TF-A) is a reference implementation of secure world software
for `Arm A-Profile architectures`_ (Armv8-A and Armv7-A), including an Exception
Level 3 (EL3) `Secure Monitor`_. It provides a suitable starting point for
productization of secure world boot and runtime firmware, in either the AArch32
or AArch64 execution states.

TF-A implements Arm interface standards, including:

-  `Power State Coordination Interface (PSCI)`_
-  `Trusted Board Boot Requirements CLIENT (TBBR-CLIENT)`_
-  `SMC Calling Convention`_
-  `System Control and Management Interface (SCMI)`_
-  `Software Delegated Exception Interface (SDEI)`_

The code is designed to be portable and reusable across hardware platforms and
software models that are based on the Armv8-A and Armv7-A architectures.

In collaboration with interested parties, we will continue to enhance TF-A
with reference implementations of Arm standards to benefit developers working
with Armv7-A and Armv8-A TrustZone technology.

Users are encouraged to do their own security validation, including penetration
testing, on any secure world code derived from TF-A.

More Info and Documentation
---------------------------

To find out more about Trusted Firmware-A, please `view the full documentation`_
that is available through `trustedfirmware.org`_.

--------------

*Copyright (c) 2013-2019, Arm Limited and Contributors. All rights reserved.*

.. _Armv7-A and Armv8-A: https://developer.arm.com/products/architecture/a-profile
.. _Secure Monitor: http://www.arm.com/products/processors/technologies/trustzone/tee-smc.php
.. _Power State Coordination Interface (PSCI): PSCI_
.. _PSCI: http://infocenter.arm.com/help/topic/com.arm.doc.den0022d/Power_State_Coordination_Interface_PDD_v1_1_DEN0022D.pdf
.. _Trusted Board Boot Requirements CLIENT (TBBR-CLIENT): https://developer.arm.com/docs/den0006/latest/trusted-board-boot-requirements-client-tbbr-client-armv8-a
.. _SMC Calling Convention: http://infocenter.arm.com/help/topic/com.arm.doc.den0028b/ARM_DEN0028B_SMC_Calling_Convention.pdf
.. _System Control and Management Interface (SCMI): SCMI_
.. _SCMI: http://infocenter.arm.com/help/topic/com.arm.doc.den0056a/DEN0056A_System_Control_and_Management_Interface.pdf
.. _Software Delegated Exception Interface (SDEI): SDEI_
.. _SDEI: http://infocenter.arm.com/help/topic/com.arm.doc.den0054a/ARM_DEN0054A_Software_Delegated_Exception_Interface.pdf
.. _Arm A-Profile architectures: https://developer.arm.com/architectures/cpu-architecture/a-profile
.. _view the full documentation: https://www.trustedfirmware.org/docs/tf-a
.. _trustedfirmware.org: http://www.trustedfirmware.org