All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] cmd: Add a pwm command
@ 2020-11-23  8:08 Pragnesh Patel
  2020-11-23 15:52 ` Tom Rini
  0 siblings, 1 reply; 5+ messages in thread
From: Pragnesh Patel @ 2020-11-23  8:08 UTC (permalink / raw)
  To: u-boot

Add the command "pwm" for controlling the pwm channels. This
command provides pwm invert/config/enable/disable functionalities
via PWM uclass drivers

Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
---
 cmd/Kconfig  |   6 +++
 cmd/Makefile |   1 +
 cmd/pwm.c    | 119 +++++++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 126 insertions(+)
 create mode 100644 cmd/pwm.c

diff --git a/cmd/Kconfig b/cmd/Kconfig
index 1595de999b..4f3a70b1d5 100644
--- a/cmd/Kconfig
+++ b/cmd/Kconfig
@@ -918,6 +918,12 @@ config CMD_GPIO
 	help
 	  GPIO support.
 
+config CMD_PWM
+	bool "pwm"
+	depends on DM_PWM
+	help
+	  PWM support.
+
 config CMD_GPT
 	bool "GPT (GUID Partition Table) command"
 	select EFI_PARTITION
diff --git a/cmd/Makefile b/cmd/Makefile
index dd86675bf2..75df3c136c 100644
--- a/cmd/Makefile
+++ b/cmd/Makefile
@@ -120,6 +120,7 @@ endif
 obj-$(CONFIG_CMD_PINMUX) += pinmux.o
 obj-$(CONFIG_CMD_PMC) += pmc.o
 obj-$(CONFIG_CMD_PSTORE) += pstore.o
+obj-$(CONFIG_CMD_PWM) += pwm.o
 obj-$(CONFIG_CMD_PXE) += pxe.o pxe_utils.o
 obj-$(CONFIG_CMD_WOL) += wol.o
 obj-$(CONFIG_CMD_QFW) += qfw.o
diff --git a/cmd/pwm.c b/cmd/pwm.c
new file mode 100644
index 0000000000..f82f7789cd
--- /dev/null
+++ b/cmd/pwm.c
@@ -0,0 +1,119 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Control PWM channels
+ *
+ * Copyright (c) 2020 SiFive, Inc
+ * author: Pragnesh Patel <pragnesh.patel@sifive.com>
+ */
+
+#include <command.h>
+#include <dm.h>
+#include <pwm.h>
+
+enum pwm_cmd {
+	PWM_SET_INVERT,
+	PWM_SET_CONFIG,
+	PWM_SET_ENABLE,
+	PWM_SET_DISABLE,
+};
+
+static int do_pwm(struct cmd_tbl *cmdtp, int flag, int argc,
+		  char *const argv[])
+{
+	const char *str_cmd, *str_channel = NULL, *str_enable = NULL;
+	const char *str_pwm = NULL, *str_period = NULL, *str_duty = NULL;
+	enum pwm_cmd sub_cmd;
+	struct udevice *dev;
+	u32 channel, pwm_enable, period_ns = 0, duty_ns = 0;
+	int ret;
+
+	if (argc < 4)
+ show_usage:
+		return CMD_RET_USAGE;
+
+	str_cmd = argv[1];
+	argc -= 2;
+	argv += 2;
+
+	if (argc > 0) {
+		str_pwm = *argv;
+		argc--;
+		argv++;
+	}
+
+	if (!str_pwm)
+		goto show_usage;
+
+	switch (*str_cmd) {
+	case 'i':
+		sub_cmd = PWM_SET_INVERT;
+		break;
+	case 'c':
+		sub_cmd = PWM_SET_CONFIG;
+		break;
+	case 'e':
+		sub_cmd = PWM_SET_ENABLE;
+		break;
+	case 'd':
+		sub_cmd = PWM_SET_DISABLE;
+		break;
+	default:
+		goto show_usage;
+	}
+
+	if (IS_ENABLED(CONFIG_DM_PWM)) {
+		ret = uclass_get_device_by_name(UCLASS_PWM, str_pwm, &dev);
+		if (ret) {
+			printf("PWM: '%s' not found\n", str_pwm);
+			return cmd_process_error(cmdtp, ret);
+		}
+	}
+
+	if (argc > 0) {
+		str_channel = *argv;
+		channel = simple_strtoul(str_channel, NULL, 10);
+		argc--;
+		argv++;
+	} else {
+		goto show_usage;
+	}
+
+	if (sub_cmd == PWM_SET_INVERT && argc > 0) {
+		str_enable = *argv;
+		pwm_enable = simple_strtoul(str_enable, NULL, 10);
+		ret = pwm_set_invert(dev, channel, pwm_enable);
+	} else if (sub_cmd == PWM_SET_CONFIG && argc == 2) {
+		str_period = *argv;
+		argc--;
+		argv++;
+		period_ns = simple_strtoul(str_period, NULL, 10);
+
+		if (argc > 0) {
+			str_duty = *argv;
+			duty_ns = simple_strtoul(str_duty, NULL, 10);
+		}
+
+		ret = pwm_set_config(dev, channel, period_ns, duty_ns);
+	} else if (sub_cmd == PWM_SET_ENABLE) {
+		ret = pwm_set_enable(dev, channel, 1);
+	} else if (sub_cmd == PWM_SET_DISABLE) {
+		ret = pwm_set_enable(dev, channel, 0);
+	} else {
+		printf("PWM arguments missing\n");
+		return CMD_RET_FAILURE;
+	}
+
+	if (ret) {
+		printf("error!\n");
+		return CMD_RET_FAILURE;
+	}
+
+	printf("success!\n");
+	return CMD_RET_SUCCESS;
+}
+
+U_BOOT_CMD(pwm, 6, 0, do_pwm,
+	   "control pwm channels",
+	   "pwm <invert> <pwm_device> <channel> <polarity>\n"
+	   "pwm <config> <pwm_device> <channel> <period_ns> <duty_ns>\n"
+	   "pwm <enable/disable> <pwm_device> <channel>");
-- 
2.17.1

^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH] cmd: Add a pwm command
  2020-11-23  8:08 [PATCH] cmd: Add a pwm command Pragnesh Patel
@ 2020-11-23 15:52 ` Tom Rini
  2020-11-24 12:41   ` Pragnesh Patel
  0 siblings, 1 reply; 5+ messages in thread
From: Tom Rini @ 2020-11-23 15:52 UTC (permalink / raw)
  To: u-boot

On Mon, Nov 23, 2020 at 01:38:41PM +0530, Pragnesh Patel wrote:

> Add the command "pwm" for controlling the pwm channels. This
> command provides pwm invert/config/enable/disable functionalities
> via PWM uclass drivers
> 
> Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
> ---
>  cmd/Kconfig  |   6 +++
>  cmd/Makefile |   1 +
>  cmd/pwm.c    | 119 +++++++++++++++++++++++++++++++++++++++++++++++++++
>  3 files changed, 126 insertions(+)
>  create mode 100644 cmd/pwm.c

Can you please add some tests and dt fragments to sandbox for this?
Thanks.

-- 
Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 659 bytes
Desc: not available
URL: <https://lists.denx.de/pipermail/u-boot/attachments/20201123/3589e8f4/attachment.sig>

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH] cmd: Add a pwm command
  2020-11-23 15:52 ` Tom Rini
@ 2020-11-24 12:41   ` Pragnesh Patel
  2020-11-24 13:23     ` Tom Rini
  0 siblings, 1 reply; 5+ messages in thread
From: Pragnesh Patel @ 2020-11-24 12:41 UTC (permalink / raw)
  To: u-boot



>-----Original Message-----
>From: Tom Rini <trini@konsulko.com>
>Sent: 23 November 2020 21:22
>To: Pragnesh Patel <pragnesh.patel@openfive.com>
>Cc: u-boot at lists.denx.de; atish.patra at wdc.com; palmerdabbelt at google.com;
>bmeng.cn at gmail.com; Paul Walmsley ( Sifive) <paul.walmsley@sifive.com>;
>anup.patel at wdc.com; Sagar Kadam <sagar.kadam@openfive.com>;
>rick at andestech.com; Simon Glass <sjg@chromium.org>; Heinrich Schuchardt
><xypron.glpk@gmx.de>; Bin Meng <bin.meng@windriver.com>; Miquel Raynal
><miquel.raynal@bootlin.com>; Patrick Delaunay <patrick.delaunay@st.com>;
>Sam Protsenko <joe.skb7@gmail.com>; Philippe Reynes
><philippe.reynes@softathome.com>; Fr?d?ric Danis
><frederic.danis@collabora.com>; Patrice Chotard <patrice.chotard@st.com>;
>Vladimir Olovyannikov <vladimir.olovyannikov@broadcom.com>; Ramon Fried
><rfried.dev@gmail.com>; Eugeniu Rosca <roscaeugeniu@gmail.com>
>Subject: Re: [PATCH] cmd: Add a pwm command
>
>On Mon, Nov 23, 2020 at 01:38:41PM +0530, Pragnesh Patel wrote:
>
>> Add the command "pwm" for controlling the pwm channels. This command
>> provides pwm invert/config/enable/disable functionalities via PWM
>> uclass drivers
>>
>> Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
>> ---
>>  cmd/Kconfig  |   6 +++
>>  cmd/Makefile |   1 +
>>  cmd/pwm.c    | 119
>+++++++++++++++++++++++++++++++++++++++++++++++++++
>>  3 files changed, 126 insertions(+)
>>  create mode 100644 cmd/pwm.c
>
>Can you please add some tests and dt fragments to sandbox for this?

There is already a "test/dm/pwm.c".

>Thanks.
>
>--
>Tom

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH] cmd: Add a pwm command
  2020-11-24 12:41   ` Pragnesh Patel
@ 2020-11-24 13:23     ` Tom Rini
  2020-11-24 16:53       ` Simon Glass
  0 siblings, 1 reply; 5+ messages in thread
From: Tom Rini @ 2020-11-24 13:23 UTC (permalink / raw)
  To: u-boot

On Tue, Nov 24, 2020 at 12:41:34PM +0000, Pragnesh Patel wrote:
> 
> 
> >-----Original Message-----
> >From: Tom Rini <trini@konsulko.com>
> >Sent: 23 November 2020 21:22
> >To: Pragnesh Patel <pragnesh.patel@openfive.com>
> >Cc: u-boot at lists.denx.de; atish.patra at wdc.com; palmerdabbelt at google.com;
> >bmeng.cn at gmail.com; Paul Walmsley ( Sifive) <paul.walmsley@sifive.com>;
> >anup.patel at wdc.com; Sagar Kadam <sagar.kadam@openfive.com>;
> >rick at andestech.com; Simon Glass <sjg@chromium.org>; Heinrich Schuchardt
> ><xypron.glpk@gmx.de>; Bin Meng <bin.meng@windriver.com>; Miquel Raynal
> ><miquel.raynal@bootlin.com>; Patrick Delaunay <patrick.delaunay@st.com>;
> >Sam Protsenko <joe.skb7@gmail.com>; Philippe Reynes
> ><philippe.reynes@softathome.com>; Fr?d?ric Danis
> ><frederic.danis@collabora.com>; Patrice Chotard <patrice.chotard@st.com>;
> >Vladimir Olovyannikov <vladimir.olovyannikov@broadcom.com>; Ramon Fried
> ><rfried.dev@gmail.com>; Eugeniu Rosca <roscaeugeniu@gmail.com>
> >Subject: Re: [PATCH] cmd: Add a pwm command
> >
> >On Mon, Nov 23, 2020 at 01:38:41PM +0530, Pragnesh Patel wrote:
> >
> >> Add the command "pwm" for controlling the pwm channels. This command
> >> provides pwm invert/config/enable/disable functionalities via PWM
> >> uclass drivers
> >>
> >> Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
> >> ---
> >>  cmd/Kconfig  |   6 +++
> >>  cmd/Makefile |   1 +
> >>  cmd/pwm.c    | 119
> >+++++++++++++++++++++++++++++++++++++++++++++++++++
> >>  3 files changed, 126 insertions(+)
> >>  create mode 100644 cmd/pwm.c
> >
> >Can you please add some tests and dt fragments to sandbox for this?
> 
> There is already a "test/dm/pwm.c".

Right, but for the new command as well please, similar to
test/py/tests/test_gpio.py.

-- 
Tom
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 659 bytes
Desc: not available
URL: <https://lists.denx.de/pipermail/u-boot/attachments/20201124/2b5f7fa3/attachment.sig>

^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH] cmd: Add a pwm command
  2020-11-24 13:23     ` Tom Rini
@ 2020-11-24 16:53       ` Simon Glass
  0 siblings, 0 replies; 5+ messages in thread
From: Simon Glass @ 2020-11-24 16:53 UTC (permalink / raw)
  To: u-boot

Hi,

On Tue, 24 Nov 2020 at 06:23, Tom Rini <trini@konsulko.com> wrote:
>
> On Tue, Nov 24, 2020 at 12:41:34PM +0000, Pragnesh Patel wrote:
> >
> >
> > >-----Original Message-----
> > >From: Tom Rini <trini@konsulko.com>
> > >Sent: 23 November 2020 21:22
> > >To: Pragnesh Patel <pragnesh.patel@openfive.com>
> > >Cc: u-boot at lists.denx.de; atish.patra at wdc.com; palmerdabbelt at google.com;
> > >bmeng.cn at gmail.com; Paul Walmsley ( Sifive) <paul.walmsley@sifive.com>;
> > >anup.patel at wdc.com; Sagar Kadam <sagar.kadam@openfive.com>;
> > >rick at andestech.com; Simon Glass <sjg@chromium.org>; Heinrich Schuchardt
> > ><xypron.glpk@gmx.de>; Bin Meng <bin.meng@windriver.com>; Miquel Raynal
> > ><miquel.raynal@bootlin.com>; Patrick Delaunay <patrick.delaunay@st.com>;
> > >Sam Protsenko <joe.skb7@gmail.com>; Philippe Reynes
> > ><philippe.reynes@softathome.com>; Fr?d?ric Danis
> > ><frederic.danis@collabora.com>; Patrice Chotard <patrice.chotard@st.com>;
> > >Vladimir Olovyannikov <vladimir.olovyannikov@broadcom.com>; Ramon Fried
> > ><rfried.dev@gmail.com>; Eugeniu Rosca <roscaeugeniu@gmail.com>
> > >Subject: Re: [PATCH] cmd: Add a pwm command
> > >
> > >On Mon, Nov 23, 2020 at 01:38:41PM +0530, Pragnesh Patel wrote:
> > >
> > >> Add the command "pwm" for controlling the pwm channels. This command
> > >> provides pwm invert/config/enable/disable functionalities via PWM
> > >> uclass drivers
> > >>
> > >> Signed-off-by: Pragnesh Patel <pragnesh.patel@sifive.com>
> > >> ---
> > >>  cmd/Kconfig  |   6 +++
> > >>  cmd/Makefile |   1 +
> > >>  cmd/pwm.c    | 119
> > >+++++++++++++++++++++++++++++++++++++++++++++++++++
> > >>  3 files changed, 126 insertions(+)
> > >>  create mode 100644 cmd/pwm.c
> > >
> > >Can you please add some tests and dt fragments to sandbox for this?
> >
> > There is already a "test/dm/pwm.c".
>
> Right, but for the new command as well please, similar to
> test/py/tests/test_gpio.py.

I would be happier with a C test like [1] as it is faster and allows
debugging, etc.

Regards,
Simon

[1] test/cmd/mem_search.c

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2020-11-24 16:53 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-11-23  8:08 [PATCH] cmd: Add a pwm command Pragnesh Patel
2020-11-23 15:52 ` Tom Rini
2020-11-24 12:41   ` Pragnesh Patel
2020-11-24 13:23     ` Tom Rini
2020-11-24 16:53       ` Simon Glass

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.