lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <b16a6936-b6b8-44cc-9c9f-3415cef54b29@amlogic.com>
Date: Mon, 22 Sep 2025 16:43:54 +0800
From: Keke Li <keke.li@...ogic.com>
To: Neil Armstrong <neil.armstrong@...aro.org>,
 Kevin Hilman <khilman@...libre.com>, Jerome Brunet <jbrunet@...libre.com>,
 Martin Blumenstingl <martin.blumenstingl@...glemail.com>,
 Rob Herring <robh@...nel.org>, Krzysztof Kozlowski <krzk+dt@...nel.org>,
 Conor Dooley <conor+dt@...nel.org>
Cc: linux-arm-kernel@...ts.infradead.org, linux-amlogic@...ts.infradead.org,
 devicetree@...r.kernel.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH RESEND] dts: arm64: amlogic: Add ISP related nodes for C3

Hi Neil

Thanks for your reply.

On 2025/9/19 22:43, Neil Armstrong wrote:
> [You don't often get email from neil.armstrong@...aro.org. Learn why 
> this is important at https://aka.ms/LearnAboutSenderIdentification ]
>
> [ EXTERNAL EMAIL ]
>
> On 18/09/2025 10:35, Keke Li via B4 Relay wrote:
>> From: Keke Li <keke.li@...ogic.com>
>>
>> Add the IMX290 sensor node description to the device tree file,
>> which will be controlled via I2C bus with image data transmission
>> through MIPI CSI-2 interface.
>>
>> Add CSI-2, adapter and ISP nodes for C3 family.
>>
>> Signed-off-by: Keke Li <keke.li@...ogic.com>
>> ---
>> The C3 ISP driver and device-tree bindings have been
>> submitted. To facilitate using the C3 ISP driver, the
>> related device nodes need to be added.
>
> No need to resend until the bindings are merged.
>
> Neil
>
https://lore.kernel.org/all/20250427-c3isp-v9-1-e0fe09433d94@amlogic.com/

https://lore.kernel.org/all/20250427-c3isp-v9-3-e0fe09433d94@amlogic.com/

https://lore.kernel.org/all/20250427-c3isp-v9-5-e0fe09433d94@amlogic.com/

The device-tree bindings for C3 ISP have been merged into the Linux 
kernel v6.16.

Thanks.

>> ---
>>   .../boot/dts/amlogic/amlogic-c3-c308l-aw419.dts    | 84 
>> +++++++++++++++++++++
>>   arch/arm64/boot/dts/amlogic/amlogic-c3.dtsi        | 88 
>> ++++++++++++++++++++++
>>   2 files changed, 172 insertions(+)
>>
>> diff --git a/arch/arm64/boot/dts/amlogic/amlogic-c3-c308l-aw419.dts 
>> b/arch/arm64/boot/dts/amlogic/amlogic-c3-c308l-aw419.dts
>> index 45f8631f9feb..e026604c55e6 100644
>> --- a/arch/arm64/boot/dts/amlogic/amlogic-c3-c308l-aw419.dts
>> +++ b/arch/arm64/boot/dts/amlogic/amlogic-c3-c308l-aw419.dts
>> @@ -17,6 +17,7 @@ / {
>>       aliases {
>>               serial0 = &uart_b;
>>               spi0 = &spifc;
>> +             i2c2 = &i2c2;
>>       };
>>
>>       memory@0 {
>> @@ -146,6 +147,36 @@ sdcard: regulator-sdcard {
>>               regulator-boot-on;
>>               regulator-always-on;
>>       };
>> +
>> +     camera_vdddo_1v8: regulator-camera-1v8 {
>> +             compatible = "regulator-fixed";
>> +             regulator-name = "CAMERA_VDDDO";
>> +             regulator-min-microvolt = <1800000>;
>> +             regulator-max-microvolt = <1800000>;
>> +             vin-supply = <&vcc_3v3>;
>> +             regulator-boot-on;
>> +             regulator-always-on;
>> +     };
>> +
>> +     camera_vdda_2v9: regulator-camera-2v9 {
>> +             compatible = "regulator-fixed";
>> +             regulator-name = "CAMERA_VDDA";
>> +             regulator-min-microvolt = <2900000>;
>> +             regulator-max-microvolt = <2900000>;
>> +             vin-supply = <&vcc_5v>;
>> +             regulator-boot-on;
>> +             regulator-always-on;
>> +     };
>> +
>> +     camera_vddd_1v2: regulator-camera-1v2 {
>> +             compatible = "regulator-fixed";
>> +             regulator-name = "CAMERA_VDDD";
>> +             regulator-min-microvolt = <1200000>;
>> +             regulator-max-microvolt = <1200000>;
>> +             vin-supply = <&vcc_3v3>;
>> +             regulator-boot-on;
>> +             regulator-always-on;
>> +     };
>>   };
>>
>>   &uart_b {
>> @@ -258,3 +289,56 @@ &sd {
>>       vmmc-supply = <&sdcard>;
>>       vqmmc-supply = <&sdcard>;
>>   };
>> +
>> +&i2c2 {
>> +     status = "okay";
>> +     pinctrl-names = "default";
>> +     pinctrl-0 = <&i2c2_pins1>;
>> +     clock-frequency = <100000>; /* default 100k */
>> +
>> +     imx290: sensor0@1a {
>> +             compatible = "sony,imx290";
>> +             reg = <0x1a>;
>> +             clocks = <&clkc_pll CLKID_MCLK0>;
>> +             clock-names = "xclk";
>> +             clock-frequency = <37125000>;
>> +             assigned-clocks = <&clkc_pll CLKID_MCLK_PLL>,
>> +                               <&clkc_pll CLKID_MCLK0>;
>> +             assigned-clock-rates = <74250000>, <37125000>;
>> +
>> +             vdddo-supply = <&camera_vdddo_1v8>;
>> +             vdda-supply = <&camera_vdda_2v9>;
>> +             vddd-supply = <&camera_vddd_1v2>;
>> +
>> +             reset-gpios = <&gpio GPIOE_4 GPIO_ACTIVE_LOW>;
>> +
>> +             port {
>> +                     imx290_out: endpoint {
>> +                             data-lanes = <1 2 3 4>;
>> +                             link-frequencies = /bits/ 64 <222750000 
>> 148500000>;
>> +                             remote-endpoint = <&c3_mipi_csi_in>;
>> +                     };
>> +             };
>> +     };
>> +};
>> +
>> +&csi2 {
>> +     status = "okay";
>> +
>> +     ports {
>> +             port@0 {
>> +                     c3_mipi_csi_in: endpoint {
>> +                             remote-endpoint = <&imx290_out>;
>> +                             data-lanes = <1 2 3 4>;
>> +                     };
>> +             };
>> +     };
>> +};
>> +
>> +&adap {
>> +     status = "okay";
>> +};
>> +
>> +&isp {
>> +     status = "okay";
>> +};
>> diff --git a/arch/arm64/boot/dts/amlogic/amlogic-c3.dtsi 
>> b/arch/arm64/boot/dts/amlogic/amlogic-c3.dtsi
>> index cb9ea3ca6ee0..a62fd8534209 100644
>> --- a/arch/arm64/boot/dts/amlogic/amlogic-c3.dtsi
>> +++ b/arch/arm64/boot/dts/amlogic/amlogic-c3.dtsi
>> @@ -992,5 +992,93 @@ mdio0: mdio {
>>                               #size-cells = <0>;
>>                       };
>>               };
>> +
>> +             csi2: csi2@...18000 {
>> +                     compatible = "amlogic,c3-mipi-csi2";
>> +                     reg = <0x0 0xff018000 0x0 0x100>,
>> +                           <0x0 0xff019000 0x0 0x300>,
>> +                           <0x0 0xff01a000 0x0 0x100>;
>> +                     reg-names = "aphy", "dphy", "host";
>> +                     power-domains = <&pwrc PWRC_C3_MIPI_ISP_WRAP_ID>;
>> +                     clocks = <&clkc_periphs CLKID_VAPB>,
>> +                              <&clkc_periphs CLKID_CSI_PHY0>;
>> +                     clock-names = "vapb", "phy0";
>> +                     assigned-clocks = <&clkc_periphs CLKID_VAPB>,
>> +                                       <&clkc_periphs CLKID_CSI_PHY0>;
>> +                     assigned-clock-rates = <0>, <200000000>;
>> +                     status = "disabled";
>> +
>> +                     ports {
>> +                             #address-cells = <1>;
>> +                             #size-cells = <0>;
>> +
>> +                             port@0 {
>> +                                     reg = <0>;
>> +                             };
>> +
>> +                             port@1 {
>> +                                     reg = <1>;
>> +                                     c3_mipi_csi_out: endpoint {
>> +                                             remote-endpoint = 
>> <&c3_adap_in>;
>> +                                     };
>> +                             };
>> +                     };
>> +             };
>> +
>> +             adap: adap@...10000 {
>> +                     compatible = "amlogic,c3-mipi-adapter";
>> +                     reg = <0x0 0xff010000 0x0 0x100>,
>> +                           <0x0 0xff01b000 0x0 0x100>,
>> +                           <0x0 0xff01d000 0x0 0x200>;
>> +                     reg-names = "top", "fd", "rd";
>> +                     power-domains = <&pwrc PWRC_C3_ISP_TOP_ID>;
>> +                     clocks = <&clkc_periphs CLKID_VAPB>,
>> +                              <&clkc_periphs CLKID_ISP0>;
>> +                     clock-names = "vapb", "isp0";
>> +                     assigned-clocks = <&clkc_periphs CLKID_VAPB>,
>> +                                       <&clkc_periphs CLKID_ISP0>;
>> +                     assigned-clock-rates = <0>, <400000000>;
>> +                     status = "disabled";
>> +
>> +                     ports {
>> +                             #address-cells = <1>;
>> +                             #size-cells = <0>;
>> +
>> +                             port@0 {
>> +                                     reg = <0>;
>> +                                     c3_adap_in: endpoint {
>> +                                             remote-endpoint = 
>> <&c3_mipi_csi_out>;
>> +                                     };
>> +                             };
>> +
>> +                             port@1 {
>> +                                     reg = <1>;
>> +                                     c3_adap_out: endpoint {
>> +                                             remote-endpoint = 
>> <&c3_isp_in>;
>> +                                     };
>> +                             };
>> +                     };
>> +             };
>> +
>> +             isp: isp@...00000 {
>> +                     compatible = "amlogic,c3-isp";
>> +                     reg = <0x0 0xff000000 0x0 0xf000>;
>> +                     reg-names = "isp";
>> +                     power-domains = <&pwrc PWRC_C3_ISP_TOP_ID>;
>> +                     clocks = <&clkc_periphs CLKID_VAPB>,
>> +                              <&clkc_periphs CLKID_ISP0>;
>> +                     clock-names = "vapb", "isp0";
>> +                     assigned-clocks = <&clkc_periphs CLKID_VAPB>,
>> +                                       <&clkc_periphs CLKID_ISP0>;
>> +                     assigned-clock-rates = <0>, <400000000>;
>> +                     interrupts = <GIC_SPI 145 IRQ_TYPE_EDGE_RISING>;
>> +                     status = "disabled";
>> +
>> +                     port {
>> +                             c3_isp_in: endpoint {
>> +                                     remote-endpoint = <&c3_adap_out>;
>> +                             };
>> +                     };
>> +             };
>>       };
>>   };
>>
>> ---
>> base-commit: 84b92a499e7eca54ba1df6f6c6e01766025943f1
>> change-id: 20250731-b4-c3isp-16531391a1cb
>>
>> Best regards,
>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ