Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp1019499yba; Thu, 4 Apr 2019 02:34:02 -0700 (PDT) X-Google-Smtp-Source: APXvYqxxo8vkrHS2AE1Sxmo72xmhi2zr4oMepFn+On9KjQ2yHj2NB6ptP2rES1SCnBWqsCdomxpb X-Received: by 2002:a17:902:9884:: with SMTP id s4mr5312298plp.179.1554370442596; Thu, 04 Apr 2019 02:34:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554370442; cv=none; d=google.com; s=arc-20160816; b=h8IigQcZ2cAi2DrWB1o0FU2hcS1Idwovz4I8BtaZhthLSKXH8cL8AAhyU17lxd71YV I83zE8uUeYp7CJj07O7PWWVdqvCzqQfCH+4tYARrpog3FSmA67ifjhxydU3SCQHzy/RN V53Mbd+WKCpPELvCER47LYBwrUb1RXgy/c63Aj6cJSwmrw9hl1ki+CYTFCTY3Q9jksI/ yXaUT4mXx+I9o1TIsHF9UFVH80rpKMuYZsBjJZ/KWZxLIiPFARk03ePosMsVzP7eszcZ r2onkU7VvaC8nZowrBRq4Lw9SmL0NwjPlOqL0c4lSJ82W5dX7c7N7G2+WIlMS05yFJAS q/Jg== 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=iGYAO8IB/E8/HbgviPeeMZHAgcoYCGTg4WFf/qgZKjI=; b=WkCSTuqgfbBsy+7IKmosNNRyeXrJfzVfpYWswgyliyPIb5rgcy1Kzgf7ex0rw3v0l4 bh1nYG04BE34EjlXEtcQ0UtLI8Rx3jq6/nhKSXBQw7nxIkyOm7ax1BM2KfKtupFMNsFq V09oE4XFS11yeN4ahn1r8KyWeE1BZWOCeojVrt1hEaFsqmjCK5b9Z0c2kcOers19fFoU DZ66RjVtJjbNnBj+XzeCVK1OO7K8rBEUow3I+heqmkFwGA1Ha5Z5w9xGpOO5ZcIORjN5 Ml1LrLUAscyN8JA3xYkMy0Eus0BrMpPt+WF11aObUsXiWJTkr0ww4V9bNB0MDKFtERmX uhkg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="P/Fx+dqL"; 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 u5si16625775pgl.36.2019.04.04.02.33.47; Thu, 04 Apr 2019 02:34:02 -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; dkim=pass header.i=@kernel.org header.s=default header.b="P/Fx+dqL"; 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 S1732722AbfDDJcq (ORCPT + 99 others); Thu, 4 Apr 2019 05:32:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:47842 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732692AbfDDJIn (ORCPT ); Thu, 4 Apr 2019 05:08:43 -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 EB43C214AF; Thu, 4 Apr 2019 09:08:41 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1554368922; bh=4S+k0aX22ojcl54tAH6LapJtuvJOQgv9FRcxey5LG+Y=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=P/Fx+dqL5h1WjUhMCFO3NKEihZJmFm1BxZ2Eg6DMLe1+1OCKZGL9pozSbVXNiuGkM +gIJwczmcffcHGRi+jYQ12NAsH+CDNk/641a6TPo0P0iAkQOvcfzj2TsceHU+blUKd 41/fvvY9Y5cuq34sHOsIJ0oeImTqVFJdh2NJrkHs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Aaro Koskinen , Keerthy , Peter Ujfalusi , Russell King , Tony Lindgren , Grygorii Strashko , Linus Walleij , Sasha Levin Subject: [PATCH 5.0 015/246] gpio: gpio-omap: fix level interrupt idling Date: Thu, 4 Apr 2019 10:45:15 +0200 Message-Id: <20190404084619.718177210@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190404084619.236418459@linuxfoundation.org> References: <20190404084619.236418459@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore 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 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ [ Upstream commit d01849f7deba81f4959fd9e51bf20dbf46987d1c ] Tony notes that the GPIO module does not idle when level interrupts are in use, as the wakeup appears to get stuck. After extensive investigation, it appears that the wakeup will only be cleared if the interrupt status register is cleared while the interrupt is enabled. However, we are currently clearing it with the interrupt disabled for level-based interrupts. It is acknowledged that this observed behaviour conflicts with a statement in the TRM: CAUTION After servicing the interrupt, the status bit in the interrupt status register (GPIOi.GPIO_IRQSTATUS_0 or GPIOi.GPIO_IRQSTATUS_1) must be reset and the interrupt line released (by setting the corresponding bit of the interrupt status register to 1) before enabling an interrupt for the GPIO channel in the interrupt-enable register (GPIOi.GPIO_IRQSTATUS_SET_0 or GPIOi.GPIO_IRQSTATUS_SET_1) to prevent the occurrence of unexpected interrupts when enabling an interrupt for the GPIO channel. However, this does not appear to be a practical problem. Further, as reported by Grygorii Strashko , the TI Android kernel tree has an earlier similar patch as "GPIO: OMAP: Fix the sequence to clear the IRQ status" saying: if the status is cleared after disabling the IRQ then sWAKEUP will not be cleared and gates the module transition When we unmask the level interrupt after the interrupt has been handled, enable the interrupt and only then clear the interrupt. If the interrupt is still pending, the hardware will re-assert the interrupt status. Should the caution note in the TRM prove to be a problem, we could use a clear-enable-clear sequence instead. Cc: Aaro Koskinen Cc: Keerthy Cc: Peter Ujfalusi Signed-off-by: Russell King [tony@atomide.com: updated comments based on an earlier TI patch] Signed-off-by: Tony Lindgren Acked-by: Grygorii Strashko Signed-off-by: Linus Walleij Signed-off-by: Sasha Levin --- drivers/gpio/gpio-omap.c | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/drivers/gpio/gpio-omap.c b/drivers/gpio/gpio-omap.c index f4e9921fa966..7f33024b6d83 100644 --- a/drivers/gpio/gpio-omap.c +++ b/drivers/gpio/gpio-omap.c @@ -883,14 +883,16 @@ static void omap_gpio_unmask_irq(struct irq_data *d) if (trigger) omap_set_gpio_triggering(bank, offset, trigger); - /* For level-triggered GPIOs, the clearing must be done after - * the HW source is cleared, thus after the handler has run */ - if (bank->level_mask & BIT(offset)) { - omap_set_gpio_irqenable(bank, offset, 0); + omap_set_gpio_irqenable(bank, offset, 1); + + /* + * For level-triggered GPIOs, clearing must be done after the source + * is cleared, thus after the handler has run. OMAP4 needs this done + * after enabing the interrupt to clear the wakeup status. + */ + if (bank->level_mask & BIT(offset)) omap_clear_gpio_irqstatus(bank, offset); - } - omap_set_gpio_irqenable(bank, offset, 1); raw_spin_unlock_irqrestore(&bank->lock, flags); } -- 2.19.1