Message ID | 20241229152332.3068172-1-quic_wasimn@quicinc.com |
---|---|
Headers | show |
Series | arm64: qcom: Add support for QCS9075 boards | expand |
On 12/29/2024 11:23 PM, Wasim Nazir wrote: > From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and [...] > Add cpu frequency cooling devices that will be used by userspace > thermal governor to mitigate skin thermal management. > > Signed-off-by: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> Also need to add SOB from the patch handler(Wasim). Doc can reference [1]. snippets: - Signed-off-by: ``Patch handler <handler@mail>`` SOBs after the author SOB are from people handling and transporting the patch, but were not involved in development. SOB chains should reflect the **real** route a patch took as it was propagated to us, with the first SOB entry signalling primary authorship of a single author. https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/Documentation/process/maintainer-tip.rst [1] > --- > arch/arm64/boot/dts/qcom/qcs9075-rb8.dts | 1 + > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 1 + [...] > > #include "sa8775p-ride.dtsi" > +#include "qcs9075-thermal.dtsi" Thermal nodes are usually added by soc.dtsi chips like sa8775p.dtsi.
On 29.12.2024 4:23 PM, Wasim Nazir wrote: > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > subsystem which is available in QCS9100, and it affects thermal > management. > > Also, between ride and ride-r3 ethernet phy is different. > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > --- + Andrew IIUC we have a similar case to https://lore.kernel.org/linux-arm-msm/cbd696c0-3b25-438b-a279-a4263308323a@lunn.ch/ here in the first file changed, please see below and let me know if the rest makes sense for the networking part Konrad > arch/arm64/boot/dts/qcom/Makefile | 2 + > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > 3 files changed, 94 insertions(+) > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > index 78613a1bd34a..41cb2bbd3472 100644 > --- a/arch/arm64/boot/dts/qcom/Makefile > +++ b/arch/arm64/boot/dts/qcom/Makefile > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > new file mode 100644 > index 000000000000..d9a8956d3a76 > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > @@ -0,0 +1,46 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > + */ > +/dts-v1/; > + > +#include "sa8775p-ride.dtsi" > + > +/ { > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > +}; > + > +ðernet0 { > + phy-mode = "2500base-x"; > +}; > + > +ðernet1 { > + phy-mode = "2500base-x"; > +}; > + > +&mdio { > + compatible = "snps,dwmac-mdio"; > + #address-cells = <1>; > + #size-cells = <0>; > + > + sgmii_phy0: phy@8 { > + compatible = "ethernet-phy-id31c3.1c33"; > + reg = <0x8>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > + > + sgmii_phy1: phy@0 { > + compatible = "ethernet-phy-id31c3.1c33"; > + reg = <0x0>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > +}; > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > new file mode 100644 > index 000000000000..3b524359a72d > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > @@ -0,0 +1,46 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > + */ > +/dts-v1/; > + > +#include "sa8775p-ride.dtsi" > + > +/ { > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > +}; > + > +ðernet0 { > + phy-mode = "sgmii"; > +}; > + > +ðernet1 { > + phy-mode = "sgmii"; > +}; > + > +&mdio { > + compatible = "snps,dwmac-mdio"; > + #address-cells = <1>; > + #size-cells = <0>; > + > + sgmii_phy0: phy@8 { > + compatible = "ethernet-phy-id0141.0dd4"; > + reg = <0x8>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > + > + sgmii_phy1: phy@a { > + compatible = "ethernet-phy-id0141.0dd4"; > + reg = <0xa>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > +}; > -- > 2.47.0 >
On 29.12.2024 4:23 PM, Wasim Nazir wrote: > From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > does corrective action for each subsystem based on sensor violation > to comply safety standards. But as QCS9075 is non-safe SoC it > requires conventional thermal mitigation to control thermal for > different subsystems. > > The cpu frequency throttling for different cpu tsens is enabled in > hardware as first defense for cpu thermal control. But QCS9075 SoC > has higher ambient specification. During high ambient condition, even > lowest frequency with multi cores can slowly build heat over the time > and it can lead to thermal run-away situations. This patch restrict > cpu cores during this scenario helps further thermal control and > avoids thermal critical violation. > > Add cpu idle injection cooling bindings for cpu tsens thermal zones > as a mitigation for cpu subsystem prior to thermal shutdown. > > Add cpu frequency cooling devices that will be used by userspace > thermal governor to mitigate skin thermal management. > > Signed-off-by: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > --- Does this bring measurable benefits over just making the CPU a cooling device and pointing the thermal zones to it (and not the idle subnode)? Konrad
On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: > From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > does corrective action for each subsystem based on sensor violation > to comply safety standards. But as QCS9075 is non-safe SoC it > requires conventional thermal mitigation to control thermal for > different subsystems. > > The cpu frequency throttling for different cpu tsens is enabled in > hardware as first defense for cpu thermal control. But QCS9075 SoC > has higher ambient specification. During high ambient condition, even > lowest frequency with multi cores can slowly build heat over the time > and it can lead to thermal run-away situations. This patch restrict > cpu cores during this scenario helps further thermal control and > avoids thermal critical violation. > > Add cpu idle injection cooling bindings for cpu tsens thermal zones > as a mitigation for cpu subsystem prior to thermal shutdown. > > Add cpu frequency cooling devices that will be used by userspace > thermal governor to mitigate skin thermal management. Does anything prevent us from having this config as a part of the basic sa8775p.dtsi setup? If HW is present in the base version but it is not accessible for whatever reason, please move it the base device config and use status "disabled" or "reserved" to the respective board files. > > Signed-off-by: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > --- > arch/arm64/boot/dts/qcom/qcs9075-rb8.dts | 1 + > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 1 + > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 1 + > arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi | 287 ++++++++++++++++++ > 4 files changed, 290 insertions(+) > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-rb8.dts b/arch/arm64/boot/dts/qcom/qcs9075-rb8.dts > index ecaa383b6508..3ab6deeaacf1 100644 > --- a/arch/arm64/boot/dts/qcom/qcs9075-rb8.dts > +++ b/arch/arm64/boot/dts/qcom/qcs9075-rb8.dts > @@ -9,6 +9,7 @@ > > #include "sa8775p.dtsi" > #include "sa8775p-pmics.dtsi" > +#include "qcs9075-thermal.dtsi" > > / { > model = "Qualcomm Technologies, Inc. Robotics RB8"; > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > index d9a8956d3a76..5f2d9f416617 100644 > --- a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > @@ -5,6 +5,7 @@ > /dts-v1/; > > #include "sa8775p-ride.dtsi" > +#include "qcs9075-thermal.dtsi" > > / { > model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > index 3b524359a72d..10ce48e7ba2f 100644 > --- a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > @@ -5,6 +5,7 @@ > /dts-v1/; > > #include "sa8775p-ride.dtsi" > +#include "qcs9075-thermal.dtsi" > > / { > model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi b/arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi > new file mode 100644 > index 000000000000..40544c8582c4 > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi > @@ -0,0 +1,287 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2024 Qualcomm Innovation Center, Inc. All rights reserved. > + */ > + > +#include <dt-bindings/thermal/thermal.h> > + > +&cpu0 { > + #cooling-cells = <2>; > +}; > + > +&cpu1 { > + #cooling-cells = <2>; > + cpu1_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu2 { > + #cooling-cells = <2>; > + cpu2_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu3 { > + #cooling-cells = <2>; > + cpu3_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu4 { > + #cooling-cells = <2>; > + cpu4_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu5 { > + #cooling-cells = <2>; > + cpu5_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu6 { > + #cooling-cells = <2>; > + cpu6_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +&cpu7 { > + #cooling-cells = <2>; > + cpu7_idle: thermal-idle { > + #cooling-cells = <2>; > + duration-us = <800000>; > + exit-latency-us = <10000>; > + }; > +}; > + > +/ { > + thermal-zones { > + cpu-0-1-0-thermal { > + trips { > + cpu_0_1_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_1_0_passive>; > + cooling-device = <&cpu1_idle 100 100>; > + }; > + }; > + }; > + > + cpu-0-2-0-thermal { > + trips { > + cpu_0_2_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_2_0_passive>; > + cooling-device = <&cpu2_idle 100 100>; > + }; > + }; > + }; > + > + cpu-0-3-0-thermal { > + trips { > + cpu_0_3_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_3_0_passive>; > + cooling-device = <&cpu3_idle 100 100>; > + }; > + }; > + }; > + > + cpu-0-1-1-thermal { > + trips { > + cpu_0_1_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_1_1_passive>; > + cooling-device = <&cpu1_idle 100 100>; > + }; > + }; > + }; > + > + cpu-0-2-1-thermal { > + trips { > + cpu_0_2_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_2_1_passive>; > + cooling-device = <&cpu2_idle 100 100>; > + }; > + }; > + }; > + > + cpu-0-3-1-thermal { > + trips { > + cpu_0_3_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_0_3_1_passive>; > + cooling-device = <&cpu3_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-0-0-thermal { > + trips { > + cpu_1_0_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_0_0_passive>; > + cooling-device = <&cpu4_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-1-0-thermal { > + trips { > + cpu_1_1_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_1_0_passive>; > + cooling-device = <&cpu5_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-2-0-thermal { > + trips { > + cpu_1_2_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_2_0_passive>; > + cooling-device = <&cpu6_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-3-0-thermal { > + trips { > + cpu_1_3_0_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_3_0_passive>; > + cooling-device = <&cpu7_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-0-1-thermal { > + trips { > + cpu_1_0_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_0_1_passive>; > + cooling-device = <&cpu4_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-1-1-thermal { > + trips { > + cpu_1_1_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_1_1_passive>; > + cooling-device = <&cpu5_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-2-1-thermal { > + trips { > + cpu_1_2_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_2_1_passive>; > + cooling-device = <&cpu6_idle 100 100>; > + }; > + }; > + }; > + > + cpu-1-3-1-thermal { > + trips { > + cpu_1_3_1_passive: trip-point1 { > + temperature = <116000>; > + }; > + }; > + > + cooling-maps { > + map0 { > + trip = <&cpu_1_3_1_passive>; > + cooling-device = <&cpu7_idle 100 100>; > + }; > + }; > + }; > + }; > +}; > -- > 2.47.0 >
On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > subsystem which is available in QCS9100, and it affects thermal > management. > > Also, between ride and ride-r3 ethernet phy is different. > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just include corresponding SA8775P files. This is not ideal for the following reasons: - The approach is not uniform (between QCS9100 and QCS9075), which might lead to mistakes. - The approach ends up duplicating DT code unnecessarily, which can lead to issues being patches in the one board file, but not in the other file. If there are any reasons why you want to follow this approach, they must be a part of the commit message. > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > --- > arch/arm64/boot/dts/qcom/Makefile | 2 + > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > 3 files changed, 94 insertions(+) > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > index 78613a1bd34a..41cb2bbd3472 100644 > --- a/arch/arm64/boot/dts/qcom/Makefile > +++ b/arch/arm64/boot/dts/qcom/Makefile > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > new file mode 100644 > index 000000000000..d9a8956d3a76 > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > @@ -0,0 +1,46 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > + */ > +/dts-v1/; > + > +#include "sa8775p-ride.dtsi" > + > +/ { > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > +}; > + > +ðernet0 { > + phy-mode = "2500base-x"; > +}; > + > +ðernet1 { > + phy-mode = "2500base-x"; > +}; > + > +&mdio { > + compatible = "snps,dwmac-mdio"; > + #address-cells = <1>; > + #size-cells = <0>; > + > + sgmii_phy0: phy@8 { > + compatible = "ethernet-phy-id31c3.1c33"; > + reg = <0x8>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > + > + sgmii_phy1: phy@0 { > + compatible = "ethernet-phy-id31c3.1c33"; > + reg = <0x0>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > +}; > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > new file mode 100644 > index 000000000000..3b524359a72d > --- /dev/null > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > @@ -0,0 +1,46 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > + */ > +/dts-v1/; > + > +#include "sa8775p-ride.dtsi" > + > +/ { > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > +}; > + > +ðernet0 { > + phy-mode = "sgmii"; > +}; > + > +ðernet1 { > + phy-mode = "sgmii"; > +}; > + > +&mdio { > + compatible = "snps,dwmac-mdio"; > + #address-cells = <1>; > + #size-cells = <0>; > + > + sgmii_phy0: phy@8 { > + compatible = "ethernet-phy-id0141.0dd4"; > + reg = <0x8>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > + > + sgmii_phy1: phy@a { > + compatible = "ethernet-phy-id0141.0dd4"; > + reg = <0xa>; > + device_type = "ethernet-phy"; > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > + reset-assert-us = <11000>; > + reset-deassert-us = <70000>; > + }; > +}; > -- > 2.47.0 >
On Sun, 29 Dec 2024 20:53:26 +0530, Wasim Nazir wrote: > This series: > > Add support for Qualcomm's rb8, ride/ride-r3 boards using QCS9075 SoC. > > QCS9075 is compatible IoT-industrial grade variant of SA8775p SoC. > Unlike QCS9100, it doesn't have safety monitoring feature of > Safety-Island(SAIL) subsystem, which affects thermal management. > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > does corrective action for each subsystem based on sensor violation > to comply safety standards. But as QCS9075 is non-safe SoC it requires > conventional thermal mitigation for thermal management. > > Difference between Ride & ride-r3 boards is ethernet phy, > ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > This series depends on [1] for thermal functionality to work. > > [1]: https://lore.kernel.org/all/20241112-sa8775p_cpuidle-v1-1-66ff3ba72464@quicinc.com/ > > --- > Changelog: > > v5: > - Remove defconfig patch as the config is product specific. > - v4: https://lore.kernel.org/all/20241217064856.2772305-1-quic_wasimn@quicinc.com/ > > v4: > - Replace dts to dtsi in Ride/Ride-r3 platform files. > - Add thermal patch to differentiate between 9100 vs 9075. > - Add proper abbreviation and update commit for 9100 vs 9075. > - v3: https://lore.kernel.org/all/20241119174954.1219002-1-quic_wasimn@quicinc.com/ > > v3: > - Fix RB8 board compatible string. > - v2: https://lore.kernel.org/all/20241115225152.3264396-1-quic_wasimn@quicinc.com/ > > v2: > - Remove unused dp nodes & update commit for ride vs ride-r3. > - v1: https://lore.kernel.org/all/20241110145339.3635437-1-quic_wasimn@quicinc.com/ > > Manaf Meethalavalappu Pallikunhi (1): > arm64: dts: qcom: Enable cpu cooling devices for QCS9075 platforms > > Wasim Nazir (5): > dt-bindings: arm: qcom,ids: add SoC ID for QCS9075 > soc: qcom: socinfo: add QCS9075 SoC ID > dt-bindings: arm: qcom: Document rb8/ride/ride-r3 on QCS9075 > arm64: dts: qcom: Add support for QCS9075 RB8 > arm64: dts: qcom: Add support for QCS9075 Ride & Ride-r3 > > .../devicetree/bindings/arm/qcom.yaml | 9 + > arch/arm64/boot/dts/qcom/Makefile | 3 + > arch/arm64/boot/dts/qcom/qcs9075-rb8.dts | 282 +++++++++++++++++ > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 47 +++ > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 47 +++ > arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi | 287 ++++++++++++++++++ > drivers/soc/qcom/socinfo.c | 1 + > include/dt-bindings/arm/qcom,ids.h | 1 + > 8 files changed, 677 insertions(+) > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-rb8.dts > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-thermal.dtsi > > > base-commit: 8155b4ef3466f0e289e8fcc9e6e62f3f4dceeac2 > -- > 2.47.0 > > > My bot found new DTB warnings on the .dts files added or changed in this series. Some warnings may be from an existing SoC .dtsi. Or perhaps the warnings are fixed by another series. Ultimately, it is up to the platform maintainer whether these warnings are acceptable or not. No need to reply unless the platform maintainer has comments. If you already ran DT checks and didn't see these error(s), then make sure dt-schema is up to date: pip3 install dtschema --upgrade New warnings running 'make CHECK_DTBS=y qcom/qcs9075-rb8.dtb qcom/qcs9075-ride-r3.dtb qcom/qcs9075-ride.dtb' for 20241229152332.3068172-1-quic_wasimn@quicinc.com: arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: qcom,gpi-dma@800000: $nodename:0: 'qcom,gpi-dma@800000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: qcom,gpi-dma@800000: $nodename:0: 'qcom,gpi-dma@800000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: qcom,gpi-dma@800000: $nodename:0: 'qcom,gpi-dma@800000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: bluetooth: 'vddwlcx-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: bluetooth: 'vddwlmx-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: bluetooth: 'vddrfa1p8-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: bluetooth: 'vddwlcx-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: bluetooth: 'vddwlmx-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: bluetooth: 'vddrfa1p8-supply' is a required property from schema $id: http://devicetree.org/schemas/net/bluetooth/qualcomm-bluetooth.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: qcom,gpi-dma@900000: $nodename:0: 'qcom,gpi-dma@900000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: qcom,gpi-dma@900000: $nodename:0: 'qcom,gpi-dma@900000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: qcom,gpi-dma@900000: $nodename:0: 'qcom,gpi-dma@900000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: qcom,gpi-dma@a00000: $nodename:0: 'qcom,gpi-dma@a00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: qcom,gpi-dma@a00000: $nodename:0: 'qcom,gpi-dma@a00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: qcom,gpi-dma@a00000: $nodename:0: 'qcom,gpi-dma@a00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: qcom,gpi-dma@b00000: $nodename:0: 'qcom,gpi-dma@b00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: qcom,gpi-dma@b00000: $nodename:0: 'qcom,gpi-dma@b00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: qcom,gpi-dma@b00000: $nodename:0: 'qcom,gpi-dma@b00000' does not match '^dma-controller(@.*)?$' from schema $id: http://devicetree.org/schemas/dma/qcom,gpi.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: crypto@1dfa000: compatible: 'oneOf' conditional failed, one must be fixed: ['qcom,sa8775p-qce', 'qcom,qce'] is too long ['qcom,sa8775p-qce', 'qcom,qce'] is too short 'qcom,crypto-v5.1' was expected 'qcom,crypto-v5.4' was expected 'qcom,sa8775p-qce' is not one of ['qcom,ipq4019-qce', 'qcom,sm8150-qce'] 'qcom,sa8775p-qce' is not one of ['qcom,ipq6018-qce', 'qcom,ipq8074-qce', 'qcom,ipq9574-qce', 'qcom,msm8996-qce', 'qcom,qcm2290-qce', 'qcom,sdm845-qce', 'qcom,sm6115-qce'] 'qcom,ipq4019-qce' was expected 'qcom,sm8150-qce' was expected from schema $id: http://devicetree.org/schemas/crypto/qcom-qce.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: crypto@1dfa000: compatible: 'oneOf' conditional failed, one must be fixed: ['qcom,sa8775p-qce', 'qcom,qce'] is too long ['qcom,sa8775p-qce', 'qcom,qce'] is too short 'qcom,crypto-v5.1' was expected 'qcom,crypto-v5.4' was expected 'qcom,sa8775p-qce' is not one of ['qcom,ipq4019-qce', 'qcom,sm8150-qce'] 'qcom,sa8775p-qce' is not one of ['qcom,ipq6018-qce', 'qcom,ipq8074-qce', 'qcom,ipq9574-qce', 'qcom,msm8996-qce', 'qcom,qcm2290-qce', 'qcom,sdm845-qce', 'qcom,sm6115-qce'] 'qcom,ipq4019-qce' was expected 'qcom,sm8150-qce' was expected from schema $id: http://devicetree.org/schemas/crypto/qcom-qce.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: crypto@1dfa000: compatible: 'oneOf' conditional failed, one must be fixed: ['qcom,sa8775p-qce', 'qcom,qce'] is too long ['qcom,sa8775p-qce', 'qcom,qce'] is too short 'qcom,crypto-v5.1' was expected 'qcom,crypto-v5.4' was expected 'qcom,sa8775p-qce' is not one of ['qcom,ipq4019-qce', 'qcom,sm8150-qce'] 'qcom,sa8775p-qce' is not one of ['qcom,ipq6018-qce', 'qcom,ipq8074-qce', 'qcom,ipq9574-qce', 'qcom,msm8996-qce', 'qcom,qcm2290-qce', 'qcom,sdm845-qce', 'qcom,sm6115-qce'] 'qcom,ipq4019-qce' was expected 'qcom,sm8150-qce' was expected from schema $id: http://devicetree.org/schemas/crypto/qcom-qce.yaml# arch/arm64/boot/dts/qcom/qcs9075-rb8.dtb: rsc@18200000: 'power-domains' is a required property from schema $id: http://devicetree.org/schemas/soc/qcom/qcom,rpmh-rsc.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: rsc@18200000: 'power-domains' is a required property from schema $id: http://devicetree.org/schemas/soc/qcom/qcom,rpmh-rsc.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: rsc@18200000: 'power-domains' is a required property from schema $id: http://devicetree.org/schemas/soc/qcom/qcom,rpmh-rsc.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: ethernet@23000000: tx-queues-config: 'snps,tx-sched-sp' does not match any of the regexes: '^queue[0-9]$', 'pinctrl-[0-9]+' from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: ethernet@23000000: Unevaluated properties are not allowed ('interconnect-names', 'interconnects', 'phy-handle', 'phy-mode', 'power-domains', 'rx-fifo-depth', 'rx-queues-config', 'snps,mtl-rx-config', 'snps,mtl-tx-config', 'snps,pbl', 'snps,ps-speed', 'snps,tso', 'tx-fifo-depth', 'tx-queues-config' were unexpected) from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: ethernet@23000000: tx-queues-config: 'snps,tx-sched-sp' does not match any of the regexes: '^queue[0-9]$', 'pinctrl-[0-9]+' from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: ethernet@23000000: Unevaluated properties are not allowed ('interconnect-names', 'interconnects', 'phy-handle', 'phy-mode', 'power-domains', 'rx-fifo-depth', 'rx-queues-config', 'snps,mtl-rx-config', 'snps,mtl-tx-config', 'snps,pbl', 'snps,ps-speed', 'snps,tso', 'tx-fifo-depth', 'tx-queues-config' were unexpected) from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: ethernet@23040000: tx-queues-config: 'snps,tx-sched-sp' does not match any of the regexes: '^queue[0-9]$', 'pinctrl-[0-9]+' from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: ethernet@23040000: Unevaluated properties are not allowed ('interconnect-names', 'interconnects', 'mdio', 'phy-handle', 'phy-mode', 'power-domains', 'rx-fifo-depth', 'rx-queues-config', 'snps,mtl-rx-config', 'snps,mtl-tx-config', 'snps,pbl', 'snps,ps-speed', 'snps,tso', 'tx-fifo-depth', 'tx-queues-config' were unexpected) from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: ethernet@23040000: tx-queues-config: 'snps,tx-sched-sp' does not match any of the regexes: '^queue[0-9]$', 'pinctrl-[0-9]+' from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: ethernet@23040000: Unevaluated properties are not allowed ('interconnect-names', 'interconnects', 'mdio', 'phy-handle', 'phy-mode', 'power-domains', 'rx-fifo-depth', 'rx-queues-config', 'snps,mtl-rx-config', 'snps,mtl-tx-config', 'snps,pbl', 'snps,ps-speed', 'snps,tso', 'tx-fifo-depth', 'tx-queues-config' were unexpected) from schema $id: http://devicetree.org/schemas/net/qcom,ethqos.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: wcn6855-pmu: 'vddpmumx-supply' is a required property from schema $id: http://devicetree.org/schemas/regulator/qcom,qca6390-pmu.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dtb: wcn6855-pmu: 'vddpmucx-supply' is a required property from schema $id: http://devicetree.org/schemas/regulator/qcom,qca6390-pmu.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: wcn6855-pmu: 'vddpmumx-supply' is a required property from schema $id: http://devicetree.org/schemas/regulator/qcom,qca6390-pmu.yaml# arch/arm64/boot/dts/qcom/qcs9075-ride.dtb: wcn6855-pmu: 'vddpmucx-supply' is a required property from schema $id: http://devicetree.org/schemas/regulator/qcom,qca6390-pmu.yaml#
> > +ðernet0 { > > + phy-mode = "2500base-x"; > > +}; > > + > > +ðernet1 { > > + phy-mode = "2500base-x"; > > +}; > > + > > +&mdio { > > + compatible = "snps,dwmac-mdio"; > > + #address-cells = <1>; > > + #size-cells = <0>; > > + > > + sgmii_phy0: phy@8 { > > + compatible = "ethernet-phy-id31c3.1c33"; > > + reg = <0x8>; > > + device_type = "ethernet-phy"; > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > + reset-assert-us = <11000>; > > + reset-deassert-us = <70000>; > > + }; > > + > > + sgmii_phy1: phy@0 { SGMII is 10/100/1000. You have a phy-mode of 2500base-x, which is only 2500. So calling this sgmii_phy is wrong. Just call it phy1: phy@0. Andrew
On 31.12.2024 12:05 PM, Manaf Meethalavalappu Pallikunhi wrote: > > Hi Konrad, > > On 12/30/2024 9:05 PM, Konrad Dybcio wrote: >> On 29.12.2024 4:23 PM, Wasim Nazir wrote: >>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>> >>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and >>> does corrective action for each subsystem based on sensor violation >>> to comply safety standards. But as QCS9075 is non-safe SoC it >>> requires conventional thermal mitigation to control thermal for >>> different subsystems. >>> >>> The cpu frequency throttling for different cpu tsens is enabled in >>> hardware as first defense for cpu thermal control. But QCS9075 SoC >>> has higher ambient specification. During high ambient condition, even >>> lowest frequency with multi cores can slowly build heat over the time >>> and it can lead to thermal run-away situations. This patch restrict >>> cpu cores during this scenario helps further thermal control and >>> avoids thermal critical violation. >>> >>> Add cpu idle injection cooling bindings for cpu tsens thermal zones >>> as a mitigation for cpu subsystem prior to thermal shutdown. >>> >>> Add cpu frequency cooling devices that will be used by userspace >>> thermal governor to mitigate skin thermal management. >>> >>> Signed-off-by: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>> --- >> Does this bring measurable benefits over just making the CPU a cooling >> device and pointing the thermal zones to it (and not the idle subnode)? >> >> Konrad > As noted in the commit, CPU frequency mitigation is handled by hardware as a first level mitigation. The software/scheduler will be updated via arch_update_hw_pressure API [1] for this mitigation. Adding the same CPU mitigation in thermal zones is redundant. We are adding idle injection with a 100% duty cycle as an additional mitigation step at higher trip to further reduce CPU power consumption. This helps device thermal stability further, especially in high ambient conditions. I understood this much from the commit message. What I'm asking is, whether your solution actually works better than just letting Linux software-throttle the CPUs, preferably backed by some numbers. I'm also unsure how this is supposed to reduce power consumption. If the CPUs aren't busy, they should idle, and if they are not fully utilized, a lower frequency would likely be scheduled. Konrad > > [1]. https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git/tree/drivers/cpufreq/qcom-cpufreq-hw.c?h=next-20241220#n352 > > Best regards, > > Manaf >
On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > subsystem which is available in QCS9100, and it affects thermal > > management. > > > > Also, between ride and ride-r3 ethernet phy is different. > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > include corresponding SA8775P files. > > This is not ideal for the following reasons: > - The approach is not uniform (between QCS9100 and QCS9075), which might > lead to mistakes. > - The approach ends up duplicating DT code unnecessarily, which can lead > to issues being patches in the one board file, but not in the other > file. > > If there are any reasons why you want to follow this approach, they must > be a part of the commit message. > Hi Dmitry, Initially, we included the DTS [1] file to avoid duplication. However, based on Krzysztof's previous suggestion [2], we change to this format. Please let us know how to proceed further on this. [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > --- > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > 3 files changed, 94 insertions(+) > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > index 78613a1bd34a..41cb2bbd3472 100644 > > --- a/arch/arm64/boot/dts/qcom/Makefile > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > new file mode 100644 > > index 000000000000..d9a8956d3a76 > > --- /dev/null > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > @@ -0,0 +1,46 @@ > > +// SPDX-License-Identifier: BSD-3-Clause > > +/* > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > + */ > > +/dts-v1/; > > + > > +#include "sa8775p-ride.dtsi" > > + > > +/ { > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > +}; > > + > > +ðernet0 { > > + phy-mode = "2500base-x"; > > +}; > > + > > +ðernet1 { > > + phy-mode = "2500base-x"; > > +}; > > + > > +&mdio { > > + compatible = "snps,dwmac-mdio"; > > + #address-cells = <1>; > > + #size-cells = <0>; > > + > > + sgmii_phy0: phy@8 { > > + compatible = "ethernet-phy-id31c3.1c33"; > > + reg = <0x8>; > > + device_type = "ethernet-phy"; > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > + reset-assert-us = <11000>; > > + reset-deassert-us = <70000>; > > + }; > > + > > + sgmii_phy1: phy@0 { > > + compatible = "ethernet-phy-id31c3.1c33"; > > + reg = <0x0>; > > + device_type = "ethernet-phy"; > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > + reset-assert-us = <11000>; > > + reset-deassert-us = <70000>; > > + }; > > +}; > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > new file mode 100644 > > index 000000000000..3b524359a72d > > --- /dev/null > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > @@ -0,0 +1,46 @@ > > +// SPDX-License-Identifier: BSD-3-Clause > > +/* > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > + */ > > +/dts-v1/; > > + > > +#include "sa8775p-ride.dtsi" > > + > > +/ { > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > +}; > > + > > +ðernet0 { > > + phy-mode = "sgmii"; > > +}; > > + > > +ðernet1 { > > + phy-mode = "sgmii"; > > +}; > > + > > +&mdio { > > + compatible = "snps,dwmac-mdio"; > > + #address-cells = <1>; > > + #size-cells = <0>; > > + > > + sgmii_phy0: phy@8 { > > + compatible = "ethernet-phy-id0141.0dd4"; > > + reg = <0x8>; > > + device_type = "ethernet-phy"; > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > + reset-assert-us = <11000>; > > + reset-deassert-us = <70000>; > > + }; > > + > > + sgmii_phy1: phy@a { > > + compatible = "ethernet-phy-id0141.0dd4"; > > + reg = <0xa>; > > + device_type = "ethernet-phy"; > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > + reset-assert-us = <11000>; > > + reset-deassert-us = <70000>; > > + }; > > +}; > > -- > > 2.47.0 > > > > -- > With best wishes > Dmitry Thanks & Regards, Wasim
On Tue, Dec 31, 2024 at 06:10:15AM +0100, Andrew Lunn wrote: > > > +ðernet0 { > > > + phy-mode = "2500base-x"; > > > +}; > > > + > > > +ðernet1 { > > > + phy-mode = "2500base-x"; > > > +}; > > > + > > > +&mdio { > > > + compatible = "snps,dwmac-mdio"; > > > + #address-cells = <1>; > > > + #size-cells = <0>; > > > + > > > + sgmii_phy0: phy@8 { > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > + reg = <0x8>; > > > + device_type = "ethernet-phy"; > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > + reset-assert-us = <11000>; > > > + reset-deassert-us = <70000>; > > > + }; > > > + > > > + sgmii_phy1: phy@0 { > > SGMII is 10/100/1000. You have a phy-mode of 2500base-x, which is only > 2500. So calling this sgmii_phy is wrong. Just call it phy1: phy@0. > Thanks Konrad/Andrew will fix this in next patch. Regards, Wasim
On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > subsystem which is available in QCS9100, and it affects thermal > > > management. > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > include corresponding SA8775P files. > > > > This is not ideal for the following reasons: > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > lead to mistakes. > > - The approach ends up duplicating DT code unnecessarily, which can lead > > to issues being patches in the one board file, but not in the other > > file. > > > > If there are any reasons why you want to follow this approach, they must > > be a part of the commit message. > > > > Hi Dmitry, > > Initially, we included the DTS [1] file to avoid duplication. However, > based on Krzysztof's previous suggestion [2], we change to this format. > > Please let us know how to proceed further on this. Krzysztof asked you to include DTSI files instead of including DTS files. Hope this helps. > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > --- > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > 3 files changed, 94 insertions(+) > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > new file mode 100644 > > > index 000000000000..d9a8956d3a76 > > > --- /dev/null > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > @@ -0,0 +1,46 @@ > > > +// SPDX-License-Identifier: BSD-3-Clause > > > +/* > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > + */ > > > +/dts-v1/; > > > + > > > +#include "sa8775p-ride.dtsi" > > > + > > > +/ { > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > +}; > > > + > > > +ðernet0 { > > > + phy-mode = "2500base-x"; > > > +}; > > > + > > > +ðernet1 { > > > + phy-mode = "2500base-x"; > > > +}; > > > + > > > +&mdio { > > > + compatible = "snps,dwmac-mdio"; > > > + #address-cells = <1>; > > > + #size-cells = <0>; > > > + > > > + sgmii_phy0: phy@8 { > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > + reg = <0x8>; > > > + device_type = "ethernet-phy"; > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > + reset-assert-us = <11000>; > > > + reset-deassert-us = <70000>; > > > + }; > > > + > > > + sgmii_phy1: phy@0 { > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > + reg = <0x0>; > > > + device_type = "ethernet-phy"; > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > + reset-assert-us = <11000>; > > > + reset-deassert-us = <70000>; > > > + }; > > > +}; > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > new file mode 100644 > > > index 000000000000..3b524359a72d > > > --- /dev/null > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > @@ -0,0 +1,46 @@ > > > +// SPDX-License-Identifier: BSD-3-Clause > > > +/* > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > + */ > > > +/dts-v1/; > > > + > > > +#include "sa8775p-ride.dtsi" > > > + > > > +/ { > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > +}; > > > + > > > +ðernet0 { > > > + phy-mode = "sgmii"; > > > +}; > > > + > > > +ðernet1 { > > > + phy-mode = "sgmii"; > > > +}; > > > + > > > +&mdio { > > > + compatible = "snps,dwmac-mdio"; > > > + #address-cells = <1>; > > > + #size-cells = <0>; > > > + > > > + sgmii_phy0: phy@8 { > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > + reg = <0x8>; > > > + device_type = "ethernet-phy"; > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > + reset-assert-us = <11000>; > > > + reset-deassert-us = <70000>; > > > + }; > > > + > > > + sgmii_phy1: phy@a { > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > + reg = <0xa>; > > > + device_type = "ethernet-phy"; > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > + reset-assert-us = <11000>; > > > + reset-deassert-us = <70000>; > > > + }; > > > +}; > > > -- > > > 2.47.0 > > > > > > > -- > > With best wishes > > Dmitry > > > Thanks & Regards, > Wasim
On Fri, Jan 03, 2025 at 07:50:43AM +0200, Dmitry Baryshkov wrote: > On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > > subsystem which is available in QCS9100, and it affects thermal > > > > management. > > > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > > include corresponding SA8775P files. > > > > > > This is not ideal for the following reasons: > > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > > lead to mistakes. > > > - The approach ends up duplicating DT code unnecessarily, which can lead > > > to issues being patches in the one board file, but not in the other > > > file. > > > > > > If there are any reasons why you want to follow this approach, they must > > > be a part of the commit message. > > > > > > > Hi Dmitry, > > > > Initially, we included the DTS [1] file to avoid duplication. However, > > based on Krzysztof's previous suggestion [2], we change to this format. > > > > Please let us know how to proceed further on this. > > Krzysztof asked you to include DTSI files instead of including DTS > files. Hope this helps. Are you suggesting that we should also modify the 9100-ride files to include DTSI instead of DTS for consistency between QCS9100 and QCS9075? However, this would result in the duplication of Ethernet nodes in all the ride board files. Would that be acceptable? > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > > --- > > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > > 3 files changed, 94 insertions(+) > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > new file mode 100644 > > > > index 000000000000..d9a8956d3a76 > > > > --- /dev/null > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > @@ -0,0 +1,46 @@ > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > +/* > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > + */ > > > > +/dts-v1/; > > > > + > > > > +#include "sa8775p-ride.dtsi" > > > > + > > > > +/ { > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > > +}; > > > > + > > > > +ðernet0 { > > > > + phy-mode = "2500base-x"; > > > > +}; > > > > + > > > > +ðernet1 { > > > > + phy-mode = "2500base-x"; > > > > +}; > > > > + > > > > +&mdio { > > > > + compatible = "snps,dwmac-mdio"; > > > > + #address-cells = <1>; > > > > + #size-cells = <0>; > > > > + > > > > + sgmii_phy0: phy@8 { > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > + reg = <0x8>; > > > > + device_type = "ethernet-phy"; > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > + reset-assert-us = <11000>; > > > > + reset-deassert-us = <70000>; > > > > + }; > > > > + > > > > + sgmii_phy1: phy@0 { > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > + reg = <0x0>; > > > > + device_type = "ethernet-phy"; > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > + reset-assert-us = <11000>; > > > > + reset-deassert-us = <70000>; > > > > + }; > > > > +}; > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > new file mode 100644 > > > > index 000000000000..3b524359a72d > > > > --- /dev/null > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > @@ -0,0 +1,46 @@ > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > +/* > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > + */ > > > > +/dts-v1/; > > > > + > > > > +#include "sa8775p-ride.dtsi" > > > > + > > > > +/ { > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > > +}; > > > > + > > > > +ðernet0 { > > > > + phy-mode = "sgmii"; > > > > +}; > > > > + > > > > +ðernet1 { > > > > + phy-mode = "sgmii"; > > > > +}; > > > > + > > > > +&mdio { > > > > + compatible = "snps,dwmac-mdio"; > > > > + #address-cells = <1>; > > > > + #size-cells = <0>; > > > > + > > > > + sgmii_phy0: phy@8 { > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > + reg = <0x8>; > > > > + device_type = "ethernet-phy"; > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > + reset-assert-us = <11000>; > > > > + reset-deassert-us = <70000>; > > > > + }; > > > > + > > > > + sgmii_phy1: phy@a { > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > + reg = <0xa>; > > > > + device_type = "ethernet-phy"; > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > + reset-assert-us = <11000>; > > > > + reset-deassert-us = <70000>; > > > > + }; > > > > +}; > > > > -- > > > > 2.47.0 > > > > > > > > > > -- > > > With best wishes > > > Dmitry > > > > > > Thanks & Regards, > > Wasim > > -- > With best wishes > Dmitry Thanks & Regards, Wasim
On Fri, Jan 03, 2025 at 12:37:50PM +0530, Wasim Nazir wrote: > On Fri, Jan 03, 2025 at 07:50:43AM +0200, Dmitry Baryshkov wrote: > > On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > > > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > > > subsystem which is available in QCS9100, and it affects thermal > > > > > management. > > > > > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > > > include corresponding SA8775P files. > > > > > > > > This is not ideal for the following reasons: > > > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > > > lead to mistakes. > > > > - The approach ends up duplicating DT code unnecessarily, which can lead > > > > to issues being patches in the one board file, but not in the other > > > > file. > > > > > > > > If there are any reasons why you want to follow this approach, they must > > > > be a part of the commit message. > > > > > > > > > > Hi Dmitry, > > > > > > Initially, we included the DTS [1] file to avoid duplication. However, > > > based on Krzysztof's previous suggestion [2], we change to this format. > > > > > > Please let us know how to proceed further on this. > > > > Krzysztof asked you to include DTSI files instead of including DTS > > files. Hope this helps. > > Are you suggesting that we should also modify the 9100-ride files to > include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > However, this would result in the duplication of Ethernet nodes in all > the ride board files. Would that be acceptable? git mv foo.dts foo.dtsi echo '#include "foo.dtsi"' > foo.dts git add foo.dts git commit > > > > > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > > > --- > > > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > > > 3 files changed, 94 insertions(+) > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > new file mode 100644 > > > > > index 000000000000..d9a8956d3a76 > > > > > --- /dev/null > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > @@ -0,0 +1,46 @@ > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > +/* > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > + */ > > > > > +/dts-v1/; > > > > > + > > > > > +#include "sa8775p-ride.dtsi" > > > > > + > > > > > +/ { > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > > > +}; > > > > > + > > > > > +ðernet0 { > > > > > + phy-mode = "2500base-x"; > > > > > +}; > > > > > + > > > > > +ðernet1 { > > > > > + phy-mode = "2500base-x"; > > > > > +}; > > > > > + > > > > > +&mdio { > > > > > + compatible = "snps,dwmac-mdio"; > > > > > + #address-cells = <1>; > > > > > + #size-cells = <0>; > > > > > + > > > > > + sgmii_phy0: phy@8 { > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > + reg = <0x8>; > > > > > + device_type = "ethernet-phy"; > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > + reset-assert-us = <11000>; > > > > > + reset-deassert-us = <70000>; > > > > > + }; > > > > > + > > > > > + sgmii_phy1: phy@0 { > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > + reg = <0x0>; > > > > > + device_type = "ethernet-phy"; > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > + reset-assert-us = <11000>; > > > > > + reset-deassert-us = <70000>; > > > > > + }; > > > > > +}; > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > new file mode 100644 > > > > > index 000000000000..3b524359a72d > > > > > --- /dev/null > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > @@ -0,0 +1,46 @@ > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > +/* > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > + */ > > > > > +/dts-v1/; > > > > > + > > > > > +#include "sa8775p-ride.dtsi" > > > > > + > > > > > +/ { > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > > > +}; > > > > > + > > > > > +ðernet0 { > > > > > + phy-mode = "sgmii"; > > > > > +}; > > > > > + > > > > > +ðernet1 { > > > > > + phy-mode = "sgmii"; > > > > > +}; > > > > > + > > > > > +&mdio { > > > > > + compatible = "snps,dwmac-mdio"; > > > > > + #address-cells = <1>; > > > > > + #size-cells = <0>; > > > > > + > > > > > + sgmii_phy0: phy@8 { > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > + reg = <0x8>; > > > > > + device_type = "ethernet-phy"; > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > + reset-assert-us = <11000>; > > > > > + reset-deassert-us = <70000>; > > > > > + }; > > > > > + > > > > > + sgmii_phy1: phy@a { > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > + reg = <0xa>; > > > > > + device_type = "ethernet-phy"; > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > + reset-assert-us = <11000>; > > > > > + reset-deassert-us = <70000>; > > > > > + }; > > > > > +}; > > > > > -- > > > > > 2.47.0 > > > > > > > > > > > > > -- > > > > With best wishes > > > > Dmitry > > > > > > > > > Thanks & Regards, > > > Wasim > > > > -- > > With best wishes > > Dmitry > > > Thanks & Regards, > Wasim
On Fri, Jan 03, 2025 at 12:31:55PM +0200, Dmitry Baryshkov wrote: > On Fri, Jan 03, 2025 at 12:37:50PM +0530, Wasim Nazir wrote: > > On Fri, Jan 03, 2025 at 07:50:43AM +0200, Dmitry Baryshkov wrote: > > > On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > > > > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > > > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > > > > subsystem which is available in QCS9100, and it affects thermal > > > > > > management. > > > > > > > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > > > > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > > > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > > > > include corresponding SA8775P files. > > > > > > > > > > This is not ideal for the following reasons: > > > > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > > > > lead to mistakes. > > > > > - The approach ends up duplicating DT code unnecessarily, which can lead > > > > > to issues being patches in the one board file, but not in the other > > > > > file. > > > > > > > > > > If there are any reasons why you want to follow this approach, they must > > > > > be a part of the commit message. > > > > > > > > > > > > > Hi Dmitry, > > > > > > > > Initially, we included the DTS [1] file to avoid duplication. However, > > > > based on Krzysztof's previous suggestion [2], we change to this format. > > > > > > > > Please let us know how to proceed further on this. > > > > > > Krzysztof asked you to include DTSI files instead of including DTS > > > files. Hope this helps. > > > > Are you suggesting that we should also modify the 9100-ride files to > > include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > > However, this would result in the duplication of Ethernet nodes in all > > the ride board files. Would that be acceptable? > > git mv foo.dts foo.dtsi > echo '#include "foo.dtsi"' > foo.dts > git add foo.dts > git commit > We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as they represent different platforms. In patch [1], we included these DTS files to reuse the common hardware nodes. Could you please advise on how we should proceed with the following approaches? a) Previous approach [1]: Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride platform DTS, similar to the qcs9100-ride platform DTS. This approach avoids duplicating Ethernet nodes and maintains uniformity. However, it involves including the DTS file directly. b) Current suggestion: Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also modify the qcs9100-ride platform DTS files to maintain uniformity. This approach results in duplicating Ethernet nodes. Please let us know your recommendation to finalize the DT structure. [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > > > > > > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > > > > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > > > > --- > > > > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > > > > 3 files changed, 94 insertions(+) > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > new file mode 100644 > > > > > > index 000000000000..d9a8956d3a76 > > > > > > --- /dev/null > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > @@ -0,0 +1,46 @@ > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > +/* > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > + */ > > > > > > +/dts-v1/; > > > > > > + > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > + > > > > > > +/ { > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > +}; > > > > > > + > > > > > > +ðernet0 { > > > > > > + phy-mode = "2500base-x"; > > > > > > +}; > > > > > > + > > > > > > +ðernet1 { > > > > > > + phy-mode = "2500base-x"; > > > > > > +}; > > > > > > + > > > > > > +&mdio { > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > + #address-cells = <1>; > > > > > > + #size-cells = <0>; > > > > > > + > > > > > > + sgmii_phy0: phy@8 { > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > + reg = <0x8>; > > > > > > + device_type = "ethernet-phy"; > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > + reset-assert-us = <11000>; > > > > > > + reset-deassert-us = <70000>; > > > > > > + }; > > > > > > + > > > > > > + sgmii_phy1: phy@0 { > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > + reg = <0x0>; > > > > > > + device_type = "ethernet-phy"; > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > + reset-assert-us = <11000>; > > > > > > + reset-deassert-us = <70000>; > > > > > > + }; > > > > > > +}; > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > new file mode 100644 > > > > > > index 000000000000..3b524359a72d > > > > > > --- /dev/null > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > @@ -0,0 +1,46 @@ > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > +/* > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > + */ > > > > > > +/dts-v1/; > > > > > > + > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > + > > > > > > +/ { > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > +}; > > > > > > + > > > > > > +ðernet0 { > > > > > > + phy-mode = "sgmii"; > > > > > > +}; > > > > > > + > > > > > > +ðernet1 { > > > > > > + phy-mode = "sgmii"; > > > > > > +}; > > > > > > + > > > > > > +&mdio { > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > + #address-cells = <1>; > > > > > > + #size-cells = <0>; > > > > > > + > > > > > > + sgmii_phy0: phy@8 { > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > + reg = <0x8>; > > > > > > + device_type = "ethernet-phy"; > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > + reset-assert-us = <11000>; > > > > > > + reset-deassert-us = <70000>; > > > > > > + }; > > > > > > + > > > > > > + sgmii_phy1: phy@a { > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > + reg = <0xa>; > > > > > > + device_type = "ethernet-phy"; > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > + reset-assert-us = <11000>; > > > > > > + reset-deassert-us = <70000>; > > > > > > + }; > > > > > > +}; > > > > > > -- > > > > > > 2.47.0 > > > > > > > > > > > > > > > > -- > > > > > With best wishes > > > > > Dmitry > > > > > > > > > > > > Thanks & Regards, > > > > Wasim > > > > > > -- > > > With best wishes > > > Dmitry > > > > > > Thanks & Regards, > > Wasim > > -- > With best wishes > Dmitry Thanks & Regards, Wasim
On Sat, Jan 04, 2025 at 12:29:07AM +0530, Wasim Nazir wrote: > On Fri, Jan 03, 2025 at 12:31:55PM +0200, Dmitry Baryshkov wrote: > > On Fri, Jan 03, 2025 at 12:37:50PM +0530, Wasim Nazir wrote: > > > On Fri, Jan 03, 2025 at 07:50:43AM +0200, Dmitry Baryshkov wrote: > > > > On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > > > > > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > > > > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > > > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > > > > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > > > > > subsystem which is available in QCS9100, and it affects thermal > > > > > > > management. > > > > > > > > > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > > > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > > > > > > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > > > > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > > > > > include corresponding SA8775P files. > > > > > > > > > > > > This is not ideal for the following reasons: > > > > > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > > > > > lead to mistakes. > > > > > > - The approach ends up duplicating DT code unnecessarily, which can lead > > > > > > to issues being patches in the one board file, but not in the other > > > > > > file. > > > > > > > > > > > > If there are any reasons why you want to follow this approach, they must > > > > > > be a part of the commit message. > > > > > > > > > > > > > > > > Hi Dmitry, > > > > > > > > > > Initially, we included the DTS [1] file to avoid duplication. However, > > > > > based on Krzysztof's previous suggestion [2], we change to this format. > > > > > > > > > > Please let us know how to proceed further on this. > > > > > > > > Krzysztof asked you to include DTSI files instead of including DTS > > > > files. Hope this helps. > > > > > > Are you suggesting that we should also modify the 9100-ride files to > > > include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > > > However, this would result in the duplication of Ethernet nodes in all > > > the ride board files. Would that be acceptable? > > > > git mv foo.dts foo.dtsi > > echo '#include "foo.dtsi"' > foo.dts > > git add foo.dts > > git commit > > > > We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as > they represent different platforms. In patch [1], we included these DTS > files to reuse the common hardware nodes. > > Could you please advise on how we should proceed with the following > approaches? > > a) Previous approach [1]: > Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride > platform DTS, similar to the qcs9100-ride platform DTS. This approach > avoids duplicating Ethernet nodes and maintains uniformity. However, it > involves including the DTS file directly. > > b) Current suggestion: > Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also > modify the qcs9100-ride platform DTS files to maintain uniformity. This > approach results in duplicating Ethernet nodes. > > Please let us know your recommendation to finalize the DT structure. sa8775p.dtsi `__sa8775p-ride.dtsi `__sa8775p-ride-r2.dtsi `__sa8775p-ride.dts `__qcs9100-ride.dts `__qcs9075-ride.dts `__sa8775p-ride-r3.dtsi `__sa8775p-ride-r3.dts `__qcs9100-ride-r3.dts `__qcs9075-ride-r3.dts > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > > > > > > > > > > > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > > > > > > > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > > > > > --- > > > > > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > > > > > 3 files changed, 94 insertions(+) > > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > > > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > > > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > > > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > > > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > new file mode 100644 > > > > > > > index 000000000000..d9a8956d3a76 > > > > > > > --- /dev/null > > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > @@ -0,0 +1,46 @@ > > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > > +/* > > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > > + */ > > > > > > > +/dts-v1/; > > > > > > > + > > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > > + > > > > > > > +/ { > > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > > > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > > +}; > > > > > > > + > > > > > > > +ðernet0 { > > > > > > > + phy-mode = "2500base-x"; > > > > > > > +}; > > > > > > > + > > > > > > > +ðernet1 { > > > > > > > + phy-mode = "2500base-x"; > > > > > > > +}; > > > > > > > + > > > > > > > +&mdio { > > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > > + #address-cells = <1>; > > > > > > > + #size-cells = <0>; > > > > > > > + > > > > > > > + sgmii_phy0: phy@8 { > > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > > + reg = <0x8>; > > > > > > > + device_type = "ethernet-phy"; > > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > > + reset-assert-us = <11000>; > > > > > > > + reset-deassert-us = <70000>; > > > > > > > + }; > > > > > > > + > > > > > > > + sgmii_phy1: phy@0 { > > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > > + reg = <0x0>; > > > > > > > + device_type = "ethernet-phy"; > > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > > + reset-assert-us = <11000>; > > > > > > > + reset-deassert-us = <70000>; > > > > > > > + }; > > > > > > > +}; > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > new file mode 100644 > > > > > > > index 000000000000..3b524359a72d > > > > > > > --- /dev/null > > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > @@ -0,0 +1,46 @@ > > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > > +/* > > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > > + */ > > > > > > > +/dts-v1/; > > > > > > > + > > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > > + > > > > > > > +/ { > > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > > > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > > +}; > > > > > > > + > > > > > > > +ðernet0 { > > > > > > > + phy-mode = "sgmii"; > > > > > > > +}; > > > > > > > + > > > > > > > +ðernet1 { > > > > > > > + phy-mode = "sgmii"; > > > > > > > +}; > > > > > > > + > > > > > > > +&mdio { > > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > > + #address-cells = <1>; > > > > > > > + #size-cells = <0>; > > > > > > > + > > > > > > > + sgmii_phy0: phy@8 { > > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > > + reg = <0x8>; > > > > > > > + device_type = "ethernet-phy"; > > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > > + reset-assert-us = <11000>; > > > > > > > + reset-deassert-us = <70000>; > > > > > > > + }; > > > > > > > + > > > > > > > + sgmii_phy1: phy@a { > > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > > + reg = <0xa>; > > > > > > > + device_type = "ethernet-phy"; > > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > > + reset-assert-us = <11000>; > > > > > > > + reset-deassert-us = <70000>; > > > > > > > + }; > > > > > > > +}; > > > > > > > -- > > > > > > > 2.47.0 > > > > > > > > > > > > > > > > > > > -- > > > > > > With best wishes > > > > > > Dmitry > > > > > > > > > > > > > > > Thanks & Regards, > > > > > Wasim > > > > > > > > -- > > > > With best wishes > > > > Dmitry > > > > > > > > > Thanks & Regards, > > > Wasim > > > > -- > > With best wishes > > Dmitry > > Thanks & Regards, > Wasim
On Sun, 29 Dec 2024 20:53:26 +0530, Wasim Nazir wrote: > This series: > > Add support for Qualcomm's rb8, ride/ride-r3 boards using QCS9075 SoC. > > QCS9075 is compatible IoT-industrial grade variant of SA8775p SoC. > Unlike QCS9100, it doesn't have safety monitoring feature of > Safety-Island(SAIL) subsystem, which affects thermal management. > > [...] Applied, thanks! [1/6] dt-bindings: arm: qcom,ids: add SoC ID for QCS9075 commit: cee3947b1aed42f71f99ce4e5d1410ee8670621a [2/6] soc: qcom: socinfo: add QCS9075 SoC ID commit: 7b115b623545650407e3f262ee9cdd8a778a9fdf Best regards,
On 03/01/2025 20:58, Dmitry Baryshkov wrote: >>>>>> Initially, we included the DTS [1] file to avoid duplication. However, >>>>>> based on Krzysztof's previous suggestion [2], we change to this format. >>>>>> >>>>>> Please let us know how to proceed further on this. >>>>> >>>>> Krzysztof asked you to include DTSI files instead of including DTS >>>>> files. Hope this helps. >>>> >>>> Are you suggesting that we should also modify the 9100-ride files to >>>> include DTSI instead of DTS for consistency between QCS9100 and QCS9075? >>>> However, this would result in the duplication of Ethernet nodes in all >>>> the ride board files. Would that be acceptable? >>> >>> git mv foo.dts foo.dtsi >>> echo '#include "foo.dtsi"' > foo.dts >>> git add foo.dts >>> git commit >>> >> >> We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as >> they represent different platforms. In patch [1], we included these DTS >> files to reuse the common hardware nodes. >> >> Could you please advise on how we should proceed with the following >> approaches? >> >> a) Previous approach [1]: >> Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride >> platform DTS, similar to the qcs9100-ride platform DTS. This approach >> avoids duplicating Ethernet nodes and maintains uniformity. However, it >> involves including the DTS file directly. >> >> b) Current suggestion: >> Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also >> modify the qcs9100-ride platform DTS files to maintain uniformity. This >> approach results in duplicating Ethernet nodes. >> >> Please let us know your recommendation to finalize the DT structure. > > sa8775p.dtsi > `__sa8775p-ride.dtsi > `__sa8775p-ride-r2.dtsi > `__sa8775p-ride.dts > `__qcs9100-ride.dts > `__qcs9075-ride.dts > `__sa8775p-ride-r3.dtsi > `__sa8775p-ride-r3.dts > `__qcs9100-ride-r3.dts > `__qcs9075-ride-r3.dts > Wasim and all other copy-pasters of sa8775p-ride, Just to recap, qcs9100 contributions started this terrible pattern of board including a board. Unfortunately qcs9100 was merged, so that ship has sailed. This patchset was going the same way, because poor choices like to keep spreading, but at one of previous versions I noticed it and objected. This v5 however solves above problem by duplicating the nodes. Apparently all these designs - sa8755p, qcs9100 and qcs9075 - use the same board, but none of this was communicated. I checked all the commit msgs in this patchset and nothing explained about it. What annoys me is that you do not communicate your design forcing us to accept poor DTS or forcing us to guess and make poor judgments. Come with proper hardware description and split out shared parts, like motherboard. Look how other vendors are doing it, e.g. NXP or Renesas. But assuming there are shared parts because I am pretty sure you will pick my comments when it suits you without actually following them fully and without understanding and explaining to us your own hardware. Best regards, Krzysztof
Hi Dmitry, On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: > On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >> Hi Dmitry, >> >> >> On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: >>> On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>> Hi Dmitry, >>>> >>>> On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: >>>>> On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: >>>>>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>>>>> >>>>>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and >>>>>> does corrective action for each subsystem based on sensor violation >>>>>> to comply safety standards. But as QCS9075 is non-safe SoC it >>>>>> requires conventional thermal mitigation to control thermal for >>>>>> different subsystems. >>>>>> >>>>>> The cpu frequency throttling for different cpu tsens is enabled in >>>>>> hardware as first defense for cpu thermal control. But QCS9075 SoC >>>>>> has higher ambient specification. During high ambient condition, even >>>>>> lowest frequency with multi cores can slowly build heat over the time >>>>>> and it can lead to thermal run-away situations. This patch restrict >>>>>> cpu cores during this scenario helps further thermal control and >>>>>> avoids thermal critical violation. >>>>>> >>>>>> Add cpu idle injection cooling bindings for cpu tsens thermal zones >>>>>> as a mitigation for cpu subsystem prior to thermal shutdown. >>>>>> >>>>>> Add cpu frequency cooling devices that will be used by userspace >>>>>> thermal governor to mitigate skin thermal management. >>>>> Does anything prevent us from having this config as a part of the basic >>>>> sa8775p.dtsi setup? If HW is present in the base version but it is not >>>>> accessible for whatever reason, please move it the base device config >>>>> and use status "disabled" or "reserved" to the respective board files. >>>> Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep >>>> it disabled state. #cooling cells property for CPU, still wanted to keep it >>>> in board files as we don't want to enable any cooling device in base DT. >>> "we don't want" is not a proper justification. So, no. >> As noted in the commit, thermal cooling mitigation is only necessary for >> non-safe SoCs. Adding this cooling cell property to the CPU node in the base >> DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would >> violate the requirements for safe SoCs. Therefore, we will include it only >> in non-safe SoC boards. > "is only necessary" is fine. It means that it is an optional part which > is going to be unused / ignored / duplicate functionality on the "safe" > SoCs. What kind of requirement is going to be violated in this way? From the perspective of a safe SoC, any software mitigation that compromises the safety subsystem’s compliance should not be allowed. Enabling the cooling device also opens up the sysfs interface for userspace, which we may not fully control. Userspace apps or partner apps might inadvertently use it. Therefore, we believe it is better not to expose such an interface, as it is not required for that SoC and helps to avoid opening up an interface that could potentially lead to a safety failure. Best Regards, Manaf >
On Fri, Jan 03, 2025 at 09:58:40PM +0200, Dmitry Baryshkov wrote: > On Sat, Jan 04, 2025 at 12:29:07AM +0530, Wasim Nazir wrote: > > On Fri, Jan 03, 2025 at 12:31:55PM +0200, Dmitry Baryshkov wrote: > > > On Fri, Jan 03, 2025 at 12:37:50PM +0530, Wasim Nazir wrote: > > > > On Fri, Jan 03, 2025 at 07:50:43AM +0200, Dmitry Baryshkov wrote: > > > > > On Thu, Jan 02, 2025 at 02:37:39PM +0530, Wasim Nazir wrote: > > > > > > On Mon, Dec 30, 2024 at 05:45:39PM +0200, Dmitry Baryshkov wrote: > > > > > > > On Sun, Dec 29, 2024 at 08:53:31PM +0530, Wasim Nazir wrote: > > > > > > > > Add device tree support for QCS9075 Ride & Ride-r3 boards. > > > > > > > > > > > > > > > > QCS9075 lacks the safety monitoring features of Safety-Island (SAIL) > > > > > > > > subsystem which is available in QCS9100, and it affects thermal > > > > > > > > management. > > > > > > > > > > > > > > > > Also, between ride and ride-r3 ethernet phy is different. > > > > > > > > Ride uses 1G ethernet phy while ride-r3 uses 2.5G ethernet phy. > > > > > > > > > > > > > > Your board files duplicate sa8775p-ride-r3.dts and sa8775p-ride.dts, but > > > > > > > include them. Existing qcs9100-ride-r3.dts and qcs9100-ride-r3.dts just > > > > > > > include corresponding SA8775P files. > > > > > > > > > > > > > > This is not ideal for the following reasons: > > > > > > > - The approach is not uniform (between QCS9100 and QCS9075), which might > > > > > > > lead to mistakes. > > > > > > > - The approach ends up duplicating DT code unnecessarily, which can lead > > > > > > > to issues being patches in the one board file, but not in the other > > > > > > > file. > > > > > > > > > > > > > > If there are any reasons why you want to follow this approach, they must > > > > > > > be a part of the commit message. > > > > > > > > > > > > > > > > > > > Hi Dmitry, > > > > > > > > > > > > Initially, we included the DTS [1] file to avoid duplication. However, > > > > > > based on Krzysztof's previous suggestion [2], we change to this format. > > > > > > > > > > > > Please let us know how to proceed further on this. > > > > > > > > > > Krzysztof asked you to include DTSI files instead of including DTS > > > > > files. Hope this helps. > > > > > > > > Are you suggesting that we should also modify the 9100-ride files to > > > > include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > > > > However, this would result in the duplication of Ethernet nodes in all > > > > the ride board files. Would that be acceptable? > > > > > > git mv foo.dts foo.dtsi > > > echo '#include "foo.dtsi"' > foo.dts > > > git add foo.dts > > > git commit > > > > > > > We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as > > they represent different platforms. In patch [1], we included these DTS > > files to reuse the common hardware nodes. > > > > Could you please advise on how we should proceed with the following > > approaches? > > > > a) Previous approach [1]: > > Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride > > platform DTS, similar to the qcs9100-ride platform DTS. This approach > > avoids duplicating Ethernet nodes and maintains uniformity. However, it > > involves including the DTS file directly. > > > > b) Current suggestion: > > Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also > > modify the qcs9100-ride platform DTS files to maintain uniformity. This > > approach results in duplicating Ethernet nodes. > > > > Please let us know your recommendation to finalize the DT structure. > > sa8775p.dtsi > `__sa8775p-ride.dtsi > `__sa8775p-ride-r2.dtsi > `__sa8775p-ride.dts > `__qcs9100-ride.dts > `__qcs9075-ride.dts > `__sa8775p-ride-r3.dtsi > `__sa8775p-ride-r3.dts > `__qcs9100-ride-r3.dts > `__qcs9075-ride-r3.dts Thanks Dmitry, we need slight modification to the above structure as we don't have any ride-r2 boards, so we want to go ahead with this structure: sa8775p.dtsi `__sa8775p-ride-common.dtsi `__sa8775p-ride.dtsi `__sa8775p-ride.dts `__qcs9100-ride.dts `__qcs9075-ride.dts `__sa8775p-ride-r3.dtsi `__sa8775p-ride-r3.dts `__qcs9100-ride-r3.dts `__qcs9075-ride-r3.dts > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > > > > > > > > > > > > > > > > > > > > [1] https://lore.kernel.org/all/20241119174954.1219002-6-quic_wasimn@quicinc.com/ > > > > > > [2] https://lore.kernel.org/all/8cf9edc0-a0cb-4fd0-b10e-2138784dfba3@kernel.org/ > > > > > > > > > > > > > > > > > > > > > > Signed-off-by: Wasim Nazir <quic_wasimn@quicinc.com> > > > > > > > > --- > > > > > > > > arch/arm64/boot/dts/qcom/Makefile | 2 + > > > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts | 46 ++++++++++++++++++++ > > > > > > > > arch/arm64/boot/dts/qcom/qcs9075-ride.dts | 46 ++++++++++++++++++++ > > > > > > > > 3 files changed, 94 insertions(+) > > > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > > create mode 100644 arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/Makefile b/arch/arm64/boot/dts/qcom/Makefile > > > > > > > > index 78613a1bd34a..41cb2bbd3472 100644 > > > > > > > > --- a/arch/arm64/boot/dts/qcom/Makefile > > > > > > > > +++ b/arch/arm64/boot/dts/qcom/Makefile > > > > > > > > @@ -118,6 +118,8 @@ dtb-$(CONFIG_ARCH_QCOM) += qcs6490-rb3gen2.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8300-ride.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs8550-aim300-aiot.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9075-rb8.dtb > > > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride.dtb > > > > > > > > +dtb-$(CONFIG_ARCH_QCOM) += qcs9075-ride-r3.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qcs9100-ride-r3.dtb > > > > > > > > dtb-$(CONFIG_ARCH_QCOM) += qdu1000-idp.dtb > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > > new file mode 100644 > > > > > > > > index 000000000000..d9a8956d3a76 > > > > > > > > --- /dev/null > > > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride-r3.dts > > > > > > > > @@ -0,0 +1,46 @@ > > > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > > > +/* > > > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > > > + */ > > > > > > > > +/dts-v1/; > > > > > > > > + > > > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > > > + > > > > > > > > +/ { > > > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride Rev3"; > > > > > > > > + compatible = "qcom,qcs9075-ride-r3", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +ðernet0 { > > > > > > > > + phy-mode = "2500base-x"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +ðernet1 { > > > > > > > > + phy-mode = "2500base-x"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +&mdio { > > > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > > > + #address-cells = <1>; > > > > > > > > + #size-cells = <0>; > > > > > > > > + > > > > > > > > + sgmii_phy0: phy@8 { > > > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > > > + reg = <0x8>; > > > > > > > > + device_type = "ethernet-phy"; > > > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > > > + reset-assert-us = <11000>; > > > > > > > > + reset-deassert-us = <70000>; > > > > > > > > + }; > > > > > > > > + > > > > > > > > + sgmii_phy1: phy@0 { > > > > > > > > + compatible = "ethernet-phy-id31c3.1c33"; > > > > > > > > + reg = <0x0>; > > > > > > > > + device_type = "ethernet-phy"; > > > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > > > + reset-assert-us = <11000>; > > > > > > > > + reset-deassert-us = <70000>; > > > > > > > > + }; > > > > > > > > +}; > > > > > > > > diff --git a/arch/arm64/boot/dts/qcom/qcs9075-ride.dts b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > new file mode 100644 > > > > > > > > index 000000000000..3b524359a72d > > > > > > > > --- /dev/null > > > > > > > > +++ b/arch/arm64/boot/dts/qcom/qcs9075-ride.dts > > > > > > > > @@ -0,0 +1,46 @@ > > > > > > > > +// SPDX-License-Identifier: BSD-3-Clause > > > > > > > > +/* > > > > > > > > + * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved. > > > > > > > > + */ > > > > > > > > +/dts-v1/; > > > > > > > > + > > > > > > > > +#include "sa8775p-ride.dtsi" > > > > > > > > + > > > > > > > > +/ { > > > > > > > > + model = "Qualcomm Technologies, Inc. QCS9075 Ride"; > > > > > > > > + compatible = "qcom,qcs9075-ride", "qcom,qcs9075", "qcom,sa8775p"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +ðernet0 { > > > > > > > > + phy-mode = "sgmii"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +ðernet1 { > > > > > > > > + phy-mode = "sgmii"; > > > > > > > > +}; > > > > > > > > + > > > > > > > > +&mdio { > > > > > > > > + compatible = "snps,dwmac-mdio"; > > > > > > > > + #address-cells = <1>; > > > > > > > > + #size-cells = <0>; > > > > > > > > + > > > > > > > > + sgmii_phy0: phy@8 { > > > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > > > + reg = <0x8>; > > > > > > > > + device_type = "ethernet-phy"; > > > > > > > > + interrupts-extended = <&tlmm 7 IRQ_TYPE_EDGE_FALLING>; > > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 8 GPIO_ACTIVE_LOW>; > > > > > > > > + reset-assert-us = <11000>; > > > > > > > > + reset-deassert-us = <70000>; > > > > > > > > + }; > > > > > > > > + > > > > > > > > + sgmii_phy1: phy@a { > > > > > > > > + compatible = "ethernet-phy-id0141.0dd4"; > > > > > > > > + reg = <0xa>; > > > > > > > > + device_type = "ethernet-phy"; > > > > > > > > + interrupts-extended = <&tlmm 26 IRQ_TYPE_EDGE_FALLING>; > > > > > > > > + reset-gpios = <&pmm8654au_2_gpios 9 GPIO_ACTIVE_LOW>; > > > > > > > > + reset-assert-us = <11000>; > > > > > > > > + reset-deassert-us = <70000>; > > > > > > > > + }; > > > > > > > > +}; > > > > > > > > -- > > > > > > > > 2.47.0 > > > > > > > > > > > > > > > > > > > > > > -- > > > > > > > With best wishes > > > > > > > Dmitry > > > > > > > > > > > > > > > > > > Thanks & Regards, > > > > > > Wasim > > > > > > > > > > -- > > > > > With best wishes > > > > > Dmitry > > > > > > > > > > > > Thanks & Regards, > > > > Wasim > > > > > > -- > > > With best wishes > > > Dmitry > > > > Thanks & Regards, > > Wasim > > -- > With best wishes > Dmitry Thanks & Regards, Wasim
On 8.01.2025 5:08 PM, Manaf Meethalavalappu Pallikunhi wrote: > > Hi Dmitry, > > > On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: >> On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>> Hi Dmitry, >>> >>> >>> On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: >>>> On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>>> Hi Dmitry, >>>>> >>>>> On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: >>>>>> On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: >>>>>>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>>>>>> >>>>>>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and >>>>>>> does corrective action for each subsystem based on sensor violation >>>>>>> to comply safety standards. But as QCS9075 is non-safe SoC it >>>>>>> requires conventional thermal mitigation to control thermal for >>>>>>> different subsystems. >>>>>>> >>>>>>> The cpu frequency throttling for different cpu tsens is enabled in >>>>>>> hardware as first defense for cpu thermal control. But QCS9075 SoC >>>>>>> has higher ambient specification. During high ambient condition, even >>>>>>> lowest frequency with multi cores can slowly build heat over the time >>>>>>> and it can lead to thermal run-away situations. This patch restrict >>>>>>> cpu cores during this scenario helps further thermal control and >>>>>>> avoids thermal critical violation. >>>>>>> >>>>>>> Add cpu idle injection cooling bindings for cpu tsens thermal zones >>>>>>> as a mitigation for cpu subsystem prior to thermal shutdown. >>>>>>> >>>>>>> Add cpu frequency cooling devices that will be used by userspace >>>>>>> thermal governor to mitigate skin thermal management. >>>>>> Does anything prevent us from having this config as a part of the basic >>>>>> sa8775p.dtsi setup? If HW is present in the base version but it is not >>>>>> accessible for whatever reason, please move it the base device config >>>>>> and use status "disabled" or "reserved" to the respective board files. >>>>> Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep >>>>> it disabled state. #cooling cells property for CPU, still wanted to keep it >>>>> in board files as we don't want to enable any cooling device in base DT. >>>> "we don't want" is not a proper justification. So, no. >>> As noted in the commit, thermal cooling mitigation is only necessary for >>> non-safe SoCs. Adding this cooling cell property to the CPU node in the base >>> DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would >>> violate the requirements for safe SoCs. Therefore, we will include it only >>> in non-safe SoC boards. >> "is only necessary" is fine. It means that it is an optional part which >> is going to be unused / ignored / duplicate functionality on the "safe" >> SoCs. What kind of requirement is going to be violated in this way? > > From the perspective of a safe SoC, any software mitigation that compromises the safety subsystem’s compliance should not be allowed. Enabling the cooling device also opens up the sysfs interface for userspace, which we may not fully control. Userspace apps or partner apps might inadvertently use it. Therefore, we believe it is better not to expose such an interface, as it is not required for that SoC and helps to avoid opening up an interface that could potentially lead to a safety failure. So, to recalibrate, would this be accurate?: * "safe" SoCs are the ones with a SAIL/Safety Island block which performs thermal throttling without OS intervention and does so on all SAIL-equipped platforms * SoCs with a SAIL are intended to be used in e.g. cars and if we want to keep mainline viable on those, we must comply with some regulations, which prevent e.g. software thermal throttling * idle injection provides measurable improvements over software- based frequency throttling on platforms with SAIL Konrad
On Wed, Jan 08, 2025 at 03:09:09PM +0100, Krzysztof Kozlowski wrote: > On 03/01/2025 20:58, Dmitry Baryshkov wrote: > >>>>>> Initially, we included the DTS [1] file to avoid duplication. However, > >>>>>> based on Krzysztof's previous suggestion [2], we change to this format. > >>>>>> > >>>>>> Please let us know how to proceed further on this. > >>>>> > >>>>> Krzysztof asked you to include DTSI files instead of including DTS > >>>>> files. Hope this helps. > >>>> > >>>> Are you suggesting that we should also modify the 9100-ride files to > >>>> include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > >>>> However, this would result in the duplication of Ethernet nodes in all > >>>> the ride board files. Would that be acceptable? > >>> > >>> git mv foo.dts foo.dtsi > >>> echo '#include "foo.dtsi"' > foo.dts > >>> git add foo.dts > >>> git commit > >>> > >> > >> We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as > >> they represent different platforms. In patch [1], we included these DTS > >> files to reuse the common hardware nodes. > >> > >> Could you please advise on how we should proceed with the following > >> approaches? > >> > >> a) Previous approach [1]: > >> Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride > >> platform DTS, similar to the qcs9100-ride platform DTS. This approach > >> avoids duplicating Ethernet nodes and maintains uniformity. However, it > >> involves including the DTS file directly. > >> > >> b) Current suggestion: > >> Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also > >> modify the qcs9100-ride platform DTS files to maintain uniformity. This > >> approach results in duplicating Ethernet nodes. > >> > >> Please let us know your recommendation to finalize the DT structure. > > > > sa8775p.dtsi > > `__sa8775p-ride.dtsi > > `__sa8775p-ride-r2.dtsi > > `__sa8775p-ride.dts > > `__qcs9100-ride.dts > > `__qcs9075-ride.dts > > `__sa8775p-ride-r3.dtsi > > `__sa8775p-ride-r3.dts > > `__qcs9100-ride-r3.dts > > `__qcs9075-ride-r3.dts > > > Wasim and all other copy-pasters of sa8775p-ride, > > Just to recap, qcs9100 contributions started this terrible pattern of > board including a board. Unfortunately qcs9100 was merged, so that ship > has sailed. > > This patchset was going the same way, because poor choices like to keep > spreading, but at one of previous versions I noticed it and objected. > > This v5 however solves above problem by duplicating the nodes. > > Apparently all these designs - sa8755p, qcs9100 and qcs9075 - use the > same board, but none of this was communicated. I checked all the commit > msgs in this patchset and nothing explained about it. What annoys me is > that you do not communicate your design forcing us to accept poor DTS or > forcing us to guess and make poor judgments. > > Come with proper hardware description and split out shared parts, like > motherboard. Look how other vendors are doing it, e.g. NXP or Renesas. > But assuming there are shared parts because I am pretty sure you will > pick my comments when it suits you without actually following them fully > and without understanding and explaining to us your own hardware. > Hi Krzysztof, Here is the pictorial flow showing how SoCs are derived and what all boards are supported. +---------------------------------------------------------------------+ | | | sa8775p | | | | | +-----------------------+-----------------------+ | | | | | | | v | v | | qcs9100 | qcs9075 | | | | | | | v v v | | (IOT) (AUTO) (IOT) | | qcs9100-ride.dts sa8775p-ride.dts qcs9075-ride.dts | | qcs9100-ride-r3.dts sa8775p-ride-r3.dts qcs9075-ride-r3.dts | | qcs9075-rb8.dts | | | +---------------------------------------------------------------------+ Although we included details about the QCS9075 and QCS9100 in the cover letter and commit message, explaining their differences and common origin from the SA8775P SOC, the new DT structure suggested by Dmitry should make things clearer. This structure properly splits common parts and enhances reusability. > Best regards, > Krzysztof Thanks & Regards, Wasim
On Thu, Jan 09, 2025 at 08:17:54PM +0530, Wasim Nazir wrote: > On Wed, Jan 08, 2025 at 03:09:09PM +0100, Krzysztof Kozlowski wrote: > > On 03/01/2025 20:58, Dmitry Baryshkov wrote: > > >>>>>> Initially, we included the DTS [1] file to avoid duplication. However, > > >>>>>> based on Krzysztof's previous suggestion [2], we change to this format. > > >>>>>> > > >>>>>> Please let us know how to proceed further on this. > > >>>>> > > >>>>> Krzysztof asked you to include DTSI files instead of including DTS > > >>>>> files. Hope this helps. > > >>>> > > >>>> Are you suggesting that we should also modify the 9100-ride files to > > >>>> include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > > >>>> However, this would result in the duplication of Ethernet nodes in all > > >>>> the ride board files. Would that be acceptable? > > >>> > > >>> git mv foo.dts foo.dtsi > > >>> echo '#include "foo.dtsi"' > foo.dts > > >>> git add foo.dts > > >>> git commit > > >>> > > >> > > >> We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as > > >> they represent different platforms. In patch [1], we included these DTS > > >> files to reuse the common hardware nodes. > > >> > > >> Could you please advise on how we should proceed with the following > > >> approaches? > > >> > > >> a) Previous approach [1]: > > >> Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride > > >> platform DTS, similar to the qcs9100-ride platform DTS. This approach > > >> avoids duplicating Ethernet nodes and maintains uniformity. However, it > > >> involves including the DTS file directly. > > >> > > >> b) Current suggestion: > > >> Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also > > >> modify the qcs9100-ride platform DTS files to maintain uniformity. This > > >> approach results in duplicating Ethernet nodes. > > >> > > >> Please let us know your recommendation to finalize the DT structure. > > > > > > sa8775p.dtsi > > > `__sa8775p-ride.dtsi > > > `__sa8775p-ride-r2.dtsi > > > `__sa8775p-ride.dts > > > `__qcs9100-ride.dts > > > `__qcs9075-ride.dts > > > `__sa8775p-ride-r3.dtsi > > > `__sa8775p-ride-r3.dts > > > `__qcs9100-ride-r3.dts > > > `__qcs9075-ride-r3.dts > > > > > Wasim and all other copy-pasters of sa8775p-ride, > > > > Just to recap, qcs9100 contributions started this terrible pattern of > > board including a board. Unfortunately qcs9100 was merged, so that ship > > has sailed. > > > > This patchset was going the same way, because poor choices like to keep > > spreading, but at one of previous versions I noticed it and objected. > > > > This v5 however solves above problem by duplicating the nodes. > > > > Apparently all these designs - sa8755p, qcs9100 and qcs9075 - use the > > same board, but none of this was communicated. I checked all the commit > > msgs in this patchset and nothing explained about it. What annoys me is > > that you do not communicate your design forcing us to accept poor DTS or > > forcing us to guess and make poor judgments. > > > > Come with proper hardware description and split out shared parts, like > > motherboard. Look how other vendors are doing it, e.g. NXP or Renesas. > > But assuming there are shared parts because I am pretty sure you will > > pick my comments when it suits you without actually following them fully > > and without understanding and explaining to us your own hardware. > > > > Hi Krzysztof, > > Here is the pictorial flow showing how SoCs are derived and what all boards > are supported. > +-----------------------------------------------------------------------+ | | | sa8775p | | | | | +-----------------------+-----------------------+ | | | | | | | v | v | | qcs9100 | qcs9075 | | | | | | | v v v | | (IOT) (AUTO) (IOT) | | qcs9100-ride.dts sa8775p-ride.dts qcs9075-ride.dts | | qcs9100-ride-r3.dts sa8775p-ride-r3.dts qcs9075-ride-r3.dts | | qcs9075-rb8.dts | | | +-----------------------------------------------------------------------+ Updating it as previous one is messed up with whitespaces. > > Although we included details about the QCS9075 and QCS9100 in the cover > letter and commit message, explaining their differences and common > origin from the SA8775P SOC, the new DT structure suggested by Dmitry > should make things clearer. This structure properly splits common parts > and enhances reusability. > > > Best regards, > > Krzysztof > > Thanks & Regards, > Wasim
On 09/01/2025 15:47, Wasim Nazir wrote: > On Wed, Jan 08, 2025 at 03:09:09PM +0100, Krzysztof Kozlowski wrote: >> On 03/01/2025 20:58, Dmitry Baryshkov wrote: >>>>>>>> Initially, we included the DTS [1] file to avoid duplication. However, >>>>>>>> based on Krzysztof's previous suggestion [2], we change to this format. >>>>>>>> >>>>>>>> Please let us know how to proceed further on this. >>>>>>> >>>>>>> Krzysztof asked you to include DTSI files instead of including DTS >>>>>>> files. Hope this helps. >>>>>> >>>>>> Are you suggesting that we should also modify the 9100-ride files to >>>>>> include DTSI instead of DTS for consistency between QCS9100 and QCS9075? >>>>>> However, this would result in the duplication of Ethernet nodes in all >>>>>> the ride board files. Would that be acceptable? >>>>> >>>>> git mv foo.dts foo.dtsi >>>>> echo '#include "foo.dtsi"' > foo.dts >>>>> git add foo.dts >>>>> git commit >>>>> >>>> >>>> We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as >>>> they represent different platforms. In patch [1], we included these DTS >>>> files to reuse the common hardware nodes. >>>> >>>> Could you please advise on how we should proceed with the following >>>> approaches? >>>> >>>> a) Previous approach [1]: >>>> Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride >>>> platform DTS, similar to the qcs9100-ride platform DTS. This approach >>>> avoids duplicating Ethernet nodes and maintains uniformity. However, it >>>> involves including the DTS file directly. >>>> >>>> b) Current suggestion: >>>> Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also >>>> modify the qcs9100-ride platform DTS files to maintain uniformity. This >>>> approach results in duplicating Ethernet nodes. >>>> >>>> Please let us know your recommendation to finalize the DT structure. >>> >>> sa8775p.dtsi >>> `__sa8775p-ride.dtsi >>> `__sa8775p-ride-r2.dtsi >>> `__sa8775p-ride.dts >>> `__qcs9100-ride.dts >>> `__qcs9075-ride.dts >>> `__sa8775p-ride-r3.dtsi >>> `__sa8775p-ride-r3.dts >>> `__qcs9100-ride-r3.dts >>> `__qcs9075-ride-r3.dts >>> >> Wasim and all other copy-pasters of sa8775p-ride, >> >> Just to recap, qcs9100 contributions started this terrible pattern of >> board including a board. Unfortunately qcs9100 was merged, so that ship >> has sailed. >> >> This patchset was going the same way, because poor choices like to keep >> spreading, but at one of previous versions I noticed it and objected. >> >> This v5 however solves above problem by duplicating the nodes. >> >> Apparently all these designs - sa8755p, qcs9100 and qcs9075 - use the >> same board, but none of this was communicated. I checked all the commit >> msgs in this patchset and nothing explained about it. What annoys me is >> that you do not communicate your design forcing us to accept poor DTS or >> forcing us to guess and make poor judgments. >> >> Come with proper hardware description and split out shared parts, like >> motherboard. Look how other vendors are doing it, e.g. NXP or Renesas. >> But assuming there are shared parts because I am pretty sure you will >> pick my comments when it suits you without actually following them fully >> and without understanding and explaining to us your own hardware. >> > > Hi Krzysztof, > > Here is the pictorial flow showing how SoCs are derived and what all boards > are supported. > > +---------------------------------------------------------------------+ > | | > | sa8775p | > | | | > | +-----------------------+-----------------------+ | > | | | | | > | v | v | > | qcs9100 | qcs9075 | > | | | | | > | v v v | > | (IOT) (AUTO) (IOT) | > | qcs9100-ride.dts sa8775p-ride.dts qcs9075-ride.dts | > | qcs9100-ride-r3.dts sa8775p-ride-r3.dts qcs9075-ride-r3.dts | > | qcs9075-rb8.dts | > | | > +---------------------------------------------------------------------+ The the SoC, I am asking about the board. Why each of them is for example r3? So this is not sufficient explanation, nothing about the board, and again just look Renesas and NXP. Best regards, Krzysztof
On Wed, Jan 08, 2025 at 09:38:19PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > Hi Dmitry, > > > On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: > > On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > > Hi Dmitry, > > > > > > > > > On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: > > > > On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > > > > Hi Dmitry, > > > > > > > > > > On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: > > > > > > On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: > > > > > > > From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > > > > > > > > > > > > > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > > > > > > > does corrective action for each subsystem based on sensor violation > > > > > > > to comply safety standards. But as QCS9075 is non-safe SoC it > > > > > > > requires conventional thermal mitigation to control thermal for > > > > > > > different subsystems. > > > > > > > > > > > > > > The cpu frequency throttling for different cpu tsens is enabled in > > > > > > > hardware as first defense for cpu thermal control. But QCS9075 SoC > > > > > > > has higher ambient specification. During high ambient condition, even > > > > > > > lowest frequency with multi cores can slowly build heat over the time > > > > > > > and it can lead to thermal run-away situations. This patch restrict > > > > > > > cpu cores during this scenario helps further thermal control and > > > > > > > avoids thermal critical violation. > > > > > > > > > > > > > > Add cpu idle injection cooling bindings for cpu tsens thermal zones > > > > > > > as a mitigation for cpu subsystem prior to thermal shutdown. > > > > > > > > > > > > > > Add cpu frequency cooling devices that will be used by userspace > > > > > > > thermal governor to mitigate skin thermal management. > > > > > > Does anything prevent us from having this config as a part of the basic > > > > > > sa8775p.dtsi setup? If HW is present in the base version but it is not > > > > > > accessible for whatever reason, please move it the base device config > > > > > > and use status "disabled" or "reserved" to the respective board files. > > > > > Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep > > > > > it disabled state. #cooling cells property for CPU, still wanted to keep it > > > > > in board files as we don't want to enable any cooling device in base DT. > > > > "we don't want" is not a proper justification. So, no. > > > As noted in the commit, thermal cooling mitigation is only necessary for > > > non-safe SoCs. Adding this cooling cell property to the CPU node in the base > > > DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would > > > violate the requirements for safe SoCs. Therefore, we will include it only > > > in non-safe SoC boards. > > "is only necessary" is fine. It means that it is an optional part which > > is going to be unused / ignored / duplicate functionality on the "safe" > > SoCs. What kind of requirement is going to be violated in this way? > > From the perspective of a safe SoC, any software mitigation that compromises > the safety subsystem’s compliance should not be allowed. Enabling the > cooling device also opens up the sysfs interface for userspace, which we may > not fully control. THere are a lot of interfaces exported to the userspace. > Userspace apps or partner apps might inadvertently use > it. Therefore, we believe it is better not to expose such an interface, as > it is not required for that SoC and helps to avoid opening up an interface > that could potentially lead to a safety failure. How can thermal mitigation interface lead to safety failure? Userspace can possibly lower trip points, but it can not override existing firmware-based mitigation. And if there is a known problem with the interface, it should be fixed instead. > > Best Regards, > > Manaf > > >
On 10.01.2025 12:54 AM, Dmitry Baryshkov wrote: > On Wed, Jan 08, 2025 at 09:38:19PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >> >> Hi Dmitry, >> >> >> On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: >>> On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>> Hi Dmitry, >>>> >>>> >>>> On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: >>>>> On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>>>> Hi Dmitry, >>>>>> >>>>>> On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: >>>>>>> On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: >>>>>>>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>>>>>>> >>>>>>>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and >>>>>>>> does corrective action for each subsystem based on sensor violation >>>>>>>> to comply safety standards. But as QCS9075 is non-safe SoC it >>>>>>>> requires conventional thermal mitigation to control thermal for >>>>>>>> different subsystems. >>>>>>>> >>>>>>>> The cpu frequency throttling for different cpu tsens is enabled in >>>>>>>> hardware as first defense for cpu thermal control. But QCS9075 SoC >>>>>>>> has higher ambient specification. During high ambient condition, even >>>>>>>> lowest frequency with multi cores can slowly build heat over the time >>>>>>>> and it can lead to thermal run-away situations. This patch restrict >>>>>>>> cpu cores during this scenario helps further thermal control and >>>>>>>> avoids thermal critical violation. >>>>>>>> >>>>>>>> Add cpu idle injection cooling bindings for cpu tsens thermal zones >>>>>>>> as a mitigation for cpu subsystem prior to thermal shutdown. >>>>>>>> >>>>>>>> Add cpu frequency cooling devices that will be used by userspace >>>>>>>> thermal governor to mitigate skin thermal management. >>>>>>> Does anything prevent us from having this config as a part of the basic >>>>>>> sa8775p.dtsi setup? If HW is present in the base version but it is not >>>>>>> accessible for whatever reason, please move it the base device config >>>>>>> and use status "disabled" or "reserved" to the respective board files. >>>>>> Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep >>>>>> it disabled state. #cooling cells property for CPU, still wanted to keep it >>>>>> in board files as we don't want to enable any cooling device in base DT. >>>>> "we don't want" is not a proper justification. So, no. >>>> As noted in the commit, thermal cooling mitigation is only necessary for >>>> non-safe SoCs. Adding this cooling cell property to the CPU node in the base >>>> DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would >>>> violate the requirements for safe SoCs. Therefore, we will include it only >>>> in non-safe SoC boards. >>> "is only necessary" is fine. It means that it is an optional part which >>> is going to be unused / ignored / duplicate functionality on the "safe" >>> SoCs. What kind of requirement is going to be violated in this way? >> >> From the perspective of a safe SoC, any software mitigation that compromises >> the safety subsystem’s compliance should not be allowed. Enabling the >> cooling device also opens up the sysfs interface for userspace, which we may >> not fully control. > > THere are a lot of interfaces exported to the userspace. > >> Userspace apps or partner apps might inadvertently use >> it. Therefore, we believe it is better not to expose such an interface, as >> it is not required for that SoC and helps to avoid opening up an interface >> that could potentially lead to a safety failure. > > How can thermal mitigation interface lead to safety failure? Userspace > can possibly lower trip points, but it can not override existing > firmware-based mitigation. > And if there is a known problem with the interface, it should be fixed > instead. I think the intended case to avoid is where a malicious actor would set the trips too low, resulting in throttling down the CPU to FMIN / Linux throttling CPUs to try and escape what it believes to be possible thermal runaway / a system reboot. Not something desired in a car. Konrad
On Fri, Jan 10, 2025 at 01:31:00PM +0100, Konrad Dybcio wrote: > On 10.01.2025 12:54 AM, Dmitry Baryshkov wrote: > > On Wed, Jan 08, 2025 at 09:38:19PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > >> > >> Hi Dmitry, > >> > >> > >> On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: > >>> On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > >>>> Hi Dmitry, > >>>> > >>>> > >>>> On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: > >>>>> On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > >>>>>> Hi Dmitry, > >>>>>> > >>>>>> On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: > >>>>>>> On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: > >>>>>>>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > >>>>>>>> > >>>>>>>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > >>>>>>>> does corrective action for each subsystem based on sensor violation > >>>>>>>> to comply safety standards. But as QCS9075 is non-safe SoC it > >>>>>>>> requires conventional thermal mitigation to control thermal for > >>>>>>>> different subsystems. > >>>>>>>> > >>>>>>>> The cpu frequency throttling for different cpu tsens is enabled in > >>>>>>>> hardware as first defense for cpu thermal control. But QCS9075 SoC > >>>>>>>> has higher ambient specification. During high ambient condition, even > >>>>>>>> lowest frequency with multi cores can slowly build heat over the time > >>>>>>>> and it can lead to thermal run-away situations. This patch restrict > >>>>>>>> cpu cores during this scenario helps further thermal control and > >>>>>>>> avoids thermal critical violation. > >>>>>>>> > >>>>>>>> Add cpu idle injection cooling bindings for cpu tsens thermal zones > >>>>>>>> as a mitigation for cpu subsystem prior to thermal shutdown. > >>>>>>>> > >>>>>>>> Add cpu frequency cooling devices that will be used by userspace > >>>>>>>> thermal governor to mitigate skin thermal management. > >>>>>>> Does anything prevent us from having this config as a part of the basic > >>>>>>> sa8775p.dtsi setup? If HW is present in the base version but it is not > >>>>>>> accessible for whatever reason, please move it the base device config > >>>>>>> and use status "disabled" or "reserved" to the respective board files. > >>>>>> Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep > >>>>>> it disabled state. #cooling cells property for CPU, still wanted to keep it > >>>>>> in board files as we don't want to enable any cooling device in base DT. > >>>>> "we don't want" is not a proper justification. So, no. > >>>> As noted in the commit, thermal cooling mitigation is only necessary for > >>>> non-safe SoCs. Adding this cooling cell property to the CPU node in the base > >>>> DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would > >>>> violate the requirements for safe SoCs. Therefore, we will include it only > >>>> in non-safe SoC boards. > >>> "is only necessary" is fine. It means that it is an optional part which > >>> is going to be unused / ignored / duplicate functionality on the "safe" > >>> SoCs. What kind of requirement is going to be violated in this way? > >> > >> From the perspective of a safe SoC, any software mitigation that compromises > >> the safety subsystem’s compliance should not be allowed. Enabling the > >> cooling device also opens up the sysfs interface for userspace, which we may > >> not fully control. > > > > THere are a lot of interfaces exported to the userspace. > > > >> Userspace apps or partner apps might inadvertently use > >> it. Therefore, we believe it is better not to expose such an interface, as > >> it is not required for that SoC and helps to avoid opening up an interface > >> that could potentially lead to a safety failure. > > > > How can thermal mitigation interface lead to safety failure? Userspace > > can possibly lower trip points, but it can not override existing > > firmware-based mitigation. > > And if there is a known problem with the interface, it should be fixed > > instead. > > I think the intended case to avoid is where a malicious actor would set > the trips too low, resulting in throttling down the CPU to FMIN / Linux > throttling CPUs to try and escape what it believes to be possible thermal > runaway / a system reboot. Not something desired in a car. Being able to set trip points via sysfs means that the system is already compromised. At this point it can do whatever the actor wants - e.g. display malicious HUD or just a gren bar or black screen, scream into dynamic, etc. That doesn't sound like the temperature trip points being the only or the major problem of a car. Anyway, if that's really the only problem, please use the framework to make the temperature and hysteresis of the trip point R/O for sa8775p / qcs9100. Other attributes might need to be made R/O too. It well might be that I'm missing one of the automotive peculiarties here. In such a case the commit message should be more explicit that it's AGL or some other requirement and provide a link.
Hi Dmitry, Sorry, I was busy with some other priority tasks. On 1/10/2025 5:24 AM, Dmitry Baryshkov wrote: > On Wed, Jan 08, 2025 at 09:38:19PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >> Hi Dmitry, >> >> >> On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: >>> On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>> Hi Dmitry, >>>> >>>> >>>> On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: >>>>> On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: >>>>>> Hi Dmitry, >>>>>> >>>>>> On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: >>>>>>> On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: >>>>>>>> From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> >>>>>>>> >>>>>>>> In QCS9100 SoC, the safety subsystem monitors all thermal sensors and >>>>>>>> does corrective action for each subsystem based on sensor violation >>>>>>>> to comply safety standards. But as QCS9075 is non-safe SoC it >>>>>>>> requires conventional thermal mitigation to control thermal for >>>>>>>> different subsystems. >>>>>>>> >>>>>>>> The cpu frequency throttling for different cpu tsens is enabled in >>>>>>>> hardware as first defense for cpu thermal control. But QCS9075 SoC >>>>>>>> has higher ambient specification. During high ambient condition, even >>>>>>>> lowest frequency with multi cores can slowly build heat over the time >>>>>>>> and it can lead to thermal run-away situations. This patch restrict >>>>>>>> cpu cores during this scenario helps further thermal control and >>>>>>>> avoids thermal critical violation. >>>>>>>> >>>>>>>> Add cpu idle injection cooling bindings for cpu tsens thermal zones >>>>>>>> as a mitigation for cpu subsystem prior to thermal shutdown. >>>>>>>> >>>>>>>> Add cpu frequency cooling devices that will be used by userspace >>>>>>>> thermal governor to mitigate skin thermal management. >>>>>>> Does anything prevent us from having this config as a part of the basic >>>>>>> sa8775p.dtsi setup? If HW is present in the base version but it is not >>>>>>> accessible for whatever reason, please move it the base device config >>>>>>> and use status "disabled" or "reserved" to the respective board files. >>>>>> Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep >>>>>> it disabled state. #cooling cells property for CPU, still wanted to keep it >>>>>> in board files as we don't want to enable any cooling device in base DT. >>>>> "we don't want" is not a proper justification. So, no. >>>> As noted in the commit, thermal cooling mitigation is only necessary for >>>> non-safe SoCs. Adding this cooling cell property to the CPU node in the base >>>> DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would >>>> violate the requirements for safe SoCs. Therefore, we will include it only >>>> in non-safe SoC boards. >>> "is only necessary" is fine. It means that it is an optional part which >>> is going to be unused / ignored / duplicate functionality on the "safe" >>> SoCs. What kind of requirement is going to be violated in this way? >> From the perspective of a safe SoC, any software mitigation that compromises >> the safety subsystem’s compliance should not be allowed. Enabling the >> cooling device also opens up the sysfs interface for userspace, which we may >> not fully control. > THere are a lot of interfaces exported to the userspace. > >> Userspace apps or partner apps might inadvertently use >> it. Therefore, we believe it is better not to expose such an interface, as >> it is not required for that SoC and helps to avoid opening up an interface >> that could potentially lead to a safety failure. > How can thermal mitigation interface lead to safety failure? Userspace > can possibly lower trip points, but it can not override existing > firmware-based mitigation. Both firmware and software passive mitigations (CPU/GPU) are not permitted for Safe SoC. As mentioned in the commit, it is the responsibility of the safety subsystem to take corrective action for high temperatures. One of the safety requirements (not a functional requirement) for Safe SoC is to avoid scaling of CPUs and bus DCVS, as this could impact safety-critical workloads. Therefore, Safe SoC will operate at maximum frequency with the performance governor. Enabling a cooling device for the CPU would expose the cooling device sysfs interface, allowing userspace to request different cooling states via the cooling device cur_state sysfs, which could potentially lower the frequency and violate the safety requirement. > And if there is a known problem with the interface, it should be fixed > instead. There is no interface issue, as it is not required and can be disabled for Safe SoC. This approach has already been used for commercializing the SA8775P, and we do not want to disrupt it now. Therefore, we believe it is better not to add cpu cooling cell property (CPU cooling device) in sa8775p base dtsi. Best Regards, Manaf > >> Best Regards, >> >> Manaf >>
On Thu, Jan 09, 2025 at 05:16:25PM +0100, Krzysztof Kozlowski wrote: > On 09/01/2025 15:47, Wasim Nazir wrote: > > On Wed, Jan 08, 2025 at 03:09:09PM +0100, Krzysztof Kozlowski wrote: > >> On 03/01/2025 20:58, Dmitry Baryshkov wrote: > >>>>>>>> Initially, we included the DTS [1] file to avoid duplication. However, > >>>>>>>> based on Krzysztof's previous suggestion [2], we change to this format. > >>>>>>>> > >>>>>>>> Please let us know how to proceed further on this. > >>>>>>> > >>>>>>> Krzysztof asked you to include DTSI files instead of including DTS > >>>>>>> files. Hope this helps. > >>>>>> > >>>>>> Are you suggesting that we should also modify the 9100-ride files to > >>>>>> include DTSI instead of DTS for consistency between QCS9100 and QCS9075? > >>>>>> However, this would result in the duplication of Ethernet nodes in all > >>>>>> the ride board files. Would that be acceptable? > >>>>> > >>>>> git mv foo.dts foo.dtsi > >>>>> echo '#include "foo.dtsi"' > foo.dts > >>>>> git add foo.dts > >>>>> git commit > >>>>> > >>>> > >>>> We cannot convert sa8775p-ride-r3.dts and sa8775p-ride.dts to .dtsi as > >>>> they represent different platforms. In patch [1], we included these DTS > >>>> files to reuse the common hardware nodes. > >>>> > >>>> Could you please advise on how we should proceed with the following > >>>> approaches? > >>>> > >>>> a) Previous approach [1]: > >>>> Include sa8775p-ride-r3.dts and sa8775p-ride.dts in the qcs9075-ride > >>>> platform DTS, similar to the qcs9100-ride platform DTS. This approach > >>>> avoids duplicating Ethernet nodes and maintains uniformity. However, it > >>>> involves including the DTS file directly. > >>>> > >>>> b) Current suggestion: > >>>> Include sa8775p-ride.dtsi in the qcs9075-ride platform DTS and also > >>>> modify the qcs9100-ride platform DTS files to maintain uniformity. This > >>>> approach results in duplicating Ethernet nodes. > >>>> > >>>> Please let us know your recommendation to finalize the DT structure. > >>> > >>> sa8775p.dtsi > >>> `__sa8775p-ride.dtsi > >>> `__sa8775p-ride-r2.dtsi > >>> `__sa8775p-ride.dts > >>> `__qcs9100-ride.dts > >>> `__qcs9075-ride.dts > >>> `__sa8775p-ride-r3.dtsi > >>> `__sa8775p-ride-r3.dts > >>> `__qcs9100-ride-r3.dts > >>> `__qcs9075-ride-r3.dts > >>> > >> Wasim and all other copy-pasters of sa8775p-ride, > >> > >> Just to recap, qcs9100 contributions started this terrible pattern of > >> board including a board. Unfortunately qcs9100 was merged, so that ship > >> has sailed. > >> > >> This patchset was going the same way, because poor choices like to keep > >> spreading, but at one of previous versions I noticed it and objected. > >> > >> This v5 however solves above problem by duplicating the nodes. > >> > >> Apparently all these designs - sa8755p, qcs9100 and qcs9075 - use the > >> same board, but none of this was communicated. I checked all the commit > >> msgs in this patchset and nothing explained about it. What annoys me is > >> that you do not communicate your design forcing us to accept poor DTS or > >> forcing us to guess and make poor judgments. > >> > >> Come with proper hardware description and split out shared parts, like > >> motherboard. Look how other vendors are doing it, e.g. NXP or Renesas. > >> But assuming there are shared parts because I am pretty sure you will > >> pick my comments when it suits you without actually following them fully > >> and without understanding and explaining to us your own hardware. > >> > > > > Hi Krzysztof, > > > > Here is the pictorial flow showing how SoCs are derived and what all boards > > are supported. > > > > +---------------------------------------------------------------------+ > > | | > > | sa8775p | > > | | | > > | +-----------------------+-----------------------+ | > > | | | | | > > | v | v | > > | qcs9100 | qcs9075 | > > | | | | | > > | v v v | > > | (IOT) (AUTO) (IOT) | > > | qcs9100-ride.dts sa8775p-ride.dts qcs9075-ride.dts | > > | qcs9100-ride-r3.dts sa8775p-ride-r3.dts qcs9075-ride-r3.dts | > > | qcs9075-rb8.dts | > > | | > > +---------------------------------------------------------------------+ > > The the SoC, I am asking about the board. Why each of them is for > example r3? > > So this is not sufficient explanation, nothing about the board, and > again just look Renesas and NXP. > Hi Krzysztof, sa8775p(AUTO), qcs9100(IOT), qcs9075(IOT) are different SoCs based on safety capabilities and memory map, serving different purpose. Ride & Ride-r3 are different boards based on ethernet capabilities and are compatible with all the SoCs mentioned. With the combination of these 3 SoCs and 2 boards, we have 6 platforms, all of which we need. - sa8775p-ride.dts is auto grade Ride platform with safety feature. - qcs9100-ride.dts is IOT grade Ride platform with safety feature. - qcs9075-ride.dts is IOT grade Ride platform without safety feature. Since the Ride-r3 boards are essentially Ride boards with Ethernet modifications, we can convert the Ride-r3 DTS to overlays. Please let me know if this solution works for you. > > Best regards, > Krzysztof Thanks & Regards, Wasim
On 15/01/2025 06:48, Wasim Nazir wrote: >> The the SoC, I am asking about the board. Why each of them is for >> example r3? >> >> So this is not sufficient explanation, nothing about the board, and >> again just look Renesas and NXP. >> > > Hi Krzysztof, > > sa8775p(AUTO), qcs9100(IOT), qcs9075(IOT) are different SoCs based on > safety capabilities and memory map, serving different purpose. > Ride & Ride-r3 are different boards based on ethernet capabilities and > are compatible with all the SoCs mentioned. Compatible? What does it mean for a board? Third time: did you look how other vendors do it? > > With the combination of these 3 SoCs and 2 boards, we have 6 platforms, > all of which we need. > - sa8775p-ride.dts is auto grade Ride platform with safety feature. > - qcs9100-ride.dts is IOT grade Ride platform with safety feature. > - qcs9075-ride.dts is IOT grade Ride platform without safety feature. > > Since the Ride-r3 boards are essentially Ride boards with Ethernet > modifications, we can convert the Ride-r3 DTS to overlays. How one board can be with multiple SoCs? If it is soldered, it's close to impossible - that's just not the same board. If it is not soldered, why you are not explaining it? What is Ride board? What is there? What can go there? How it can be used in other SoCs? Or for which SoCs? Is there a datasheet available? You keep repeating my about SoC and I keep responding the same: don't care. Best regards, Krzysztof
On Wed, Jan 15, 2025 at 12:46:50AM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > Hi Dmitry, > > Sorry, I was busy with some other priority tasks. > > On 1/10/2025 5:24 AM, Dmitry Baryshkov wrote: > > On Wed, Jan 08, 2025 at 09:38:19PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > > Hi Dmitry, > > > > > > > > > On 1/8/2025 6:16 PM, Dmitry Baryshkov wrote: > > > > On Wed, Jan 08, 2025 at 05:57:06PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > > > > Hi Dmitry, > > > > > > > > > > > > > > > On 1/3/2025 11:21 AM, Dmitry Baryshkov wrote: > > > > > > On Tue, Dec 31, 2024 at 05:31:41PM +0530, Manaf Meethalavalappu Pallikunhi wrote: > > > > > > > Hi Dmitry, > > > > > > > > > > > > > > On 12/30/2024 9:10 PM, Dmitry Baryshkov wrote: > > > > > > > > On Sun, Dec 29, 2024 at 08:53:32PM +0530, Wasim Nazir wrote: > > > > > > > > > From: Manaf Meethalavalappu Pallikunhi <quic_manafm@quicinc.com> > > > > > > > > > > > > > > > > > > In QCS9100 SoC, the safety subsystem monitors all thermal sensors and > > > > > > > > > does corrective action for each subsystem based on sensor violation > > > > > > > > > to comply safety standards. But as QCS9075 is non-safe SoC it > > > > > > > > > requires conventional thermal mitigation to control thermal for > > > > > > > > > different subsystems. > > > > > > > > > > > > > > > > > > The cpu frequency throttling for different cpu tsens is enabled in > > > > > > > > > hardware as first defense for cpu thermal control. But QCS9075 SoC > > > > > > > > > has higher ambient specification. During high ambient condition, even > > > > > > > > > lowest frequency with multi cores can slowly build heat over the time > > > > > > > > > and it can lead to thermal run-away situations. This patch restrict > > > > > > > > > cpu cores during this scenario helps further thermal control and > > > > > > > > > avoids thermal critical violation. > > > > > > > > > > > > > > > > > > Add cpu idle injection cooling bindings for cpu tsens thermal zones > > > > > > > > > as a mitigation for cpu subsystem prior to thermal shutdown. > > > > > > > > > > > > > > > > > > Add cpu frequency cooling devices that will be used by userspace > > > > > > > > > thermal governor to mitigate skin thermal management. > > > > > > > > Does anything prevent us from having this config as a part of the basic > > > > > > > > sa8775p.dtsi setup? If HW is present in the base version but it is not > > > > > > > > accessible for whatever reason, please move it the base device config > > > > > > > > and use status "disabled" or "reserved" to the respective board files. > > > > > > > Sure, I will move idle injection node for each cpu to sa8775p.dtsi and keep > > > > > > > it disabled state. #cooling cells property for CPU, still wanted to keep it > > > > > > > in board files as we don't want to enable any cooling device in base DT. > > > > > > "we don't want" is not a proper justification. So, no. > > > > > As noted in the commit, thermal cooling mitigation is only necessary for > > > > > non-safe SoCs. Adding this cooling cell property to the CPU node in the base > > > > > DT (sa8775p.dtsi), which is shared by both safe and non-safe SoCs, would > > > > > violate the requirements for safe SoCs. Therefore, we will include it only > > > > > in non-safe SoC boards. > > > > "is only necessary" is fine. It means that it is an optional part which > > > > is going to be unused / ignored / duplicate functionality on the "safe" > > > > SoCs. What kind of requirement is going to be violated in this way? > > > From the perspective of a safe SoC, any software mitigation that compromises > > > the safety subsystem’s compliance should not be allowed. Enabling the > > > cooling device also opens up the sysfs interface for userspace, which we may > > > not fully control. > > THere are a lot of interfaces exported to the userspace. > > > > > Userspace apps or partner apps might inadvertently use > > > it. Therefore, we believe it is better not to expose such an interface, as > > > it is not required for that SoC and helps to avoid opening up an interface > > > that could potentially lead to a safety failure. > > How can thermal mitigation interface lead to safety failure? Userspace > > can possibly lower trip points, but it can not override existing > > firmware-based mitigation. > Both firmware and software passive mitigations (CPU/GPU) are not permitted > for Safe SoC. Not permitted by whom? > As mentioned in the commit, it is the responsibility of the > safety subsystem to take corrective action for high temperatures. One of the > safety requirements (not a functional requirement) for Safe SoC is to avoid > scaling of CPUs and bus DCVS, as this could impact safety-critical > workloads. Therefore, Safe SoC will operate at maximum frequency with the > performance governor. Enabling a cooling device for the CPU would expose the > cooling device sysfs interface, allowing userspace to request different > cooling states via the cooling device cur_state sysfs, which could > potentially lower the frequency and violate the safety requirement. So, you disable thermal mitigation controls, but your description allows userspace to change the CPUfreq governor through sysfs. Isn't that also unsafe? > > And if there is a known problem with the interface, it should be fixed > > instead. > > There is no interface issue, as it is not required and can be disabled for > Safe SoC. This approach has already been used for commercializing the > SA8775P, and we do not want to disrupt it now. Therefore, we believe it is > better not to add cpu cooling cell property (CPU cooling device) in sa8775p > base dtsi. Okay, assuming SA8775P may not have any thermal-related properties, what is the issue with having them for the IoT-related QCS9100 device? So, you have an alternative proposal: rename sa8775p.dtsi to qcs9100.dtsi, defining a full set of thermal properties there and add sa8775p.dtsi which includes qcs9100.dtsi and just removes thermal and cpufreq nodes. Doing it in any other way, especially by including a random SoC-related include defeats the logic of the DTSI files. > > Best Regards, > > Manaf > > > > > > Best Regards, > > > > > > Manaf > > >