1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
|
// SPDX-License-Identifier: BSD-2-Clause
/*
* Copyright (c) 2014, STMicroelectronics International N.V.
*/
#include <mm/vm.h>
#include <stdlib.h>
#include <tee_api_defines.h>
#include <tee/tee_fs.h>
#include <tee/tee_obj.h>
#include <tee/tee_pobj.h>
#include <tee/tee_svc_cryp.h>
#include <trace.h>
void tee_obj_add(struct user_ta_ctx *utc, struct tee_obj *o)
{
TAILQ_INSERT_TAIL(&utc->objects, o, link);
}
TEE_Result tee_obj_get(struct user_ta_ctx *utc, vaddr_t obj_id,
struct tee_obj **obj)
{
struct tee_obj *o;
TAILQ_FOREACH(o, &utc->objects, link) {
if (obj_id == (vaddr_t)o) {
*obj = o;
return TEE_SUCCESS;
}
}
return TEE_ERROR_BAD_STATE;
}
void tee_obj_close(struct user_ta_ctx *utc, struct tee_obj *o)
{
TAILQ_REMOVE(&utc->objects, o, link);
if ((o->info.handleFlags & TEE_HANDLE_FLAG_PERSISTENT)) {
o->pobj->fops->close(&o->fh);
tee_pobj_release(o->pobj);
}
tee_obj_free(o);
}
void tee_obj_close_all(struct user_ta_ctx *utc)
{
struct tee_obj_head *objects = &utc->objects;
while (!TAILQ_EMPTY(objects))
tee_obj_close(utc, TAILQ_FIRST(objects));
}
TEE_Result tee_obj_verify(struct tee_ta_session *sess, struct tee_obj *o)
{
TEE_Result res;
const struct tee_file_operations *fops = o->pobj->fops;
struct tee_file_handle *fh = NULL;
if (!fops)
return TEE_ERROR_STORAGE_NOT_AVAILABLE;
res = fops->open(o->pobj, NULL, &fh);
if (res == TEE_ERROR_CORRUPT_OBJECT) {
EMSG("Object corrupt");
fops->remove(o->pobj);
tee_obj_close(to_user_ta_ctx(sess->ts_sess.ctx), o);
}
fops->close(&fh);
return res;
}
struct tee_obj *tee_obj_alloc(void)
{
return calloc(1, sizeof(struct tee_obj));
}
void tee_obj_free(struct tee_obj *o)
{
if (o) {
tee_obj_attr_free(o);
free(o->attr);
free(o);
}
}
|