drivers: gpio: shell: add vendor specific flags argument
Allow the optional setting of vendor specific flags in the conf command. Signed-off-by: Nick Ward <nix.ward@gmail.com>
This commit is contained in:
parent
738a1517b1
commit
cd9f307e71
|
@ -15,6 +15,7 @@
|
||||||
#define ARGV_PIN 2
|
#define ARGV_PIN 2
|
||||||
#define ARGV_CONF 3
|
#define ARGV_CONF 3
|
||||||
#define ARGV_VALUE 3
|
#define ARGV_VALUE 3
|
||||||
|
#define ARGV_VENDOR_SPECIFIC 4
|
||||||
|
|
||||||
#define NGPIOS_UNKNOWN -1
|
#define NGPIOS_UNKNOWN -1
|
||||||
#define PIN_NOT_FOUND UINT8_MAX
|
#define PIN_NOT_FOUND UINT8_MAX
|
||||||
|
@ -221,6 +222,7 @@ static int get_sh_gpio(const struct shell *sh, char **argv, struct sh_gpio *gpio
|
||||||
static int cmd_gpio_conf(const struct shell *sh, size_t argc, char **argv, void *data)
|
static int cmd_gpio_conf(const struct shell *sh, size_t argc, char **argv, void *data)
|
||||||
{
|
{
|
||||||
gpio_flags_t flags = 0;
|
gpio_flags_t flags = 0;
|
||||||
|
gpio_flags_t vendor_specific;
|
||||||
struct sh_gpio gpio;
|
struct sh_gpio gpio;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
|
@ -304,6 +306,22 @@ static int cmd_gpio_conf(const struct shell *sh, size_t argc, char **argv, void
|
||||||
return SHELL_CMD_HELP_PRINTED;
|
return SHELL_CMD_HELP_PRINTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (argc == 5) {
|
||||||
|
vendor_specific = shell_strtoul(argv[ARGV_VENDOR_SPECIFIC], 0, &ret);
|
||||||
|
if ((ret == 0) && ((vendor_specific & ~(0xFF00U)) == 0)) {
|
||||||
|
flags |= vendor_specific;
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* See include/zephyr/dt-bindings/gpio/ for the
|
||||||
|
* available flags for your vendor.
|
||||||
|
*/
|
||||||
|
shell_error(sh, "vendor specific flags must be within "
|
||||||
|
"the mask 0xFF00");
|
||||||
|
shell_help(sh);
|
||||||
|
return SHELL_CMD_HELP_PRINTED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ret = gpio_pin_configure(gpio.dev, gpio.pin, flags);
|
ret = gpio_pin_configure(gpio.dev, gpio.pin, flags);
|
||||||
if (ret != 0) {
|
if (ret != 0) {
|
||||||
shell_error(sh, "error: %d", ret);
|
shell_error(sh, "error: %d", ret);
|
||||||
|
@ -563,12 +581,14 @@ static int cmd_gpio_info(const struct shell *sh, size_t argc, char **argv)
|
||||||
SHELL_STATIC_SUBCMD_SET_CREATE(sub_gpio,
|
SHELL_STATIC_SUBCMD_SET_CREATE(sub_gpio,
|
||||||
SHELL_CMD_ARG(conf, &sub_gpio_dev,
|
SHELL_CMD_ARG(conf, &sub_gpio_dev,
|
||||||
"Configure GPIO pin\n"
|
"Configure GPIO pin\n"
|
||||||
"Usage: gpio conf <device> <pin> <configuration <i|o>[u|d][h|l][0|1]>\n"
|
"Usage: gpio conf <device> <pin> <configuration <i|o>[u|d][h|l][0|1]> [vendor specific]\n"
|
||||||
"<i|o> - input|output\n"
|
"<i|o> - input|output\n"
|
||||||
"[u|d] - pull up|pull down, otherwise open\n"
|
"[u|d] - pull up|pull down, otherwise open\n"
|
||||||
"[h|l] - active high|active low, otherwise defaults to active high\n"
|
"[h|l] - active high|active low, otherwise defaults to active high\n"
|
||||||
"[0|1] - initialise to logic 0|logic 1, otherwise defaults to logic 0",
|
"[0|1] - initialise to logic 0|logic 1, otherwise defaults to logic 0\n"
|
||||||
cmd_gpio_conf, 4, 0),
|
"[vendor specific] - configuration flags within the mask 0xFF00\n"
|
||||||
|
" see include/zephyr/dt-bindings/gpio/",
|
||||||
|
cmd_gpio_conf, 4, 1),
|
||||||
SHELL_CMD_ARG(get, &sub_gpio_dev,
|
SHELL_CMD_ARG(get, &sub_gpio_dev,
|
||||||
"Get GPIO pin value\n"
|
"Get GPIO pin value\n"
|
||||||
"Usage: gpio get <device> <pin>", cmd_gpio_get, 3, 0),
|
"Usage: gpio get <device> <pin>", cmd_gpio_get, 3, 0),
|
||||||
|
|
Loading…
Reference in a new issue