From patchwork Fri Jan 19 19:43:23 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Bryan O'Donoghue X-Patchwork-Id: 125222 Delivered-To: patch@linaro.org Received: by 10.46.66.141 with SMTP id h13csp444605ljf; Fri, 19 Jan 2018 11:49:03 -0800 (PST) X-Google-Smtp-Source: AH8x226+1qr4VWkYU8Q3Q71mRyG9C0Wb8xUBWFY4TaRaC6U65ZguAElPG1D+Qev0IIG3fLo15Jgv X-Received: by 10.80.165.87 with SMTP id z23mr61415edb.300.1516391343201; Fri, 19 Jan 2018 11:49:03 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1516391343; cv=none; d=google.com; s=arc-20160816; b=WX4dizK930197dBpOWPdacYx790KKAGu1tdBGYYWozqhYDkw0ZUnUomMflltVj8k1d r9WUEuNrJam0kDjTLcCEg4SS1QOEj5uENFPVM2GDBq0kUvFq8Pu2VvX1wT5w0Q7TSDfX u3t+/JIASiYd86yRFH1B6JB+/B5POzCoh2HJuoiCi6e4U0ZWkikwOs29da8V8euIONpc SLhE7MlHPen9cgns2fuXfCAh+hxONalsTqHJms6yw0dvDdxqJ593mL7hRI0mWas0sEXF y11zOLBrqW5oul0Cbbvxsbj2Z+9EHrRmdeUyUA5Py3Z4xTsMxxWtkxU8OMd+JsSmOdB5 pzNQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=sender:errors-to:content-transfer-encoding:mime-version :list-subscribe:list-help:list-post:list-archive:list-unsubscribe :list-id:precedence:subject:cc:references:in-reply-to:message-id :date:to:from:dkim-signature:arc-authentication-results; bh=ncLozwEYCI8dTXb9wg5+4XfZtB5WjzlshyPvjQZYLtM=; b=ojdP/SIFkVytR9J/o8hdXYPaubkcNDgR12iBZzRu4jnZwGsRhxQk9W0hi0HhJi0aoY tAW7OvquxXSOvZor40BMcYJ0xi2Oq1yWkGIQO2AedQNyskRRNkEgNvZ/s+MEwzKBvctF 0iHSddaWAe2NJjiHKtb5I5jPWC+z3WbZn848ujRTIyBE/UXhPwTkPmEW5R5dTNRYeev8 ulaJ0nvrEQ8qsS75bjShQ233WbibUvCvWtUFhIsA4HQ/2HenA2zMZdwJfGRq4Uy+eb1s +HG6pGXCFupxf/Gjd2Gu4JWXHk5lAYo1u+1gSr48NmAbz9QQFYQQ/hS1adbgmajOyWFl jlPw== ARC-Authentication-Results: i=1; mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=M2drpsZq; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from lists.denx.de (dione.denx.de. [81.169.180.215]) by mx.google.com with ESMTP id m1si3575823edb.448.2018.01.19.11.49.02; Fri, 19 Jan 2018 11:49:03 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) client-ip=81.169.180.215; Authentication-Results: mx.google.com; dkim=neutral (body hash did not verify) header.i=@linaro.org header.s=google header.b=M2drpsZq; spf=pass (google.com: best guess record for domain of u-boot-bounces@lists.denx.de designates 81.169.180.215 as permitted sender) smtp.mailfrom=u-boot-bounces@lists.denx.de; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: by lists.denx.de (Postfix, from userid 105) id A50CBC21FB2; Fri, 19 Jan 2018 19:46:35 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on lists.denx.de X-Spam-Level: X-Spam-Status: No, score=-0.0 required=5.0 tests=RCVD_IN_MSPIKE_H3, RCVD_IN_MSPIKE_WL, T_DKIM_INVALID autolearn=unavailable autolearn_force=no version=3.4.0 Received: from lists.denx.de (localhost [IPv6:::1]) by lists.denx.de (Postfix) with ESMTP id 794CFC21FAA; Fri, 19 Jan 2018 19:44:18 +0000 (UTC) Received: by lists.denx.de (Postfix, from userid 105) id 20DF6C21FB2; Fri, 19 Jan 2018 19:43:41 +0000 (UTC) Received: from mail-wm0-f66.google.com (mail-wm0-f66.google.com [74.125.82.66]) by lists.denx.de (Postfix) with ESMTPS id BD824C21F5F for ; Fri, 19 Jan 2018 19:43:37 +0000 (UTC) Received: by mail-wm0-f66.google.com with SMTP id t74so5522259wme.3 for ; Fri, 19 Jan 2018 11:43:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=ZflaXR1zhk0qwf7CFLVXBSyeQm1rVE3wJf74G5rZf8g=; b=M2drpsZq+f6Sa4GC7DVN/4HwRwepzek0oOh3KVC6LztzPZh4sjXOjQOFG1+gbE2Cof Pmux4x/yfsmoakgsiwkf8bKJToidV6unjluwx3hkMjdrrRTqO9vjoN6LdDLStjJZ23eX 3bSZYrIKMvVUjz6H1kbsvw+GE29MuvuKisUcI= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=ZflaXR1zhk0qwf7CFLVXBSyeQm1rVE3wJf74G5rZf8g=; b=iuEKOe692G5koMEL773DymBAaW5Dy9/A3UDlMB3e9IENNbh+MT42yLZDWU4WN4enzU H2GtMyPzrCHoBhakN93Geshbcxz5Mf+iF9Ia0qwSMwzIRpSJAbUYl6ozbRs1RPi/rxr4 HxepLYPbusd3FV+Z1fbyUu11aRVK4MaWxjUGswqnNDuVQ4q+hjfg5jRJRC3Pbu6mMsIe Wu1gqh+A/xWsFZm5hLVHakvQjqCoL6NdQv9/312CTkktrb18W0mie0kxTWDOO+nHjA/1 AdGSQY9tM5+TOL+yTVus5h8AEmD7fMnbc6AHB2EGokABRZeexZYOAjuDrO/8SVYmu/LM FnAA== X-Gm-Message-State: AKwxytf36/BXcgDJ8NrT/RwDVGZZE1OBWfnZXqyv2Fv8vXvB3rxoOpY/ 3kfZWAjnyoXyhH4jzUSCosCMcE7fUpE= X-Received: by 10.80.187.73 with SMTP id y67mr55760ede.172.1516391017059; Fri, 19 Jan 2018 11:43:37 -0800 (PST) Received: from localhost.localdomain ([109.255.42.2]) by smtp.gmail.com with ESMTPSA id p6sm5936051edh.68.2018.01.19.11.43.35 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Fri, 19 Jan 2018 11:43:36 -0800 (PST) From: Bryan O'Donoghue To: u-boot@lists.denx.de, trini@konsulko.com Date: Fri, 19 Jan 2018 19:43:23 +0000 Message-Id: <1516391006-22483-7-git-send-email-bryan.odonoghue@linaro.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1516391006-22483-1-git-send-email-bryan.odonoghue@linaro.org> References: <1516391006-22483-1-git-send-email-bryan.odonoghue@linaro.org> Cc: harinarayan@ti.com Subject: [U-Boot] [PATCH v2 6/9] tools: mkimage: add optee image type X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.18 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , MIME-Version: 1.0 Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" This patch adds support for bootable OPTEE images to mkimage. Currently there is a (Trusted Execution Environment) TEE image type, the TEE image type is installed to a memory location with u-boot continuing to own the boot process whereas the OPTEE image type defined here is a bootable image, which typically wants to live at a defined location in memory. Defining a new image type allows us to pull out the load address and entry point defined in the OPTEE header and having a separate image type lays the foundation for a subsequent patch to validate the OPTEE memory defined in a board-port matches the link location specified in the OPTEE bootable image. example usage: mkimage -A arm -T optee -C none -d ./out/arm-plat-imx/core/tee.bin uTee.optee making a separate image type means you don't need to specify things like entry point and load address as you would if you were defining the OPTEE image as a linux image. mkimage -A arm -O linux -C none -a 0x9c0fffe4 -e 0x9c100000 -d ./out/arm-plat-imx/core/tee.bin uTee Signed-off-by: Bryan O'Donoghue Cc: Harinarayan Bhatta Cc: Andrew F. Davis Cc: Tom Rini Cc: Kever Yang Cc: Philipp Tomsich Cc: Peng Fan Tested-by: Peng Fan --- common/image.c | 1 + include/image.h | 1 + tools/default_image.c | 25 +++++++++++++++++++------ 3 files changed, 21 insertions(+), 6 deletions(-) diff --git a/common/image.c b/common/image.c index e9609cd..14e738b 100644 --- a/common/image.c +++ b/common/image.c @@ -161,6 +161,7 @@ static const table_entry_t uimage_type[] = { { IH_TYPE_TEE, "tee", "Trusted Execution Environment Image",}, { IH_TYPE_FIRMWARE_IVT, "firmware_ivt", "Firmware with HABv4 IVT" }, { IH_TYPE_PMMC, "pmmc", "TI Power Management Micro-Controller Firmware",}, + { IH_TYPE_OPTEE, "optee", "OPTEE Boot Image",}, { -1, "", "", }, }; diff --git a/include/image.h b/include/image.h index a128a62..9175624 100644 --- a/include/image.h +++ b/include/image.h @@ -271,6 +271,7 @@ enum { IH_TYPE_TEE, /* Trusted Execution Environment OS Image */ IH_TYPE_FIRMWARE_IVT, /* Firmware Image with HABv4 IVT */ IH_TYPE_PMMC, /* TI Power Management Micro-Controller Firmware */ + IH_TYPE_OPTEE, /* OPTEE Boot Image */ IH_TYPE_COUNT, /* Number of image types */ }; diff --git a/tools/default_image.c b/tools/default_image.c index 4e5568e..5653933 100644 --- a/tools/default_image.c +++ b/tools/default_image.c @@ -18,6 +18,7 @@ #include "mkimage.h" #include +#include #include static image_header_t header; @@ -25,7 +26,8 @@ static image_header_t header; static int image_check_image_types(uint8_t type) { if (((type > IH_TYPE_INVALID) && (type < IH_TYPE_FLATDT)) || - (type == IH_TYPE_KERNEL_NOLOAD) || (type == IH_TYPE_FIRMWARE_IVT)) + (type == IH_TYPE_KERNEL_NOLOAD) || (type == IH_TYPE_FIRMWARE_IVT) || + (type == IH_TYPE_OPTEE)) return EXIT_SUCCESS; else return EXIT_FAILURE; @@ -90,6 +92,8 @@ static void image_set_header(void *ptr, struct stat *sbuf, int ifd, uint32_t checksum; time_t time; uint32_t imagesize; + uint32_t ep; + uint32_t addr; image_header_t * hdr = (image_header_t *)ptr; @@ -99,18 +103,27 @@ static void image_set_header(void *ptr, struct stat *sbuf, int ifd, sbuf->st_size - sizeof(image_header_t)); time = imagetool_get_source_date(params, sbuf->st_mtime); - if (params->type == IH_TYPE_FIRMWARE_IVT) + ep = params->ep; + addr = params->addr; + imagesize = sbuf->st_size - sizeof(image_header_t); + + switch (params->type) { + case IH_TYPE_FIRMWARE_IVT: /* Add size of CSF minus IVT */ imagesize = sbuf->st_size - sizeof(image_header_t) + 0x1FE0; - else - imagesize = sbuf->st_size - sizeof(image_header_t); + break; + case IH_TYPE_OPTEE: + addr = optee_image_get_load_addr(hdr); + ep = optee_image_get_entry_point(hdr); + break; + } /* Build new header */ image_set_magic(hdr, IH_MAGIC); image_set_time(hdr, time); image_set_size(hdr, imagesize); - image_set_load(hdr, params->addr); - image_set_ep(hdr, params->ep); + image_set_load(hdr, addr); + image_set_ep(hdr, ep); image_set_dcrc(hdr, checksum); image_set_os(hdr, params->os); image_set_arch(hdr, params->arch);