blob: 9736de28383cdcbd80a1c3961bdd0cdc73e88328 [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 <malloc.h>
#include <amlogic/media/vout/lcd/aml_lcd.h>
#include <amlogic/media/vout/lcd/lcd_memory.h>
static int do_lcd_probe(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_probe(0);
return 0;
}
static int do_lcd_enable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
char *mode, *str;
str = env_get("outputmode");
if (!str) {
printf("no outputmode\n");
return -1;
}
mode = (char *)malloc(64);
if (!mode) {
printf("%s: create mode failed\n", __func__);
return -1;
}
memset(mode, 0, 64);
sprintf(mode, "%s", str);
aml_lcd_driver_enable(0, mode);
free(mode);
return 0;
}
static int do_lcd_disable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_disable(0);
return 0;
}
static int do_lcd_ss(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int value, temp;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "level") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xff;
aml_lcd_driver_set_ss(0, value, 0xff, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(0, 0xff, value, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "mode") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(0, 0xff, 0xff, value);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 16);
value &= 0xffff;
temp = value >> 8;
aml_lcd_driver_set_ss(0, (value & 0xff),
((temp >> LCD_CLK_SS_BIT_FREQ) & 0xf),
((temp >> LCD_CLK_SS_BIT_MODE) & 0xf));
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
aml_lcd_driver_get_ss(0);
} else {
ret = -1;
}
return ret;
}
static int do_lcd_clk(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_clk_info(0);
return 0;
}
static int do_lcd_print(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int val = 0;
if (argc == 1)
return -1;
val = (unsigned int)simple_strtoul(argv[1], NULL, 16);
aml_lcd_driver_debug_print(0, val);
return 0;
}
static int do_lcd_info(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_info(0);
return 0;
}
#ifdef CONFIG_AML_LCD_TCON
static int do_lcd_tcon(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
struct aml_lcd_drv_s *pdrv = aml_lcd_get_driver(0);
unsigned int addr, val, len;
int ret = 0, i;
if (argc == 1)
return -1;
if (!pdrv) {
printf("no lcd driver\n");
return 0;
}
if (strcmp(argv[1], "reg") == 0) {
if (pdrv->tcon_reg_print)
pdrv->tcon_reg_print();
else
printf("no lcd tcon_reg_print\n");
} else if (strcmp(argv[1], "table") == 0) {
if (pdrv->tcon_table_print)
pdrv->tcon_table_print();
else
printf("no lcd tcon_table_print\n");
} else if (strcmp(argv[1], "tw") == 0) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
val = (unsigned int)simple_strtoul(argv[3], NULL, 16);
if (pdrv->tcon_table_write) {
val = pdrv->tcon_table_write(addr, val);
printf("write tcon table[0x%04x] = 0x%02x\n",
addr, val);
} else {
printf("no tcon_table_write\n");
}
} else if (strcmp(argv[1], "tr") == 0) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
if (pdrv->tcon_table_read) {
val = pdrv->tcon_table_read(addr);
printf("read tcon table[0x%04x] = 0x%02x\n",
addr, val);
} else {
printf("no tcon_table_write\n");
}
} else if (strcmp(argv[1], "wb") == 0) {
if (pdrv->tcon_reg_write) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
val = (unsigned int)simple_strtoul(argv[3], NULL, 16);
pdrv->tcon_reg_write(addr, val, 1);
printf
("tcon byte write: 0x%04x = 0x%02x, readback 0x%02x\n",
addr, val, pdrv->tcon_reg_read(addr, 1));
} else {
printf("no tcon_reg_write\n");
}
} else if (strcmp(argv[1], "rb") == 0) {
if (pdrv->tcon_reg_read) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
val = pdrv->tcon_reg_read(addr, 1);
printf("tcon byte read: 0x%04x = 0x%02x\n", addr, val);
} else {
printf("no tcon_reg_read\n");
}
} else if (strcmp(argv[1], "db") == 0) {
if (pdrv->tcon_reg_read) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
len = (unsigned int)simple_strtoul(argv[3], NULL, 10);
printf("tcon byte reg dump:\n");
for (i = 0; i < len; i++) {
val = pdrv->tcon_reg_read((addr + i), 1);
printf(" 0x%04x = 0x%02x\n", (addr + i), val);
}
} else {
printf("no tcon_reg_read\n");
}
} else if (strcmp(argv[1], "w") == 0) {
if (pdrv->tcon_reg_write) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
val = (unsigned int)simple_strtoul(argv[3], NULL, 16);
pdrv->tcon_reg_write(addr, val, 0);
printf("tcon write: 0x%04x = 0x%08x, readback 0x%08x\n",
addr, val, pdrv->tcon_reg_read(addr, 0));
} else {
printf("no tcon_reg_write\n");
}
} else if (strcmp(argv[1], "r") == 0) {
if (pdrv->tcon_reg_read) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
val = pdrv->tcon_reg_read(addr, 0);
printf("tcon read: 0x%04x = 0x%08x\n", addr, val);
} else {
printf("no tcon_reg_read\n");
}
} else if (strcmp(argv[1], "d") == 0) {
if (pdrv->tcon_reg_read) {
addr = (unsigned int)simple_strtoul(argv[2], NULL, 16);
len = (unsigned int)simple_strtoul(argv[3], NULL, 10);
printf("tcon reg dump:\n");
for (i = 0; i < len; i++) {
val = pdrv->tcon_reg_read((addr + i), 0);
printf(" 0x%04x = 0x%08x\n", (addr + i), val);
}
} else {
printf("no tcon_reg_read\n");
}
} else if (strcmp(argv[1], "data") == 0) {
if (argc == 3) {
i = (unsigned char)simple_strtoul(argv[2], NULL, 10);
if (pdrv->tcon_data_print)
pdrv->tcon_data_print(i);
else
printf("no lcd tcon_data_print\n");
} else {
if (pdrv->tcon_data_print)
pdrv->tcon_data_print(0xff);
else
printf("no lcd tcon_data_print\n");
}
} else if (strcmp(argv[1], "tee") == 0) {
if (strcmp(argv[2], "on") == 0)
val = 1;
else
val = 0;
if (pdrv->tcon_mem_tee_protect)
pdrv->tcon_mem_tee_protect(val);
else
printf("no lcd tcon_mem_tee_protect\n");
} else if (strcmp(argv[1], "spi") == 0) {
if (pdrv->tcon_spi_print)
pdrv->tcon_spi_print();
else
printf("no lcd tcon_spi_print\n");
} else if (strcmp(argv[1], "check") == 0) {
if (pdrv->tcon_forbidden_check)
pdrv->tcon_forbidden_check();
else
printf("no lcd tcon_forbidden_check\n");
} else {
ret = -1;
}
return ret;
}
#endif
static int do_lcd_vbyone(cmd_tbl_t *cmdtp, int flag, int argc,
char * const argv[])
{
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "rst") == 0) {
aml_lcd_vbyone_rst(0);
} else if (strcmp(argv[1], "cdr") == 0) {
ret = aml_lcd_vbyone_cdr(0);
if (ret)
printf("[0]: vbyone force cdr fail!\n");
else
printf("[0]: vbyone force cdr ok.\n");
} else if (strcmp(argv[1], "lock") == 0) {
ret = aml_lcd_vbyone_lock(0);
if (ret)
printf("[0]: vbyone force lock fail!\n");
else
printf("[0]: vbyone force lock ok.\n");
} else {
return 0;
}
return 0;
}
static int do_lcd_edp(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int ret = 0, num;
if (argc == 1)
return -1;
num = argc > 2 ? simple_strtoul(argv[2], NULL, 10) : -1;
ret = aml_lcd_edp_debug(0, argv[1], num);
return ret;
}
static int do_lcd_reg(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_reg_info(0);
return 0;
}
static int do_lcd_test(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int num;
if (argc == 1)
return -1;
num = (unsigned int)simple_strtoul(argv[1], NULL, 10);
aml_lcd_driver_test(0, num);
return 0;
}
static int do_lcd_check(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_config_check(0);
return 0;
}
static int do_lcd_prbs(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int ms, prbs_freq = 0, prbs_mode_flag;
if (argc == 1)
return -1;
if (strcmp(argv[1], "vx1") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_VX1;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "lvds") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_LVDS;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 4)
prbs_mode_flag = LCD_PRBS_MODE_FREQ;
else
return -1;
prbs_freq = (unsigned int)simple_strtoul(argv[2], NULL, 10);
ms = (unsigned int)simple_strtoul(argv[3], NULL, 10);
} else {
prbs_mode_flag = LCD_PRBS_MODE_LVDS | LCD_PRBS_MODE_VX1;
ms = (unsigned int)simple_strtoul(argv[1], NULL, 10);
}
aml_lcd_driver_prbs(0, ms, prbs_freq, prbs_mode_flag);
return 0;
}
static int do_lcd_panel_dump(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc == 2)
aml_lcd_panel_dump(0, argv[1]);
else
aml_lcd_panel_dump(0, NULL);
return 0;
}
static int do_lcd_mem(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
u32 size;
char *name;
phys_addr_t pa = 0;
if (argc >= 4) {
if (strcmp(argv[1], "add") == 0) {
size = ustrtoul(argv[2], NULL, 10);
name = argv[3];
pa = lrm_phys_alloc(size, name);
} else if (strcmp(argv[1], "add_tail") == 0) {
size = ustrtoul(argv[2], NULL, 10);
name = argv[3];
pa = lrm_phys_alloc_tail(size, name);
}
} else if (argc == 3) {
if (strcmp(argv[1], "rm") == 0) {
name = argv[2];
lrm_get_by_name(name, &pa, &size);
lrm_free(NULL, pa);
}
}
lrm_show();
return 0;
}
#ifdef CONFIG_AML_LCD_EXTERN
static int do_lcd_ext(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int temp;
if (argc == 1)
return -1;
if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_ext_info(0);
} else if (strcmp(argv[1], "power") == 0) {
if (argc < 3)
return -1;
temp = simple_strtoul(argv[2], NULL, 10);
if (temp)
aml_lcd_driver_ext_power_on(0);
else
aml_lcd_driver_ext_power_off(0);
}
return 0;
}
#endif
static int do_lcd_bl(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int level;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "on") == 0) {
aml_lcd_driver_bl_on(0);
} else if (strcmp(argv[1], "off") == 0) {
aml_lcd_driver_bl_off(0);
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
level = (unsigned int)simple_strtoul(argv[2], NULL, 10);
aml_lcd_driver_set_bl_level(0, level);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
level = aml_lcd_driver_get_bl_level(0);
printf("lcd get_bl_level: %d\n", level);
} else if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_bl_config_print(0);
} else {
ret = -1;
}
return ret;
}
static int do_lcd1_probe(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_probe(1);
return 0;
}
static int do_lcd1_enable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_enable(1, "NULL");
return 0;
}
static int do_lcd1_disable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_disable(1);
return 0;
}
static int do_lcd1_ss(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int value, temp;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "level") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xff;
aml_lcd_driver_set_ss(1, value, 0xff, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(1, 0xff, value, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "mode") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(1, 0xff, 0xff, value);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 16);
value &= 0xffff;
temp = value >> 8;
aml_lcd_driver_set_ss(1, (value & 0xff),
((temp >> LCD_CLK_SS_BIT_FREQ) & 0xf),
((temp >> LCD_CLK_SS_BIT_MODE) & 0xf));
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
aml_lcd_driver_get_ss(1);
} else {
ret = -1;
}
return ret;
}
static int do_lcd1_clk(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_clk_info(1);
return 0;
}
static int do_lcd1_print(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int val = 0;
if (argc == 1)
return -1;
val = (unsigned int)simple_strtoul(argv[1], NULL, 16);
aml_lcd_driver_debug_print(1, val);
return 0;
}
static int do_lcd1_info(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_info(1);
return 0;
}
static int do_lcd1_vbyone(cmd_tbl_t *cmdtp, int flag, int argc,
char * const argv[])
{
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "rst") == 0) {
aml_lcd_vbyone_rst(1);
} else if (strcmp(argv[1], "cdr") == 0) {
ret = aml_lcd_vbyone_cdr(1);
if (ret)
printf("[1]: vbyone force cdr fail!\n");
else
printf("[1]: vbyone force cdr ok.\n");
} else if (strcmp(argv[1], "lock") == 0) {
ret = aml_lcd_vbyone_lock(1);
if (ret)
printf("[1]: vbyone force lock fail!\n");
else
printf("[1]: vbyone force lock ok.\n");
} else {
return 0;
}
return ret;
}
static int do_lcd1_edp(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int ret = 0, num;
if (argc == 1)
return -1;
num = argc > 2 ? simple_strtoul(argv[2], NULL, 10) : 0;
ret = aml_lcd_edp_debug(1, argv[1], num);
return ret;
}
static int do_lcd1_reg(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_reg_info(1);
return 0;
}
static int do_lcd1_test(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int num;
if (argc == 1)
return -1;
num = (unsigned int)simple_strtoul(argv[1], NULL, 10);
aml_lcd_driver_test(1, num);
return 0;
}
static int do_lcd1_check(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_config_check(1);
return 0;
}
static int do_lcd1_prbs(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int ms, prbs_freq = 0, prbs_mode_flag;
if (argc == 1)
return -1;
if (strcmp(argv[1], "vx1") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_VX1;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "lvds") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_LVDS;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 4)
prbs_mode_flag = LCD_PRBS_MODE_FREQ;
else
return -1;
prbs_freq = (unsigned int)simple_strtoul(argv[2], NULL, 10);
ms = (unsigned int)simple_strtoul(argv[3], NULL, 10);
} else {
prbs_mode_flag = LCD_PRBS_MODE_LVDS | LCD_PRBS_MODE_VX1;
ms = (unsigned int)simple_strtoul(argv[1], NULL, 10);
}
aml_lcd_driver_prbs(1, ms, prbs_freq, prbs_mode_flag);
return 0;
}
static int do_lcd1_panel_dump(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc == 2)
aml_lcd_panel_dump(1, argv[1]);
else
aml_lcd_panel_dump(1, NULL);
return 0;
}
#ifdef CONFIG_AML_LCD_EXTERN
static int do_lcd1_ext(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int temp;
if (argc == 1)
return -1;
if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_ext_info(1);
} else if (strcmp(argv[1], "power") == 0) {
if (argc < 3)
return -1;
temp = simple_strtoul(argv[2], NULL, 10);
if (temp)
aml_lcd_driver_ext_power_on(1);
else
aml_lcd_driver_ext_power_off(1);
}
return 0;
}
#endif
static int do_lcd1_bl(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int level;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "on") == 0) {
aml_lcd_driver_bl_on(1);
} else if (strcmp(argv[1], "off") == 0) {
aml_lcd_driver_bl_off(1);
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
level = (unsigned int)simple_strtoul(argv[2], NULL, 10);
aml_lcd_driver_set_bl_level(1, level);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
level = aml_lcd_driver_get_bl_level(1);
printf("lcd1 get_bl_level: %d\n", level);
} else if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_bl_config_print(1);
} else {
ret = -1;
}
return ret;
}
static int do_lcd2_probe(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_probe(2);
return 0;
}
static int do_lcd2_enable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_enable(2, "NULL");
return 0;
}
static int do_lcd2_disable(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_disable(2);
return 0;
}
static int do_lcd2_ss(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int value, temp;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "level") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xff;
aml_lcd_driver_set_ss(2, value, 0xff, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(2, 0xff, value, 0xff);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "mode") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 10);
value &= 0xf;
aml_lcd_driver_set_ss(2, 0xff, 0xff, value);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
value = (unsigned int)simple_strtoul(argv[2], NULL, 16);
value &= 0xffff;
temp = value >> 8;
aml_lcd_driver_set_ss(2, (value & 0xff),
((temp >> LCD_CLK_SS_BIT_FREQ) & 0xf),
((temp >> LCD_CLK_SS_BIT_MODE) & 0xf));
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
aml_lcd_driver_get_ss(2);
} else {
ret = -1;
}
return ret;
}
static int do_lcd2_clk(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_clk_info(2);
return 0;
}
static int do_lcd2_print(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int val = 0;
if (argc == 1)
return -1;
val = (unsigned int)simple_strtoul(argv[1], NULL, 16);
aml_lcd_driver_debug_print(2, val);
return 0;
}
static int do_lcd2_info(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_info(2);
return 0;
}
static int do_lcd2_reg(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_driver_reg_info(2);
return 0;
}
static int do_lcd2_test(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int num;
if (argc == 1)
return -1;
num = (unsigned int)simple_strtoul(argv[1], NULL, 10);
aml_lcd_driver_test(2, num);
return 0;
}
static int do_lcd2_check(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_config_check(2);
return 0;
}
static int do_lcd2_prbs(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int ms, prbs_freq = 0, prbs_mode_flag;
if (argc == 1)
return -1;
if (strcmp(argv[1], "vx1") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_VX1;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "lvds") == 0) {
if (argc == 3)
prbs_mode_flag = LCD_PRBS_MODE_LVDS;
else
return -1;
ms = (unsigned int)simple_strtoul(argv[2], NULL, 10);
} else if (strcmp(argv[1], "freq") == 0) {
if (argc == 4)
prbs_mode_flag = LCD_PRBS_MODE_FREQ;
else
return -1;
prbs_freq = (unsigned int)simple_strtoul(argv[2], NULL, 10);
ms = (unsigned int)simple_strtoul(argv[3], NULL, 10);
} else {
prbs_mode_flag = LCD_PRBS_MODE_LVDS | LCD_PRBS_MODE_VX1;
ms = (unsigned int)simple_strtoul(argv[1], NULL, 10);
}
aml_lcd_driver_prbs(2, ms, prbs_freq, prbs_mode_flag);
return 0;
}
static int do_lcd2_panel_dump(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc == 2)
aml_lcd_panel_dump(2, argv[1]);
else
aml_lcd_panel_dump(2, NULL);
return 0;
}
#ifdef CONFIG_AML_LCD_EXTERN
static int do_lcd2_ext(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int temp;
if (argc == 1)
return -1;
if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_ext_info(2);
} else if (strcmp(argv[1], "power") == 0) {
if (argc < 3)
return -1;
temp = simple_strtoul(argv[2], NULL, 10);
if (temp)
aml_lcd_driver_ext_power_on(2);
else
aml_lcd_driver_ext_power_off(2);
}
return 0;
}
#endif
static int do_lcd2_bl(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
unsigned int level;
int ret = 0;
if (argc == 1)
return -1;
if (strcmp(argv[1], "on") == 0) {
aml_lcd_driver_bl_on(2);
} else if (strcmp(argv[1], "off") == 0) {
aml_lcd_driver_bl_off(2);
} else if (strcmp(argv[1], "set") == 0) {
if (argc == 3) {
level = (unsigned int)simple_strtoul(argv[2], NULL, 10);
aml_lcd_driver_set_bl_level(2, level);
} else {
ret = -1;
}
} else if (strcmp(argv[1], "get") == 0) {
level = aml_lcd_driver_get_bl_level(2);
printf("lcd2 get_bl_level: %d\n", level);
} else if (strcmp(argv[1], "info") == 0) {
aml_lcd_driver_bl_config_print(2);
} else {
ret = -1;
}
return ret;
}
static int do_mipi_dsi_cmd(int index, cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
int temp, i;
unsigned char rd_c[4] = {0, 0, 0, 0};
unsigned char wr_c[32] = {0};
if (argc < 3)
return -1;
if (!strcmp(argv[1], "HS") || !strcmp(argv[1], "LP")) {
temp = (argv[1][0] == 'H') ? 0x10 : 0x00;
if (!strcmp(argv[2], "HIGH"))
temp |= 0x0;
if (!strcmp(argv[2], "LOW"))
temp |= 0x1;
if (!strcmp(argv[2], "PRBS7"))
temp |= 0x2;
if (!strcmp(argv[2], "PRBS11"))
temp |= 0x3;
if (!strcmp(argv[2], "PRBS15"))
temp |= 0x4;
aml_lcd_mipi_dsi_dphy_test(index, temp);
return 0;
}
if (strcmp(argv[1], "mpmode") == 0) {
temp = (unsigned int)simple_strtoul(argv[2], NULL, 10);
aml_lcd_mipi_dsi_mode(index, temp);
return 0;
}
if (argc < 4)
return -1;
wr_c[0] = (unsigned char)simple_strtoul(argv[2], NULL, 16); // data_type
wr_c[1] = (unsigned char)simple_strtoul(argv[3], NULL, 10); // count
for (i = 0; i < (wr_c[1] > 30 ? 30 : wr_c[1]); i++)
wr_c[i + 2] = (unsigned char)simple_strtoul(argv[4 + i], NULL, 16); // count
if (strcmp(argv[1], "mpread") == 0) {
temp = aml_lcd_mipi_dsi_read(index, &wr_c[0], &rd_c[0], 4);
if (temp < 0 || temp > 4) {
printf("lcd%d mipi dsi read failed\n", index);
return 0;
}
printf("lcd%d mipi dsi read %d: ", index, temp);
while (temp) {
printf("0x%02x ", rd_c[temp - 1]);
temp--;
}
printf("\n");
return 0;
} else if (strcmp(argv[1], "mpcmd") == 0) {
aml_lcd_mipi_dsi_cmd(index, &wr_c[0]);
return 0;
}
return -1;
}
static int do_lcd_dsi(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
return do_mipi_dsi_cmd(0, cmdtp, flag, argc, argv);
}
static int do_lcd1_dsi(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
return do_mipi_dsi_cmd(1, cmdtp, flag, argc, argv);
}
static int do_lcd_list(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
aml_lcd_list();
return argc;
}
static int do_lcd0_set(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc != 2)
return 0;
aml_lcd_set(0, argv[1]);
return argc;
}
static int do_lcd1_set(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc != 2)
return 0;
aml_lcd_set(1, argv[1]);
return argc;
}
static int do_lcd2_set(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
if (argc != 2)
return 0;
aml_lcd_set(2, argv[1]);
return argc;
}
U_BOOT_CMD(lcd_list, 4, 0, do_lcd_list, "lcd dts config setting helper", "");
static cmd_tbl_t cmd_lcd_sub[] = {
U_BOOT_CMD_MKENT(list, 2, 0, do_lcd_list, "", ""),
U_BOOT_CMD_MKENT(set, 2, 0, do_lcd0_set, "", ""),
U_BOOT_CMD_MKENT(probe, 2, 0, do_lcd_probe, "", ""),
U_BOOT_CMD_MKENT(enable, 2, 0, do_lcd_enable, "", ""),
U_BOOT_CMD_MKENT(disable, 2, 0, do_lcd_disable, "", ""),
U_BOOT_CMD_MKENT(ss, 4, 0, do_lcd_ss, "", ""),
U_BOOT_CMD_MKENT(clk, 2, 0, do_lcd_clk, "", ""),
U_BOOT_CMD_MKENT(print, 3, 0, do_lcd_print, "", ""),
U_BOOT_CMD_MKENT(info, 2, 0, do_lcd_info, "", ""),
#ifdef CONFIG_AML_LCD_TCON
U_BOOT_CMD_MKENT(tcon, 3, 0, do_lcd_tcon, "", ""),
#endif
U_BOOT_CMD_MKENT(vbyone, 3, 0, do_lcd_vbyone, "", ""),
U_BOOT_CMD_MKENT(edp, 3, 0, do_lcd_edp, "", ""),
U_BOOT_CMD_MKENT(dsi, 32, 0, do_lcd_dsi, "", ""),
U_BOOT_CMD_MKENT(reg, 2, 0, do_lcd_reg, "", ""),
U_BOOT_CMD_MKENT(test, 3, 0, do_lcd_test, "", ""),
U_BOOT_CMD_MKENT(check, 2, 0, do_lcd_check, "", ""),
U_BOOT_CMD_MKENT(prbs, 2, 0, do_lcd_prbs, "", ""),
U_BOOT_CMD_MKENT(panel_dump, 3, 0, do_lcd_panel_dump, "", ""),
U_BOOT_CMD_MKENT(mem, 4, 0, do_lcd_mem, "", ""),
#ifdef CONFIG_AML_LCD_EXTERN
U_BOOT_CMD_MKENT(ext, 4, 0, do_lcd_ext, "", ""),
#endif
U_BOOT_CMD_MKENT(bl, 4, 0, do_lcd_bl, "", ""),
};
static cmd_tbl_t cmd_lcd1_sub[] = {
U_BOOT_CMD_MKENT(list, 2, 0, do_lcd_list, "", ""),
U_BOOT_CMD_MKENT(set, 2, 0, do_lcd1_set, "", ""),
U_BOOT_CMD_MKENT(probe, 2, 0, do_lcd1_probe, "", ""),
U_BOOT_CMD_MKENT(enable, 2, 0, do_lcd1_enable, "", ""),
U_BOOT_CMD_MKENT(disable, 2, 0, do_lcd1_disable, "", ""),
U_BOOT_CMD_MKENT(ss, 4, 0, do_lcd1_ss, "", ""),
U_BOOT_CMD_MKENT(clk, 2, 0, do_lcd1_clk, "", ""),
U_BOOT_CMD_MKENT(print, 3, 0, do_lcd1_print, "", ""),
U_BOOT_CMD_MKENT(info, 2, 0, do_lcd1_info, "", ""),
U_BOOT_CMD_MKENT(vbyone, 3, 0, do_lcd1_vbyone, "", ""),
U_BOOT_CMD_MKENT(edp, 3, 0, do_lcd1_edp, "", ""),
U_BOOT_CMD_MKENT(dsi, 32, 0, do_lcd1_dsi, "", ""),
U_BOOT_CMD_MKENT(reg, 2, 0, do_lcd1_reg, "", ""),
U_BOOT_CMD_MKENT(test, 3, 0, do_lcd1_test, "", ""),
U_BOOT_CMD_MKENT(check, 2, 0, do_lcd1_check, "", ""),
U_BOOT_CMD_MKENT(prbs, 2, 0, do_lcd1_prbs, "", ""),
U_BOOT_CMD_MKENT(panel_dump, 3, 0, do_lcd1_panel_dump, "", ""),
#ifdef CONFIG_AML_LCD_EXTERN
U_BOOT_CMD_MKENT(ext, 4, 0, do_lcd1_ext, "", ""),
#endif
U_BOOT_CMD_MKENT(bl, 4, 0, do_lcd1_bl, "", ""),
};
static cmd_tbl_t cmd_lcd2_sub[] = {
U_BOOT_CMD_MKENT(list, 2, 0, do_lcd_list, "", ""),
U_BOOT_CMD_MKENT(set, 2, 0, do_lcd2_set, "", ""),
U_BOOT_CMD_MKENT(probe, 2, 0, do_lcd2_probe, "", ""),
U_BOOT_CMD_MKENT(enable, 2, 0, do_lcd2_enable, "", ""),
U_BOOT_CMD_MKENT(disable, 2, 0, do_lcd2_disable, "", ""),
U_BOOT_CMD_MKENT(ss, 4, 0, do_lcd2_ss, "", ""),
U_BOOT_CMD_MKENT(clk, 2, 0, do_lcd2_clk, "", ""),
U_BOOT_CMD_MKENT(print, 3, 0, do_lcd2_print, "", ""),
U_BOOT_CMD_MKENT(info, 2, 0, do_lcd2_info, "", ""),
U_BOOT_CMD_MKENT(reg, 2, 0, do_lcd2_reg, "", ""),
U_BOOT_CMD_MKENT(test, 3, 0, do_lcd2_test, "", ""),
U_BOOT_CMD_MKENT(check, 2, 0, do_lcd2_check, "", ""),
U_BOOT_CMD_MKENT(prbs, 2, 0, do_lcd2_prbs, "", ""),
U_BOOT_CMD_MKENT(panel_dump, 3, 0, do_lcd2_panel_dump, "", ""),
#ifdef CONFIG_AML_LCD_EXTERN
U_BOOT_CMD_MKENT(ext, 4, 0, do_lcd2_ext, "", ""),
#endif
U_BOOT_CMD_MKENT(bl, 4, 0, do_lcd2_bl, "", ""),
};
static int do_lcd(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_lcd_sub[0], ARRAY_SIZE(cmd_lcd_sub));
if (c)
return c->cmd(cmdtp, flag, argc, argv);
cmd_usage(cmdtp);
return 1;
}
U_BOOT_CMD(
lcd, 32, 0, do_lcd, "lcd sub-system",
"lcd probe - probe lcd parameters\n"
"lcd enable - enable lcd module\n"
"lcd disable - disable lcd module\n"
"lcd ss - lcd pll spread spectrum operation\n"
"lcd bl - lcd backlight operation\n"
"lcd clk - show lcd pll & clk parameters\n"
"lcd info - show lcd parameters\n"
#ifdef CONFIG_AML_LCD_TCON
"lcd tcon - show lcd tcon debug\n"
#endif
"lcd vbyone - show lcd vbyone debug\n"
"lcd reg - dump lcd registers\n"
"lcd test - show lcd bist pattern\n"
"lcd check - show lcd bist pattern\n"
"lcd panel_dump - show lcd panel config\n"
"lcd mem - show lcd memory used\n"
#ifdef CONFIG_AML_LCD_EXTERN
"lcd ext - show lcd extern information\n"
#endif
);
static int do_lcd1(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_lcd1_sub[0], ARRAY_SIZE(cmd_lcd1_sub));
if (c)
return c->cmd(cmdtp, flag, argc, argv);
cmd_usage(cmdtp);
return 1;
}
U_BOOT_CMD(
lcd1, 32, 0, do_lcd1, "lcd1 sub-system",
"lcd1 probe - probe lcd parameters\n"
"lcd1 enable - enable lcd module\n"
"lcd1 disable - disable lcd module\n"
"lcd1 ss - lcd pll spread spectrum operation\n"
"lcd1 bl - lcd backlight operation\n"
"lcd1 clk - show lcd pll & clk parameters\n"
"lcd1 info - show lcd parameters\n"
#ifdef CONFIG_AML_LCD_TCON
"lcd1 tcon - show lcd tcon debug\n"
#endif
"lcd1 vbyone - show lcd vbyone debug\n"
"lcd1 reg - dump lcd registers\n"
"lcd1 test - show lcd bist pattern\n"
"lcd1 panel_dump - show lcd panel config\n"
#ifdef CONFIG_AML_LCD_EXTERN
"lcd1 ext - show lcd extern information\n"
#endif
);
static int do_lcd2(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_lcd2_sub[0], ARRAY_SIZE(cmd_lcd2_sub));
if (c)
return c->cmd(cmdtp, flag, argc, argv);
cmd_usage(cmdtp);
return 1;
}
U_BOOT_CMD(
lcd2, 5, 0, do_lcd2, "lcd2 sub-system",
"lcd2 probe - probe lcd parameters\n"
"lcd2 enable - enable lcd module\n"
"lcd2 disable - disable lcd module\n"
"lcd2 ss - lcd pll spread spectrum operation\n"
"lcd2 bl - lcd backlight operation\n"
"lcd2 clk - show lcd pll & clk parameters\n"
"lcd2 info - show lcd parameters\n"
"lcd2 reg - dump lcd registers\n"
"lcd2 test - show lcd bist pattern\n"
"lcd2 panel_dump - show lcd panel config\n"
#ifdef CONFIG_AML_LCD_EXTERN
"lcd2 ext - show lcd extern information\n"
#endif
);
#ifdef CONFIG_AML_LCD_TCON
#define DBG_TCON_REG_8_bit 1
#define DBG_TCON_REG_32_bit 0
static int do_aml_tcon_reg(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
{
struct aml_lcd_drv_s *pdrv = aml_lcd_get_driver(0);
unsigned int addr, mask, val, temp, bit_width, len;
int ret = 0, i;
if (!pdrv) {
printf("for_tool:ERROR\n");
printf("no lcd driver\n");
return 0;
}
if (!pdrv->tcon_reg_write) {
printf("for_tool:ERROR\n");
printf("tcon_reg_write is null\n");
return 0;
}
if (!pdrv->tcon_reg_read) {
printf("for_tool:ERROR\n");
printf("tcon_reg_read is null\n");
return 0;
}
if (strcmp(argv[1], "wn") == 0) {
if (argc < 5) {
printf("for_tool:ERROR\n");
printf("argc is not enough\n");
return 0;
}
if (strcmp(argv[2], "8") == 0) {
bit_width = DBG_TCON_REG_8_bit;
} else if (strcmp(argv[2], "32") == 0) {
bit_width = DBG_TCON_REG_32_bit;
} else {
printf("for_tool:ERROR\n");
printf("aml_tcon reg bit_width %s invalid\n", argv[2]);
return 0;
}
addr = (unsigned int)simple_strtoul(argv[3], NULL, 16);
len = (unsigned int)simple_strtoul(argv[4], NULL, 10);
if (len == 0 || len > 16) {
printf("for_tool:ERROR\n");
printf("aml_tcon reg len %d not support\n", len);
return 0;
}
if (argc < (len + 5)) {
printf("for_tool:ERROR\n");
printf("aml_tcon reg data cnt %d not enough\n", (argc - 5));
return 0;
}
for (i = 0; i < len; i++) {
val = (unsigned int)simple_strtoul(argv[5 + i], NULL, 16);
pdrv->tcon_reg_write(addr + i, val, bit_width);
}
printf("for_tool:");
if (bit_width == DBG_TCON_REG_8_bit) {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr + i, bit_width);
printf("0x%04x=0x%02x ", addr + i, temp);
}
} else {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr + i, bit_width);
printf("0x%04x=0x%08x ", addr + i, temp);
}
}
printf("\n");
} else if (strcmp(argv[1], "wm") == 0) {
if (argc < 6) {
printf("for_tool:ERROR\n");
printf("argc is not enough\n");
return 0;
}
if (strcmp(argv[2], "8") == 0) {
bit_width = DBG_TCON_REG_8_bit;
} else if (strcmp(argv[2], "32") == 0) {
bit_width = DBG_TCON_REG_32_bit;
} else {
printf("for_tool:ERROR\n");
printf("aml_tcon reg bit_width %s invalid\n", argv[2]);
return 0;
}
addr = (unsigned int)simple_strtoul(argv[3], NULL, 16);
mask = (unsigned int)simple_strtoul(argv[4], NULL, 16);
val = (unsigned int)simple_strtoul(argv[5], NULL, 16);
temp = pdrv->tcon_reg_read(addr, bit_width);
temp &= ~mask;
temp |= val & mask;
pdrv->tcon_reg_write(addr, temp, bit_width);
printf("for_tool:");
temp = pdrv->tcon_reg_read(addr, bit_width);
if (bit_width == DBG_TCON_REG_8_bit)
printf("0x%04x=0x%02x\n", addr, temp);
else
printf("0x%04x=0x%08x\n", addr, temp);
} else if (strcmp(argv[1], "ws") == 0) {
if (argc < 5) {
printf("for_tool:ERROR\n");
printf("argc is not enough\n");
return 0;
}
if (strcmp(argv[2], "8") == 0) {
bit_width = DBG_TCON_REG_8_bit;
} else if (strcmp(argv[2], "32") == 0) {
bit_width = DBG_TCON_REG_32_bit;
} else {
printf("for_tool:ERROR\n");
printf("aml_tcon reg bit_width %s invalid\n", argv[2]);
return 0;
}
addr = (unsigned int)simple_strtoul(argv[3], NULL, 16);
len = (unsigned int)simple_strtoul(argv[4], NULL, 10);
if (len == 0 || len > 16) {
printf("for_tool:ERROR\n");
printf("aml_tcon reg len %d not support\n", len);
return 0;
}
if (argc < (len + 5)) {
printf("for_tool:ERROR\n");
printf("aml_tcon reg data cnt %d not enough\n", (argc - 5));
return 0;
}
for (i = 0; i < len; i++) {
val = (unsigned int)simple_strtoul(argv[5 + i], NULL, 16);
pdrv->tcon_reg_write(addr, val, bit_width);
}
printf("for_tool:");
if (bit_width == DBG_TCON_REG_8_bit) {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr, bit_width);
printf("0x%04x=0x%02x ", addr, temp);
}
} else {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr, bit_width);
printf("0x%04x=0x%08x ", addr, temp);
}
}
printf("\n");
} else if (strcmp(argv[1], "rn") == 0) {
if (argc < 4) {
printf("for_tool:ERROR\n");
printf("argc is not enough\n");
return 0;
}
if (strcmp(argv[2], "8") == 0) {
bit_width = DBG_TCON_REG_8_bit;
} else if (strcmp(argv[2], "32") == 0) {
bit_width = DBG_TCON_REG_32_bit;
} else {
printf("for_tool:ERROR\n");
printf("aml_tcon reg bit_width %s invalid\n", argv[2]);
return 0;
}
addr = (unsigned int)simple_strtoul(argv[3], NULL, 16);
if (argc == 4)
len = 1;
else
len = (unsigned int)simple_strtoul(argv[4], NULL, 10);
if (len == 0 || len > 16) {
printf("for_tool:ERROR\n");
printf("aml_tcon reg len %d not support\n", len);
return 0;
}
printf("for_tool:");
if (bit_width == DBG_TCON_REG_8_bit) {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr + i, bit_width);
printf("0x%04x=0x%02x ", addr + i, temp);
}
} else {
for (i = 0; i < len; i++) {
temp = pdrv->tcon_reg_read(addr + i, bit_width);
printf("0x%04x=0x%08x ", addr + i, temp);
}
}
printf("\n");
} else {
printf("for_tool:ERROR\n");
ret = -1;
}
return ret;
}
static cmd_tbl_t cmd_aml_tcon_sub[] = {
U_BOOT_CMD_MKENT(reg, 32, 0, do_aml_tcon_reg, "", ""),
};
static int do_aml_tcon(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_aml_tcon_sub[0], ARRAY_SIZE(cmd_aml_tcon_sub));
if (c)
return c->cmd(cmdtp, flag, argc, argv);
cmd_usage(cmdtp);
return 1;
}
U_BOOT_CMD(aml_tcon, 32, 0, do_aml_tcon,
"aml_tcon sub-system",
"aml_tcon reg - aml_tcon reg access\n"
);
#endif