Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp3334062ybd; Tue, 25 Jun 2019 00:25:56 -0700 (PDT) X-Google-Smtp-Source: APXvYqxl3KAFB8DQup24f1E+WY58VJaWzasjnhwijYorJnf8qYFhJ/ZOQwGGuOPZUtNiA2Q2uwvR X-Received: by 2002:a17:902:a03:: with SMTP id 3mr9198549plo.302.1561447556505; Tue, 25 Jun 2019 00:25:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561447556; cv=none; d=google.com; s=arc-20160816; b=jxW0HLE+itqdThSd72TgbN6Dm9m6MG3aHAji+SgCxgGC6gYd1hSqSjj4h9huP3bgo8 RoL+TgGvYRIKRqVp2vGPCwTKYgZhQeq+7UjDYfUrwhDsRz1noN5txKsCenyKMKNReHp1 JbOlccUqgfhXtbxSHNqt651ghJTHJsE2ZrYmPaAi6UuQEb4MiIr0PJtLa1/DN6FTsvyC OiqsVkoHXRI8URMleZMjNt80+djZqiYv8WPmOOJe7Er6Nre18Mcuq4lFFHCA1QDyozKz 5+U6J4qu0UYVZnZQQsMHAdrBqzWFDTX8o6JWQRQPSDriBYfahKA5DDXowWQBStt5B42P Wzgg== 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:date:message-id:from :references:cc:to:subject; bh=CfKQfWbM5j4I6JG2OD/HO4UZw2knaSVbi0SjyUOaKic=; b=mBS+FA+pIeno7I/baxilnLS8dwYkzViynFlAiYWd8f+5OsfjNW7USZNqEShQykc2WH HiHeDlhv7oXhgNM3IM1fxahQe4az371Ex9Hb7HkJQEmcFQJMO14DN+yHcsc56GzWs6pl 02QK4WcsoFYvOCqWT0Cxs6PM5DugdWREpa5BY8JWBO/yZgg5bsENXdllt1ry37aOxBq6 +jpqyz9Hsz1wpSh/xvYkfbBXS5pfOt6aqpPp3wkUeSzCrTUNjM4d5g4jJaW+0AvWN0qe xujVvds/GCcVdSuR33ptwNJbpRfjat9Yht/6cDKdr9ScAWSXSp/xlEDgLYQ0SESfcHXM 5izw== 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 3si8376359plh.265.2019.06.25.00.25.41; Tue, 25 Jun 2019 00:25:56 -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 S1727843AbfFYF1u (ORCPT + 99 others); Tue, 25 Jun 2019 01:27:50 -0400 Received: from mx1.mailbox.org ([80.241.60.212]:13500 "EHLO mx1.mailbox.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726009AbfFYF1u (ORCPT ); Tue, 25 Jun 2019 01:27:50 -0400 Received: from smtp2.mailbox.org (smtp2.mailbox.org [80.241.60.241]) (using TLSv1.2 with cipher ECDHE-RSA-CHACHA20-POLY1305 (256/256 bits)) (No client certificate requested) by mx1.mailbox.org (Postfix) with ESMTPS id 75AFD5000F; Tue, 25 Jun 2019 07:27:47 +0200 (CEST) X-Virus-Scanned: amavisd-new at heinlein-support.de Received: from smtp2.mailbox.org ([80.241.60.241]) by spamfilter04.heinlein-hosting.de (spamfilter04.heinlein-hosting.de [80.241.56.122]) (amavisd-new, port 10030) with ESMTP id Hz6CaGAM_QKI; Tue, 25 Jun 2019 07:27:41 +0200 (CEST) Subject: Re: [PATCH 1/2 v9] serial: mctrl_gpio: Check if GPIO property exisits before requesting it To: Geert Uytterhoeven Cc: "open list:SERIAL DRIVERS" , Linux Kernel Mailing List , Mika Westerberg , Andy Shevchenko , Yegor Yefremov , Greg Kroah-Hartman , Giulio Benetti , Linus Walleij , Bartosz Golaszewski , "open list:GPIO SUBSYSTEM" References: <20190620062420.11650-1-sr@denx.de> <24bfb52c-6f77-b7cd-7421-9e6e4b0aa7d3@denx.de> From: Stefan Roese Message-ID: Date: Tue, 25 Jun 2019 07:27:33 +0200 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Geert, On 24.06.19 17:35, Geert Uytterhoeven wrote: > On Mon, Jun 24, 2019 at 5:29 PM Stefan Roese wrote: >> On 24.06.19 10:42, Geert Uytterhoeven wrote: >>> On Thu, Jun 20, 2019 at 8:24 AM Stefan Roese wrote: >>>> This patch adds a check for the GPIOs property existence, before the >>>> GPIO is requested. This fixes an issue seen when the 8250 mctrl_gpio >>>> support is added (2nd patch in this patch series) on x86 platforms using >>>> ACPI. >>>> >>>> Here Mika's comments from 2016-08-09: >>>> >>>> " >>>> I noticed that with v4.8-rc1 serial console of some of our Broxton >>>> systems does not work properly anymore. I'm able to see output but input >>>> does not work. >>>> >>>> I bisected it down to commit 4ef03d328769eddbfeca1f1c958fdb181a69c341 >>>> ("tty/serial/8250: use mctrl_gpio helpers"). >>>> >>>> The reason why it fails is that in ACPI we do not have names for GPIOs >>>> (except when _DSD is used) so we use the "idx" to index into _CRS GPIO >>>> resources. Now mctrl_gpio_init_noauto() goes through a list of GPIOs >>>> calling devm_gpiod_get_index_optional() passing "idx" of 0 for each. The >>>> UART device in Broxton has following (simplified) ACPI description: >>>> >>>> Device (URT4) >>>> { >>>> ... >>>> Name (_CRS, ResourceTemplate () { >>>> GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly, >>>> "\\_SB.GPO0", 0x00, ResourceConsumer) >>>> { >>>> 0x003A >>>> } >>>> GpioIo (Exclusive, PullDefault, 0x0000, 0x0000, IoRestrictionOutputOnly, >>>> "\\_SB.GPO0", 0x00, ResourceConsumer) >>>> { >>>> 0x003D >>>> } >>>> }) >>>> >>>> In this case it finds the first GPIO (0x003A which happens to be RX pin >>>> for that UART), turns it into GPIO which then breaks input for the UART >>>> device. This also breaks systems with bluetooth connected to UART (those >>>> typically have some GPIOs in their _CRS). >>>> >>>> Any ideas how to fix this? >>>> >>>> We cannot just drop the _CRS index lookup fallback because that would >>>> break many existing machines out there so maybe we can limit this to >>>> only DT enabled machines. Or alternatively probe if the property first >>>> exists before trying to acquire the GPIOs (using >>>> device_property_present()). >>>> " >>>> >>>> This patch implements the fix suggested by Mika in his statement above. >>>> >>>> Signed-off-by: Stefan Roese > >>>> --- a/drivers/tty/serial/serial_mctrl_gpio.c >>>> +++ b/drivers/tty/serial/serial_mctrl_gpio.c > >>>> @@ -116,6 +117,19 @@ struct mctrl_gpios *mctrl_gpio_init_noauto(struct device *dev, unsigned int idx) >>>> >>>> for (i = 0; i < UART_GPIO_MAX; i++) { >>>> enum gpiod_flags flags; >>>> + char *gpio_str; >>>> + bool present; >>>> + >>>> + /* Check if GPIO property exists and continue if not */ >>>> + gpio_str = kasprintf(GFP_KERNEL, "%s-gpios", >>>> + mctrl_gpios_desc[i].name); >>> >>> This will silently break DTBs using "(cts|dsr|dcd|rng|rts|dtr)-gpio" instead >>> of "(cts|dsr|dcd|rng|rts|dtr)-gpios". >> >> Should both options be supported ("cts-gpio" vs "cts-gpios")? >> Documentation/devicetree/bindings/serial/serial.txt only mentions >> the "-gpios" variant. > > Well, the "-gpio" variant is deprecated, but still supported by > devm_gpiod_get_index_optional(), and there are active users in upstream > DTS files. > > My main objection is (trying to) replicate the matching logic inside > gpiolib.c, causing subtle semantic differences. And keeping it consistent, > of course. > > It would be nice if this could be fixed inside acpi_find_gpio(), so > users don't need to be updated. There may be other subsystems where > the difference between DT and ACPI may cause issues, unbeknownst. Sure, I can fix this. I would prefer to do this in a follow-up patch though, if nobody objects. Thanks, Stefan