blob: 8e2d7892c4d96406bc3730eee05d3f0042ed68d7 [file] [log] [blame] [edit]
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#include <common.h>
#include <command.h>
#include <amlogic/media/vpu/vpu.h>
static int do_vpu_enable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
run_command("mw fe010130 118", 0); /* TODO */
run_command("mw fe000218 00080000", 0); /* TODO */
vpu_probe();
return 0;
}
static int do_vpu_disable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
vpu_remove();
return 0;
}
static int do_vpu_clk(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int level;
int ret = 0;
if (argc == 1) {
return -1;
}
if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
level = (int)simple_strtoul(argv[2], NULL, 10);
ret = vpu_clk_change(level);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
vpu_clk_get();
} else {
ret = -1;
}
return ret;
}
static int do_vpu_arb_l1_bind_change(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int level1_module;
int level2_module;
int ret = 0;
if (argc < 3) {
printf("vpu arb_bind1 x(index) x(bind_port)\n");
return -1;
}
level1_module = (int)simple_strtoul(argv[1], NULL, 10);
level2_module = (int)simple_strtoul(argv[2], NULL, 10);
ret = vpu_rdarb_bind_l1(level1_module, level2_module);
if (ret != -1)
print_bind1_change_info(level1_module, level2_module);
return ret;
}
static int do_vpu_arb_l2_bind_change(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int level2_module;
int vpu_prot;
int ret = 0;
if (argc < 3) {
printf("vpu arb_bind2 x(index) x(bind_port)\n");
return -1;
}
level2_module = (int)simple_strtoul(argv[1], NULL, 10);
vpu_prot = (int)simple_strtoul(argv[2], NULL, 10);
ret = vpu_rdarb_bind_l2(level2_module, vpu_prot);
if (ret != -1)
print_bind2_change_info(level2_module, vpu_prot);
return ret;
}
static int do_vpu_urgent_change(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int module;
int urgent_val;
int ret = 0;
if (argc < 3) {
printf("vpu urgent_set x(index) x(value)\n");
return -1;
}
module = (int)simple_strtoul(argv[1], NULL, 10);
urgent_val = (int)simple_strtoul(argv[2], NULL, 10);
/*first parameter reserve*/
ret = vpu_urgent_set(module, urgent_val);
if (ret == -1)
return ret;
print_urgent_change_info(module, urgent_val);
return ret;
}
static int do_vpu_test(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
vcbus_test();
return 0;
}
static int do_vpu_arb_info(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
get_arb_module_info();
return 0;
}
static int do_vpu_rdarb(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
dump_vpu_rdarb_table();
return 0;
}
static int do_vpu_urgent(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
dump_vpu_urgent_table();
return 0;
}
static int do_vpu_info(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
vpu_info_print();
return 0;
}
static int do_vpu_secure(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int temp;
if (argc == 1)
return -1;
temp = (unsigned int)simple_strtoul(argv[1], NULL, 10);
vpu_sec_debug(temp);
return 0;
}
static cmd_tbl_t cmd_vpu_sub[] = {
U_BOOT_CMD_MKENT(probe, 2, 0, do_vpu_enable, "", ""),
U_BOOT_CMD_MKENT(remove, 2, 0, do_vpu_disable, "", ""),
U_BOOT_CMD_MKENT(clk, 3, 0, do_vpu_clk, "", ""),
U_BOOT_CMD_MKENT(test, 2, 0, do_vpu_test, "", ""),
U_BOOT_CMD_MKENT(rdarb, 2, 0, do_vpu_rdarb, "", ""),
U_BOOT_CMD_MKENT(urgent, 2, 0, do_vpu_urgent, "", ""),
U_BOOT_CMD_MKENT(arb_bind1, 3, 0, do_vpu_arb_l1_bind_change, "", ""),
U_BOOT_CMD_MKENT(arb_bind2, 3, 0, do_vpu_arb_l2_bind_change, "", ""),
U_BOOT_CMD_MKENT(urgent_set, 3, 0, do_vpu_urgent_change, "", ""),
U_BOOT_CMD_MKENT(arb_module_info, 2, 0, do_vpu_arb_info, "", ""),
U_BOOT_CMD_MKENT(info, 2, 0, do_vpu_info, "", ""),
U_BOOT_CMD_MKENT(sec, 2, 0, do_vpu_secure, "", ""),
};
static int do_vpu(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
cmd_tbl_t *c;
/* Strip off leading 'bmp' command argument */
argc--;
argv++;
c = find_cmd_tbl(argv[0], &cmd_vpu_sub[0], ARRAY_SIZE(cmd_vpu_sub));
if (c) {
return c->cmd(cmdtp, flag, argc, argv);
} else {
cmd_usage(cmdtp);
return 1;
}
}
U_BOOT_CMD(
vpu, 5, 0, do_vpu,
"vpu sub-system",
"vpu probe - enable vpu domain\n"
"vpu remove - disable vpu domain\n"
"vpu test - test vcbus access\n"
"vpu rdarb - get vpu rdarb info\n"
"vpu arb_module_info - get vpu arb module info\n"
"vpu urgent - get vpu urgent info\n"
"vpu arb_bind1 - change level1 arb bind\n"
"vpu arb_bind2 - change level2 arb bind\n"
"vpu urgent_set - change urgent value\n"
);