1 /* 2 * Copyright (c) 2016, ARM Limited and Contributors. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions are met: 6 * 7 * Redistributions of source code must retain the above copyright notice, this 8 * list of conditions and the following disclaimer. 9 * 10 * Redistributions in binary form must reproduce the above copyright notice, 11 * this list of conditions and the following disclaimer in the documentation 12 * and/or other materials provided with the distribution. 13 * 14 * Neither the name of ARM nor the names of its contributors may be used 15 * to endorse or promote products derived from this software without specific 16 * prior written permission. 17 * 18 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 19 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 20 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 21 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 22 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28 * POSSIBILITY OF SUCH DAMAGE. 29 */ 30 31 #include <stddef.h> 32 33 #include "firmware_image_package.h" 34 #include "tbbr_config.h" 35 36 /* The images used depends on the platform. */ 37 toc_entry_t toc_entries[] = { 38 { 39 .name = "SCP Firmware Updater Configuration FWU SCP_BL2U", 40 .uuid = UUID_TRUSTED_UPDATE_FIRMWARE_SCP_BL2U, 41 .cmdline_name = "scp-fwu-cfg" 42 }, 43 { 44 .name = "AP Firmware Updater Configuration BL2U", 45 .uuid = UUID_TRUSTED_UPDATE_FIRMWARE_BL2U, 46 .cmdline_name = "ap-fwu-cfg" 47 }, 48 { 49 .name = "Firmware Updater NS_BL2U", 50 .uuid = UUID_TRUSTED_UPDATE_FIRMWARE_NS_BL2U, 51 .cmdline_name = "fwu" 52 }, 53 { 54 .name = "Non-Trusted Firmware Updater certificate", 55 .uuid = UUID_TRUSTED_FWU_CERT, 56 .cmdline_name = "fwu-cert" 57 }, 58 { 59 .name = "Trusted Boot Firmware BL2", 60 .uuid = UUID_TRUSTED_BOOT_FIRMWARE_BL2, 61 .cmdline_name = "tb-fw" 62 }, 63 { 64 .name = "SCP Firmware SCP_BL2", 65 .uuid = UUID_SCP_FIRMWARE_SCP_BL2, 66 .cmdline_name = "scp-fw" 67 }, 68 { 69 .name = "EL3 Runtime Firmware BL31", 70 .uuid = UUID_EL3_RUNTIME_FIRMWARE_BL31, 71 .cmdline_name = "soc-fw" 72 }, 73 { 74 .name = "Secure Payload BL32 (Trusted OS)", 75 .uuid = UUID_SECURE_PAYLOAD_BL32, 76 .cmdline_name = "tos-fw" 77 }, 78 { 79 .name = "Non-Trusted Firmware BL33", 80 .uuid = UUID_NON_TRUSTED_FIRMWARE_BL33, 81 .cmdline_name = "nt-fw" 82 }, 83 84 /* Key Certificates */ 85 { 86 .name = "Root Of Trust key certificate", 87 .uuid = UUID_ROT_KEY_CERT, 88 .cmdline_name = "rot-cert" 89 }, 90 { 91 .name = "Trusted key certificate", 92 .uuid = UUID_TRUSTED_KEY_CERT, 93 .cmdline_name = "trusted-key-cert" 94 }, 95 { 96 .name = "SCP Firmware key certificate", 97 .uuid = UUID_SCP_FW_KEY_CERT, 98 .cmdline_name = "scp-fw-key-cert" 99 }, 100 { 101 .name = "SoC Firmware key certificate", 102 .uuid = UUID_SOC_FW_KEY_CERT, 103 .cmdline_name = "soc-fw-key-cert" 104 }, 105 { 106 .name = "Trusted OS Firmware key certificate", 107 .uuid = UUID_TRUSTED_OS_FW_KEY_CERT, 108 .cmdline_name = "tos-fw-key-cert" 109 }, 110 { 111 .name = "Non-Trusted Firmware key certificate", 112 .uuid = UUID_NON_TRUSTED_FW_KEY_CERT, 113 .cmdline_name = "nt-fw-key-cert" 114 }, 115 116 /* Content certificates */ 117 { 118 .name = "Trusted Boot Firmware BL2 certificate", 119 .uuid = UUID_TRUSTED_BOOT_FW_CERT, 120 .cmdline_name = "tb-fw-cert" 121 }, 122 { 123 .name = "SCP Firmware content certificate", 124 .uuid = UUID_SCP_FW_CONTENT_CERT, 125 .cmdline_name = "scp-fw-cert" 126 }, 127 { 128 .name = "SoC Firmware content certificate", 129 .uuid = UUID_SOC_FW_CONTENT_CERT, 130 .cmdline_name = "soc-fw-cert" 131 }, 132 { 133 .name = "Trusted OS Firmware content certificate", 134 .uuid = UUID_TRUSTED_OS_FW_CONTENT_CERT, 135 .cmdline_name = "tos-fw-cert" 136 }, 137 { 138 .name = "Non-Trusted Firmware content certificate", 139 .uuid = UUID_NON_TRUSTED_FW_CONTENT_CERT, 140 .cmdline_name = "nt-fw-cert" 141 }, 142 { 143 .name = NULL, 144 .uuid = { 0 }, 145 .cmdline_name = NULL, 146 } 147 }; 148