03_OPTEE-OS_系统集成之(一)编译、实例、在QEMU上执行
carloscn opened this issue · 0 comments
03_OPTEE-OS_系统集成之(一)编译、实例、在QEMU上执行
1. OP-TEE运行环境的搭建编译
OP-TEE是开源的TEE解决方案,任何人都可从github库中获取OP-TEE的源代码,本章主要包括如何从github中获取OP-TEE的源代码、如何搭建运 行环境以及整个OP-TEE工程的编译过程。本书以 QEMU作为运行平台,Hikey或者其他平台的编译和使用方式与QEMU平台类似。
1.1 环境准备
https://optee.readthedocs.io/en/latest/building/prerequisites.html
1.2 准备和编译
mkdir optee-repo && cd optee-repo
curl https://mirrors.tuna.tsinghua.edu.cn/git/git-repo -o ~/bin/repo
chmod a+x ~/bin/repo
export PATH=~/bin:$PATH
~/bin/repo init -u https://github.com/OP-TEE/manifest.git -m qemu_v8.xm
repo sync
cd ./build
make -j2 toolchains
make -f qemu_v8.mk all -j16
make -f qemu_v8.mk run-only
1.3 xtest运行
在qemu的shell输入c
就会启动系统
输入xtest
开始运行:
1.4 初识optee
Normal world会显示如下Linux相关的log:
OPTEE端也会显示内存映射的详细信息还有OPTEE的版本信息。
I/TC: OP-TEE version: 3.15.0-dev (gcc version 10.2.1 20201103 (GNU Toolchain for the A-profile Architecture 10.2-2020.11 (arm-10.16))) #8 Thu Dec 23 15:55:20 UTC 2021 aarch64
一旦OPTEE加载成功之后,就会切换到Normal World的Linux
在Linux端能够看到Linux的OPTEE的驱动probe的信息,到这里可以推断出OPTEE是以Linux驱动的结构存在于Linux Kernel中的。
[ 2.019187] optee: probing for conduit method.
[ 2.021676] optee: revision 3.15 (6be0dbca)
[ 2.027383] optee: dynamic shared memory is enabled
[ 2.058506] optee: initialized driver
可以在/dev下面看到optee的设备节点:
#ls -al /dev/tee*
crw-rw---- 1 root teeclnt 247, 0 Dec 24 07:33 /dev/tee0
crw-rw---- 1 root tee 247, 16 Dec 24 07:33 /dev/teepriv0
#
OP-TEE Client (tee-supllicant)以进程的形式运行在后台,而且随着linux启动。
#ps -A | grep tee
145 tee /usr/sbin/tee-supplicant -d /dev/teepriv0
146 root [optee_bus_scan]
180 root grep tee
#
安全应用会产生ta文件在文件系统/lib/optee_armtz
# ls /lib/optee_armtz/
12345678-5b69-11e4-9dbb-101f74f00099.ta
25497083-a58a-4fc5-8a72-1ad7b69b8562.ta
2a287631-de1b-4fdd-a55c-b9312e40769a.ta
380231ac-fb99-47ad-a689-9e017eb6e78a.ta
484d4143-2d53-4841-3120-4a6f636b6542.ta
528938ce-fc59-11e8-8eb2-f2801f1b9fd1.ta
5b9e0e40-2636-11e1-ad9e-0002a5d5c51b.ta
5ce0c432-0ab0-40e5-a056-782ca0e6aba2.ta
5dbac793-f574-4871-8ad3-04331ec17f24.ta
60276949-7ff3-4920-9bce-840c9dcf3098.ta
614789f2-39c0-4ebf-b235-92b32ac107ed.ta
731e279e-aafb-4575-a771-38caa6f0cca6.ta
873bcd08-c2c3-11e6-a937-d0bf9c45c61c.ta
8aaaf200-2450-11e4-abe2-0002a5d5c51b.ta
a4c04d50-f180-11e8-8eb2-f2801f1b9fd1.ta
a734eed9-d6a1-4244-aa50-7c99719e7b7b.ta
b3091a65-9751-4784-abf7-0298a7cc35ba.ta
b689f2a7-8adf-477a-9f99-32e90c0ad0a2.ta
b6c53aba-9669-4668-a7f2-205629d00f86.ta
c3f6e2c0-3548-11e1-b86c-0800200c9a66.ta
cb3e5ba0-adf1-11e0-998b-0002a5d5c51b.ta
d17f73a0-36ef-11e1-984a-0002a5d5c51b.ta
e13010e0-2ae1-11e5-896a-0002a5d5c51b.ta
e626662e-c0e2-485c-b8c8-09fbce6edf3d.ta
e6a33ed4-562b-463a-bb7e-ff5e15a493c8.ta
ee90d523-90ad-46a0-859d-8eea0b150086.ta
f157cda0-550c-11e5-a6fa-0002a5d5c51b.ta
f4e750bb-1437-4fbf-8785-8d3580c34994.ta
ffd2bded-ab7d-4988-95ee-e4962fff7154.ta
#
有一些实例:"/usr/bin"
# ls /usr/bin/optee*
/usr/bin/optee_example_acipher /usr/bin/optee_example_plugins
/usr/bin/optee_example_aes /usr/bin/optee_example_random
/usr/bin/optee_example_hello_world /usr/bin/optee_example_secure_storage
/usr/bin/optee_example_hotp
#
# ls /usr/bin/xtest 0
/usr/bin/xtest
#
2. 增加carlos_test实例
https://github.com/carloscn/optee_examples/tree/carlos/carlos_test