From: Biju Das <biju.das.jz@bp.renesas.com>
To: Lee Jones <lee@kernel.org>
Cc: "Philipp Zabel" <p.zabel@pengutronix.de>,
"Daniel Lezcano" <daniel.lezcano@linaro.org>,
"William Breathitt Gray" <william.gray@linaro.org>,
"Thierry Reding" <thierry.reding@gmail.com>,
"Uwe Kleine-König" <u.kleine-koenig@pengutronix.de>,
"Geert Uytterhoeven" <geert+renesas@glider.be>,
"Fabrizio Castro" <fabrizio.castro.jz@renesas.com>,
"Chris Paterson" <Chris.Paterson2@renesas.com>,
"Prabhakar Mahadev Lad" <prabhakar.mahadev-lad.rj@bp.renesas.com>,
"linux-renesas-soc@vger.kernel.org"
<linux-renesas-soc@vger.kernel.org>
Subject: RE: [PATCH v14 2/6] mfd: Add Renesas RZ/G2L MTU3a core driver
Date: Thu, 16 Mar 2023 16:04:00 +0000 [thread overview]
Message-ID: <OS0PR01MB5922FE8D99B0DB1903E6D3CB86BC9@OS0PR01MB5922.jpnprd01.prod.outlook.com> (raw)
In-Reply-To: <20230316155806.GN9667@google.com>
Hi Lee Jones,
> Subject: Re: [PATCH v14 2/6] mfd: Add Renesas RZ/G2L MTU3a core driver
>
> On Fri, 10 Mar 2023, Biju Das wrote:
>
> > The RZ/G2L multi-function timer pulse unit 3 (MTU3a) is embedded in
> > the Renesas RZ/G2L family SoCs. It consists of eight 16-bit timer
> > channels and one 32-bit timer channel. It supports the following
> > functions
> > - Counter
> > - Timer
> > - PWM
> >
> > The 8/16/32 bit registers are mixed in each channel.
> >
> > Add MTU3a core driver for RZ/G2L SoC. The core driver shares the clk
> > and channel register access for the other child devices like Counter,
> > PWM and Clock event.
> >
> > Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
> > ---
> > Ref:
> >
> > https://jpn01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fpatc
> > hwork.kernel.org%2Fproject%2Flinux-renesas-soc%2Fpatch%2F2023011316175
> > 3.1073706-3-biju.das.jz%40bp.renesas.com%2F&data=05%7C01%7Cbiju.das.jz
> > %40bp.renesas.com%7C458cfc7d8ee844528a7408db26374248%7C53d82571da1947e
> > 49cb4625a166a4a2a%7C0%7C0%7C638145790995013544%7CUnknown%7CTWFpbGZsb3d
> > 8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C
> > 3000%7C%7C%7C&sdata=fLDeHPxRQucDodqQcHm1ohwavSbNbWng4mvFtS1pSGM%3D&res
> > erved=0
> > v13->v14:
> > * Added helper macros for initializing 8/16/32 channel reg offset table
> in
> > "drivers/mfd/rz-mtu3.h"
> > * Replaced "off"->offset in read_write()
> > * Replaced __LINUX_RZ_MTU3_H__->__MFD_RZ_MTU3_H__
> > * Added header file device.h and mutex.h
> > * Updated rz_mtu3_request_channel()
> > * Replaced channel_index->channel_number in struct rz_mtu3_channel
> > * Dropped redundant comments.
> > * Renamed channel number macros from RZ_MTU*->RZ_MTU3_CHAN_*
> > * Added core driver specific private data in struct rz_mtu3 and updated
> the
> > comments. This replaces mmio from struct rz_mtu3.
> > * Started using actual offset in channel reg table and removed
> ch_reg_offsets table
> > Also simplified the code 8/16/32 bits read_write() and removed base
> from
> > struct rz_mtu3_channel.
> > * Simplified rz_mtu3_start_stop_ch()/rz_mtu3_is_enabled() by adding
> helper functions
> > rz_mtu3_get_tstr_offset()/rz_mtu3_get_tstr_bit_pos().
> > v12->v13:
> > * Moved RZ_MTU3_TMDR1_* macros from pwm driver to rz-mtu3.h.
> > v11->v2:
> > * Moved the core driver from timer to MFD.
> > * Moved header fine from clocksource/rz-mtu3.h->linux/mfd/rz-mtu3.h
> > * Removed Select MFD_CORE option from config.
> > v10->v11:
> > * No change.
> > v9->v10:
> > * No change.
> > v8->v9:
> > * No change.
> > v7->v8:
> > * Add locking for RMW on rz_mtu3_shared_reg_update_bit()
> > * Replaced enum rz_mtu3_functions with channel busy flag
> > * Added API for request and release a channel.
> > v6->v7:
> > * Added channel specific mutex to avoid races between child devices
> > (for eg: pwm and counter)
> > * Added rz_mtu3_shared_reg_update_bit() to update bit.
> > v5->v6:
> > * Updated commit and KConfig description
> > * Selected MFD_CORE to avoid build error if CONFIG_MFD_CORE not set.
> > * Improved error handling in probe().
> > * Updated MODULE_DESCRIPTION and title.
> > v4->v5:
> > * Moved core driver from MFD to timer
> > * Child devices instatiated using mfd_add_devices()
> > v3->v4:
> > * A single driver that registers both the counter and the pwm
> functionalities
> > that binds against "renesas,rz-mtu3".
> > * Moved PM handling from child devices to here.
> > * replaced include/linux/mfd/rz-mtu3.h->drivers/mfd/rz-mtu3.h
> > * Removed "remove" callback
> > v2->v3:
> > * removed unwanted header files
> > * Added LUT for 32 bit registers as it needed for 32-bit cascade
> counting.
> > * Exported 32 bit read/write functions.
> > v1->v2:
> > * Changed the compatible name
> > * Replaced devm_reset_control_get->devm_reset_control_get_exclusive
> > * Renamed function names rzg2l_mtu3->rz_mtu3 as this is generic IP
> > in RZ family SoC's.
> > ---
> > drivers/mfd/Kconfig | 10 +
> > drivers/mfd/Makefile | 1 +
> > drivers/mfd/rz-mtu3.c | 391 ++++++++++++++++++++++++++++++++++++
> > drivers/mfd/rz-mtu3.h | 147 ++++++++++++++
> > include/linux/mfd/rz-mtu3.h | 241 ++++++++++++++++++++++
> > 5 files changed, 790 insertions(+)
> > create mode 100644 drivers/mfd/rz-mtu3.c create mode 100644
> > drivers/mfd/rz-mtu3.h create mode 100644 include/linux/mfd/rz-mtu3.h
>
> I plan to take this set via MFD once you have PWM Ack.
>
> For my own reference (apply this as-is to your sign-off block):
>
> Acked-for-MFD-by: Lee Jones <lee@kernel.org>
Thank you.
Cheers,
Biju
next prev parent reply other threads:[~2023-03-16 16:04 UTC|newest]
Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-03-10 17:06 [PATCH v14 0/6] Add RZ/G2L MTU3a Core, Counter and pwm driver Biju Das
2023-03-10 17:06 ` [PATCH v14 1/6] dt-bindings: timer: Document RZ/G2L MTU3a bindings Biju Das
2023-03-10 17:06 ` [PATCH v14 2/6] mfd: Add Renesas RZ/G2L MTU3a core driver Biju Das
2023-03-16 15:58 ` Lee Jones
2023-03-16 16:04 ` Biju Das [this message]
2023-03-29 20:54 ` Uwe Kleine-König
2023-03-30 10:56 ` Lee Jones
2023-03-30 12:30 ` Uwe Kleine-König
2023-03-10 17:06 ` [PATCH v14 3/6] Documentation: ABI: sysfs-bus-counter: add cascade_counts_enable and external_input_phase_clock_select Biju Das
2023-03-10 17:06 ` [PATCH v14 4/6] counter: Add Renesas RZ/G2L MTU3a counter driver Biju Das
2023-03-10 17:06 ` [PATCH v14 5/6] MAINTAINERS: Add entries for " Biju Das
2023-03-10 17:06 ` [PATCH v14 6/6] pwm: Add Renesas RZ/G2L MTU3a PWM driver Biju Das
2023-03-23 15:48 ` Biju Das
2023-03-27 20:40 ` Uwe Kleine-König
2023-03-29 17:40 ` Biju Das
2023-03-29 20:51 ` Uwe Kleine-König
2023-03-30 11:04 ` Biju Das
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=OS0PR01MB5922FE8D99B0DB1903E6D3CB86BC9@OS0PR01MB5922.jpnprd01.prod.outlook.com \
--to=biju.das.jz@bp.renesas.com \
--cc=Chris.Paterson2@renesas.com \
--cc=daniel.lezcano@linaro.org \
--cc=fabrizio.castro.jz@renesas.com \
--cc=geert+renesas@glider.be \
--cc=lee@kernel.org \
--cc=linux-renesas-soc@vger.kernel.org \
--cc=p.zabel@pengutronix.de \
--cc=prabhakar.mahadev-lad.rj@bp.renesas.com \
--cc=thierry.reding@gmail.com \
--cc=u.kleine-koenig@pengutronix.de \
--cc=william.gray@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).