From: Rain Yang <jiyu.yang@oss.nxp.com>
To: Marek Vasut <marek.vasut@mailbox.org>
Cc: Frank.Li@nxp.com, airlied@gmail.com,
alexander.stein@ew.tq-group.com, boris.brezillon@collabora.com,
conor+dt@kernel.org, devicetree@vger.kernel.org,
dri-devel@lists.freedesktop.org, festevam@gmail.com,
imx@lists.linux.dev, jiyu.yang@oss.nxp.com,
kernel@pengutronix.de, krzk+dt@kernel.org,
linux-arm-kernel@lists.infradead.org, liviu.dudau@arm.com,
maarten.lankhorst@linux.intel.com, mripard@kernel.org,
p.zabel@pengutronix.de, robh@kernel.org, s.hauer@pengutronix.de,
shawnguo@kernel.org, simona@ffwll.ch, sre@kernel.org,
steven.price@arm.com, tzimmermann@suse.de, xianzhong.li@nxp.com
Subject: Re: [PATCH v3 2/2] arm64: dts: imx95: Describe Mali G310 GPU
Date: Tue, 30 Sep 2025 00:20:57 +0800 [thread overview]
Message-ID: <aNqx6XrUGBgUJ-pF@oss.nxp.com> (raw)
In-Reply-To: <cc873c8b-435c-467f-b1e9-dc78ddbfb483@mailbox.org>
On Mon, Sep 29, 2025 at 03:09:01PM +0200, Marek Vasut wrote:
>On 9/29/25 11:57 AM, Rain Yang wrote:
>> On Mon, Sep 29, 2025 at 02:23:01AM +0200, Marek Vasut wrote:
>> > On 9/26/25 7:57 AM, Peng Fan wrote:
>> >
>> > Hello Peng,
>> >
>> > > On Thu, Sep 25, 2025 at 10:38:31PM +0200, Marek Vasut wrote:
>> > > > The instance of the GPU populated in i.MX95 is the G310, describe this
>> > > > GPU in the DT. Include dummy GPU voltage regulator and OPP tables.
>> > > >
>> > > >
>> > > > + gpu: gpu@4d900000 {
>> > > > + compatible = "nxp,imx95-mali", "arm,mali-valhall-csf";
>> > > > + reg = <0 0x4d900000 0 0x480000>;
>> > > > + clocks = <&scmi_clk IMX95_CLK_GPU>, <&scmi_clk IMX95_CLK_GPUAPB>;
>> > > > + clock-names = "core", "coregroup";
>> > > > + interrupts = <GIC_SPI 289 IRQ_TYPE_LEVEL_HIGH>,
>> > > > + <GIC_SPI 290 IRQ_TYPE_LEVEL_HIGH>,
>> > > > + <GIC_SPI 288 IRQ_TYPE_LEVEL_HIGH>;
>> > > > + interrupt-names = "job", "mmu", "gpu";
>> > > > + mali-supply = <&gpu_fixed_reg>;
>> > > > + operating-points-v2 = <&gpu_opp_table>;
>> > > > + power-domains = <&scmi_devpd IMX95_PD_GPU>;
>> > > > + #cooling-cells = <2>;
>> > > > + dynamic-power-coefficient = <1013>;
>> > >
>> > > Sorry for my ignorance, would you please share how to get the value?
>> > Copy-pasted from NXP downstream kernel fork DT bindings, see:
>> >
>> > https://github.com/nxp-imx/linux-imx.git
>> >
>> > 11495de7c24a ("MGS-7621-4 dts: gpu: update devfreq para")
>> Hi Marek,
>>
>> 1. this "mali: gpu@4d900000" label can be found in this commit you showed.
>> please correct this to be compatible with the downstream
>
>No, sorry, that's not how it works. Upstream is not being adjusted to match
>decisions made by downstream kernel forks unless there is a good rationale
>for such a change. "Downstream does this" is not a good one. (*)
>
>> and upstream kernel
>
>All of imx*.dts* use gpu: or gpu2d:/gpu3d:/vpuvg: for the GPU label.
>Also, variants of gpu: label seems more popular:
>
>linux$ grep -hro '[a-z0-9_]\+: gpu@' arch/ | sort | uniq -c
> 3 adreno_gpu: gpu@
> 1 bb2d: gpu@
> 1 gpu2d: gpu@
> 1 gpu3d: gpu@
> 80 gpu: gpu@
> 4 gpu_2d: gpu@
> 1 gpu_3d0: gpu@
> 4 gpu_3d: gpu@
> 6 gpu_mem: gpu@
> 1 gpu_reserved: gpu@
> 2 gpu_vg: gpu@
> 17 mali: gpu@
> 1 v3d: gpu@
> 2 zap_shader_region: gpu@
>
Existence does not necessarily imply validity. Since a single SoC may contain
multiple GPUs, it's generally better to use the specific GPU name as a label
rather than simply using 'gpu', to avoid potential conflicts.
>> 2. the compatible string is different from our downstream kernel,
>
>See above (*)
Additionally, there are still some performance differences between the upstream
driver and the Mali property driver. If compatibility with both can be achieved,
it would allow users to choose the driver that best suits their needs.
Personally, I find it convenient to switch between the two drivers using insmod
and rmmod, which allows for quick testing and comparison.
>
>> also you dropped the "nxp,imx95-mali" compatible patch in the panthor
>> driver, why?
>
>Because it is unnecessary, the generic compatible string is sufficient for
>the in-tree kernel driver.
>
>> this will impact the mali property driver too, which
>> has already been used in many customer project.
>
>See above (*)
>
>All the more reason to focus on upstream and avoid deployment of various
>downstream components, blobs and so on. They cannot be maintained in the long
>run, they break, and cause all kinds of maintenance problems.
>
>Upstream cannot be hindered by downstream blobs and their issues, sorry.
>
>> 3. the number of frequency in opp-table is only one, but there are two clocks
>> in clocks property, this really make people confused.
>> CLK/CLK_COREGROUP/CLK_STACK in i.MX95 are from the same source
>> <&scmi_clk IMX95_CLK_GPU>, the other clock <&scmi_clk IMX95_CLK_GPUAPB>
>> is always-on APB clock, which can't be changed by A-cores, and has been removed
>> from clocks property in the latest release.
>
>Can the APB clock be enabled/disabled from Linux, e.g. to save power ?
please note that the APB clock can't be turned off on the A-core.
next prev parent reply other threads:[~2025-09-29 16:20 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-25 20:38 [PATCH v3 1/2] dt-bindings: gpu: mali-valhall-csf: Document i.MX95 support Marek Vasut
2025-09-25 20:38 ` [PATCH v3 2/2] arm64: dts: imx95: Describe Mali G310 GPU Marek Vasut
2025-09-25 21:34 ` Frank Li
2025-09-26 5:57 ` Peng Fan
2025-09-29 0:23 ` Marek Vasut
2025-09-29 9:57 ` Rain Yang
2025-09-29 13:09 ` Marek Vasut
2025-09-29 16:20 ` Rain Yang [this message]
2025-09-29 17:10 ` Marek Vasut
2025-10-11 10:53 ` Marek Vasut
2025-10-27 0:57 ` Shawn Guo
2025-10-28 8:21 ` Rain Yang
2025-10-28 9:08 ` Shawn Guo
2025-11-02 16:02 ` Marek Vasut
2025-11-03 7:46 ` Rain Yang
2025-11-03 23:47 ` Marek Vasut
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=aNqx6XrUGBgUJ-pF@oss.nxp.com \
--to=jiyu.yang@oss.nxp.com \
--cc=Frank.Li@nxp.com \
--cc=airlied@gmail.com \
--cc=alexander.stein@ew.tq-group.com \
--cc=boris.brezillon@collabora.com \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dri-devel@lists.freedesktop.org \
--cc=festevam@gmail.com \
--cc=imx@lists.linux.dev \
--cc=kernel@pengutronix.de \
--cc=krzk+dt@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=liviu.dudau@arm.com \
--cc=maarten.lankhorst@linux.intel.com \
--cc=marek.vasut@mailbox.org \
--cc=mripard@kernel.org \
--cc=p.zabel@pengutronix.de \
--cc=robh@kernel.org \
--cc=s.hauer@pengutronix.de \
--cc=shawnguo@kernel.org \
--cc=simona@ffwll.ch \
--cc=sre@kernel.org \
--cc=steven.price@arm.com \
--cc=tzimmermann@suse.de \
--cc=xianzhong.li@nxp.com \
/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).