1.. _tfm_psa_test: 2 3TF-M Platform Security Architecture Test Sample 4############################################### 5 6Overview 7******** 8 9Run PSA test suites tests with Zephyr and TFM. 10 11The PSA tests are implemented in the psa-arch-tests repo: https://github.com/ARM-software/psa-arch-tests 12 13This sample is supported for platforms that have a port in psa-arch-tests. 14See sample.yaml for a list of supported platforms. 15 16Building and Running 17******************** 18 19You must choose a suite via the CONFIG_TFM_PSA_TEST_* configs. 20 21Only one of these suites can be run at a time, with the test suite set via one 22of the following kconfig options: 23 24* ``CONFIG_TFM_PSA_TEST_CRYPTO`` 25* ``CONFIG_TFM_PSA_TEST_PROTECTED_STORAGE`` 26* ``CONFIG_TFM_PSA_TEST_INTERNAL_TRUSTED_STORAGE`` 27* ``CONFIG_TFM_PSA_TEST_STORAGE`` 28* ``CONFIG_TFM_PSA_TEST_INITIAL_ATTESTATION`` 29 30You can indicate the desired test suite at build time via a config flag: 31 32 .. code-block:: bash 33 34 $ west build samples/tfm_integration/tfm_psa_test/ \ 35 -p -b mps2/an521/cpu0/ns -t run -- \ 36 -DCONFIG_TFM_PSA_TEST_STORAGE=y 37 38Note that not all test suites are valid on all boards. 39 40On Target 41========= 42 43Refer to :zephyr:code-sample:`tfm_ipc` for detailed instructions. 44 45On QEMU: 46======== 47 48Refer to :zephyr:code-sample:`tfm_ipc` for detailed instructions. 49Following is an example based on ``west build`` 50 51 .. code-block:: bash 52 53 $ west build samples/tfm_integration/tfm_psa_test/ -p -b mps2/an521/cpu0/ns -t run -- -DCONFIG_TFM_PSA_TEST_STORAGE=y 54 55Sample Output 56============= 57 58 .. code-block:: console 59 60 *** Booting Zephyr OS build zephyr-v2.5.0-456-g06f4da459a99 *** 61 62 ***** PSA Architecture Test Suite - Version 1.0 ***** 63 64 Running.. Storage Suite 65 ****************************************** 66 67 TEST: 401 | DESCRIPTION: UID not found check 68 [Info] Executing tests from non-secure 69 70 [Info] Executing ITS tests 71 [Check 1] Call get API for UID 6 which is not set 72 [Check 2] Call get_info API for UID 6 which is not set 73 [Check 3] Call remove API for UID 6 which is not set 74 [Check 4] Call get API for UID 6 which is removed 75 [Check 5] Call get_info API for UID 6 which is removed 76 [Check 6] Call remove API for UID 6 which is removed 77 Set storage for UID 6 78 [Check 7] Call get API for different UID 5 79 [Check 8] Call get_info API for different UID 5 80 [Check 9] Call remove API for different UID 5 81 82 [Info] Executing PS tests 83 [Check 1] Call get API for UID 6 which is not set 84 [Check 2] Call get_info API for UID 6 which is not set 85 [Check 3] Call remove API for UID 6 which is not set 86 [Check 4] Call get API for UID 6 which is removed 87 [Check 5] Call get_info API for UID 6 which is removed 88 [Check 6] Call remove API for UID 6 which is removed 89 Set storage for UID 6 90 [Check 7] Call get API for different UID 5 91 [Check 8] Call get_info API for different UID 5 92 [Check 9] Call remove API for different UID 5 93 94 TEST RESULT: PASSED 95 96 ****************************************** 97 98 [...] 99 100 TEST: 417 | DESCRIPTION: Storage assest capacity modification check 101 [Info] Executing tests from non-secure 102 103 [Info] Executing PS tests 104 Test Case skipped as Optional PS APIs not are supported. 105 106 TEST RESULT: SKIPPED (Skip Code=0x0000002B) 107 108 ****************************************** 109 110 ************ Storage Suite Report ********** 111 TOTAL TESTS : 17 112 TOTAL PASSED : 11 113 TOTAL SIM ERROR : 0 114 TOTAL FAILED : 0 115 TOTAL SKIPPED : 6 116 ****************************************** 117 118 Entering standby.. 119