Hi, Neil Armstrong <narmstrong@xxxxxxxxxxxx> writes: > Adds support for using a OMAP dual-mode timer with PWM capability > as a Linux PWM device. The driver controls the timer by using the > dmtimer API. > > Add a platform_data structure for each pwm-omap-dmtimer nodes containing > the dmtimers functions in order to get driver not rely on platform > specific functions. > > Cc: Grant Erickson <marathon96@xxxxxxxxx> > Cc: NeilBrown <neilb@xxxxxxx> > Cc: Joachim Eastwood <manabian@xxxxxxxxx> > Suggested-by: Tony Lindgren <tony@xxxxxxxxxxx> > Signed-off-by: Neil Armstrong <narmstrong@xxxxxxxxxxxx> > --- > .../devicetree/bindings/pwm/pwm-omap-dmtimer.txt | 18 ++ > drivers/pwm/Kconfig | 9 + > drivers/pwm/Makefile | 1 + > drivers/pwm/pwm-omap-dmtimer.c | 322 +++++++++++++++++++++ > include/linux/platform_data/pwm_omap_dmtimer.h | 69 +++++ > 5 files changed, 419 insertions(+) > create mode 100644 Documentation/devicetree/bindings/pwm/pwm-omap-dmtimer.txt > create mode 100644 drivers/pwm/pwm-omap-dmtimer.c > create mode 100644 include/linux/platform_data/pwm_omap_dmtimer.h > > diff --git a/Documentation/devicetree/bindings/pwm/pwm-omap-dmtimer.txt b/Documentation/devicetree/bindings/pwm/pwm-omap-dmtimer.txt > new file mode 100644 > index 0000000..7f27606 > --- /dev/null > +++ b/Documentation/devicetree/bindings/pwm/pwm-omap-dmtimer.txt > @@ -0,0 +1,18 @@ > +* OMAP PWM for dual-mode timers > + > +Required properties: > +- compatible: Shall contain "ti,omap-dmtimer-pwm". > +- ti,timers: phandle to PWM capable OMAP timer. See arm/omap/timer.txt for info > + about these timers. > +- #pwm-cells: Should be 3. See pwm.txt in this directory for a description of > + the cells format. > + > +Optiomal properties: > +- ti,prescaler: Should be a value between 0 and 7, see the timers datasheet > + > +Example: > + pwm: omap-pwm { > + compatible = "ti,omap-pwm"; > + ti,timers = <&timer9>; > + #pwm-cells = <3>; > + }; I wonder how far are you from a generic pwm-of-timer.c. This looks pretty close to that. You already have a pdata function pointers for pretty much everything, all you need to do is pass a timer phandle and, as long as the functions pointers are implemented, it should work. You might want to get rid of pdata altogether at some point, this should work as migration path. -- balbi
Attachment:
signature.asc
Description: PGP signature