* [PATCH v3 0/2] Exynos850 AP-to-APM mailbox support
@ 2026-04-29 19:00 Alexey Klimov
2026-04-29 19:00 ` [PATCH v3 1/2] dt-bindings: mailbox: google,gs101-mbox: Add samsung,exynos850-mbox Alexey Klimov
2026-04-29 19:00 ` [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox Alexey Klimov
0 siblings, 2 replies; 4+ messages in thread
From: Alexey Klimov @ 2026-04-29 19:00 UTC (permalink / raw)
To: Krzysztof Kozlowski, Sam Protsenko, Rob Herring, Conor Dooley,
Tudor Ambarus, Jassi Brar, Alim Akhtar
Cc: Krzysztof Kozlowski, Peter Griffin, linux-samsung-soc,
linux-arm-kernel, devicetree, linux-kernel, Alexey Klimov,
Krzysztof Kozlowski
This patch series introduces support for the AP-to-APM mailbox on the
Exynos850 SoC. This mailbox is required for communicating with the APM
co-processor using ACPM.
The Exynos850 mailbox operates similarly to the existing gs101
implementation, but the register offsets and IRQ mask bits differ.
This series abstracts these differences into platform-specific data
structures matched via the device tree.
Also, it requires APM-to-AP mailbox clock in CMU_APM block (which was
already merged). I also dropped clk-list emails from this series.
Will be appreciated if it can be tested on gs101 to make sure that I
didn't break anything.
Signed-off-by: Alexey Klimov <alexey.klimov@linaro.org>
---
Changes in v3:
- exynos850 dts change is split out to a separate patch;
- updated commit messages to a proper name AP-to-APM;
- added comment "ring the doorbell" right before generating an IRQ to APM;
- renamed regs callback names to intgr, intgr_shift, intmr, intmr_mask;
- Link to v2: https://lore.kernel.org/r/20260402-exynos850-ap2apm-mailbox-v2-0-ca5ffdff99d4@linaro.org
Changes in v2:
- dropped clock patches (they seem to be merged);
- patch 3: updated commit description mentioning that
exynos850 is not compatible to gs101 mbox (as suggested by Krzysztof);
- fixed comment description for struct exynos_mbox_driver_data
(reported by kernel test robot <lkp@intel.com>);
- Link to v1: https://lore.kernel.org/r/20260320-exynos850-ap2apm-mailbox-v1-0-983eb3f296fc@linaro.org
---
Alexey Klimov (2):
dt-bindings: mailbox: google,gs101-mbox: Add samsung,exynos850-mbox
mailbox: exynos: Add support for Exynos850 mailbox
.../bindings/mailbox/google,gs101-mbox.yaml | 4 +-
drivers/mailbox/exynos-mailbox.c | 59 ++++++++++++++++++++--
2 files changed, 59 insertions(+), 4 deletions(-)
---
base-commit: 0787c45ea08a13b5482e701fabc741877cf681f6
change-id: 20260320-exynos850-ap2apm-mailbox-cff0c8d69898
Best regards,
--
Alexey Klimov <alexey.klimov@linaro.org>
^ permalink raw reply [flat|nested] 4+ messages in thread* [PATCH v3 1/2] dt-bindings: mailbox: google,gs101-mbox: Add samsung,exynos850-mbox 2026-04-29 19:00 [PATCH v3 0/2] Exynos850 AP-to-APM mailbox support Alexey Klimov @ 2026-04-29 19:00 ` Alexey Klimov 2026-04-29 19:00 ` [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox Alexey Klimov 1 sibling, 0 replies; 4+ messages in thread From: Alexey Klimov @ 2026-04-29 19:00 UTC (permalink / raw) To: Krzysztof Kozlowski, Sam Protsenko, Rob Herring, Conor Dooley, Tudor Ambarus, Jassi Brar, Alim Akhtar Cc: Krzysztof Kozlowski, Peter Griffin, linux-samsung-soc, linux-arm-kernel, devicetree, linux-kernel, Alexey Klimov, Krzysztof Kozlowski Document support for a mailbox present on Exynos850-based platforms. The registers offsets are different from gs101 mailbox, but the workflow is similar, hence new compatible. Reviewed-by: Tudor Ambarus <tudor.ambarus@linaro.org> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@oss.qualcomm.com> Signed-off-by: Alexey Klimov <alexey.klimov@linaro.org> --- Documentation/devicetree/bindings/mailbox/google,gs101-mbox.yaml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Documentation/devicetree/bindings/mailbox/google,gs101-mbox.yaml b/Documentation/devicetree/bindings/mailbox/google,gs101-mbox.yaml index e249db4c1fbc..c109c1f7af24 100644 --- a/Documentation/devicetree/bindings/mailbox/google,gs101-mbox.yaml +++ b/Documentation/devicetree/bindings/mailbox/google,gs101-mbox.yaml @@ -20,7 +20,9 @@ description: properties: compatible: - const: google,gs101-mbox + enum: + - google,gs101-mbox + - samsung,exynos850-mbox reg: maxItems: 1 -- 2.51.0 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox 2026-04-29 19:00 [PATCH v3 0/2] Exynos850 AP-to-APM mailbox support Alexey Klimov 2026-04-29 19:00 ` [PATCH v3 1/2] dt-bindings: mailbox: google,gs101-mbox: Add samsung,exynos850-mbox Alexey Klimov @ 2026-04-29 19:00 ` Alexey Klimov 2026-04-30 11:01 ` Tudor Ambarus 1 sibling, 1 reply; 4+ messages in thread From: Alexey Klimov @ 2026-04-29 19:00 UTC (permalink / raw) To: Krzysztof Kozlowski, Sam Protsenko, Rob Herring, Conor Dooley, Tudor Ambarus, Jassi Brar, Alim Akhtar Cc: Krzysztof Kozlowski, Peter Griffin, linux-samsung-soc, linux-arm-kernel, devicetree, linux-kernel, Alexey Klimov, Krzysztof Kozlowski Exynos850-based platforms support ACPM and has similar workflow of communicating with ACPM via mailbox, however mailbox controller registers are located at different offsets and writes/reads could be different. To distinguish between such different behaviours, the registers offsets for Exynos850 and the platform-specific data structs are introduced and configuration is described in such structs for gs101 and exynos850 based SoCs. Probe routine now selects the corresponding platform-specific data via device_get_match_data(). Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@oss.qualcomm.com> Signed-off-by: Alexey Klimov <alexey.klimov@linaro.org> --- drivers/mailbox/exynos-mailbox.c | 59 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 56 insertions(+), 3 deletions(-) diff --git a/drivers/mailbox/exynos-mailbox.c b/drivers/mailbox/exynos-mailbox.c index d2355b128ba4..11657dd475c0 100644 --- a/drivers/mailbox/exynos-mailbox.c +++ b/drivers/mailbox/exynos-mailbox.c @@ -31,14 +31,52 @@ #define EXYNOS_MBOX_CHAN_COUNT HWEIGHT32(EXYNOS_MBOX_INTGR1_MASK) +#define EXYNOS850_MBOX_INTGR0 0x8 /* Interrupt Generation Register 0 */ +#define EXYNOS850_MBOX_INTMR1 0x24 /* Interrupt Mask Register 1 */ + +#define EXYNOS850_MBOX_INTMR1_MASK GENMASK(15, 0) + +/** + * struct exynos_mbox_driver_data - platform-specific mailbox configuration. + * @intgr: offset to the IRQ generation register, doorbell + * to APM co-processor. + * @intgr_shift: shift to apply to the value written to IRQ generation + * register. + * @intmr: offset to the IRQ mask register. + * @intmr_mask: value to write to the mask register to mask out all + * interrupts. + */ +struct exynos_mbox_driver_data { + u16 intgr; + u16 intgr_shift; + u16 intmr; + u16 intmr_mask; +}; + /** * struct exynos_mbox - driver's private data. * @regs: mailbox registers base address. * @mbox: pointer to the mailbox controller. + * @data: pointer to driver platform-specific data. */ struct exynos_mbox { void __iomem *regs; struct mbox_controller *mbox; + const struct exynos_mbox_driver_data *data; +}; + +static const struct exynos_mbox_driver_data exynos850_mbox_data = { + .intgr = EXYNOS850_MBOX_INTGR0, + .intgr_shift = 16, + .intmr = EXYNOS850_MBOX_INTMR1, + .intmr_mask = EXYNOS850_MBOX_INTMR1_MASK, +}; + +static const struct exynos_mbox_driver_data exynos_gs101_mbox_data = { + .intgr = EXYNOS_MBOX_INTGR1, + .intgr_shift = 0, + .intmr = EXYNOS_MBOX_INTMR0, + .intmr_mask = EXYNOS_MBOX_INTMR0_MASK, }; static int exynos_mbox_send_data(struct mbox_chan *chan, void *data) @@ -57,7 +95,9 @@ static int exynos_mbox_send_data(struct mbox_chan *chan, void *data) return -EINVAL; } - writel(BIT(msg->chan_id), exynos_mbox->regs + EXYNOS_MBOX_INTGR1); + /* Ring the doorbell */ + writel(BIT(msg->chan_id) << exynos_mbox->data->intgr_shift, + exynos_mbox->regs + exynos_mbox->data->intgr); return 0; } @@ -87,13 +127,21 @@ static struct mbox_chan *exynos_mbox_of_xlate(struct mbox_controller *mbox, } static const struct of_device_id exynos_mbox_match[] = { - { .compatible = "google,gs101-mbox" }, + { + .compatible = "google,gs101-mbox", + .data = &exynos_gs101_mbox_data + }, + { + .compatible = "samsung,exynos850-mbox", + .data = &exynos850_mbox_data + }, {}, }; MODULE_DEVICE_TABLE(of, exynos_mbox_match); static int exynos_mbox_probe(struct platform_device *pdev) { + const struct exynos_mbox_driver_data *data; struct device *dev = &pdev->dev; struct exynos_mbox *exynos_mbox; struct mbox_controller *mbox; @@ -122,6 +170,11 @@ static int exynos_mbox_probe(struct platform_device *pdev) return dev_err_probe(dev, PTR_ERR(pclk), "Failed to enable clock.\n"); + data = device_get_match_data(&pdev->dev); + if (!data) + return -ENODEV; + + exynos_mbox->data = data; mbox->num_chans = EXYNOS_MBOX_CHAN_COUNT; mbox->chans = chans; mbox->dev = dev; @@ -133,7 +186,7 @@ static int exynos_mbox_probe(struct platform_device *pdev) platform_set_drvdata(pdev, exynos_mbox); /* Mask out all interrupts. We support just polling channels for now. */ - writel(EXYNOS_MBOX_INTMR0_MASK, exynos_mbox->regs + EXYNOS_MBOX_INTMR0); + writel(data->intmr_mask, exynos_mbox->regs + data->intmr); return devm_mbox_controller_register(dev, mbox); } -- 2.51.0 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox 2026-04-29 19:00 ` [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox Alexey Klimov @ 2026-04-30 11:01 ` Tudor Ambarus 0 siblings, 0 replies; 4+ messages in thread From: Tudor Ambarus @ 2026-04-30 11:01 UTC (permalink / raw) To: Alexey Klimov, Krzysztof Kozlowski, Sam Protsenko, Rob Herring, Conor Dooley, Jassi Brar, Alim Akhtar Cc: Krzysztof Kozlowski, Peter Griffin, linux-samsung-soc, linux-arm-kernel, devicetree, linux-kernel, Krzysztof Kozlowski, Juan Yescas Hi, Alexey, The abstraction is clean. Few comments below. On 4/29/26 10:00 PM, Alexey Klimov wrote: > Exynos850-based platforms support ACPM and has similar workflow > of communicating with ACPM via mailbox, however mailbox controller > registers are located at different offsets and writes/reads could be > different. To distinguish between such different behaviours, > the registers offsets for Exynos850 and the platform-specific data > structs are introduced and configuration is described in such structs > for gs101 and exynos850 based SoCs. Probe routine now selects the > corresponding platform-specific data via device_get_match_data(). > > Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@oss.qualcomm.com> > Signed-off-by: Alexey Klimov <alexey.klimov@linaro.org> > --- > drivers/mailbox/exynos-mailbox.c | 59 ++++++++++++++++++++++++++++++++++++++-- > 1 file changed, 56 insertions(+), 3 deletions(-) > > diff --git a/drivers/mailbox/exynos-mailbox.c b/drivers/mailbox/exynos-mailbox.c > index d2355b128ba4..11657dd475c0 100644 > --- a/drivers/mailbox/exynos-mailbox.c > +++ b/drivers/mailbox/exynos-mailbox.c > @@ -31,14 +31,52 @@ > > #define EXYNOS_MBOX_CHAN_COUNT HWEIGHT32(EXYNOS_MBOX_INTGR1_MASK) > > +#define EXYNOS850_MBOX_INTGR0 0x8 /* Interrupt Generation Register 0 */ > +#define EXYNOS850_MBOX_INTMR1 0x24 /* Interrupt Mask Register 1 */ > + > +#define EXYNOS850_MBOX_INTMR1_MASK GENMASK(15, 0) > + > +/** > + * struct exynos_mbox_driver_data - platform-specific mailbox configuration. > + * @intgr: offset to the IRQ generation register, doorbell > + * to APM co-processor. > + * @intgr_shift: shift to apply to the value written to IRQ generation > + * register. > + * @intmr: offset to the IRQ mask register. > + * @intmr_mask: value to write to the mask register to mask out all > + * interrupts. > + */ > +struct exynos_mbox_driver_data { > + u16 intgr; > + u16 intgr_shift; > + u16 intmr; > + u16 intmr_mask; > +}; using u16 for intmr_mask is slightly problematic. Down in the probe function, you pass it to writel(): writel(data->intmr_mask, exynos_mbox->regs + data->intmr); writel() explicitly expects a 32-bit (u32) value. While the compiler will implicitly promote the u16 to a 32-bit integer, memory-mapped I/O masks should generally match the width of the register being written to. If a future SoC requires a 32-bit mask (e.g., GENMASK(31, 0)), the u16 will silently truncate it. u32 for all fields is generally preferred in kernel platform data structs for padding/alignment reasons. > + > /** > * struct exynos_mbox - driver's private data. > * @regs: mailbox registers base address. > * @mbox: pointer to the mailbox controller. > + * @data: pointer to driver platform-specific data. > */ > struct exynos_mbox { > void __iomem *regs; > struct mbox_controller *mbox; > + const struct exynos_mbox_driver_data *data; > +}; > + > +static const struct exynos_mbox_driver_data exynos850_mbox_data = { > + .intgr = EXYNOS850_MBOX_INTGR0, > + .intgr_shift = 16, > + .intmr = EXYNOS850_MBOX_INTMR1, > + .intmr_mask = EXYNOS850_MBOX_INTMR1_MASK, > +}; > + > +static const struct exynos_mbox_driver_data exynos_gs101_mbox_data = { > + .intgr = EXYNOS_MBOX_INTGR1, > + .intgr_shift = 0, > + .intmr = EXYNOS_MBOX_INTMR0, > + .intmr_mask = EXYNOS_MBOX_INTMR0_MASK, > }; > > static int exynos_mbox_send_data(struct mbox_chan *chan, void *data) > @@ -57,7 +95,9 @@ static int exynos_mbox_send_data(struct mbox_chan *chan, void *data) > return -EINVAL; > } > > - writel(BIT(msg->chan_id), exynos_mbox->regs + EXYNOS_MBOX_INTGR1); > + /* Ring the doorbell */ > + writel(BIT(msg->chan_id) << exynos_mbox->data->intgr_shift, > + exynos_mbox->regs + exynos_mbox->data->intgr); > > return 0; > } > @@ -87,13 +127,21 @@ static struct mbox_chan *exynos_mbox_of_xlate(struct mbox_controller *mbox, > } > > static const struct of_device_id exynos_mbox_match[] = { > - { .compatible = "google,gs101-mbox" }, > + { > + .compatible = "google,gs101-mbox", > + .data = &exynos_gs101_mbox_data > + }, > + { > + .compatible = "samsung,exynos850-mbox", > + .data = &exynos850_mbox_data > + }, > {}, > }; > MODULE_DEVICE_TABLE(of, exynos_mbox_match); > > static int exynos_mbox_probe(struct platform_device *pdev) > { > + const struct exynos_mbox_driver_data *data; > struct device *dev = &pdev->dev; > struct exynos_mbox *exynos_mbox; > struct mbox_controller *mbox; > @@ -122,6 +170,11 @@ static int exynos_mbox_probe(struct platform_device *pdev) > return dev_err_probe(dev, PTR_ERR(pclk), > "Failed to enable clock.\n"); > > + data = device_get_match_data(&pdev->dev); > + if (!data) > + return -ENODEV; you shall move this first thing in probe() to avoid doing allocations gratuitously on null match data. > + > + exynos_mbox->data = data; > mbox->num_chans = EXYNOS_MBOX_CHAN_COUNT; EXYNOS_MBOX_CHAN_COUNT is globally defined as: #define EXYNOS_MBOX_CHAN_COUNT HWEIGHT32(EXYNOS_MBOX_INTGR1_MASK) Does the Exynos850 have the exact same number of channels as the GS101? You may move num_chans into struct exynos_mbox_driver_data alongside the register offsets so each SoC explicitly declares its channel capacity. Cheers, ta ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2026-04-30 11:01 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2026-04-29 19:00 [PATCH v3 0/2] Exynos850 AP-to-APM mailbox support Alexey Klimov 2026-04-29 19:00 ` [PATCH v3 1/2] dt-bindings: mailbox: google,gs101-mbox: Add samsung,exynos850-mbox Alexey Klimov 2026-04-29 19:00 ` [PATCH v3 2/2] mailbox: exynos: Add support for Exynos850 mailbox Alexey Klimov 2026-04-30 11:01 ` Tudor Ambarus
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox