Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp9538375rwb; Thu, 24 Nov 2022 14:48:23 -0800 (PST) X-Google-Smtp-Source: AA0mqf6n/YcRGnNiMOXLnWNXn4gFG1XYhgCy2FFXQOaNEsxxQ2OXLWSsX9FjV+zJ7qj30EyBHXhe X-Received: by 2002:a17:902:e883:b0:188:f4ca:97b1 with SMTP id w3-20020a170902e88300b00188f4ca97b1mr15843749plg.139.1669330103013; Thu, 24 Nov 2022 14:48:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669330103; cv=none; d=google.com; s=arc-20160816; b=wOEzayb+K+/YwtJjwyeZjthB5cZRQizCLunlo3jGQ5/b+ZbZCWCMec1qOmlY90J7Pa 5WcJZFl5wfEbl+O+SXxvZ+WIhb+n1iUXH86KOUDUV6MQEE0qNOeEnqRLYV3zNi2ER05r jDKXokf8afx7q801GI8EJqw1PnCAIayjNbUaopCND8L50gIv6kil278TEmcGXYrnLM56 yBVC3fs9DkA1ZCFcqQklzFEu7x91jWMgxXTgBtGnpNPUKu9Bn2BLzVfVc5I4rFwhBoR9 dxPgKfFag0tWKz6sv1HY/ATeLRy5Yj609RQUSdssOkSHZkO5foZlGYLzJrsOXfWIPDOw 419g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=TbHZEJ1e7KgIe4uPvOob3qJ+lzBz+FZV3JQOmyZFPxg=; b=jn4VGbUsNt+/AwOUpKOOBVC0E6hDKJtzcVlt5GLjWAm8G5jM9WhezlssMpbNBTf/Os P2xU1inWquXpx6G3RlDD8dL9+bYLMZleGyKyJTBMDqj7/LXPLPNo+uxUoVeHw2QC3A60 j3kv8nUn3NwXPekCp2R/lm0vHW/r5ZAjLtfn7vdqKwbR4BxCaec0IS055pbsMZvoIFmk W+xKRTpw9aAx8FVW63XtM7moC0gIGkdiY5i8HePxGPIMpMtWP2+/Nfo4ZazI3xz0SNM0 jtDheV78VMEnNtmfk9MduDiAllJdppL4QwVglKEzgcinY4m1RvZZ9tGK6XE82834BJhs oSyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=bsWpOpWy; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c5-20020a170903234500b00188e877e8ddsi2307870plh.139.2022.11.24.14.48.12; Thu, 24 Nov 2022 14:48:22 -0800 (PST) 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; dkim=pass header.i=@intel.com header.s=Intel header.b=bsWpOpWy; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229581AbiKXW3R (ORCPT + 88 others); Thu, 24 Nov 2022 17:29:17 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40394 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229455AbiKXW3Q (ORCPT ); Thu, 24 Nov 2022 17:29:16 -0500 Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 09ADB8FB0A; Thu, 24 Nov 2022 14:29:12 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1669328951; x=1700864951; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=RCRRDp08lZIx9uPRpzFvsZ4CNT2lsbwsHsXdZTgGwTE=; b=bsWpOpWy4zovYpWqxnSMAbSBcpGFtV0aSxR5lOEMh/06mKWobS/zgvZS GsP69ch6N+DeaAzRKyZhdVq9AFlp0c/FhYihJiUXakYdhPThk8TwbDly0 H8gU/EPsFKIgOvvhsrxuDzQQEGj/7LnaKD51BaCzKZZJeGfnjcJ1e9xlP OKvrjw4IR6eYTuLPEKBc4dgaTwyRBydvpszrr3Iml4g3Gn1H+hUGVKRTh FnuewuSzviPdj2/fIqGy2YHl4Iduoe8sBp6V3G678fU0yRHswKBMStdxn j48n+ApEFZ9xLVfiAGNHl9CUbuadZEJZPO5KaoyEKFCJxGf9h76S9dqkl g==; X-IronPort-AV: E=McAfee;i="6500,9779,10541"; a="314407970" X-IronPort-AV: E=Sophos;i="5.96,191,1665471600"; d="scan'208";a="314407970" Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Nov 2022 14:29:11 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6500,9779,10541"; a="644608935" X-IronPort-AV: E=Sophos;i="5.96,191,1665471600"; d="scan'208";a="644608935" Received: from black.fi.intel.com ([10.237.72.28]) by fmsmga007.fm.intel.com with ESMTP; 24 Nov 2022 14:29:09 -0800 Received: by black.fi.intel.com (Postfix, from userid 1003) id 604B9128; Fri, 25 Nov 2022 00:29:35 +0200 (EET) From: Andy Shevchenko To: Andy Shevchenko , linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Mika Westerberg , Andy Shevchenko , Linus Walleij , stable@vger.kernel.org, Dale Smith , John Harris Subject: [PATCH v1 1/1] pinctrl: intel: Save and restore pins in "direct IRQ" mode Date: Fri, 25 Nov 2022 00:29:26 +0200 Message-Id: <20221124222926.72326-1-andriy.shevchenko@linux.intel.com> X-Mailer: git-send-email 2.35.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,RCVD_IN_DNSWL_HI,SPF_HELO_NONE, SPF_NONE autolearn=ham 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 The firmware on some systems may configure GPIO pins to be an interrupt source in so called "direct IRQ" mode. In such cases the GPIO controller driver has no idea if those pins are being used or not. At the same time, there is a known bug in the firmwares that don't restore the pin settings correctly after suspend, i.e. by an unknown reason the Rx value becomes inverted. Hence, let's save and restore the pins that are configured as GPIOs in the input mode with GPIROUTIOXAPIC bit set. Cc: stable@vger.kernel.org Reported-and-tested-by: Dale Smith Reported-and-tested-by: John Harris BugLink: https://bugzilla.kernel.org/show_bug.cgi?id=214749 Signed-off-by: Andy Shevchenko --- Linus, I hope that this can still make v6.1 release. I'm not going to send a PR for this change unless you insist. drivers/pinctrl/intel/pinctrl-intel.c | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/drivers/pinctrl/intel/pinctrl-intel.c b/drivers/pinctrl/intel/pinctrl-intel.c index 739030e24093..57553ac77518 100644 --- a/drivers/pinctrl/intel/pinctrl-intel.c +++ b/drivers/pinctrl/intel/pinctrl-intel.c @@ -446,9 +446,14 @@ static void __intel_gpio_set_direction(void __iomem *padcfg0, bool input) writel(value, padcfg0); } +static int __intel_gpio_get_gpio_mode(u32 value) +{ + return (value & PADCFG0_PMODE_MASK) >> PADCFG0_PMODE_SHIFT; +} + static int intel_gpio_get_gpio_mode(void __iomem *padcfg0) { - return (readl(padcfg0) & PADCFG0_PMODE_MASK) >> PADCFG0_PMODE_SHIFT; + return __intel_gpio_get_gpio_mode(readl(padcfg0)); } static void intel_gpio_set_gpio_mode(void __iomem *padcfg0) @@ -1705,6 +1710,7 @@ EXPORT_SYMBOL_GPL(intel_pinctrl_get_soc_data); static bool intel_pinctrl_should_save(struct intel_pinctrl *pctrl, unsigned int pin) { const struct pin_desc *pd = pin_desc_get(pctrl->pctldev, pin); + u32 value; if (!pd || !intel_pad_usable(pctrl, pin)) return false; @@ -1719,6 +1725,25 @@ static bool intel_pinctrl_should_save(struct intel_pinctrl *pctrl, unsigned int gpiochip_line_is_irq(&pctrl->chip, intel_pin_to_gpio(pctrl, pin))) return true; + /* + * The firmware on some systems may configure GPIO pins to be + * an interrupt source in so called "direct IRQ" mode. In such + * cases the GPIO controller driver has no idea if those pins + * are being used or not. At the same time, there is a known bug + * in the firmwares that don't restore the pin settings correctly + * after suspend, i.e. by an unknown reason the Rx value becomes + * inverted. + * + * Hence, let's save and restore the pins that are configured + * as GPIOs in the input mode with GPIROUTIOXAPIC bit set. + * + * See https://bugzilla.kernel.org/show_bug.cgi?id=214749. + */ + value = readl(intel_get_padcfg(pctrl, pin, PADCFG0)); + if ((value & PADCFG0_GPIROUTIOXAPIC) && (value & PADCFG0_GPIOTXDIS) && + (__intel_gpio_get_gpio_mode(value) == PADCFG0_PMODE_GPIO)) + return true; + return false; } -- 2.35.1