unplugged-kernel/drivers/misc/mediatek/geniezone/mtee_ut/gz_vreg_ut.c

83 lines
1.7 KiB
C

// SPDX-License-Identifier: GPL-2.0
/*
* Copyright (c) 2019 MediaTek Inc.
*/
/*
* GenieZone (hypervisor-based seucrity platform) enables hardware protected
* and isolated security execution environment, includes
* 1. GZ hypervisor
* 2. Hypervisor-TEE OS (built-in Trusty OS)
* 3. Drivers (ex: debug, communication and interrupt) for GZ and
* hypervisor-TEE OS
* 4. GZ and hypervisor-TEE and GZ framework (supporting multiple TEE
* ecosystem, ex: M-TEE, Trusty, GlobalPlatform, ...)
*/
#include "gz_vreg_ut.h"
#include <linux/io.h>
#include <linux/printk.h>
#include <linux/string.h>
#include <linux/slab.h>
#include <linux/platform_device.h>
#define KREE_DEBUG(fmt...) pr_info("[SM_kUT]" fmt)
#define KREE_INFO(fmt...) pr_info("[SM_kUT]" fmt)
#define KREE_ERR(fmt...) pr_info("[SM_kUT][ERR]" fmt)
/*vreg: the same setting in gz*/
#define test_vreg_src_pa 0x1070A000 /*can modify*/
#define test_vreg_basic_size 0x1000 /*can modify*/
#define VREG_BASE_dyn_map (test_vreg_src_pa + 1 * test_vreg_basic_size)
#define WORD_WIDTH 4 /*32-bit*/
DEFINE_MUTEX(vreg_ut_mutex);
#define fg_test 0
int gz_test_vreg_main(void)
{
#if fg_test
void __iomem *io;
uint32_t v;
KREE_INFO("==> %s run\n", __func__);
io = ioremap_wc(VREG_BASE_dyn_map, test_vreg_basic_size);
if (!io) {
KREE_ERR("[%s] ioremap_wc fail\n", __func__);
goto out;
}
writel(0x2, io + (2 * WORD_WIDTH));
v = readl(io + (2 * WORD_WIDTH));
KREE_INFO("[%s] read[0x%llx]=0x%x\n", __func__,
(uint64_t) (io + (2 * WORD_WIDTH)), v);
if (io)
iounmap(io);
out:
#endif
KREE_INFO("[%s] no test here.\n", __func__);
return 0;
}
int gz_test_vreg(void *args)
{
mutex_lock(&vreg_ut_mutex);
gz_test_vreg_main();
mutex_unlock(&vreg_ut_mutex);
return 0;
}