Received: by 2002:a25:d783:0:0:0:0:0 with SMTP id o125csp831531ybg; Thu, 19 Mar 2020 09:30:18 -0700 (PDT) X-Google-Smtp-Source: ADFU+vuNuMVwj8jWoQcWoAZtDlSz5/4Zy4Ak7gaQFZMTdFXEfPgAhT5Gck4Lcf+9+LswjdpdvDwf X-Received: by 2002:aca:b608:: with SMTP id g8mr3068928oif.142.1584635418656; Thu, 19 Mar 2020 09:30:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584635418; cv=none; d=google.com; s=arc-20160816; b=EnwM7aoftx8tsbvw2K8ZE7mVs7dRetWGcZmng8ad1jRisVi5FXWJl5dLGTKfIS/w9l OzyNhY7J4hswZOM4D3mreW6Dhtnv2itixB2gLQLaGXHi0sHKKP5XaCwLEx53km7DVMxw xw639vevs6MyAK70KBnAlpPBnkKYX82Ps/5UdpIBUvC9t392vAfZXJMDMn7wJ03RGTYU RMNv19aXHxklDyLMC2J3d9+UQ9GgFZzNpAtFqwKfHgmn2RAbtI5In4uDLJbbf0NSorfK S/2Xnw6xFIO+5skfHDZ36B6kDfL+Wvy1cWKozyBmAJa1ujl7UX6opVcoePO176dV6Lvg fIXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=mgORAq16+bXXbmo/R9JEseEAbVFJw1GWYY1NsB68hTQ=; b=rVI3PVboBDy5MhcEE+FFCEuN6mDAQI97/V5lJ7A9ArPbDD09lE3+Ag/UIE7rkZTrRi JCcDPnZ2cS727SvttSa+lxfuqqV6jr25fty1nZsqLw60YLGeGL8TMW2hYNksPmp+AAEL AP9f9C8ao2XUSRGb+sy/O6xhe/dQJQ+7dE9oNGsPRLI3HOzgQTDHq3TzUTbMMBxAjdBq YhA0Sf0/HOs73Oxffl1NeU5oApHhCvCv80NFEydtLARMf1/ECemXq19Y9V1q+lxxWhq5 2nxSqc0nyI5aVypMlNBG7k5UpUAfucZ9pqHNxCLRnYzLOkl5GiWydfvL4qbxe8WyOavU 3uvA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i15si1257738oib.46.2020.03.19.09.30.05; Thu, 19 Mar 2020 09:30:18 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728576AbgCSQ3P (ORCPT + 99 others); Thu, 19 Mar 2020 12:29:15 -0400 Received: from foss.arm.com ([217.140.110.172]:38620 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727928AbgCSQ3J (ORCPT ); Thu, 19 Mar 2020 12:29:09 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 2D60830E; Thu, 19 Mar 2020 09:29:08 -0700 (PDT) Received: from [192.168.1.123] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 347323F52E; Thu, 19 Mar 2020 09:29:07 -0700 (PDT) Subject: Re: [PATCH] ARM: dts: rockchip: move uart2 pinctrl settings to each dts for rk3288 To: Katsuhiro Suzuki , =?UTF-8?Q?Heiko_St=c3=bcbner?= Cc: linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org References: <20200319151339.17909-1-katsuhiro@katsuster.net> <4307911.4IBKxFWOMT@diego> <8eed33d8-142c-28cf-7fa4-faf9bebb13cf@katsuster.net> From: Robin Murphy Message-ID: <4d93b050-6185-0d39-c89a-ac7fb6fc7780@arm.com> Date: Thu, 19 Mar 2020 16:29:06 +0000 User-Agent: Mozilla/5.0 (Windows NT 10.0; rv:68.0) Gecko/20100101 Thunderbird/68.6.0 MIME-Version: 1.0 In-Reply-To: <8eed33d8-142c-28cf-7fa4-faf9bebb13cf@katsuster.net> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2020-03-19 3:58 pm, Katsuhiro Suzuki wrote: > Hello Heiko, > > On 2020/03/20 0:25, Heiko Stübner wrote: >> Hi, >> >> Am Donnerstag, 19. März 2020, 16:13:39 CET schrieb Katsuhiro Suzuki: >>> This patch removes conflicted pinctrl settings uart2 and pwm 2/3 >>> from common rk3288.dtsi and moves exist uart2 pinctrl settings >>> into each rk3288*.dts files. >>> >>>    - pwm2_pin  : use GPIO7_C6 >>>    - pwm3_pin  : use GPIO7_C7 >>>    - uart2_xfer: use GPIO7_C6, GPIO7_C7 >> >> Board files only ever get to enable either pwm2/3 or uart2, >> not both at once - so I'm not sure where you see conflicts. >> > > At first, I think so too. But I've saw this message when booting. > > ---------- > [    2.435504] rockchip-pinctrl pinctrl: pin gpio7-22 already requested > by ff680020.pwm; cannot claim for ff690000.serial > [    2.447506] rockchip-pinctrl pinctrl: pin-238 (ff690000.serial) > status -22 > [    2.455198] rockchip-pinctrl pinctrl: could not request pin 238 > (gpio7-22) from group uart2-xfer  on device rockchip-pinctrl > ---------- > > And it seems that uart2(ttyS2) is not working correctly. > > ---------- > # cat /dev/ttyS2 > cat: /dev/ttyS2: Input/output error > ---------- > > I'm using newest linux-next, make defconfig and CONFIG_MODULES = n setting > with TinkerBoard. Can I resolve this issue in other ways? Do you perhaps have a DT overlay or bootloader script enabling pwm2? (try `cat /sys/firmware/devicetree/base/pwm@ff680020/status` for a sanity check). FWIW I don't recall ever seeing this on my RK3288 box. (or of course maybe there's just some pinctrl bug in -next that's claiming configs for disabled devices) Robin. > > Best Regards, > Katsuhiro Suzuki > > >> And of course there are alternative pins to use, if you need uart2 >> you need both pins in uart-pinmux and if you need either as pwm, then >> the board by design just can't use them as uart2. >> >> So pin setting should stay where they are, as there really is no >> conflict. >> >> >> Heiko >> >> >> >>> Currently uart2 rk3288 user is the following: >>> >>>    - rk3288-evb.dtsi:&uart2 { >>>    - rk3288-firefly-reload.dts:&uart2 { >>>    - rk3288-firefly.dtsi:&uart2 { >>>    - rk3288-miqi.dts:&uart2 { >>>    - rk3288-phycore-rdk.dts:&uart2 { >>>    - rk3288-popmetal.dts:&uart2 { >>>    - rk3288-r89.dts:&uart2 { >>>    - rk3288-rock2-square.dts:&uart2 { >>>    - rk3288-tinker.dtsi:&uart2 { >>>    - rk3288-veyron.dtsi:&uart2 { >>>    - rk3288-vyasa.dts:&uart2 { >>> >>> And no one is using pwm2 nor pwm3. >>> >>> Signed-off-by: Katsuhiro Suzuki >>> --- >>>   arch/arm/boot/dts/rk3288-evb.dtsi           | 2 ++ >>>   arch/arm/boot/dts/rk3288-firefly-reload.dts | 2 ++ >>>   arch/arm/boot/dts/rk3288-firefly.dtsi       | 2 ++ >>>   arch/arm/boot/dts/rk3288-miqi.dts           | 2 ++ >>>   arch/arm/boot/dts/rk3288-phycore-rdk.dts    | 2 ++ >>>   arch/arm/boot/dts/rk3288-popmetal.dts       | 2 ++ >>>   arch/arm/boot/dts/rk3288-r89.dts            | 2 ++ >>>   arch/arm/boot/dts/rk3288-rock2-square.dts   | 2 ++ >>>   arch/arm/boot/dts/rk3288-tinker.dtsi        | 2 ++ >>>   arch/arm/boot/dts/rk3288-veyron.dtsi        | 2 ++ >>>   arch/arm/boot/dts/rk3288-vyasa.dts          | 2 ++ >>>   arch/arm/boot/dts/rk3288.dtsi               | 6 ------ >>>   12 files changed, 22 insertions(+), 6 deletions(-) >>> >>> diff --git a/arch/arm/boot/dts/rk3288-evb.dtsi >>> b/arch/arm/boot/dts/rk3288-evb.dtsi >>> index 018802df4c0e..74091f831ecf 100644 >>> --- a/arch/arm/boot/dts/rk3288-evb.dtsi >>> +++ b/arch/arm/boot/dts/rk3288-evb.dtsi >>> @@ -285,6 +285,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-firefly-reload.dts >>> b/arch/arm/boot/dts/rk3288-firefly-reload.dts >>> index 8c38bda21a7c..b0c976c8e35b 100644 >>> --- a/arch/arm/boot/dts/rk3288-firefly-reload.dts >>> +++ b/arch/arm/boot/dts/rk3288-firefly-reload.dts >>> @@ -283,6 +283,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-firefly.dtsi >>> b/arch/arm/boot/dts/rk3288-firefly.dtsi >>> index 5e0a19004e46..1632cc083c12 100644 >>> --- a/arch/arm/boot/dts/rk3288-firefly.dtsi >>> +++ b/arch/arm/boot/dts/rk3288-firefly.dtsi >>> @@ -532,6 +532,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-miqi.dts >>> b/arch/arm/boot/dts/rk3288-miqi.dts >>> index c41d012c8850..2c0ed37fde80 100644 >>> --- a/arch/arm/boot/dts/rk3288-miqi.dts >>> +++ b/arch/arm/boot/dts/rk3288-miqi.dts >>> @@ -379,6 +379,8 @@ &tsadc { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-phycore-rdk.dts >>> b/arch/arm/boot/dts/rk3288-phycore-rdk.dts >>> index 1e33859de484..6532c1ac43cd 100644 >>> --- a/arch/arm/boot/dts/rk3288-phycore-rdk.dts >>> +++ b/arch/arm/boot/dts/rk3288-phycore-rdk.dts >>> @@ -244,6 +244,8 @@ &uart0 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-popmetal.dts >>> b/arch/arm/boot/dts/rk3288-popmetal.dts >>> index 6a51940398b5..f18306bd9e6e 100644 >>> --- a/arch/arm/boot/dts/rk3288-popmetal.dts >>> +++ b/arch/arm/boot/dts/rk3288-popmetal.dts >>> @@ -481,6 +481,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-r89.dts >>> b/arch/arm/boot/dts/rk3288-r89.dts >>> index a258c7ae5329..02d2f5cfe201 100644 >>> --- a/arch/arm/boot/dts/rk3288-r89.dts >>> +++ b/arch/arm/boot/dts/rk3288-r89.dts >>> @@ -340,6 +340,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-rock2-square.dts >>> b/arch/arm/boot/dts/rk3288-rock2-square.dts >>> index cdcdc921ee09..a44290e882be 100644 >>> --- a/arch/arm/boot/dts/rk3288-rock2-square.dts >>> +++ b/arch/arm/boot/dts/rk3288-rock2-square.dts >>> @@ -264,6 +264,8 @@ &spdif { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-tinker.dtsi >>> b/arch/arm/boot/dts/rk3288-tinker.dtsi >>> index acfaa12ec239..0327119f71b4 100644 >>> --- a/arch/arm/boot/dts/rk3288-tinker.dtsi >>> +++ b/arch/arm/boot/dts/rk3288-tinker.dtsi >>> @@ -500,6 +500,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-veyron.dtsi >>> b/arch/arm/boot/dts/rk3288-veyron.dtsi >>> index 54a6838d73f5..baa44d00e49a 100644 >>> --- a/arch/arm/boot/dts/rk3288-veyron.dtsi >>> +++ b/arch/arm/boot/dts/rk3288-veyron.dtsi >>> @@ -412,6 +412,8 @@ &uart1 { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288-vyasa.dts >>> b/arch/arm/boot/dts/rk3288-vyasa.dts >>> index 385dd59393e1..aa50cdc7f839 100644 >>> --- a/arch/arm/boot/dts/rk3288-vyasa.dts >>> +++ b/arch/arm/boot/dts/rk3288-vyasa.dts >>> @@ -398,6 +398,8 @@ &tsadc { >>>   }; >>>   &uart2 { >>> +    pinctrl-names = "default"; >>> +    pinctrl-0 = <&uart2_xfer>; >>>       status = "okay"; >>>   }; >>> diff --git a/arch/arm/boot/dts/rk3288.dtsi >>> b/arch/arm/boot/dts/rk3288.dtsi >>> index 0cd88774db95..4c1f8cabb5eb 100644 >>> --- a/arch/arm/boot/dts/rk3288.dtsi >>> +++ b/arch/arm/boot/dts/rk3288.dtsi >>> @@ -450,8 +450,6 @@ uart2: serial@ff690000 { >>>           reg-io-width = <4>; >>>           clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>; >>>           clock-names = "baudclk", "apb_pclk"; >>> -        pinctrl-names = "default"; >>> -        pinctrl-0 = <&uart2_xfer>; >>>           status = "disabled"; >>>       }; >>> @@ -706,8 +704,6 @@ pwm2: pwm@ff680020 { >>>           compatible = "rockchip,rk3288-pwm"; >>>           reg = <0x0 0xff680020 0x0 0x10>; >>>           #pwm-cells = <3>; >>> -        pinctrl-names = "default"; >>> -        pinctrl-0 = <&pwm2_pin>; >>>           clocks = <&cru PCLK_RKPWM>; >>>           clock-names = "pwm"; >>>           status = "disabled"; >>> @@ -717,8 +713,6 @@ pwm3: pwm@ff680030 { >>>           compatible = "rockchip,rk3288-pwm"; >>>           reg = <0x0 0xff680030 0x0 0x10>; >>>           #pwm-cells = <3>; >>> -        pinctrl-names = "default"; >>> -        pinctrl-0 = <&pwm3_pin>; >>>           clocks = <&cru PCLK_RKPWM>; >>>           clock-names = "pwm"; >>>           status = "disabled"; >>> >> >> >> >> >> > > > _______________________________________________ > linux-arm-kernel mailing list > linux-arm-kernel@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-arm-kernel