1 // Licensed to the Apache Software Foundation (ASF) under one
2 // or more contributor license agreements.  See the NOTICE file
3 // distributed with this work for additional information
4 // regarding copyright ownership.  The ASF licenses this file
5 // to you under the Apache License, Version 2.0 (the
6 // "License"); you may not use this file except in compliance
7 // with the License.  You may obtain a copy of the License at
8 //
9 //   http://www.apache.org/licenses/LICENSE-2.0
10 //
11 // Unless required by applicable law or agreed to in writing,
12 // software distributed under the License is distributed on an
13 // "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14 // KIND, either express or implied.  See the License for the
15 // specific language governing permissions and limitations
16 // under the License.
17 
18 #![no_main]
19 
20 use optee_utee::{
21     ta_close_session, ta_create, ta_destroy, ta_invoke_command, ta_open_session, trace_println,
22 };
23 use optee_utee::{Error, ErrorKind, Parameters, Result};
24 use optee_utee::net::UdpSocket;
25 use proto::Command;
26 use std::io::Read;
27 use std::io::Write;
28 
29 #[ta_create]
create() -> Result<()>30 fn create() -> Result<()> {
31     trace_println!("[+] TA create");
32     Ok(())
33 }
34 
35 #[ta_open_session]
open_session(_params: &mut Parameters) -> Result<()>36 fn open_session(_params: &mut Parameters) -> Result<()> {
37     trace_println!("[+] TA open session");
38     Ok(())
39 }
40 
41 #[ta_close_session]
close_session()42 fn close_session() {
43     trace_println!("[+] TA close session");
44 }
45 
46 #[ta_destroy]
destroy()47 fn destroy() {
48     trace_println!("[+] TA destroy");
49 }
50 
51 #[ta_invoke_command]
invoke_command(cmd_id: u32, _params: &mut Parameters) -> Result<()>52 fn invoke_command(cmd_id: u32, _params: &mut Parameters) -> Result<()> {
53     trace_println!("[+] TA invoke command");
54     match Command::from(cmd_id) {
55         Command::Start => {
56             udp_socket();
57             Ok(())
58         }
59         _ => Err(Error::new(ErrorKind::BadParameters)),
60     }
61 }
62 
udp_socket()63 fn udp_socket() {
64     let mut stream = UdpSocket::connect("127.0.0.1", 34254).unwrap();
65     stream.write_all(b"[TA]: Hello, Teaclave!").unwrap();
66     let mut response = Vec::new();
67     let mut chunk = [0u8; 1024];
68 
69     // Loop until read something.
70     loop {
71         match stream.read(&mut chunk) {
72             Ok(0) => continue,
73             Ok(n) => {
74                 response.extend_from_slice(&chunk[..n]);
75                 break;
76             }
77             Err(_) => {
78                 trace_println!("Error");
79                 panic!();
80             }
81         }
82     }
83     trace_println!("{}", String::from_utf8_lossy(&response));
84 }
85 
86 // TA configurations
87 const TA_FLAGS: u32 = 0;
88 const TA_DATA_SIZE: u32 = 1 * 1024 * 1024;
89 const TA_STACK_SIZE: u32 = 2 * 1024 * 1024;
90 const TA_VERSION: &[u8] = b"0.1\0";
91 const TA_DESCRIPTION: &[u8] = b"This is a hello world example.\0";
92 const EXT_PROP_VALUE_1: &[u8] = b"Hello World TA\0";
93 const EXT_PROP_VALUE_2: u32 = 0x0010;
94 const TRACE_LEVEL: i32 = 4;
95 const TRACE_EXT_PREFIX: &[u8] = b"TA\0";
96 const TA_FRAMEWORK_STACK_SIZE: u32 = 2048;
97 
98 include!(concat!(env!("OUT_DIR"), "/user_ta_header.rs"));
99