This patch adds code to lib to enable sharing of useful OPTEE code between board-ports and architectures. The code on lib/optee/optee.c comes from the TI omap2 port. Eventually the OMAP2 code will be patched to include the shared code. The intention here is to add more useful OPTEE specific code as more functionality gets added. Signed-off-by: Bryan O'Donoghue <bryan.odonoghue@linaro.org> Cc: Harinarayan Bhatta <harinarayan@ti.com> Cc: Andrew F. Davis <afd@ti.com> Cc: Tom Rini <trini@konsulko.com> Cc: Kever Yang <kever.yang@rock-chips.com> Cc: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> Cc: Peng Fan <peng.fan@nxp.com> Tested-by: Peng Fan <peng.fan@nxp.com>master
parent
5cf32518ea
commit
32ce6179fb
@ -0,0 +1,8 @@ |
||||
config OPTEE |
||||
bool "Support OPTEE images" |
||||
help |
||||
U-Boot can be configured to boot OPTEE images. |
||||
Selecting this option will enable shared OPTEE library code and |
||||
enable an OPTEE specific bootm command that will perform additional |
||||
OPTEE specific checks before booting an OPTEE image created with |
||||
mkimage. |
@ -0,0 +1,7 @@ |
||||
#
|
||||
# (C) Copyright 2017 Linaro
|
||||
#
|
||||
# SPDX-License-Identifier: GPL-2.0+
|
||||
#
|
||||
|
||||
obj-$(CONFIG_OPTEE) += optee.o
|
@ -0,0 +1,31 @@ |
||||
/*
|
||||
* Copyright (C) 2017 Linaro |
||||
* Bryan O'Donoghue <bryan.odonoghue@linaro.org> |
||||
* |
||||
* SPDX-License-Identifier: GPL-2.0+ |
||||
*/ |
||||
|
||||
#include <common.h> |
||||
#include <tee/optee.h> |
||||
|
||||
int optee_verify_image(struct optee_header *hdr, unsigned long tzdram_start, |
||||
unsigned long tzdram_len, unsigned long image_len) |
||||
{ |
||||
unsigned long tzdram_end = tzdram_start + tzdram_len; |
||||
uint32_t tee_file_size; |
||||
|
||||
tee_file_size = hdr->init_size + hdr->paged_size + |
||||
sizeof(struct optee_header); |
||||
|
||||
if (hdr->magic != OPTEE_MAGIC || |
||||
hdr->version != OPTEE_VERSION || |
||||
hdr->init_load_addr_hi > tzdram_end || |
||||
hdr->init_load_addr_lo < tzdram_start || |
||||
tee_file_size > tzdram_len || |
||||
tee_file_size != image_len || |
||||
(hdr->init_load_addr_lo + tee_file_size) > tzdram_end) { |
||||
return -EINVAL; |
||||
} |
||||
|
||||
return 0; |
||||
} |
Loading…
Reference in new issue