2023-11-30 19:48:02 +08:00
|
|
|
|
/*
|
|
|
|
|
|
* Copyright (c) 2022-2023, ArtInChip Technology Co., Ltd
|
|
|
|
|
|
*
|
|
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
*
|
|
|
|
|
|
* Authors: Geo.Dong <guojun.dong@artinchip.com>
|
|
|
|
|
|
*/
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
#include <getopt.h>
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
|
#include "rtdevice.h"
|
|
|
|
|
|
#include "aic_core.h"
|
|
|
|
|
|
#include "rtconfig.h"
|
|
|
|
|
|
|
|
|
|
|
|
static const char sopts[] = "s:c:h";
|
|
|
|
|
|
static const struct option lopts[] = {
|
|
|
|
|
|
{"start", required_argument, NULL, 's'},
|
|
|
|
|
|
{"count", required_argument, NULL, 'c'},
|
|
|
|
|
|
{"help", no_argument, NULL, 'h'},
|
|
|
|
|
|
{0, 0, 0, 0}
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static void usage(char *program)
|
|
|
|
|
|
{
|
|
|
|
|
|
printf("Compile time: %s %s\n", __DATE__, __TIME__);
|
|
|
|
|
|
printf("Usage: %s [options]\n", program);
|
|
|
|
|
|
printf("\t -s, --start\t\tprint PIN start from PXn . Default as start from PA0\n");
|
|
|
|
|
|
printf("\t -c, --count\t\tprint PIN count.\n");
|
|
|
|
|
|
printf("\t -h, --help \n");
|
|
|
|
|
|
printf("\n");
|
|
|
|
|
|
printf("Example: \n");
|
|
|
|
|
|
printf(" %s -s PA0 -c 2 \n", program);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct gpio_info
|
|
|
|
|
|
{
|
|
|
|
|
|
char name;
|
|
|
|
|
|
u8 group_index;
|
|
|
|
|
|
u8 pin_max_size;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2024-04-03 16:40:57 +08:00
|
|
|
|
#if defined(AIC_CHIP_D13X) || defined(AIC_CHIP_G73X)
|
2023-11-30 19:48:02 +08:00
|
|
|
|
static const struct gpio_info pinmux_list[] = {
|
|
|
|
|
|
{'A', 0, 16},
|
|
|
|
|
|
{'B', 1, 18},
|
|
|
|
|
|
{'C', 2, 12},
|
|
|
|
|
|
{'D', 3, 28},
|
|
|
|
|
|
{'E', 4, 18},
|
|
|
|
|
|
{'U', 14, 2},
|
|
|
|
|
|
};
|
2024-04-03 16:40:57 +08:00
|
|
|
|
#elif defined(AIC_CHIP_D12X)
|
|
|
|
|
|
static const struct gpio_info pinmux_list[] = {
|
|
|
|
|
|
{'A', 0, 12},
|
|
|
|
|
|
{'B', 1, 18},
|
|
|
|
|
|
{'C', 2, 8},
|
|
|
|
|
|
{'D', 3, 28},
|
|
|
|
|
|
{'E', 4, 14},
|
|
|
|
|
|
};
|
2023-11-30 19:48:02 +08:00
|
|
|
|
#else
|
|
|
|
|
|
static const struct gpio_info pinmux_list[] = {
|
|
|
|
|
|
{'A', 0, 12},
|
|
|
|
|
|
{'B', 1, 12},
|
|
|
|
|
|
{'C', 2, 7},
|
|
|
|
|
|
{'D', 3, 28},
|
|
|
|
|
|
{'E', 4, 20},
|
|
|
|
|
|
{'F', 5, 16},
|
|
|
|
|
|
{'U', 14, 2},
|
|
|
|
|
|
};
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
static u32 get_pin_cfg_reg(u32 group, u32 pin)
|
|
|
|
|
|
{
|
|
|
|
|
|
return readl(0x18700000 + 0x80 + pin * 0x4 + group * 0x100);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int show_pinmux_info(char start_group, u32 start_pin, u32 pin_count)
|
|
|
|
|
|
{
|
|
|
|
|
|
for (u32 g = 0; g < sizeof(pinmux_list)/sizeof(struct gpio_info); g++) {
|
|
|
|
|
|
if (pinmux_list[g].name == start_group) {
|
|
|
|
|
|
for (u32 p = start_pin; p < start_pin + pin_count; p++) {
|
|
|
|
|
|
u32 ret_val = get_pin_cfg_reg(pinmux_list[g].group_index, p);
|
|
|
|
|
|
printf("P%c%u: 0x%08x, fun[%u], drv[%u], pull[%u], IE[%u], OE[%u], IE_FORCE[%u]\n",
|
|
|
|
|
|
pinmux_list[g].name, p, ret_val, ret_val&0xf, (ret_val >> 4)&0b111, (ret_val >> 8)&0b11,
|
|
|
|
|
|
(ret_val >> 12)&0b111, (ret_val >> 16)&0b1, (ret_val >> 17)&0b1);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int pinmux_check(int argc, char **argv)
|
|
|
|
|
|
{
|
|
|
|
|
|
int c = 0;
|
|
|
|
|
|
char start_group = 0;
|
|
|
|
|
|
u32 start_pin = 0, pin_count = 0;
|
|
|
|
|
|
|
|
|
|
|
|
if (argc < 2) {
|
|
|
|
|
|
usage(argv[0]);
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
optind = 0;
|
|
|
|
|
|
while ((c = getopt_long(argc, argv, sopts, lopts, NULL)) != -1) {
|
|
|
|
|
|
switch (c) {
|
|
|
|
|
|
case 's':
|
|
|
|
|
|
if (optarg == NULL || strlen(optarg) == 0) {
|
|
|
|
|
|
printf("-s arg[%s] error!!!\n\n", optarg);
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
memcpy(&start_group, optarg+1, 1);
|
|
|
|
|
|
start_pin = atoi(optarg+2);
|
|
|
|
|
|
|
|
|
|
|
|
if (start_group < 'A') {
|
|
|
|
|
|
printf("start group out of range [%c]!\n\n", start_group);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (start_pin < 0 || start_pin > 32) {
|
|
|
|
|
|
printf("start pin out of range [%u]!\n\n", start_pin);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
case 'c':
|
|
|
|
|
|
if (optarg == NULL || strlen(optarg) == 0) {
|
|
|
|
|
|
printf("-c arg[%s] error!!!\n\n", optarg);
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
pin_count = atoi(optarg);
|
|
|
|
|
|
if (pin_count < 0 || pin_count > 32) {
|
|
|
|
|
|
printf("pin_count out of range [%u]!\n\n", pin_count);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
break;
|
|
|
|
|
|
case 'h':
|
|
|
|
|
|
default:
|
|
|
|
|
|
usage(argv[0]);
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
show_pinmux_info(start_group, start_pin, pin_count);
|
|
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
MSH_CMD_EXPORT(pinmux_check, pinmux check);
|
|
|
|
|
|
|