Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp773734ybt; Fri, 19 Jun 2020 13:24:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyvSVq0BUNVHq8vpwgpOIPqC/V90f+zmoOkgkAi/VfOGNnfi/Qzmz0Bwqc+QoJopQpO1oQE X-Received: by 2002:a17:906:138b:: with SMTP id f11mr5177556ejc.288.1592598298596; Fri, 19 Jun 2020 13:24:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592598298; cv=none; d=google.com; s=arc-20160816; b=t4hQC5fKuMyTwdhJQSTel/A7G8UdZ7JHZ/Ho9ugf98+mY4hR9+3uAGuCrC1zYxhU/q QDZDV91UeZgIzrsPexfBI+ILLQq5bKBJbISix62NpdtKEaGwGAHxD569UtM5ikpYaEDX jNHwG5Xz8Jy7YRfVMq2Wx2+C5dtQn2N+IUIoRk88eVgr0UhsXVW3Be8PV07G7SuFjaZN DhfCCqvE+nyJY8pGjeFDACAtrssnzrcBGQauK8QyRECE/UUexNUWvaqXpXwX7M64hS+x jq0ho3MxMZnBtu/4klYJbUZWmG8xIeetOjtDtVhnleSOcz18g58KE4tJUBDwxaJLISZq HH4g== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=vZCrRI1KS32RU8jP/zJbfKUMFNzaXkIoanQ67CMlTtk=; b=qy9jloNcFzsq01KkK7pPXoC51pB+nrqVUwzGYvOmtvSxSyv3aa8dPCZ1Wx8SHyDHOd SsNJcvYXjOlKkGFdGgJ09h749lVrYxRbV37IQYI34J8iY946Sdm6+Q5gJD8SV2lzAJus po+lTGiYE+GMJHZoDXVix0FZrG1fwEZVBLeRJW59asJ0JxKITtx/bOyzMSyjMW6OdJYO R59Qy/m9lAVsUHBwOO2FDzJiVM+8P54lCaGl9qQEVkrAMn6zKAv2/LaIVGUJGZYtOrB0 X4UshcjcIXCDjnwja76Szg2ZLOvk+6Dl/UpcPo9zS5B+Y6RdGSD82ykYr0wGH685RRhr gnyw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HOkfyGgI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v25si4384694edq.70.2020.06.19.13.24.36; Fri, 19 Jun 2020 13:24:58 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=HOkfyGgI; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388711AbgFSOwT (ORCPT + 99 others); Fri, 19 Jun 2020 10:52:19 -0400 Received: from mail.kernel.org ([198.145.29.99]:46258 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389541AbgFSOwM (ORCPT ); Fri, 19 Jun 2020 10:52:12 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 145AF217D8; Fri, 19 Jun 2020 14:52:11 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592578332; bh=HJV67g+Cu4recq4VZvPz8EKtOhwuvtYX10glrNNPZ20=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HOkfyGgICmVHm4kf3RdSaJZRrO16k7NJuOuoN9MqqMiQB3duAn3gEAf+Rz3BMpT3G VFuxEW4DUhjLFzQ2qyKceVb53KwV3Fkgrbg0xykM1D7utYunBQgGHinxfs1ubswWC+ 8kNveLjEPqrm5K3ckvu3IdNBwwQQerAEqABSa7oY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jonathan Bakker , Krzysztof Kozlowski Subject: [PATCH 4.14 173/190] pinctrl: samsung: Save/restore eint_mask over suspend for EINT_TYPE GPIOs Date: Fri, 19 Jun 2020 16:33:38 +0200 Message-Id: <20200619141642.424902400@linuxfoundation.org> X-Mailer: git-send-email 2.27.0 In-Reply-To: <20200619141633.446429600@linuxfoundation.org> References: <20200619141633.446429600@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jonathan Bakker commit f354157a7d184db430c1a564c506434e33b1bec5 upstream. Currently, for EINT_TYPE GPIOs, the CON and FLTCON registers are saved and restored over a suspend/resume cycle. However, the EINT_MASK registers are not. On S5PV210 at the very least, these registers are not retained over suspend, leading to the interrupts remaining masked upon resume and therefore no interrupts being triggered for the device. There should be no effect on any SoCs that do retain these registers as theoretically we would just be re-writing what was already there. Fixes: 7ccbc60cd9c2 ("pinctrl: exynos: Handle suspend/resume of GPIO EINT registers") Cc: Signed-off-by: Jonathan Bakker Signed-off-by: Krzysztof Kozlowski Signed-off-by: Greg Kroah-Hartman --- drivers/pinctrl/samsung/pinctrl-exynos.c | 9 +++++++++ 1 file changed, 9 insertions(+) --- a/drivers/pinctrl/samsung/pinctrl-exynos.c +++ b/drivers/pinctrl/samsung/pinctrl-exynos.c @@ -266,6 +266,7 @@ struct exynos_eint_gpio_save { u32 eint_con; u32 eint_fltcon0; u32 eint_fltcon1; + u32 eint_mask; }; /* @@ -561,10 +562,13 @@ static void exynos_pinctrl_suspend_bank( + 2 * bank->eint_offset); save->eint_fltcon1 = readl(regs + EXYNOS_GPIO_EFLTCON_OFFSET + 2 * bank->eint_offset + 4); + save->eint_mask = readl(regs + bank->irq_chip->eint_mask + + bank->eint_offset); pr_debug("%s: save con %#010x\n", bank->name, save->eint_con); pr_debug("%s: save fltcon0 %#010x\n", bank->name, save->eint_fltcon0); pr_debug("%s: save fltcon1 %#010x\n", bank->name, save->eint_fltcon1); + pr_debug("%s: save mask %#010x\n", bank->name, save->eint_mask); } void exynos_pinctrl_suspend(struct samsung_pinctrl_drv_data *drvdata) @@ -593,6 +597,9 @@ static void exynos_pinctrl_resume_bank( pr_debug("%s: fltcon1 %#010x => %#010x\n", bank->name, readl(regs + EXYNOS_GPIO_EFLTCON_OFFSET + 2 * bank->eint_offset + 4), save->eint_fltcon1); + pr_debug("%s: mask %#010x => %#010x\n", bank->name, + readl(regs + bank->irq_chip->eint_mask + + bank->eint_offset), save->eint_mask); writel(save->eint_con, regs + EXYNOS_GPIO_ECON_OFFSET + bank->eint_offset); @@ -600,6 +607,8 @@ static void exynos_pinctrl_resume_bank( + 2 * bank->eint_offset); writel(save->eint_fltcon1, regs + EXYNOS_GPIO_EFLTCON_OFFSET + 2 * bank->eint_offset + 4); + writel(save->eint_mask, regs + bank->irq_chip->eint_mask + + bank->eint_offset); } void exynos_pinctrl_resume(struct samsung_pinctrl_drv_data *drvdata)