1
0
mirror of https://github.com/physwizz/a155-U-u1.git synced 2025-09-26 19:04:54 +00:00
Files
physwizz 99537be4e2 first
2024-03-11 06:53:12 +11:00

48 lines
1.1 KiB
C

// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (c) 2015-2019, MICROTRUST Incorporated
* All Rights Reserved.
*
*/
#include <linux/slab.h>
#include "teei_keymaster.h"
#include "teei_client_transfer_data.h"
#define IMSG_TAG "[tz_driver]"
#include <imsg_log.h>
#include <linux/vmalloc.h>
#define KM_COMMAND_MAGIC 'X'
int send_keymaster_command(void *buffer, unsigned long size)
{
int ret = 0;
struct TEEC_Context context;
struct TEEC_UUID uuid_ta = { 0xc09c9c5d, 0xaa50, 0x4b78,
{ 0xb0, 0xe4, 0x6e, 0xda, 0x61, 0x55, 0x6c, 0x3a } };
/* IMSG_INFO("TEEI start send_keymaster_command\n"); */
if (buffer == NULL || size < 1)
return -1;
memset(&context, 0, sizeof(context));
ret = ut_pf_gp_initialize_context(&context);
if (ret) {
IMSG_ERROR("Failed to initialize keymaster context ,err: %x",
ret);
goto release_1;
}
ret = ut_pf_gp_transfer_user_data(&context, &uuid_ta, KM_COMMAND_MAGIC,
buffer, size);
if (ret) {
IMSG_ERROR("Failed to transfer data,err: %x", ret);
goto release_2;
}
release_2:
ut_pf_gp_finalize_context(&context);
release_1:
/* IMSG_INFO("TEEI end of send_keymaster_command\n"); */
return ret;
}