blob: cd410b2c3a24422b2c1d21dad031b1f94fa7fc12 [file] [log] [blame]
#!/bin/bash
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
set -xe
# Include base script
source setup.sh
# Copy TA and host binary
cp ../examples/time-rs/ta/target/aarch64-unknown-optee-trustzone/release/*.ta shared
cp ../examples/time-rs/host/target/aarch64-unknown-linux-gnu/release/time-rs shared
# Run script specific commands in QEMU
run_in_qemu "cp *.ta /lib/optee_armtz/\n"
run_in_qemu "./time-rs\n"
run_in_qemu "^C"
# Script specific checks
{
grep -q "Success" screenlog.0 &&
grep -q "\[+] Get REE time (second: [0-9]*, millisecond: [0-9]*)" /tmp/serial.log &&
grep -q "\[+] Now wait 1 second in TEE" /tmp/serial.log &&
grep -q "\[+] Get system time (second: [0-9]*, millisecond: [0-9]*)" /tmp/serial.log &&
grep -q "\[+] After set the TA time 5 seconds ahead of system time, new TA time (second: [0-9]*, millisecond: [0-9]*)" /tmp/serial.log
} || {
cat -v screenlog.0
cat -v /tmp/serial.log
false
}
rm screenlog.0