17509ff7cSJens Wiklander // SPDX-License-Identifier: BSD-2-Clause
27509ff7cSJens Wiklander /*
37509ff7cSJens Wiklander * Copyright (c) 2019, Linaro Limited
4*baa5161dSBalint Dobszay * Copyright (c) 2020, Arm Limited
57509ff7cSJens Wiklander */
67509ff7cSJens Wiklander
7*baa5161dSBalint Dobszay #include <ldelf.h>
87509ff7cSJens Wiklander #include <trace.h>
97509ff7cSJens Wiklander
107509ff7cSJens Wiklander #include "sys.h"
117509ff7cSJens Wiklander
127509ff7cSJens Wiklander int trace_level = TRACE_LEVEL;
137509ff7cSJens Wiklander const char trace_ext_prefix[] = "LD";
147509ff7cSJens Wiklander
__panic(const char * file __maybe_unused,const int line __maybe_unused,const char * func __maybe_unused)157509ff7cSJens Wiklander void __panic(const char *file __maybe_unused, const int line __maybe_unused,
167509ff7cSJens Wiklander const char *func __maybe_unused)
177509ff7cSJens Wiklander {
187509ff7cSJens Wiklander if (!file && !func)
197509ff7cSJens Wiklander EMSG_RAW("Panic");
207509ff7cSJens Wiklander else
217509ff7cSJens Wiklander EMSG_RAW("Panic at %s:%d %s%s%s",
227509ff7cSJens Wiklander file ? file : "?", file ? line : 0,
237509ff7cSJens Wiklander func ? "<" : "", func ? func : "", func ? ">" : "");
247509ff7cSJens Wiklander
25*baa5161dSBalint Dobszay _ldelf_panic(1);
267509ff7cSJens Wiklander /*NOTREACHED*/
277509ff7cSJens Wiklander while (true)
287509ff7cSJens Wiklander ;
297509ff7cSJens Wiklander }
307509ff7cSJens Wiklander
sys_return_cleanup(void)317509ff7cSJens Wiklander void sys_return_cleanup(void)
327509ff7cSJens Wiklander {
33*baa5161dSBalint Dobszay _ldelf_return(0);
347509ff7cSJens Wiklander /*NOTREACHED*/
357509ff7cSJens Wiklander while (true)
367509ff7cSJens Wiklander ;
377509ff7cSJens Wiklander }
387509ff7cSJens Wiklander
sys_map_zi(size_t num_bytes,uint32_t flags,vaddr_t * va,size_t pad_begin,size_t pad_end)397509ff7cSJens Wiklander TEE_Result sys_map_zi(size_t num_bytes, uint32_t flags, vaddr_t *va,
407509ff7cSJens Wiklander size_t pad_begin, size_t pad_end)
417509ff7cSJens Wiklander {
42*baa5161dSBalint Dobszay return _ldelf_map_zi(va, num_bytes, pad_begin, pad_end, flags);
437509ff7cSJens Wiklander }
447509ff7cSJens Wiklander
sys_unmap(vaddr_t va,size_t num_bytes)457509ff7cSJens Wiklander TEE_Result sys_unmap(vaddr_t va, size_t num_bytes)
467509ff7cSJens Wiklander {
47*baa5161dSBalint Dobszay return _ldelf_unmap(va, num_bytes);
487509ff7cSJens Wiklander }
497509ff7cSJens Wiklander
sys_open_ta_bin(const TEE_UUID * uuid,uint32_t * handle)507509ff7cSJens Wiklander TEE_Result sys_open_ta_bin(const TEE_UUID *uuid, uint32_t *handle)
517509ff7cSJens Wiklander {
52*baa5161dSBalint Dobszay return _ldelf_open_bin(uuid, sizeof(TEE_UUID), handle);
537509ff7cSJens Wiklander }
547509ff7cSJens Wiklander
sys_close_ta_bin(uint32_t handle)557509ff7cSJens Wiklander TEE_Result sys_close_ta_bin(uint32_t handle)
567509ff7cSJens Wiklander {
57*baa5161dSBalint Dobszay return _ldelf_close_bin(handle);
587509ff7cSJens Wiklander }
597509ff7cSJens Wiklander
sys_map_ta_bin(vaddr_t * va,size_t num_bytes,uint32_t flags,uint32_t handle,size_t offs,size_t pad_begin,size_t pad_end)607509ff7cSJens Wiklander TEE_Result sys_map_ta_bin(vaddr_t *va, size_t num_bytes, uint32_t flags,
617509ff7cSJens Wiklander uint32_t handle, size_t offs, size_t pad_begin,
627509ff7cSJens Wiklander size_t pad_end)
637509ff7cSJens Wiklander {
64*baa5161dSBalint Dobszay return _ldelf_map_bin(va, num_bytes, handle, offs,
65*baa5161dSBalint Dobszay pad_begin, pad_end, flags);
667509ff7cSJens Wiklander }
677509ff7cSJens Wiklander
687509ff7cSJens Wiklander
sys_copy_from_ta_bin(void * dst,size_t num_bytes,uint32_t handle,size_t offs)697509ff7cSJens Wiklander TEE_Result sys_copy_from_ta_bin(void *dst, size_t num_bytes, uint32_t handle,
707509ff7cSJens Wiklander size_t offs)
717509ff7cSJens Wiklander {
72*baa5161dSBalint Dobszay return _ldelf_cp_from_bin(dst, offs, num_bytes, handle);
737509ff7cSJens Wiklander }
747509ff7cSJens Wiklander
sys_set_prot(vaddr_t va,size_t num_bytes,uint32_t flags)757509ff7cSJens Wiklander TEE_Result sys_set_prot(vaddr_t va, size_t num_bytes, uint32_t flags)
767509ff7cSJens Wiklander {
77*baa5161dSBalint Dobszay return _ldelf_set_prot(va, num_bytes, flags);
787509ff7cSJens Wiklander }
7988796f89SJens Wiklander
sys_remap(vaddr_t old_va,vaddr_t * new_va,size_t num_bytes,size_t pad_begin,size_t pad_end)8088796f89SJens Wiklander TEE_Result sys_remap(vaddr_t old_va, vaddr_t *new_va, size_t num_bytes,
8188796f89SJens Wiklander size_t pad_begin, size_t pad_end)
8288796f89SJens Wiklander {
83*baa5161dSBalint Dobszay return _ldelf_remap(old_va, new_va, num_bytes, pad_begin, pad_end);
84*baa5161dSBalint Dobszay }
8588796f89SJens Wiklander
sys_gen_random_num(void * buf,size_t blen)86*baa5161dSBalint Dobszay TEE_Result sys_gen_random_num(void *buf, size_t blen)
87*baa5161dSBalint Dobszay {
88*baa5161dSBalint Dobszay return _ldelf_gen_rnd_num(buf, blen);
8988796f89SJens Wiklander }
90