OPTEE: 3.16.0-stm32mp1-r1
Signed-off-by: Christophe Priouzeau <christophe.priouzeau@foss.st.com> Change-Id: Idd8b84221d5f0621b31dbd8523e0b8e28368dc89
This commit is contained in:
parent
c2166edf50
commit
b361e0b1a3
|
|
@ -21,31 +21,16 @@ DEPLOYDIR ?= \$(SRC_PATH)/../deploy
|
||||||
# Set default optee-os config
|
# Set default optee-os config
|
||||||
CFG_EMBED_DTB_SOURCE_FILE ?= ${OPTEE_CONF}
|
CFG_EMBED_DTB_SOURCE_FILE ?= ${OPTEE_CONF}
|
||||||
|
|
||||||
# Configure default optee-os features
|
|
||||||
ENABLE_FIP ?= ${@bb.utils.contains('MACHINE_FEATURES','fip','1','',d)}
|
|
||||||
|
|
||||||
# Remove default variables
|
# Remove default variables
|
||||||
LDFLAGS =
|
LDFLAGS =
|
||||||
CFLAGS =
|
CFLAGS =
|
||||||
CPPFLAGS =
|
CPPFLAGS =
|
||||||
# Define default make options
|
# Define default make options
|
||||||
EXTRA_OEMAKE = $(echo "${EXTRA_OEMAKE}" | sed "s|LIBGCC_LOCATE_CFLAGS=[^ ]* |LIBGCC_LOCATE_CFLAGS=\$(KCFLAGS) |")
|
EXTRA_OEMAKE = $(echo "${EXTRA_OEMAKE}" | sed "s|LIBGCC_LOCATE_CFLAGS=[^ ]* |LIBGCC_LOCATE_CFLAGS=\$(KCFLAGS) |")
|
||||||
ifeq (\$(ENABLE_FIP), 0)
|
|
||||||
EXTRA_OEMAKE += CFG_STM32MP15x_STM32IMAGE=y
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Configure default optee-os features
|
|
||||||
ifeq (\$(ENABLE_FIP), 1)
|
|
||||||
OPTEE_SUFFIX ?= bin
|
|
||||||
else
|
|
||||||
OPTEE_SUFFIX ?= stm32
|
|
||||||
endif
|
|
||||||
|
|
||||||
# Set dependencies list for building all
|
# Set dependencies list for building all
|
||||||
DEPS = optee
|
DEPS = optee
|
||||||
ifeq (\$(ENABLE_FIP), 1)
|
|
||||||
DEPS += fip
|
DEPS += fip
|
||||||
endif
|
|
||||||
|
|
||||||
help:
|
help:
|
||||||
@echo
|
@echo
|
||||||
|
|
@ -58,10 +43,7 @@ help:
|
||||||
@echo " DEPLOYDIR = \$(DEPLOYDIR)"
|
@echo " DEPLOYDIR = \$(DEPLOYDIR)"
|
||||||
@echo
|
@echo
|
||||||
@echo "FIP configuration:"
|
@echo "FIP configuration:"
|
||||||
@echo " ENABLE_FIP = \$(ENABLE_FIP) ('1' to generate fip binary)"
|
|
||||||
ifeq (\$(ENABLE_FIP),1)
|
|
||||||
@echo " Do not forget to set FIP deploydir folders (such as FIP_DEPLOYDIR_ROOT) to provide path to needed binaries"
|
@echo " Do not forget to set FIP deploydir folders (such as FIP_DEPLOYDIR_ROOT) to provide path to needed binaries"
|
||||||
endif
|
|
||||||
@echo
|
@echo
|
||||||
@echo "Available targets:"
|
@echo "Available targets:"
|
||||||
@echo " all : build OPTEE-OS binaries for defined config(s)"
|
@echo " all : build OPTEE-OS binaries for defined config(s)"
|
||||||
|
|
@ -77,22 +59,22 @@ optee:
|
||||||
for dt in \$(CFG_EMBED_DTB_SOURCE_FILE) ; do \\
|
for dt in \$(CFG_EMBED_DTB_SOURCE_FILE) ; do \\
|
||||||
\$(MAKE) \$(EXTRA_OEMAKE) -C \$(SRC_PATH) PREFIX=\$(SDKTARGETSYSROOT) O=\$(BLD_PATH)/\$\$dt CFG_EMBED_DTB_SOURCE_FILE=\$\$dt.dts ; \\
|
\$(MAKE) \$(EXTRA_OEMAKE) -C \$(SRC_PATH) PREFIX=\$(SDKTARGETSYSROOT) O=\$(BLD_PATH)/\$\$dt CFG_EMBED_DTB_SOURCE_FILE=\$\$dt.dts ; \\
|
||||||
# Copy binary files with explicit name \\
|
# Copy binary files with explicit name \\
|
||||||
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_HEADER}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/${OPTEE_HEADER}-\$\$dt.\$(OPTEE_SUFFIX) ; \\
|
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_HEADER}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/${OPTEE_HEADER}-\$\$dt.${OPTEE_SUFFIX} ; \\
|
||||||
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_PAGER}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/${OPTEE_PAGER}-\$\$dt.\$(OPTEE_SUFFIX) ; \\
|
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_PAGER}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/${OPTEE_PAGER}-\$\$dt.${OPTEE_SUFFIX} ; \\
|
||||||
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_PAGEABLE}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/${OPTEE_PAGEABLE}-\$\$dt.\$(OPTEE_SUFFIX) ; \\
|
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_PAGEABLE}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/${OPTEE_PAGEABLE}-\$\$dt.${OPTEE_SUFFIX} ; \\
|
||||||
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_ELF}.${OPTEE_ELF_SUFFIX} \$(DEPLOYDIR)/debug/${OPTEE_ELF}-\$\$dt.${OPTEE_ELF_SUFFIX} ; \\
|
cp \$(BLD_PATH)/\$\$dt/core/${OPTEE_ELF}.${OPTEE_ELF_SUFFIX} \$(DEPLOYDIR)/debug/${OPTEE_ELF}-\$\$dt.${OPTEE_ELF_SUFFIX} ; \\
|
||||||
done ; \\
|
done ; \\
|
||||||
else \\
|
else \\
|
||||||
\$(MAKE) \$(EXTRA_OEMAKE) -C \$(SRC_PATH) PREFIX=\$(SDKTARGETSYSROOT) O=\$(BLD_PATH)/ ; \\
|
\$(MAKE) \$(EXTRA_OEMAKE) -C \$(SRC_PATH) PREFIX=\$(SDKTARGETSYSROOT) O=\$(BLD_PATH)/ ; \\
|
||||||
# Copy binary files with explicit name \\
|
# Copy binary files with explicit name \\
|
||||||
cp \$(BLD_PATH)/core/${OPTEE_HEADER}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/ ; \\
|
cp \$(BLD_PATH)/core/${OPTEE_HEADER}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/ ; \\
|
||||||
cp \$(BLD_PATH)/core/${OPTEE_PAGER}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/ ; \\
|
cp \$(BLD_PATH)/core/${OPTEE_PAGER}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/ ; \\
|
||||||
cp \$(BLD_PATH)/core/${OPTEE_PAGEABLE}.\$(OPTEE_SUFFIX) \$(DEPLOYDIR)/ ; \\
|
cp \$(BLD_PATH)/core/${OPTEE_PAGEABLE}.${OPTEE_SUFFIX} \$(DEPLOYDIR)/ ; \\
|
||||||
cp \$(BLD_PATH)/core/${OPTEE_ELF}.${OPTEE_ELF_SUFFIX} \$(DEPLOYDIR)/debug/ ; \\
|
cp \$(BLD_PATH)/core/${OPTEE_ELF}.${OPTEE_ELF_SUFFIX} \$(DEPLOYDIR)/debug/ ; \\
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fip: optee
|
fip: optee
|
||||||
FIP_DEPLOYDIR_OPTEE=\$(DEPLOYDIR) FIP_DEVICETREE="\$(CFG_EMBED_DTB_SOURCE_FILE)" fiptool-stm32mp
|
FIP_DEPLOYDIR_OPTEE=\$(DEPLOYDIR) FIP_DEVICETREE="\$(CFG_EMBED_DTB_SOURCE_FILE)" FIP_CONFIG="optee" FIP_BL32_CONF="optee" fiptool-stm32mp
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@echo "Removing \$(BLD_PATH) ..."
|
@echo "Removing \$(BLD_PATH) ..."
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,7 @@ DEPENDS += "dtc-native"
|
||||||
DEPENDS += "python3-pycryptodomex-native"
|
DEPENDS += "python3-pycryptodomex-native"
|
||||||
DEPENDS += "python3-pyelftools-native"
|
DEPENDS += "python3-pyelftools-native"
|
||||||
DEPENDS += "libgcc python3-cryptography-native"
|
DEPENDS += "libgcc python3-cryptography-native"
|
||||||
|
DEPENDS += "python3-pillow-native"
|
||||||
|
|
||||||
inherit deploy python3native
|
inherit deploy python3native
|
||||||
|
|
||||||
|
|
@ -22,17 +23,18 @@ OPTEEOUTPUTMACHINE ?= "${MACHINE}"
|
||||||
# Default log level
|
# Default log level
|
||||||
ST_OPTEE_DEBUG_LOG_LEVEL ??= "2"
|
ST_OPTEE_DEBUG_LOG_LEVEL ??= "2"
|
||||||
|
|
||||||
|
# default core debug
|
||||||
|
ST_OPTEE_CORE_DEBUG ??="y"
|
||||||
|
|
||||||
EXTRA_OEMAKE = "PLATFORM=${OPTEEMACHINE}"
|
EXTRA_OEMAKE = "PLATFORM=${OPTEEMACHINE}"
|
||||||
EXTRA_OEMAKE += "CROSS_COMPILE_core=${HOST_PREFIX}"
|
EXTRA_OEMAKE += "CROSS_COMPILE_core=${HOST_PREFIX}"
|
||||||
EXTRA_OEMAKE += "CROSS_COMPILE_ta_arm64=${HOST_PREFIX}"
|
EXTRA_OEMAKE += "CROSS_COMPILE_ta_arm64=${HOST_PREFIX}"
|
||||||
EXTRA_OEMAKE += "${@bb.utils.contains('TUNE_FEATURES', 'aarch64', 'CFG_ARM64_core=y ta-targets=ta_arm64', 'CFG_ARM32_core=y CROSS_COMPILE_ta_arm32=${HOST_PREFIX}', d)}"
|
EXTRA_OEMAKE += "${@bb.utils.contains('TUNE_FEATURES', 'aarch64', 'CFG_ARM64_core=y ta-targets=ta_arm64', 'CFG_ARM32_core=y CROSS_COMPILE_ta_arm32=${HOST_PREFIX}', d)}"
|
||||||
EXTRA_OEMAKE += "NOWERROR=1"
|
EXTRA_OEMAKE += "NOWERROR=1"
|
||||||
EXTRA_OEMAKE += "LDFLAGS="
|
EXTRA_OEMAKE += "LDFLAGS="
|
||||||
EXTRA_OEMAKE += "LIBGCC_LOCATE_CFLAGS=--sysroot=${STAGING_DIR_TARGET}"
|
|
||||||
EXTRA_OEMAKE += "${@bb.utils.contains('MACHINE_FEATURES', 'fip', '', 'CFG_STM32MP15x_STM32IMAGE=y', d)}"
|
|
||||||
|
|
||||||
# debug and trace
|
# debug and trace
|
||||||
EXTRA_OEMAKE += "${@bb.utils.contains('ST_OPTEE_DEBUG_TRACE', '1', 'CFG_TEE_CORE_LOG_LEVEL=${ST_OPTEE_DEBUG_LOG_LEVEL} CFG_TEE_CORE_DEBUG=n', '', d)}"
|
EXTRA_OEMAKE += "${@bb.utils.contains('ST_OPTEE_DEBUG_TRACE', '1', 'CFG_TEE_CORE_LOG_LEVEL=${ST_OPTEE_DEBUG_LOG_LEVEL} CFG_TEE_CORE_DEBUG=${ST_OPTEE_CORE_DEBUG}', '', d)}"
|
||||||
|
|
||||||
OPTEE_ARCH:armv7a = "arm32"
|
OPTEE_ARCH:armv7a = "arm32"
|
||||||
OPTEE_ARCH:armv7ve = "arm32"
|
OPTEE_ARCH:armv7ve = "arm32"
|
||||||
|
|
@ -77,7 +79,7 @@ do_install() {
|
||||||
OPTEE_HEADER = "tee-header_v2"
|
OPTEE_HEADER = "tee-header_v2"
|
||||||
OPTEE_PAGEABLE = "tee-pageable_v2"
|
OPTEE_PAGEABLE = "tee-pageable_v2"
|
||||||
OPTEE_PAGER = "tee-pager_v2"
|
OPTEE_PAGER = "tee-pager_v2"
|
||||||
OPTEE_SUFFIX = "${@bb.utils.contains('MACHINE_FEATURES','fip','bin','stm32',d)}"
|
OPTEE_SUFFIX = "bin"
|
||||||
# Output the ELF generated
|
# Output the ELF generated
|
||||||
ELF_DEBUG_ENABLE ?= ""
|
ELF_DEBUG_ENABLE ?= ""
|
||||||
OPTEE_ELF = "tee"
|
OPTEE_ELF = "tee"
|
||||||
|
|
|
||||||
|
|
@ -2,18 +2,19 @@ SUMMARY = "OPTEE TA development kit for stm32mp"
|
||||||
LICENSE = "BSD-2-Clause & BSD-3-Clause"
|
LICENSE = "BSD-2-Clause & BSD-3-Clause"
|
||||||
LIC_FILES_CHKSUM = "file://LICENSE;md5=c1f21c4f72f372ef38a5a4aee55ec173"
|
LIC_FILES_CHKSUM = "file://LICENSE;md5=c1f21c4f72f372ef38a5a4aee55ec173"
|
||||||
|
|
||||||
SRC_URI = "git://github.com/OP-TEE/optee_os.git;protocol=https;name=os"
|
SRC_URI = "git://github.com/OP-TEE/optee_os.git;protocol=https;branch=master;name=os"
|
||||||
SRCREV = "3d47a131bca1d9ed511bfd516aa5e70269e12c1d"
|
SRCREV = "d0b742d1564834dac903f906168d7357063d5459"
|
||||||
|
|
||||||
SRC_URI += " \
|
SRC_URI += " \
|
||||||
file://0001-3.12.0-stm32mp-r1.patch \
|
file://fonts.tar.gz;subdir=git;name=fonts \
|
||||||
file://0002-3.12.0-stm32mp-r1.1-rc1.patch \
|
file://0001-3.16.0-stm32mp-r1.patch \
|
||||||
file://0003-3.12.0-stm32mp-r2.patch \
|
|
||||||
"
|
"
|
||||||
|
|
||||||
OPTEE_VERSION = "3.12.0"
|
SRC_URI[fonts.sha256sum] = "4941e8bb6d8ac377838e27b214bf43008c496a24a8f897e0b06433988cbd53b2"
|
||||||
OPTEE_SUBVERSION = "stm32mp"
|
|
||||||
OPTEE_RELEASE = "r2"
|
OPTEE_VERSION = "3.16.0"
|
||||||
|
OPTEE_SUBVERSION = "stm32mp1"
|
||||||
|
OPTEE_RELEASE = "r1"
|
||||||
|
|
||||||
PV = "${OPTEE_VERSION}-${OPTEE_SUBVERSION}-${OPTEE_RELEASE}"
|
PV = "${OPTEE_VERSION}-${OPTEE_SUBVERSION}-${OPTEE_RELEASE}"
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
|
|
@ -1,61 +0,0 @@
|
||||||
From 4a99b2016fd0a2e207395da314a3c903c2e65c08 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Romuald JEANNE <romuald.jeanne@st.com>
|
|
||||||
Date: Wed, 2 Jun 2021 16:53:20 +0200
|
|
||||||
Subject: [PATCH 2/3] 3.12.0-stm32mp-r1.1-rc1
|
|
||||||
|
|
||||||
---
|
|
||||||
core/arch/arm/plat-stm32mp1/remoteproc_pta.c | 9 +++------
|
|
||||||
core/drivers/clk/clk-stm32mp15.c | 2 +-
|
|
||||||
core/drivers/stm32_bsec.c | 2 +-
|
|
||||||
3 files changed, 5 insertions(+), 8 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/core/arch/arm/plat-stm32mp1/remoteproc_pta.c b/core/arch/arm/plat-stm32mp1/remoteproc_pta.c
|
|
||||||
index 27b0dfa07..8f3360122 100644
|
|
||||||
--- a/core/arch/arm/plat-stm32mp1/remoteproc_pta.c
|
|
||||||
+++ b/core/arch/arm/plat-stm32mp1/remoteproc_pta.c
|
|
||||||
@@ -492,13 +492,10 @@ static TEE_Result
|
|
||||||
TEE_Param params[TEE_NUM_PARAMS] __unused,
|
|
||||||
void **sess_ctx __unused)
|
|
||||||
{
|
|
||||||
- struct tee_ta_session *s = tee_ta_get_calling_session();
|
|
||||||
+ struct ts_session *s = ts_get_calling_session();
|
|
||||||
|
|
||||||
- /* Check that we're called from a user TA */
|
|
||||||
- if (!s)
|
|
||||||
- return TEE_ERROR_ACCESS_DENIED;
|
|
||||||
-
|
|
||||||
- if (!is_user_ta_ctx(s->ctx))
|
|
||||||
+ /* TODO: check that we're called the remove proc TA (check UUID) */
|
|
||||||
+ if (!s || !is_user_ta_ctx(s->ctx))
|
|
||||||
return TEE_ERROR_ACCESS_DENIED;
|
|
||||||
|
|
||||||
return TEE_SUCCESS;
|
|
||||||
diff --git a/core/drivers/clk/clk-stm32mp15.c b/core/drivers/clk/clk-stm32mp15.c
|
|
||||||
index 794fd5e75..6bbab8902 100644
|
|
||||||
--- a/core/drivers/clk/clk-stm32mp15.c
|
|
||||||
+++ b/core/drivers/clk/clk-stm32mp15.c
|
|
||||||
@@ -962,7 +962,7 @@ static unsigned long __clk_get_parent_rate(enum stm32mp1_parent_id p)
|
|
||||||
unsigned long clock = 0;
|
|
||||||
vaddr_t rcc_base = stm32_rcc_base();
|
|
||||||
|
|
||||||
- switch (p) {
|
|
||||||
+ switch ((unsigned int)p) {
|
|
||||||
case _CK_MPU:
|
|
||||||
/* MPU sub system */
|
|
||||||
reg = io_read32(rcc_base + RCC_MPCKSELR);
|
|
||||||
diff --git a/core/drivers/stm32_bsec.c b/core/drivers/stm32_bsec.c
|
|
||||||
index 7d389a061..a8eba5f7d 100644
|
|
||||||
--- a/core/drivers/stm32_bsec.c
|
|
||||||
+++ b/core/drivers/stm32_bsec.c
|
|
||||||
@@ -646,7 +646,7 @@ static void bsec_dt_otp_nsec_access(void *fdt, int bsec_node)
|
|
||||||
|
|
||||||
size = length / sizeof(uint32_t);
|
|
||||||
|
|
||||||
- if (otp_id + size > STM32MP1_OTP_MAX_ID)
|
|
||||||
+ if (otp_id + size > OTP_MAX_SIZE)
|
|
||||||
panic("OTP range oversized");
|
|
||||||
|
|
||||||
for (i = otp_id; i < otp_id + size; i++)
|
|
||||||
--
|
|
||||||
2.17.1
|
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -1,20 +1,22 @@
|
||||||
Compilation of Optee-os (Trusted Execution Environment):
|
Compilation of Optee-os (Trusted Execution Environment):
|
||||||
1. Pre-requisite
|
1. Pre-requisite
|
||||||
2. Initialise cross-compilation via SDK
|
2. Initialize cross-compilation via SDK
|
||||||
3. Prepare optee-os source code
|
3. Prepare optee-os source code
|
||||||
4. Management of optee-os source code
|
4. Manage optee-os source code
|
||||||
5. Compile optee-os source code
|
5. Compile optee-os source code
|
||||||
6. Update software on board
|
6. Update software on board
|
||||||
|
|
||||||
1. Pre-requisite:
|
----------------
|
||||||
-----------------
|
1. Pre-requisite
|
||||||
|
----------------
|
||||||
OpenSTLinux SDK must be installed.
|
OpenSTLinux SDK must be installed.
|
||||||
|
|
||||||
If you have never configured you git configuration:
|
If you have never configured you git configuration:
|
||||||
$ git config --global user.name "your_name"
|
$ git config --global user.name "your_name"
|
||||||
$ git config --global user.email "your_email@example.com"
|
$ git config --global user.email "your_email@example.com"
|
||||||
|
|
||||||
2. Initialise cross-compilation via SDK:
|
---------------------------------------
|
||||||
|
2. Initialize cross-compilation via SDK
|
||||||
---------------------------------------
|
---------------------------------------
|
||||||
Source SDK environment:
|
Source SDK environment:
|
||||||
$ source <path to SDK>/environment-setup-cortexa7t2hf-neon-vfpv4-ostl-linux-gnueabi
|
$ source <path to SDK>/environment-setup-cortexa7t2hf-neon-vfpv4-ostl-linux-gnueabi
|
||||||
|
|
@ -26,25 +28,39 @@ If you have never configured you git configuration:
|
||||||
Warning: the environment are valid only on the shell session where you have
|
Warning: the environment are valid only on the shell session where you have
|
||||||
sourced the sdk environment.
|
sourced the sdk environment.
|
||||||
|
|
||||||
3. Prepare optee-os source:
|
--------------------------
|
||||||
------------------------
|
3. Prepare optee-os source
|
||||||
If you have the tarball and the list of patch then you must extract the
|
--------------------------
|
||||||
tarball and apply the patch.
|
If not already done, extract the sources from Developer Package tarball, for example:
|
||||||
$> tar xfz ##BP##-##PR##.tar.gz
|
$ tar xfJ en.SOURCES-stm32mp1-*.tar.xz
|
||||||
A new directory containing optee standard source code will be created, go into it:
|
|
||||||
$> cd ##BP##
|
|
||||||
|
|
||||||
NB: if there is no git management on source code and you would like to have a git management
|
In the optee-os source directory (sources/*/##BP##-##PR##),
|
||||||
on the code see section 4 [Management of optee-os source code]
|
you have one optee-os source tarball, the patches and one Makefile:
|
||||||
if there is some patch, please apply it on source code
|
- ##BP##-##PR##.tar.xz
|
||||||
|
- 00*.patch
|
||||||
|
- Makefile.sdk
|
||||||
|
|
||||||
|
If you would like to have a git management for the source code move to
|
||||||
|
to section 4 [Management of optee-os source code with GIT].
|
||||||
|
|
||||||
|
Otherwise, to manage optee-os source code without git, you must extract the
|
||||||
|
tarball now and apply the patch:
|
||||||
|
|
||||||
|
$> tar xf ##BP##-##PR##.tar.xz
|
||||||
|
$> cd ##BP##
|
||||||
|
$> tar xfz ../fonts.tar.gz
|
||||||
$> for p in `ls -1 ../*.patch`; do patch -p1 < $p; done
|
$> for p in `ls -1 ../*.patch`; do patch -p1 < $p; done
|
||||||
|
|
||||||
4. Management of optee-os source code:
|
You can now move to section 5 [Compile optee-os source code].
|
||||||
-----------------------------------
|
|
||||||
|
---------------------------------------
|
||||||
|
4. Manage optee-os source code with GIT
|
||||||
|
---------------------------------------
|
||||||
If you like to have a better management of change made on optee-os source,
|
If you like to have a better management of change made on optee-os source,
|
||||||
you have 3 solutions to use git
|
you have 3 solutions to use git
|
||||||
|
|
||||||
4.1 Get STMicroelectronics optee-os source from GitHub
|
4.1 Get STMicroelectronics optee-os source from GitHub
|
||||||
|
------------------------------------------------------
|
||||||
URL: https://github.com/STMicroelectronics/optee_os.git
|
URL: https://github.com/STMicroelectronics/optee_os.git
|
||||||
Branch: ##ARCHIVER_ST_BRANCH##
|
Branch: ##ARCHIVER_ST_BRANCH##
|
||||||
Revision: ##ARCHIVER_ST_REVISION##
|
Revision: ##ARCHIVER_ST_REVISION##
|
||||||
|
|
@ -53,33 +69,39 @@ you have 3 solutions to use git
|
||||||
$ git checkout -b WORKING ##ARCHIVER_ST_REVISION##
|
$ git checkout -b WORKING ##ARCHIVER_ST_REVISION##
|
||||||
|
|
||||||
4.2 Create Git from tarball
|
4.2 Create Git from tarball
|
||||||
|
---------------------------
|
||||||
$ cd <optee-os source>
|
$ cd <optee-os source>
|
||||||
$ test -d .git || git init . && git add . && git commit -m "optee-os source code" && git gc
|
$ test -d .git || git init . && git add . && git commit -m "optee-os source code" && git gc
|
||||||
$ git checkout -b WORKING
|
$ git checkout -b WORKING
|
||||||
$ for p in `ls -1 <path to patch>/*.patch`; do git am $p; done
|
$ tar xfz ../fonts.tar.gz
|
||||||
|
$ for p in `ls -1 ../*.patch`; do git am $p; done
|
||||||
|
|
||||||
MANDATORY: You must update sources
|
MANDATORY: You must update sources
|
||||||
$ cd <directory to optee-os source code>
|
$ cd <directory to optee-os source code>
|
||||||
$ chmod 755 scripts/bin_to_c.py
|
$ chmod 755 scripts/bin_to_c.py
|
||||||
|
|
||||||
4.3 Get Git from community and apply STMicroelectronics patches
|
4.3 Get Git from community and apply STMicroelectronics patches
|
||||||
|
---------------------------------------------------------------
|
||||||
|
* With the optee-os source code from the OP-TEE git repositories:
|
||||||
URL: git://github.com/OP-TEE/optee_os.git
|
URL: git://github.com/OP-TEE/optee_os.git
|
||||||
Branch: ##ARCHIVER_COMMUNITY_BRANCH##
|
Branch: ##ARCHIVER_COMMUNITY_BRANCH##
|
||||||
Revision: ##ARCHIVER_COMMUNITY_REVISION##
|
Revision: ##ARCHIVER_COMMUNITY_REVISION##
|
||||||
|
|
||||||
$ git clone git://github.com/OP-TEE/optee_os.git
|
$ git clone git://github.com/OP-TEE/optee_os.git
|
||||||
$ cd <optee-os source>
|
$ cd optee_os
|
||||||
$ git checkout -b WORKING ##ARCHIVER_COMMUNITY_REVISION##
|
$ git checkout -b WORKING ##ARCHIVER_COMMUNITY_REVISION##
|
||||||
|
$ tar xfz <path to patch>/fonts.tar.gz
|
||||||
$ for p in `ls -1 <path to patch>/*.patch`; do git am $p; done
|
$ for p in `ls -1 <path to patch>/*.patch`; do git am $p; done
|
||||||
|
|
||||||
MANDATORY: You must update sources
|
MANDATORY: You must update sources
|
||||||
$ cd <directory to optee-os source code>
|
$ cd <directory to optee-os source code>
|
||||||
$ chmod 755 scripts/bin_to_c.py
|
$ chmod 755 scripts/bin_to_c.py
|
||||||
|
|
||||||
5. Build optee-os source code:
|
-------------------------------
|
||||||
--------------------------------
|
5. Compile optee-os source code
|
||||||
Since OpenSTLinux has activated FIP by default, so the FIP_artifacts should be specified before launching compilation
|
-------------------------------
|
||||||
- In case of using SOURCES-xxxx.tar.gz of Developer package the FIP_DEPLOYDIR_ROOT should be set as below:
|
Since OpenSTLinux activates FIP by default, FIP_artifacts directory path must be specified before launching compilation
|
||||||
|
- In case of using SOURCES-xxxx.tar.gz of Developer package the FIP_DEPLOYDIR_ROOT must be set as below:
|
||||||
$> export FIP_DEPLOYDIR_ROOT=$PWD/../../FIP_artifacts
|
$> export FIP_DEPLOYDIR_ROOT=$PWD/../../FIP_artifacts
|
||||||
|
|
||||||
To compile optee-os source code
|
To compile optee-os source code
|
||||||
|
|
@ -87,10 +109,14 @@ To compile optee-os source code
|
||||||
or for a specific config :
|
or for a specific config :
|
||||||
$ make -f $PWD/../Makefile.sdk CFG_EMBED_DTB_SOURCE_FILE=stm32mp157c-ev1 all
|
$ make -f $PWD/../Makefile.sdk CFG_EMBED_DTB_SOURCE_FILE=stm32mp157c-ev1 all
|
||||||
|
|
||||||
|
By default, the build results for this component are available in $PWD/../deploy directory.
|
||||||
|
If needed, this deploy directory can be specified by added "DEPLOYDIR=<your_deploy_dir_path>" compilation option to the build command line above.
|
||||||
|
In case DEPLOYDIR=$FIP_DEPLOYDIR_ROOT/optee it overwrites files directly in FIP artifacts directory.
|
||||||
|
|
||||||
The generated FIP images are available in $FIP_DEPLOYDIR_ROOT/fip
|
The generated FIP images are available in $FIP_DEPLOYDIR_ROOT/fip
|
||||||
|
|
||||||
|
---------------------------
|
||||||
6. Update software on board:
|
6. Update software on board
|
||||||
----------------------------
|
---------------------------
|
||||||
Please use STM32CubeProgrammer and only tick the ssbl-boot and fip partitions (more informations on the wiki website http://wiki.st.com/stm32mpu)
|
Please use STM32CubeProgrammer and only tick the ssbl-boot and fip partitions (more informations on the wiki website http://wiki.st.com/stm32mpu)
|
||||||
|
|
||||||
|
|
|
||||||
Binary file not shown.
Loading…
Reference in New Issue