Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp733119pxf; Wed, 10 Mar 2021 16:44:02 -0800 (PST) X-Google-Smtp-Source: ABdhPJzTDY3Di3+XymZKFHRLTIftBB62Nh1dT93MuBagi3tkayCujhPc88E/NwOfYeovj5qZRASu X-Received: by 2002:a17:906:a052:: with SMTP id bg18mr563933ejb.18.1615423441945; Wed, 10 Mar 2021 16:44:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615423441; cv=none; d=google.com; s=arc-20160816; b=Zrt812hoAFok5kw9sBo6o/wFbMtYvsDvYMo8opLsBMQc7Po9Jb1Eq6kFnQQ7TmGGJT vvUJK7S1zq39oot4n+hLzB7cMOibt0+A835sN6LKrHut1DP9tbESK2DwsABVy9z+Fi/4 V6mlnYRXnx3N9NcDy8zrr4+UC1eX3adGpdf8PJi3y7+oZt3CNfERbTzDD0Xdj0mSb0j3 C7bCBDCU6NuxYurtNZ3W21v37Vu8aqWZmP8LTaKakVxLm1RbNclbB+waMMVm16O8XORo mGcQcM5iQu5H5DDtf6zTOLKDLuIg87OCykeUD7dczmNfP0KNcMOdsKEGczQlEAgQt9pT JV5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:references:in-reply-to :message-id:date:subject:cc:to:from; bh=5V3qwy2OwHme5565RqF/PNsLyoiv08TUzvT2Y73KwsE=; b=wpSXVlOszAwqYl9n0WgpQczF4d4BrChJVjkv+7lNgj9zl/UfQ+EOZhK2BJAFceDd88 Lrf+aVlTF8GdueYN/ETKjWXBVO0H38AzamVaChKKF96DtgDjmc2+4fzr4Yq49DLWnVZp 2FogbojeH3u45IvUsoXorS1lRINR4cdwBs3p1LsByWE6iCRcrHpWRUGWsoSHQLBsnwQd 50u8zNeKAY/vjR0/WSOFK3KqTAdYPyNA+1kXGRA0SjUF3GQqW1RMuxtQUS13eqeNHmgP 0blLO1TMAGSXpWec0LVkiPG82Zcsplj3da3O3DOt1bKWc7P8Ua3U4nLpiiVPGii3RIEo EC6Q== ARC-Authentication-Results: i=1; mx.google.com; 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 v18si636027ejy.223.2021.03.10.16.43.36; Wed, 10 Mar 2021 16:44:01 -0800 (PST) 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; 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 S229646AbhCKAk1 (ORCPT + 99 others); Wed, 10 Mar 2021 19:40:27 -0500 Received: from alexa-out-sd-02.qualcomm.com ([199.106.114.39]:36569 "EHLO alexa-out-sd-02.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229570AbhCKAj5 (ORCPT ); Wed, 10 Mar 2021 19:39:57 -0500 Received: from unknown (HELO ironmsg03-sd.qualcomm.com) ([10.53.140.143]) by alexa-out-sd-02.qualcomm.com with ESMTP; 10 Mar 2021 16:39:57 -0800 X-QCInternal: smtphost Received: from gurus-linux.qualcomm.com (HELO gurus-linux.localdomain) ([10.46.162.81]) by ironmsg03-sd.qualcomm.com with ESMTP; 10 Mar 2021 16:39:57 -0800 Received: by gurus-linux.localdomain (Postfix, from userid 383780) id 1908618EE; Wed, 10 Mar 2021 16:39:56 -0800 (PST) From: Guru Das Srinagesh To: Mark Brown , Markus Elfring , Lee Jones , Rob Herring Cc: Bjorn Andersson , Greg KH , Guenter Roeck , Joe Perches , Subbaraman Narayanamurthy , David Collins , Anirudh Ghayal , linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Guru Das Srinagesh Subject: [RFC PATCH v3 3/3] regmap-irq: Modify type_buf handling for IRQ_TYPE_LEVEL_* Date: Wed, 10 Mar 2021 16:39:54 -0800 Message-Id: <46a360a9dff869606a417364a0a76c8ec4d0d4c9.1615423027.git.gurus@codeaurora.org> X-Mailer: git-send-email 2.7.4 In-Reply-To: References: In-Reply-To: References: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In order to configure LEVEL_HIGH and LEVEL_LOW for QCOM's type registers, the bit corresponding to the interrupt must be cleared. Therefore, in QCOM's case, the type_*_val are all to be configured as BIT() masks. Quite clearly, this is a fundamental change, and am looking for feedback on whether and how this may be handled in a generic manner. Signed-off-by: Guru Das Srinagesh --- drivers/base/regmap/regmap-irq.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/base/regmap/regmap-irq.c b/drivers/base/regmap/regmap-irq.c index cb13855..c70ef90 100644 --- a/drivers/base/regmap/regmap-irq.c +++ b/drivers/base/regmap/regmap-irq.c @@ -327,11 +327,11 @@ static int regmap_irq_set_type(struct irq_data *data, unsigned int type) break; case IRQ_TYPE_LEVEL_HIGH: - d->type_buf[reg] |= t->type_level_high_val; + d->type_buf[reg] &= t->type_level_high_val; break; case IRQ_TYPE_LEVEL_LOW: - d->type_buf[reg] |= t->type_level_low_val; + d->type_buf[reg] &= t->type_level_low_val; break; default: return -EINVAL; -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project