Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp541958rwb; Sat, 17 Sep 2022 09:43:10 -0700 (PDT) X-Google-Smtp-Source: AMsMyM7YRJIcGXi3QzTMwNq62D1K3OEYeeCeYD8buGaiNiWD/1N9CHJIuNcfAEHM0Q6eFbIWsmZC X-Received: by 2002:a17:902:d88b:b0:178:264b:5aa4 with SMTP id b11-20020a170902d88b00b00178264b5aa4mr5261612plz.44.1663432989923; Sat, 17 Sep 2022 09:43:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663432989; cv=none; d=google.com; s=arc-20160816; b=a3VbPKidycaap2veyf+GYzfatjYsdsRyMvspEfvxQUz/obC3PcwZ+Fw7aoQhmUEVn0 4SQzZ23R4zmr7FVivOqBX3W62q13nweaekZHgBMt9c1WQKkVtjvLKxtHnArtqIdbRL+E 9yJ7yHpd+OSVJCe1Xmi/Yc1uZj+40Vc62cc/SW/SGDXLNtan37sznz9pm057GWiNA7PI iZSUZZPaLj+n8J6mXufE6rx7KCv6MJEowHS0Tdqlbmv5YJUoiQiArrDWXQjEDY7gSX+I RAoFayxAmKwtq8JlEOK01smqzGbwE6ZU+edYhJi61IKwmLSiYRh0+nNraCR/yOx3pYVh kzLA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=N4M97A/EQ0mr29su3MiNovNGAF+wRRd5G3D9AvoU6EU=; b=uaajxXoO8vWLsa7tvDRqlMoFsXiFxR6n+C3MAlpH5CJQqOcGQXSiRyoJsSODp6Hv/q nBi0hAQHeJw7JbGX6Y8e2TtIkZ5Qvwj7C/uXdiI6dvoM94609cUdbvnY6+LDKpqC8zHU khnwB3t/K0WlIx2s6sLDZOD/l4EQXy/aicDy3Uk0Yf1X4ybTRUDmmeybxHRIediSqTmf VWO5oRWoPZAdeOPH5X7Jhn3Rm7CnYIzOvE2aCax0T0G8VLPnEs+cBGmqlrZ2vPw5/uR2 a1ivxjB3WRY9/BaCCAX22ty2Sg/9CshDijM9iVSniyQZ/JfUMXTl9Nhoktby+TcTesG/ U1lg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x191-20020a6386c8000000b004393c8d6181si15653146pgd.724.2022.09.17.09.42.58; Sat, 17 Sep 2022 09:43:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229662AbiIQQgW (ORCPT + 99 others); Sat, 17 Sep 2022 12:36:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34662 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229626AbiIQQgS (ORCPT ); Sat, 17 Sep 2022 12:36:18 -0400 Received: from relay06.th.seeweb.it (relay06.th.seeweb.it [IPv6:2001:4b7a:2000:18::167]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EBA452CCB6; Sat, 17 Sep 2022 09:36:15 -0700 (PDT) Received: from [192.168.1.101] (95.49.30.72.neoplus.adsl.tpnet.pl [95.49.30.72]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by m-r2.th.seeweb.it (Postfix) with ESMTPSA id 83F793F3BC; Sat, 17 Sep 2022 18:36:12 +0200 (CEST) Message-ID: <62b59cd4-39e1-ecb9-2ab2-8a5279566398@somainline.org> Date: Sat, 17 Sep 2022 18:36:11 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.2.2 Subject: Re: [PATCH 2/2] ARM: dts: qcom: Add support for Huawei Watch Content-Language: en-US To: Luca Weiss , linux-arm-msm@vger.kernel.org Cc: ~postmarketos/upstreaming@lists.sr.ht, phone-devel@vger.kernel.org, Arnd Bergmann , Olof Johansson , soc@kernel.org, Rob Herring , Krzysztof Kozlowski , Andy Gross , Bjorn Andersson , linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org References: <20220917152829.23568-1-luca@z3ntu.xyz> <20220917152829.23568-2-luca@z3ntu.xyz> From: Konrad Dybcio In-Reply-To: <20220917152829.23568-2-luca@z3ntu.xyz> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-5.4 required=5.0 tests=BAYES_00,NICE_REPLY_A, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 17.09.2022 17:28, Luca Weiss wrote: > Add support for this smartwatch, based on Snapdragon 400 SoC. > > Currently supported functionality: > * Internal storage > * USB > * Charger > * Power button > * Bluetooth > * Wifi > > Signed-off-by: Luca Weiss > --- > arch/arm/boot/dts/Makefile | 1 + > .../boot/dts/qcom-apq8026-huawei-sturgeon.dts | 343 ++++++++++++++++++ > 2 files changed, 344 insertions(+) > create mode 100644 arch/arm/boot/dts/qcom-apq8026-huawei-sturgeon.dts > > diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile > index 3bc6bd5c8238..55087f16d718 100644 > --- a/arch/arm/boot/dts/Makefile > +++ b/arch/arm/boot/dts/Makefile > @@ -1026,6 +1026,7 @@ dtb-$(CONFIG_ARCH_OXNAS) += \ > dtb-$(CONFIG_ARCH_QCOM) += \ > qcom-apq8016-sbc.dtb \ > qcom-apq8026-asus-sparrow.dtb \ > + qcom-apq8026-huawei-sturgeon.dtb \ > qcom-apq8026-lg-lenok.dtb \ > qcom-apq8060-dragonboard.dtb \ > qcom-apq8064-cm-qs600.dtb \ > diff --git a/arch/arm/boot/dts/qcom-apq8026-huawei-sturgeon.dts b/arch/arm/boot/dts/qcom-apq8026-huawei-sturgeon.dts > new file mode 100644 > index 000000000000..e43fcef7144c > --- /dev/null > +++ b/arch/arm/boot/dts/qcom-apq8026-huawei-sturgeon.dts > @@ -0,0 +1,343 @@ > +// SPDX-License-Identifier: BSD-3-Clause > +/* > + * Copyright (c) 2022, Luca Weiss > + */ > + > +/dts-v1/; > + > +#include "qcom-msm8226.dtsi" > +#include "qcom-pm8226.dtsi" > + > +/delete-node/ &adsp_region; > + > +/ { > + model = "Huawei Watch"; > + compatible = "huawei,sturgeon", "qcom,apq8026"; > + chassis-type = "watch"; > + qcom,msm-id = <199 0x20000>; > + qcom,board-id = <8 4>; > + > + reserved-memory { > + sbl_region: sbl@2f00000 { > + reg = <0x02f00000 0x100000>; > + no-map; > + }; Please add newlines after each }; here and in pm*-regulators and make the status property last on referenced nodes. Otherwise LGTM. Konrad > + external_image_region: external-image@3100000 { > + reg = <0x3100000 0x200000>; > + no-map; > + }; > + peripheral_region: peripheral@3300000 { > + reg = <0x3300000 0x600000>; > + no-map; > + }; > + adsp_region: adsp@3900000 { > + reg = <0x3900000 0x1400000>; > + no-map; > + }; > + modem_region: modem@4d00000 { > + reg = <0x4d00000 0x1b00000>; > + no-map; > + }; > + modem_efs_region: modem-efs@7f00000 { > + reg = <0x7f00000 0x100000>; > + no-map; > + }; > + }; > + > + vreg_wlan: wlan-regulator { > + compatible = "regulator-fixed"; > + > + regulator-name = "wl-reg"; > + regulator-min-microvolt = <2950000>; > + regulator-max-microvolt = <2950000>; > + > + gpio = <&tlmm 110 GPIO_ACTIVE_HIGH>; > + enable-active-high; > + > + pinctrl-names = "default"; > + pinctrl-0 = <&wlan_regulator_default_state>; > + }; > +}; > + > +&adsp { > + status = "okay"; > +}; > + > +&blsp1_i2c5 { > + status = "okay"; > + clock-frequency = <384000>; > + > + touchscreen@20 { > + compatible = "syna,rmi4-i2c"; > + reg = <0x20>; > + > + interrupts-extended = <&tlmm 17 IRQ_TYPE_EDGE_FALLING>; > + vdd-supply = <&pm8226_l19>; > + vio-supply = <&pm8226_lvs1>; > + > + pinctrl-names = "default"; > + pinctrl-0 = <&touch_default_state>; > + > + syna,startup-delay-ms = <160>; > + > + #address-cells = <1>; > + #size-cells = <0>; > + > + rmi4-f01@1 { > + reg = <0x1>; > + syna,nosleep-mode = <1>; > + }; > + > + rmi4-f12@12 { > + reg = <0x12>; > + syna,sensor-type = <1>; > + }; > + }; > +}; > + > +&blsp1_uart4 { > + status = "okay"; > + > + pinctrl-names = "default"; > + pinctrl-0 = <&blsp1_uart4_default_state>; > + > + bluetooth { > + compatible = "brcm,bcm43430a0-bt"; > + max-speed = <3000000>; > + > + pinctrl-names = "default"; > + pinctrl-0 = <&bluetooth_default_state>; > + > + host-wakeup-gpios = <&tlmm 64 GPIO_ACTIVE_HIGH>; > + device-wakeup-gpios = <&tlmm 63 GPIO_ACTIVE_HIGH>; > + shutdown-gpios = <&tlmm 67 GPIO_ACTIVE_HIGH>; > + }; > +}; > + > +&rpm_requests { > + pm8226-regulators { > + compatible = "qcom,rpm-pm8226-regulators"; > + > + pm8226_s3: s3 { > + regulator-min-microvolt = <1200000>; > + regulator-max-microvolt = <1300000>; > + }; > + pm8226_s4: s4 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <2200000>; > + }; > + pm8226_s5: s5 { > + regulator-min-microvolt = <1150000>; > + regulator-max-microvolt = <1150000>; > + }; > + > + pm8226_l1: l1 { > + regulator-min-microvolt = <1225000>; > + regulator-max-microvolt = <1225000>; > + }; > + pm8226_l2: l2 { > + regulator-min-microvolt = <1200000>; > + regulator-max-microvolt = <1200000>; > + }; > + pm8226_l3: l3 { > + regulator-min-microvolt = <750000>; > + regulator-max-microvolt = <1337500>; > + }; > + pm8226_l4: l4 { > + regulator-min-microvolt = <1200000>; > + regulator-max-microvolt = <1200000>; > + }; > + pm8226_l5: l5 { > + regulator-min-microvolt = <1200000>; > + regulator-max-microvolt = <1200000>; > + }; > + pm8226_l6: l6 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + }; > + pm8226_l7: l7 { > + regulator-min-microvolt = <1850000>; > + regulator-max-microvolt = <1850000>; > + }; > + pm8226_l8: l8 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + }; > + pm8226_l9: l9 { > + regulator-min-microvolt = <2050000>; > + regulator-max-microvolt = <2050000>; > + }; > + pm8226_l10: l10 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + }; > + pm8226_l12: l12 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <1800000>; > + }; > + pm8226_l14: l14 { > + regulator-min-microvolt = <2750000>; > + regulator-max-microvolt = <2750000>; > + }; > + pm8226_l15: l15 { > + regulator-min-microvolt = <2800000>; > + regulator-max-microvolt = <2800000>; > + }; > + pm8226_l16: l16 { > + regulator-min-microvolt = <3000000>; > + regulator-max-microvolt = <3350000>; > + }; > + pm8226_l17: l17 { > + regulator-min-microvolt = <2950000>; > + regulator-max-microvolt = <2950000>; > + }; > + pm8226_l18: l18 { > + regulator-min-microvolt = <2950000>; > + regulator-max-microvolt = <2950000>; > + }; > + pm8226_l19: l19 { > + regulator-min-microvolt = <2850000>; > + regulator-max-microvolt = <2850000>; > + }; > + pm8226_l20: l20 { > + regulator-min-microvolt = <3075000>; > + regulator-max-microvolt = <3075000>; > + }; > + pm8226_l21: l21 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <2950000>; > + }; > + pm8226_l22: l22 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <2950000>; > + }; > + pm8226_l23: l23 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <2950000>; > + }; > + pm8226_l24: l24 { > + regulator-min-microvolt = <1300000>; > + regulator-max-microvolt = <1350000>; > + }; > + pm8226_l25: l25 { > + regulator-min-microvolt = <1775000>; > + regulator-max-microvolt = <2125000>; > + }; > + pm8226_l26: l26 { > + regulator-min-microvolt = <1225000>; > + regulator-max-microvolt = <1225000>; > + }; > + pm8226_l27: l27 { > + regulator-min-microvolt = <2050000>; > + regulator-max-microvolt = <2050000>; > + }; > + pm8226_l28: l28 { > + regulator-min-microvolt = <1800000>; > + regulator-max-microvolt = <2950000>; > + }; > + > + pm8226_lvs1: lvs1 {}; > + }; > +}; > + > +&sdhc_1 { > + status = "okay"; > + > + vmmc-supply = <&pm8226_l17>; > + vqmmc-supply = <&pm8226_l6>; > + > + bus-width = <8>; > + non-removable; > +}; > + > +&sdhc_3 { > + status = "okay"; > + > + max-frequency = <100000000>; > + non-removable; > + > + vmmc-supply = <&vreg_wlan>; > + vqmmc-supply = <&pm8226_l6>; > + > + #address-cells = <1>; > + #size-cells = <0>; > + > + wifi@1 { > + compatible = "brcm,bcm43430a0-fmac", "brcm,bcm4329-fmac"; > + reg = <1>; > + > + interrupts-extended = <&tlmm 66 IRQ_TYPE_EDGE_FALLING>; > + interrupt-names = "host-wake"; > + > + pinctrl-names = "default"; > + pinctrl-0 = <&wlan_hostwake_default_state>; > + }; > +}; > + > +&smbb { > + qcom,fast-charge-safe-voltage = <4370000>; > + qcom,fast-charge-high-threshold-voltage = <4350000>; > + qcom,minimum-input-voltage = <4350000>; > + qcom,fast-charge-current-limit = <300000>; > + qcom,fast-charge-safe-current = <600000>; > + qcom,auto-recharge-threshold-voltage = <4240000>; > +}; > + > +&tlmm { > + blsp1_uart4_default_state: blsp1-uart4-default-state { > + pins = "gpio12", "gpio13", "gpio14", "gpio15"; > + function = "blsp_uart4"; > + drive-strength = <8>; > + bias-disable; > + }; > + > + bluetooth_default_state: bluetooth-default-state { > + pins = "gpio63", "gpio64"; > + function = "gpio"; > + drive-strength = <2>; > + bias-pull-down; > + }; > + > + touch_default_state: touch-default-state { > + irq { > + pins = "gpio17"; > + function = "gpio"; > + drive-strength = <8>; > + bias-pull-up; > + }; > + > + reset { > + pins = "gpio16"; > + function = "gpio"; > + drive-strength = <6>; > + bias-pull-up; > + }; > + }; > + > + wlan_hostwake_default_state: wlan-hostwake-default-state { > + pins = "gpio66"; > + function = "gpio"; > + drive-strength = <2>; > + bias-disable; > + input-enable; > + }; > + > + wlan_regulator_default_state: wlan-regulator-default-state { > + pins = "gpio110"; > + function = "gpio"; > + drive-strength = <2>; > + bias-pull-down; > + }; > +}; > + > +&usb { > + status = "okay"; > + extcon = <&smbb>; > + dr_mode = "peripheral"; > +}; > + > +&usb_hs_phy { > + extcon = <&smbb>; > + v1p8-supply = <&pm8226_l10>; > + v3p3-supply = <&pm8226_l20>; > +};