From: Andrea della Porta <andrea.porta@suse.com>
To: Andrea della Porta <andrea.porta@suse.com>
Cc: "Uwe Kleine-König" <ukleinek@kernel.org>,
linux-pwm@vger.kernel.org, "Rob Herring" <robh@kernel.org>,
"Krzysztof Kozlowski" <krzk+dt@kernel.org>,
"Conor Dooley" <conor+dt@kernel.org>,
"Florian Fainelli" <florian.fainelli@broadcom.com>,
"Broadcom internal kernel review list"
<bcm-kernel-feedback-list@broadcom.com>,
devicetree@vger.kernel.org, linux-rpi-kernel@lists.infradead.org,
linux-arm-kernel@lists.infradead.org,
linux-kernel@vger.kernel.org,
"Naushir Patuck" <naush@raspberrypi.com>,
"Stanimir Varbanov" <svarbanov@suse.de>,
mbrugger@suse.com
Subject: Re: [PATCH v3 0/3] Add RP1 PWM controller support
Date: Fri, 8 May 2026 10:15:44 +0200 [thread overview]
Message-ID: <af2bsEdAhYY9c4rb@apocalypse> (raw)
In-Reply-To: <cover.1776932336.git.andrea.porta@suse.com>
Hi Uwe,
On 10:30 Thu 23 Apr , Andrea della Porta wrote:
> This patchset adds support for the PWM controller found on the
> Raspberry Pi RP1 southbridge. This is necessary to operate the
> cooling fan connected to one of the PWM channels.
>
> The tachometer pin for the fan speed is managed by the firmware
> running on the RP1's M-core. It uses the PHASE2 register
> to report the RPM, which is then exported by this driver via
> syscon registers. A subsequent patch will add a new device
> and driver to read the RPM and export this value via hwmon.
>
> Subsequent patches will also add the CPU thermal zone, which
> acts as a consumer of the PWM device.
>
> Best regards,
> Andrea
>
> CHANGES in V3:
>
> - Refactored all the register macros. They now have RP1_PWM_ prefix
> and follow the register name.
> - Dropped the tab alignment in front of struct declarations (use a space
> instead).
> - Added a check in tohw() to test (and bail out quickly) in case that
> period_length_ns is zero.
> - Probing now returns an error if clk_rate > 1 GHz.
> - Added a check on minimum period ticks. Return 1 to signal round-up.
> - Fixed inverted polarity detection on edge cases.
> - Fixed rounding errors (in both tohwi() and fromhw()) in inverted
> polarity calculations.
> - Dropped a redundant check on period >= duty.
> - Replaced memset by inline struct init.
> - Disabling a channel now is faster, skipping the duty/period/polarity
> setup.
> - Fixed an error string (s/Fail/Failed)
> - Used %pe to signal error string instead of an integer.
> - Added several new sections to the Limitations paragraph to better
> explain what will happen on edge cases.
> - Maximum period is now U32_MAX-1 to allow 100% duty cycle on all
> selectable periods.
> - The hw period register now takes into account for the extra tick at
> the end of the period (subtracted one to wfhw->period_ticks in tohw
> and added 1 in fromhw).
> - Added .remove() callback to free resources even if the driver is
> not unbindable/unloadable, to avoid accumulating tech debt.
>
>
> Naushir Patuck (2):
> dt-bindings: pwm: Add Raspberry Pi RP1 PWM controller
> pwm: rp1: Add RP1 PWM controller driver
>
> Stanimir Varbanov (1):
> arm64: dts: broadcom: rpi-5: Add RP1 PWM node
>
> .../bindings/pwm/raspberrypi,rp1-pwm.yaml | 54 +++
> .../boot/dts/broadcom/bcm2712-rpi-5-b.dts | 12 +
> arch/arm64/boot/dts/broadcom/rp1-common.dtsi | 10 +
> drivers/pwm/Kconfig | 9 +
> drivers/pwm/Makefile | 1 +
> drivers/pwm/pwm-rp1.c | 414 ++++++++++++++++++
> 6 files changed, 500 insertions(+)
> create mode 100644 Documentation/devicetree/bindings/pwm/raspberrypi,rp1-pwm.yaml
> create mode 100644 drivers/pwm/pwm-rp1.c
>
> --
> 2.35.3
>
A gentle reminder about this patchset :)
Many thanks,
Andrea
prev parent reply other threads:[~2026-05-08 8:12 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-23 8:30 [PATCH v3 0/3] Add RP1 PWM controller support Andrea della Porta
2026-04-23 8:30 ` [PATCH v3 1/3] dt-bindings: pwm: Add Raspberry Pi RP1 PWM controller Andrea della Porta
2026-04-23 8:30 ` [PATCH v3 2/3] pwm: rp1: Add RP1 PWM controller driver Andrea della Porta
2026-04-23 8:30 ` [PATCH v3 3/3] arm64: dts: broadcom: rpi-5: Add RP1 PWM node Andrea della Porta
2026-05-08 8:15 ` Andrea della Porta [this message]
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=af2bsEdAhYY9c4rb@apocalypse \
--to=andrea.porta@suse.com \
--cc=bcm-kernel-feedback-list@broadcom.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=florian.fainelli@broadcom.com \
--cc=krzk+dt@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pwm@vger.kernel.org \
--cc=linux-rpi-kernel@lists.infradead.org \
--cc=mbrugger@suse.com \
--cc=naush@raspberrypi.com \
--cc=robh@kernel.org \
--cc=svarbanov@suse.de \
--cc=ukleinek@kernel.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