* [PATCH v7 0/2] pwm: Add support for R-Car PWM Timer @ 2015-09-30 8:47 Yoshihiro Shimoda 2015-09-30 8:47 ` [PATCH v7 1/2] pwm: Add device tree binding document " Yoshihiro Shimoda 2015-09-30 8:47 ` [PATCH v7 2/2] pwm: Add support " Yoshihiro Shimoda 0 siblings, 2 replies; 7+ messages in thread From: Yoshihiro Shimoda @ 2015-09-30 8:47 UTC (permalink / raw) To: thierry.reding, robh+dt, pawel.moll, mark.rutland, ijc+devicetree, galak Cc: linux-pwm, linux-sh, devicetree, Yoshihiro Shimoda This patch set is based on the latest linux-pwm.git / for-next branch. (commit id = a83a6a82250fe900be85c8e142f5cb504d9482bd) Changes from v6: - Modify rcar_pwm_set_counter() to be readable code. - Add a condition not to call rcar_pwm_set_clock_control() in rcar_pwm_config. - Remove chip.of_xlate setting to use of_pwm_simple_xlate(). Changes from v5: - Fix coding style and unreadable code in patch 2. - Add "Reviewed-by: Simon Horman <horms+renesas@verge.net.au>". Changes from v4: - Clean up coding style and typo in patch 2. - Change to_rcar_pwm_chip() macro to static inline function in patch 2. - Use writel()/readl() instead of iowrite32()/ioread32() in patch 2. - Add an error handling in rcar_pwm_config() to avoid silent in patch 2. - Remove success message in rcar_pwm_probe() in patch 2. - Change rcar_pwm_remove() to always call pm_runtime_disable() in patch 2. Changes from v3: - Fix register size in patch 1. - Add "Acked-by: Geert Uytterhoeven <geert+renesas@glider.be>" in patch 1 - Remove an unnecessary definition in patch 2. - Use "ULL" to avoid overflow in patch 2. - Remove unnecessary casts in patch 2. Changes from v2: - Add compatible string "renesas,pwm-rcar". - Remove compatible strings "renesas,pwm-r8a77xx" in rcar_pwm_of_table. - Fix build error. Changes from v1: - Change compatible string to SoC-specific compatible values. - Fix #pwm-call value to 2 in the device tree document. - Fix "depends on" value in Kconfig. - Fix help explanation in Kconfig. - Remove an unnecessary member in rcar_pwm_chip. - Remove hardcoded number of channels and change chip.npwm value to 1. - Fix formulas for clock calculation to improve accuracy. Yoshihiro Shimoda (2): pwm: Add device tree binding document for R-Car PWM Timer pwm: Add support for R-Car PWM Timer .../devicetree/bindings/pwm/renesas,pwm-rcar.txt | 27 +++ drivers/pwm/Kconfig | 11 + drivers/pwm/Makefile | 1 + drivers/pwm/pwm-rcar.c | 266 +++++++++++++++++++++ 4 files changed, 305 insertions(+) create mode 100644 Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt create mode 100644 drivers/pwm/pwm-rcar.c -- 1.9.1 ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v7 1/2] pwm: Add device tree binding document for R-Car PWM Timer 2015-09-30 8:47 [PATCH v7 0/2] pwm: Add support for R-Car PWM Timer Yoshihiro Shimoda @ 2015-09-30 8:47 ` Yoshihiro Shimoda [not found] ` <1443602873-4316-2-git-send-email-yoshihiro.shimoda.uh-zM6kxYcvzFBBDgjK7y7TUQ@public.gmane.org> 2015-10-05 15:38 ` Rob Herring 2015-09-30 8:47 ` [PATCH v7 2/2] pwm: Add support " Yoshihiro Shimoda 1 sibling, 2 replies; 7+ messages in thread From: Yoshihiro Shimoda @ 2015-09-30 8:47 UTC (permalink / raw) To: thierry.reding, robh+dt, pawel.moll, mark.rutland, ijc+devicetree, galak Cc: linux-pwm, linux-sh, devicetree, Yoshihiro Shimoda Add binding document for Renesas PWM Timer on R-Car SoCs. Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Acked-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Simon Horman <horms+renesas@verge.net.au> --- .../devicetree/bindings/pwm/renesas,pwm-rcar.txt | 27 ++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt diff --git a/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt b/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt new file mode 100644 index 0000000..ea0a27b --- /dev/null +++ b/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt @@ -0,0 +1,27 @@ +* Renesas R-Car PWM Timer Controller + +Required Properties: +- compatible: should be one of the following. + - "renesas,pwm-rcar": for generic R-Car compatible PWM Timer + - "renesas,pwm-r8a7778": for R-Car M1A + - "renesas,pwm-r8a7779": for R-Car H1 + - "renesas,pwm-r8a7790": for R-Car H2 + - "renesas,pwm-r8a7791": for R-Car M2-W + - "renesas,pwm-r8a7794": for R-Car E2 +- reg: base address and length of the registers block for the PWM. +- #pwm-cells: should be 2. See pwm.txt in this directory for a description of + the cells format. +- clocks: clock phandle and specifier pair. +- pinctrl-0: phandle, referring to a default pin configuration node. +- pinctrl-names: Set to "default". + +Example: R8A7790 (R-Car H2) PWM Timer node + + pwm0: pwm@e6e30000 { + compatible = "renesas,pwm-r8a7790", "renesas,pwm-rcar"; + reg = <0 0xe6e30000 0 0x8>; + #pwm-cells = <2>; + clocks = <&mstp5_clks R8A7790_CLK_PWM>; + pinctrl-0 = <&pwm0_pins>; + pinctrl-names = "default"; + }; -- 1.9.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
[parent not found: <1443602873-4316-2-git-send-email-yoshihiro.shimoda.uh-zM6kxYcvzFBBDgjK7y7TUQ@public.gmane.org>]
* Re: [PATCH v7 1/2] pwm: Add device tree binding document for R-Car PWM Timer [not found] ` <1443602873-4316-2-git-send-email-yoshihiro.shimoda.uh-zM6kxYcvzFBBDgjK7y7TUQ@public.gmane.org> @ 2015-10-05 14:42 ` Thierry Reding 0 siblings, 0 replies; 7+ messages in thread From: Thierry Reding @ 2015-10-05 14:42 UTC (permalink / raw) To: Yoshihiro Shimoda Cc: robh+dt-DgEjT+Ai2ygdnm+yROfE0A, pawel.moll-5wv7dgnIgG8, mark.rutland-5wv7dgnIgG8, ijc+devicetree-KcIKpvwj1kUDXYZnReoRVg, galak-sgV2jX0FEOL9JmXXK+q4OQ, linux-pwm-u79uwXL29TY76Z2rM5mHXA, linux-sh-u79uwXL29TY76Z2rM5mHXA, devicetree-u79uwXL29TY76Z2rM5mHXA [-- Attachment #1: Type: text/plain, Size: 560 bytes --] On Wed, Sep 30, 2015 at 05:47:52PM +0900, Yoshihiro Shimoda wrote: > Add binding document for Renesas PWM Timer on R-Car SoCs. > > Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> > Acked-by: Geert Uytterhoeven <geert+renesas@glider.be> > Reviewed-by: Simon Horman <horms+renesas@verge.net.au> > --- > .../devicetree/bindings/pwm/renesas,pwm-rcar.txt | 27 ++++++++++++++++++++++ > 1 file changed, 27 insertions(+) > create mode 100644 Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt Applied, thanks. Thierry [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 819 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH v7 1/2] pwm: Add device tree binding document for R-Car PWM Timer 2015-09-30 8:47 ` [PATCH v7 1/2] pwm: Add device tree binding document " Yoshihiro Shimoda [not found] ` <1443602873-4316-2-git-send-email-yoshihiro.shimoda.uh-zM6kxYcvzFBBDgjK7y7TUQ@public.gmane.org> @ 2015-10-05 15:38 ` Rob Herring 2015-10-06 6:31 ` Yoshihiro Shimoda 1 sibling, 1 reply; 7+ messages in thread From: Rob Herring @ 2015-10-05 15:38 UTC (permalink / raw) To: Yoshihiro Shimoda Cc: Thierry Reding, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell, Kumar Gala, Linux PWM List, SH-Linux, devicetree@vger.kernel.org On Wed, Sep 30, 2015 at 3:47 AM, Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> wrote: > Add binding document for Renesas PWM Timer on R-Car SoCs. > > Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> > Acked-by: Geert Uytterhoeven <geert+renesas@glider.be> > Reviewed-by: Simon Horman <horms+renesas@verge.net.au> > --- > .../devicetree/bindings/pwm/renesas,pwm-rcar.txt | 27 ++++++++++++++++++++++ > 1 file changed, 27 insertions(+) > create mode 100644 Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt > > diff --git a/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt b/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt > new file mode 100644 > index 0000000..ea0a27b > --- /dev/null > +++ b/Documentation/devicetree/bindings/pwm/renesas,pwm-rcar.txt > @@ -0,0 +1,27 @@ > +* Renesas R-Car PWM Timer Controller > + > +Required Properties: > +- compatible: should be one of the following. > + - "renesas,pwm-rcar": for generic R-Car compatible PWM Timer Should be this one and one of the following? That is what the example shows. > + - "renesas,pwm-r8a7778": for R-Car M1A > + - "renesas,pwm-r8a7779": for R-Car H1 > + - "renesas,pwm-r8a7790": for R-Car H2 > + - "renesas,pwm-r8a7791": for R-Car M2-W > + - "renesas,pwm-r8a7794": for R-Car E2 > +- reg: base address and length of the registers block for the PWM. > +- #pwm-cells: should be 2. See pwm.txt in this directory for a description of > + the cells format. > +- clocks: clock phandle and specifier pair. > +- pinctrl-0: phandle, referring to a default pin configuration node. > +- pinctrl-names: Set to "default". > + > +Example: R8A7790 (R-Car H2) PWM Timer node > + > + pwm0: pwm@e6e30000 { > + compatible = "renesas,pwm-r8a7790", "renesas,pwm-rcar"; > + reg = <0 0xe6e30000 0 0x8>; > + #pwm-cells = <2>; > + clocks = <&mstp5_clks R8A7790_CLK_PWM>; > + pinctrl-0 = <&pwm0_pins>; > + pinctrl-names = "default"; > + }; > -- > 1.9.1 > ^ permalink raw reply [flat|nested] 7+ messages in thread
* RE: [PATCH v7 1/2] pwm: Add device tree binding document for R-Car PWM Timer 2015-10-05 15:38 ` Rob Herring @ 2015-10-06 6:31 ` Yoshihiro Shimoda 0 siblings, 0 replies; 7+ messages in thread From: Yoshihiro Shimoda @ 2015-10-06 6:31 UTC (permalink / raw) To: Rob Herring Cc: Thierry Reding, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell, Kumar Gala, Linux PWM List, SH-Linux, devicetree@vger.kernel.org SGkgUm9iLA0KDQo+IFNlbnQ6IFR1ZXNkYXksIE9jdG9iZXIgMDYsIDIwMTUgMTI6MzkgQU0NCj4g DQo+IE9uIFdlZCwgU2VwIDMwLCAyMDE1IGF0IDM6NDcgQU0sIFlvc2hpaGlybyBTaGltb2RhDQo+ IDx5b3NoaWhpcm8uc2hpbW9kYS51aEByZW5lc2FzLmNvbT4gd3JvdGU6DQo+ID4gQWRkIGJpbmRp bmcgZG9jdW1lbnQgZm9yIFJlbmVzYXMgUFdNIFRpbWVyIG9uIFItQ2FyIFNvQ3MuDQo+ID4NCj4g PiBTaWduZWQtb2ZmLWJ5OiBZb3NoaWhpcm8gU2hpbW9kYSA8eW9zaGloaXJvLnNoaW1vZGEudWhA cmVuZXNhcy5jb20+DQo+ID4gQWNrZWQtYnk6IEdlZXJ0IFV5dHRlcmhvZXZlbiA8Z2VlcnQrcmVu ZXNhc0BnbGlkZXIuYmU+DQo+ID4gUmV2aWV3ZWQtYnk6IFNpbW9uIEhvcm1hbiA8aG9ybXMrcmVu ZXNhc0B2ZXJnZS5uZXQuYXU+DQo+ID4gLS0tDQo+ID4gIC4uLi9kZXZpY2V0cmVlL2JpbmRpbmdz L3B3bS9yZW5lc2FzLHB3bS1yY2FyLnR4dCAgIHwgMjcgKysrKysrKysrKysrKysrKysrKysrKw0K PiA+ICAxIGZpbGUgY2hhbmdlZCwgMjcgaW5zZXJ0aW9ucygrKQ0KPiA+ICBjcmVhdGUgbW9kZSAx MDA2NDQgRG9jdW1lbnRhdGlvbi9kZXZpY2V0cmVlL2JpbmRpbmdzL3B3bS9yZW5lc2FzLHB3bS1y Y2FyLnR4dA0KPiA+DQo+ID4gZGlmZiAtLWdpdCBhL0RvY3VtZW50YXRpb24vZGV2aWNldHJlZS9i aW5kaW5ncy9wd20vcmVuZXNhcyxwd20tcmNhci50eHQNCj4gYi9Eb2N1bWVudGF0aW9uL2Rldmlj ZXRyZWUvYmluZGluZ3MvcHdtL3JlbmVzYXMscHdtLXJjYXIudHh0DQo+ID4gbmV3IGZpbGUgbW9k ZSAxMDA2NDQNCj4gPiBpbmRleCAwMDAwMDAwLi5lYTBhMjdiDQo+ID4gLS0tIC9kZXYvbnVsbA0K PiA+ICsrKyBiL0RvY3VtZW50YXRpb24vZGV2aWNldHJlZS9iaW5kaW5ncy9wd20vcmVuZXNhcyxw d20tcmNhci50eHQNCj4gPiBAQCAtMCwwICsxLDI3IEBADQo+ID4gKyogUmVuZXNhcyBSLUNhciBQ V00gVGltZXIgQ29udHJvbGxlcg0KPiA+ICsNCj4gPiArUmVxdWlyZWQgUHJvcGVydGllczoNCj4g PiArLSBjb21wYXRpYmxlOiBzaG91bGQgYmUgb25lIG9mIHRoZSBmb2xsb3dpbmcuDQo+ID4gKyAt ICJyZW5lc2FzLHB3bS1yY2FyIjogZm9yIGdlbmVyaWMgUi1DYXIgY29tcGF0aWJsZSBQV00gVGlt ZXINCj4gDQo+IFNob3VsZCBiZSB0aGlzIG9uZSBhbmQgb25lIG9mIHRoZSBmb2xsb3dpbmc/IFRo YXQgaXMgd2hhdCB0aGUgZXhhbXBsZSBzaG93cy4NCg0KVGhhbmsgeW91IGZvciB0aGUgcG9pbnQu DQpTaW5jZSB0aGlzIHBhdGNoIGlzIGFscmVhZHkgbWVyZ2VkIGluIGxpbnV4LXB3bSByZXBvc2l0 b3J5LCBJIHdpbGwgc3VibWl0DQphIG5ldyBwYXRjaCB0byByZXZpc2UgaXQuDQoNCkJlc3QgcmVn YXJkcywNCllvc2hpaGlybyBTaGltb2RhDQoNCj4gPiArIC0gInJlbmVzYXMscHdtLXI4YTc3Nzgi OiBmb3IgUi1DYXIgTTFBDQo+ID4gKyAtICJyZW5lc2FzLHB3bS1yOGE3Nzc5IjogZm9yIFItQ2Fy IEgxDQo+ID4gKyAtICJyZW5lc2FzLHB3bS1yOGE3NzkwIjogZm9yIFItQ2FyIEgyDQo+ID4gKyAt ICJyZW5lc2FzLHB3bS1yOGE3NzkxIjogZm9yIFItQ2FyIE0yLVcNCj4gPiArIC0gInJlbmVzYXMs cHdtLXI4YTc3OTQiOiBmb3IgUi1DYXIgRTINCj4gPiArLSByZWc6IGJhc2UgYWRkcmVzcyBhbmQg bGVuZ3RoIG9mIHRoZSByZWdpc3RlcnMgYmxvY2sgZm9yIHRoZSBQV00uDQo+ID4gKy0gI3B3bS1j ZWxsczogc2hvdWxkIGJlIDIuIFNlZSBwd20udHh0IGluIHRoaXMgZGlyZWN0b3J5IGZvciBhIGRl c2NyaXB0aW9uIG9mDQo+ID4gKyAgdGhlIGNlbGxzIGZvcm1hdC4NCj4gPiArLSBjbG9ja3M6IGNs b2NrIHBoYW5kbGUgYW5kIHNwZWNpZmllciBwYWlyLg0KPiA+ICstIHBpbmN0cmwtMDogcGhhbmRs ZSwgcmVmZXJyaW5nIHRvIGEgZGVmYXVsdCBwaW4gY29uZmlndXJhdGlvbiBub2RlLg0KPiA+ICst IHBpbmN0cmwtbmFtZXM6IFNldCB0byAiZGVmYXVsdCIuDQo+ID4gKw0KPiA+ICtFeGFtcGxlOiBS OEE3NzkwIChSLUNhciBIMikgUFdNIFRpbWVyIG5vZGUNCj4gPiArDQo+ID4gKyAgICAgICBwd20w OiBwd21AZTZlMzAwMDAgew0KPiA+ICsgICAgICAgICAgICAgICBjb21wYXRpYmxlID0gInJlbmVz YXMscHdtLXI4YTc3OTAiLCAicmVuZXNhcyxwd20tcmNhciI7DQo+ID4gKyAgICAgICAgICAgICAg IHJlZyA9IDwwIDB4ZTZlMzAwMDAgMCAweDg+Ow0KPiA+ICsgICAgICAgICAgICAgICAjcHdtLWNl bGxzID0gPDI+Ow0KPiA+ICsgICAgICAgICAgICAgICBjbG9ja3MgPSA8Jm1zdHA1X2Nsa3MgUjhB Nzc5MF9DTEtfUFdNPjsNCj4gPiArICAgICAgICAgICAgICAgcGluY3RybC0wID0gPCZwd20wX3Bp bnM+Ow0KPiA+ICsgICAgICAgICAgICAgICBwaW5jdHJsLW5hbWVzID0gImRlZmF1bHQiOw0KPiA+ ICsgICAgICAgfTsNCj4gPiAtLQ0KPiA+IDEuOS4xDQo+ID4NCg= ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH v7 2/2] pwm: Add support for R-Car PWM Timer 2015-09-30 8:47 [PATCH v7 0/2] pwm: Add support for R-Car PWM Timer Yoshihiro Shimoda 2015-09-30 8:47 ` [PATCH v7 1/2] pwm: Add device tree binding document " Yoshihiro Shimoda @ 2015-09-30 8:47 ` Yoshihiro Shimoda 2015-10-05 14:42 ` Thierry Reding 1 sibling, 1 reply; 7+ messages in thread From: Yoshihiro Shimoda @ 2015-09-30 8:47 UTC (permalink / raw) To: thierry.reding, robh+dt, pawel.moll, mark.rutland, ijc+devicetree, galak Cc: linux-pwm, linux-sh, devicetree, Yoshihiro Shimoda This patch adds support for R-Car SoCs PWM Timer. The PWM timer of R-Car H2 has 7 channels. So, we can use the channels if we describe device tree nodes. Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> Reviewed-by: Simon Horman <horms+renesas@verge.net.au> --- drivers/pwm/Kconfig | 11 ++ drivers/pwm/Makefile | 1 + drivers/pwm/pwm-rcar.c | 266 +++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 278 insertions(+) create mode 100644 drivers/pwm/pwm-rcar.c diff --git a/drivers/pwm/Kconfig b/drivers/pwm/Kconfig index 062630a..5dac49f 100644 --- a/drivers/pwm/Kconfig +++ b/drivers/pwm/Kconfig @@ -268,6 +268,17 @@ config PWM_PXA To compile this driver as a module, choose M here: the module will be called pwm-pxa. +config PWM_RCAR + tristate "Renesas R-Car PWM support" + depends on ARCH_RCAR_GEN1 || ARCH_RCAR_GEN2 || COMPILE_TEST + depends on HAS_IOMEM + help + This driver exposes the PWM Timer controller found in Renesas + R-Car chips through the PWM API. + + To compile this driver as a module, choose M here: the module + will be called pwm-rcar. + config PWM_RENESAS_TPU tristate "Renesas TPU PWM support" depends on ARCH_SHMOBILE || COMPILE_TEST diff --git a/drivers/pwm/Makefile b/drivers/pwm/Makefile index a0e00c0..9107d65 100644 --- a/drivers/pwm/Makefile +++ b/drivers/pwm/Makefile @@ -24,6 +24,7 @@ obj-$(CONFIG_PWM_MXS) += pwm-mxs.o obj-$(CONFIG_PWM_PCA9685) += pwm-pca9685.o obj-$(CONFIG_PWM_PUV3) += pwm-puv3.o obj-$(CONFIG_PWM_PXA) += pwm-pxa.o +obj-$(CONFIG_PWM_RCAR) += pwm-rcar.o obj-$(CONFIG_PWM_RENESAS_TPU) += pwm-renesas-tpu.o obj-$(CONFIG_PWM_ROCKCHIP) += pwm-rockchip.o obj-$(CONFIG_PWM_SAMSUNG) += pwm-samsung.o diff --git a/drivers/pwm/pwm-rcar.c b/drivers/pwm/pwm-rcar.c new file mode 100644 index 0000000..b641701 --- /dev/null +++ b/drivers/pwm/pwm-rcar.c @@ -0,0 +1,266 @@ +/* + * R-Car PWM Timer driver + * + * Copyright (C) 2015 Renesas Electronics Corporation + * + * This is free software; you can redistribute it and/or modify + * it under the terms of version 2 of the GNU General Public License as + * published by the Free Software Foundation. + */ + +#include <linux/clk.h> +#include <linux/err.h> +#include <linux/io.h> +#include <linux/module.h> +#include <linux/of.h> +#include <linux/platform_device.h> +#include <linux/pm_runtime.h> +#include <linux/pwm.h> +#include <linux/slab.h> + +#define RCAR_PWM_MAX_DIVISION 24 +#define RCAR_PWM_MAX_CYCLE 1023 + +#define RCAR_PWMCR 0x00 +#define RCAR_PWMCNT 0x04 + +#define RCAR_PWMCR_CC0_MASK 0x000f0000 +#define RCAR_PWMCR_CC0_SHIFT 16 +#define RCAR_PWMCR_CCMD BIT(15) +#define RCAR_PWMCR_SYNC BIT(11) +#define RCAR_PWMCR_SS0 BIT(4) +#define RCAR_PWMCR_EN0 BIT(0) + +#define RCAR_PWMCNT_CYC0_MASK 0x03ff0000 +#define RCAR_PWMCNT_CYC0_SHIFT 16 +#define RCAR_PWMCNT_PH0_MASK 0x000003ff +#define RCAR_PWMCNT_PH0_SHIFT 0 + +struct rcar_pwm_chip { + struct pwm_chip chip; + void __iomem *base; + struct clk *clk; +}; + +static inline struct rcar_pwm_chip *to_rcar_pwm_chip(struct pwm_chip *chip) +{ + return container_of(chip, struct rcar_pwm_chip, chip); +} + +static void rcar_pwm_write(struct rcar_pwm_chip *rp, u32 data, u32 reg) +{ + writel(data, rp->base + reg); +} + +static u32 rcar_pwm_read(struct rcar_pwm_chip *rp, u32 reg) +{ + return readl(rp->base + reg); +} + +static void rcar_pwm_bit_modify(struct rcar_pwm_chip *rp, u32 mask, u32 data, + u32 reg) +{ + u32 val = rcar_pwm_read(rp, reg); + + val &= ~mask; + val |= data & mask; + rcar_pwm_write(rp, val, reg); +} + +static int rcar_pwm_get_clock_division(struct rcar_pwm_chip *rp, int period_ns) +{ + unsigned int div; + unsigned long clk_rate = clk_get_rate(rp->clk); + unsigned long long max; /* max cycle / nanoseconds */ + + if (clk_rate = 0) + return -EINVAL; + + for (div = 0; div <= RCAR_PWM_MAX_DIVISION; div++) { + max = (unsigned long long)NSEC_PER_SEC * RCAR_PWM_MAX_CYCLE * + (1 << div); + do_div(max, clk_rate); + if (period_ns < max) + break; + } + + return (div <= RCAR_PWM_MAX_DIVISION) ? div : -ERANGE; +} + +static void rcar_pwm_set_clock_control(struct rcar_pwm_chip *rp, int div) +{ + u32 val = rcar_pwm_read(rp, RCAR_PWMCR); + + val &= ~(RCAR_PWMCR_CCMD | RCAR_PWMCR_CC0_MASK); + if (div & 1) + val |= RCAR_PWMCR_CCMD; + div >>= 1; + val |= div << RCAR_PWMCR_CC0_SHIFT; + rcar_pwm_write(rp, val, RCAR_PWMCR); +} + +static int rcar_pwm_set_counter(struct rcar_pwm_chip *rp, int div, int duty_ns, + int period_ns) +{ + unsigned long long one_cycle, tmp; /* 0.01 nanoseconds */ + unsigned long clk_rate = clk_get_rate(rp->clk); + u32 cyc, ph; + + one_cycle = (unsigned long long)NSEC_PER_SEC * 100ULL * (1 << div); + do_div(one_cycle, clk_rate); + + tmp = period_ns * 100ULL; + do_div(tmp, one_cycle); + cyc = (tmp << RCAR_PWMCNT_CYC0_SHIFT) & RCAR_PWMCNT_CYC0_MASK; + + tmp = duty_ns * 100ULL; + do_div(tmp, one_cycle); + ph = tmp & RCAR_PWMCNT_PH0_MASK; + + /* Avoid prohibited setting */ + if (cyc = 0 || ph = 0) + return -EINVAL; + + rcar_pwm_write(rp, cyc | ph, RCAR_PWMCNT); + + return 0; +} + +static int rcar_pwm_request(struct pwm_chip *chip, struct pwm_device *pwm) +{ + struct rcar_pwm_chip *rp = to_rcar_pwm_chip(chip); + + return clk_prepare_enable(rp->clk); +} + +static void rcar_pwm_free(struct pwm_chip *chip, struct pwm_device *pwm) +{ + struct rcar_pwm_chip *rp = to_rcar_pwm_chip(chip); + + clk_disable_unprepare(rp->clk); +} + +static int rcar_pwm_config(struct pwm_chip *chip, struct pwm_device *pwm, + int duty_ns, int period_ns) +{ + struct rcar_pwm_chip *rp = to_rcar_pwm_chip(chip); + int div = rcar_pwm_get_clock_division(rp, period_ns); + int ret; + + if (div < 0) + return div; + + /* Let the core driver set pwm->period if disabled and duty_ns = 0 */ + if (!test_bit(PWMF_ENABLED, &pwm->flags) && !duty_ns) + return 0; + + rcar_pwm_bit_modify(rp, RCAR_PWMCR_SYNC, RCAR_PWMCR_SYNC, RCAR_PWMCR); + ret = rcar_pwm_set_counter(rp, div, duty_ns, period_ns); + if (!ret) + rcar_pwm_set_clock_control(rp, div); + /* The SYNC should be set to 0 even if rcar_pwm_set_counter failed */ + rcar_pwm_bit_modify(rp, RCAR_PWMCR_SYNC, 0, RCAR_PWMCR); + + return ret; +} + +static int rcar_pwm_enable(struct pwm_chip *chip, struct pwm_device *pwm) +{ + struct rcar_pwm_chip *rp = to_rcar_pwm_chip(chip); + u32 pwmcnt; + + /* Don't enable the PWM device if CYC0 or PH0 is 0 */ + pwmcnt = rcar_pwm_read(rp, RCAR_PWMCNT); + if ((pwmcnt & RCAR_PWMCNT_CYC0_MASK) = 0 || + (pwmcnt & RCAR_PWMCNT_PH0_MASK) = 0) + return -EINVAL; + + rcar_pwm_bit_modify(rp, RCAR_PWMCR_EN0, RCAR_PWMCR_EN0, RCAR_PWMCR); + + return 0; +} + +static void rcar_pwm_disable(struct pwm_chip *chip, struct pwm_device *pwm) +{ + struct rcar_pwm_chip *rp = to_rcar_pwm_chip(chip); + + rcar_pwm_bit_modify(rp, RCAR_PWMCR_EN0, 0, RCAR_PWMCR); +} + +static const struct pwm_ops rcar_pwm_ops = { + .request = rcar_pwm_request, + .free = rcar_pwm_free, + .config = rcar_pwm_config, + .enable = rcar_pwm_enable, + .disable = rcar_pwm_disable, + .owner = THIS_MODULE, +}; + +static int rcar_pwm_probe(struct platform_device *pdev) +{ + struct rcar_pwm_chip *rcar_pwm; + struct resource *res; + int ret; + + rcar_pwm = devm_kzalloc(&pdev->dev, sizeof(*rcar_pwm), GFP_KERNEL); + if (rcar_pwm = NULL) + return -ENOMEM; + + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); + rcar_pwm->base = devm_ioremap_resource(&pdev->dev, res); + if (IS_ERR(rcar_pwm->base)) + return PTR_ERR(rcar_pwm->base); + + rcar_pwm->clk = devm_clk_get(&pdev->dev, NULL); + if (IS_ERR(rcar_pwm->clk)) { + dev_err(&pdev->dev, "cannot get clock\n"); + return PTR_ERR(rcar_pwm->clk); + } + + platform_set_drvdata(pdev, rcar_pwm); + + rcar_pwm->chip.dev = &pdev->dev; + rcar_pwm->chip.ops = &rcar_pwm_ops; + rcar_pwm->chip.base = -1; + rcar_pwm->chip.npwm = 1; + + ret = pwmchip_add(&rcar_pwm->chip); + if (ret < 0) { + dev_err(&pdev->dev, "failed to register PWM chip\n"); + return ret; + } + + pm_runtime_enable(&pdev->dev); + + return 0; +} + +static int rcar_pwm_remove(struct platform_device *pdev) +{ + struct rcar_pwm_chip *rcar_pwm = platform_get_drvdata(pdev); + + pm_runtime_disable(&pdev->dev); + + return pwmchip_remove(&rcar_pwm->chip); +} + +static const struct of_device_id rcar_pwm_of_table[] = { + { .compatible = "renesas,pwm-rcar", }, + { }, +}; +MODULE_DEVICE_TABLE(of, rcar_pwm_of_table); + +static struct platform_driver rcar_pwm_driver = { + .probe = rcar_pwm_probe, + .remove = rcar_pwm_remove, + .driver = { + .name = "pwm-rcar", + .of_match_table = of_match_ptr(rcar_pwm_of_table), + } +}; +module_platform_driver(rcar_pwm_driver); + +MODULE_AUTHOR("Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>"); +MODULE_DESCRIPTION("Renesas PWM Timer Driver"); +MODULE_LICENSE("GPL v2"); +MODULE_ALIAS("platform:pwm-rcar"); -- 1.9.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH v7 2/2] pwm: Add support for R-Car PWM Timer 2015-09-30 8:47 ` [PATCH v7 2/2] pwm: Add support " Yoshihiro Shimoda @ 2015-10-05 14:42 ` Thierry Reding 0 siblings, 0 replies; 7+ messages in thread From: Thierry Reding @ 2015-10-05 14:42 UTC (permalink / raw) To: Yoshihiro Shimoda Cc: robh+dt, pawel.moll, mark.rutland, ijc+devicetree, galak, linux-pwm, linux-sh, devicetree [-- Attachment #1: Type: text/plain, Size: 686 bytes --] On Wed, Sep 30, 2015 at 05:47:53PM +0900, Yoshihiro Shimoda wrote: > This patch adds support for R-Car SoCs PWM Timer. The PWM timer of > R-Car H2 has 7 channels. So, we can use the channels if we describe > device tree nodes. > > Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com> > Reviewed-by: Simon Horman <horms+renesas@verge.net.au> > --- > drivers/pwm/Kconfig | 11 ++ > drivers/pwm/Makefile | 1 + > drivers/pwm/pwm-rcar.c | 266 +++++++++++++++++++++++++++++++++++++++++++++++++ > 3 files changed, 278 insertions(+) > create mode 100644 drivers/pwm/pwm-rcar.c Applied (with some bikeshedding changes squashed in), thanks. Thierry [-- Attachment #2: signature.asc --] [-- Type: application/pgp-signature, Size: 819 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2015-10-06 6:31 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-09-30 8:47 [PATCH v7 0/2] pwm: Add support for R-Car PWM Timer Yoshihiro Shimoda 2015-09-30 8:47 ` [PATCH v7 1/2] pwm: Add device tree binding document " Yoshihiro Shimoda [not found] ` <1443602873-4316-2-git-send-email-yoshihiro.shimoda.uh-zM6kxYcvzFBBDgjK7y7TUQ@public.gmane.org> 2015-10-05 14:42 ` Thierry Reding 2015-10-05 15:38 ` Rob Herring 2015-10-06 6:31 ` Yoshihiro Shimoda 2015-09-30 8:47 ` [PATCH v7 2/2] pwm: Add support " Yoshihiro Shimoda 2015-10-05 14:42 ` Thierry Reding
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).