Received: by 10.223.185.116 with SMTP id b49csp856605wrg; Sat, 3 Mar 2018 09:02:35 -0800 (PST) X-Google-Smtp-Source: AG47ELs1Dy4E3iKSOFktRzAnWH5zV08uSe7krXhyo4u6C4t9lnQvX+8t4CfOKhXWbbFritOugBC2 X-Received: by 10.101.76.204 with SMTP id n12mr7797653pgt.249.1520096555072; Sat, 03 Mar 2018 09:02:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1520096555; cv=none; d=google.com; s=arc-20160816; b=kXc4ui9cOGSLptSILiLXWWxXeiavdj26JkOyC5zmtElrtQaPnpcdHjDxpoflsR0F7s ruPl0pJn/h+Kl6qaOj6o79vH2K05rAp6K2g98Yd6WK2gMVv10fqRs0ZKyrwhGdQW2xm5 cU3N896iAUyFkEp1gz8vdECPTgffWC5U4we5GRuNm3BnYbkyvaSFlKXwJtvB5nhxnjIe OuwXDhRJizTSzZWEaHohCo+aPMQJ1ugUUt0AIW7pBr+7dy40Gy7wVQecXYWKbrvndQaV uzvMCYNWtQerdh6i5ngOR2r07YRWUctfNqHwMOVAwoYoD8QChNsPfjivFy3rDztWvObU RE2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=Bqh7KFGM1lwMh8x548dO1usE5L18M2+VtKH9jhAkUO8=; b=vCaUoUUga3OmvtjlG3Z4UoY3xkCr5w8Fv8N4fHfIDg/GOoQsKy+Y6jMVNjTnQF4vjQ XtP4GWcAT0kdU6OJ8+3JdsL3xkmv7ZXJNPH4Yc1Q7hefm+daaKiE92Gm9lhhdqTshMmj 2xfCFF0euus2Hzp7NwyZT7oEHeaBfcEnybCWOVzURZ4p5yp+TjmRmn6Pa3aO/2mPYFjF hzRVmFywi3FI9kbLosGkbngOsHTQVOa2agN+QYadUTLh7h1reR35/tAgy4CB1gTfl1CF YiKgzkbwpb8IP6kNLxYqL9OykSfgcji4FQlbSyRARvjlD0LEqSkOlVZXGYw8vyFBLrmx 0dhg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gateworks-com.20150623.gappssmtp.com header.s=20150623 header.b=mVU6dQhG; 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 w24-v6si5526753pll.14.2018.03.03.09.02.20; Sat, 03 Mar 2018 09:02:35 -0800 (PST) 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=@gateworks-com.20150623.gappssmtp.com header.s=20150623 header.b=mVU6dQhG; 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 S1752190AbeCCRBX (ORCPT + 99 others); Sat, 3 Mar 2018 12:01:23 -0500 Received: from mail-wr0-f193.google.com ([209.85.128.193]:45635 "EHLO mail-wr0-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752091AbeCCRBW (ORCPT ); Sat, 3 Mar 2018 12:01:22 -0500 Received: by mail-wr0-f193.google.com with SMTP id p104so13086097wrc.12 for ; Sat, 03 Mar 2018 09:01:21 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gateworks-com.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:from:date:message-id:subject:to; bh=Bqh7KFGM1lwMh8x548dO1usE5L18M2+VtKH9jhAkUO8=; b=mVU6dQhGCtp4J5sDOLP2HPQzypNiKZjDW5ZcJuYc8EHmGCjUiZN/qgvFAU78d6VO0O Y56qEpCovT3n+uWtFHDIuDoOpOJRwTS8wvYENcjKVKV5Oqa+CyaqAmB7H2Zgtzt6lYx5 MCyK4oliQicUTpOHEz6IR/hDTiLW6o1qC2QjyezZrrKTxmtRZfA9D4Pmu5hdm+xnxMgM NDAz6Vti9tORvEANeq4L+9kNC+PwEPAd7hbmagmCpSr0Gox7PejXTEKcVQXkl7Jk5XYG KsB0j6xgE9KzwOe7feHZ7EwJN0A+qgqSsSXmFUbsfxJ9Ksi3RJ4bgkzYxgCCZItsfBJ9 Oj/w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to; bh=Bqh7KFGM1lwMh8x548dO1usE5L18M2+VtKH9jhAkUO8=; b=DFLFbTVUOR4eeGPKU9jm1UissiQX4eOuKjOEoq14KYZnmRlPElluBOHsOdrAg60PX1 cKK5DjPZ5ynYqh2y0Eml/39iKcv7HuhDjLovM+YqmuQpoQR6cZTZXYOL6mI0V27BQfBM JFllTp5yzQ3+kTZ0KS35wN9epUMdeapINInIkKLBMgUt97jJd35GFcJfhUZydLy/0M38 6r5b3Sn4ncknacKpdgYdq6iB13xmtPNPlX06/mfNNwEWPpP7aO2dBWorsnu4go3TD/H0 MhRvtbMMZr002wYxShJfaowyHVEqv2pyzxxC3I4xdObAQ4yjUzgHqGeGlDpRklVwdCVc aGVA== X-Gm-Message-State: APf1xPBcCvGynHoais/yaHiGSnwJUnqvSFI4ycUtBIG/AgYkJQ3Icieo QbcO5Nqp5CQuDt/M0yVrnEVCtoulS/SiZrnJBOUocQ== X-Received: by 10.223.185.112 with SMTP id b45mr8002444wrg.159.1520096479931; Sat, 03 Mar 2018 09:01:19 -0800 (PST) MIME-Version: 1.0 Received: by 10.28.6.66 with HTTP; Sat, 3 Mar 2018 09:01:19 -0800 (PST) In-Reply-To: <1519747558-17257-1-git-send-email-tharvey@gateworks.com> References: <1519747558-17257-1-git-send-email-tharvey@gateworks.com> From: Tim Harvey Date: Sat, 3 Mar 2018 09:01:19 -0800 Message-ID: Subject: Re: [PATCH] regmap: irq: fix ack-invert To: linux-kernel@vger.kernel.org, Mark Brown , Benjamin Gaignard , Lee Jones , Tony Lindgren Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Feb 27, 2018 at 8:05 AM, Tim Harvey wrote: > When acking irqs we need to take into account the ack-invert case. Without > this chips that require 0's to ACK interrupts will never clear the interrupt. > > I am working on an mfd driver that will use ack-invert and discovered > this issue. The only user of ack_invert currently appears to be the > motorola-cpcap driver. I'm not clear why that driver doesn't appear affected > so I'm cc'ing those involved with that driver for review and testing. > > Cc: Benjamin Gaignard > Cc: Lee Jones > Cc: Tony Lindgren > Signed-off-by: Tim Harvey > --- > drivers/base/regmap/regmap-irq.c | 17 +++++++++++++---- > 1 file changed, 13 insertions(+), 4 deletions(-) > > diff --git a/drivers/base/regmap/regmap-irq.c b/drivers/base/regmap/regmap-irq.c > index 429ca8e..abfed41 100644 > --- a/drivers/base/regmap/regmap-irq.c > +++ b/drivers/base/regmap/regmap-irq.c > @@ -355,16 +355,25 @@ static irqreturn_t regmap_irq_thread(int irq, void *d) > * doing a write per register. > */ > for (i = 0; i < data->chip->num_regs; i++) { > - data->status_buf[i] &= ~data->mask_buf[i]; > - > - if (data->status_buf[i] && (chip->ack_base || chip->use_ack)) { > + if ( (data->status_buf[i] & ~data->mask_buf[i]) && > + (chip->ack_base || chip->use_ack) ) { > reg = chip->ack_base + > (i * map->reg_stride * data->irq_reg_stride); > - ret = regmap_write(map, reg, data->status_buf[i]); > + /* some chips ack by write 0 */ > + if (chip->ack_invert) > + ret = regmap_write(map, reg, > + ~data->status_buf[i] & > + ~data->mask_buf[i]); > + > + else > + ret = regmap_write(map, reg, > + data->status_buf[i] & > + ~data->mask_buf[i]); > if (ret != 0) > dev_err(map->dev, "Failed to ack 0x%x: %d\n", > reg, ret); > } > + data->status_buf[i] &= ~data->mask_buf[i]; > } > > for (i = 0; i < chip->num_irqs; i++) { > -- > 2.7.4 > This still needs some work. For the mask_invert=true and ack_invert=true case which is the case for the driver I'm writing it ends up setting bits that didn't even fire. I will revisit on Monday with a patch that uses update_bits to ensure only the correct bits are set or cleared on an ack regardless of akc_invert. Regards, Tim