Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp3537858imm; Tue, 17 Jul 2018 06:31:49 -0700 (PDT) X-Google-Smtp-Source: AAOMgpc0kuuvDrQWLoQocb+tU9BBaedb9U7pRQM+VEgY5qJ00TxyXSEAr6ExMOylSsYJ8EYl7YU9 X-Received: by 2002:a17:902:2884:: with SMTP id f4-v6mr1678456plb.204.1531834309122; Tue, 17 Jul 2018 06:31:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531834309; cv=none; d=google.com; s=arc-20160816; b=lGdZmxrklah8zJY4ENhV7ipw546W5bSSuA4MT0kcosV4O8GDj94CAr3DBPYS4nrEw6 VZzqdoOUliRt4VC6W0l8fE5mhBn1xbEAfQ3pYfHerPJiqj1DaJPLoZZkyF6j0wrF7zrk QHbw9tj7He9JNjtm2FEvc2+x7jxVFMfVQwnm+dc+jz5hT+UV0p5h8p7Qy+Fn6z86OBwr OD4b+TtGpJDCdFDnfBNjUbwbu2zF1DZWYtOFYhYmsdSU9dtP9HPg5Ri8LoKKruNpMXrm OFeTRzkYNBlER6HHWAu0uKjHCKrT1EFJcZFIuquh9p4rFGYTZ9xmwlQHxYnmv+TqNEix zu+Q== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=AmwOSweuVqr5Mp1FUMPCLwSjPKt2Wr0/lQOEB3ug5ig=; b=AYAKoL/gLKsL1YGP3zZ8FWdUnEmUmy0FD5YgLbp4loYVW4e4qdZqikT6rWI+7JNA0V 0W3VVagMAOxDsB6WM8FJRMBAD/zNcdon6877MYuSeewhkSn5rKwScD+bxTGXLgT+a0Eg DOXFtitMqY0WoTbz20KoUdvHC1vEMzr1V/vxDvIcg+lF6piNtL56q5XqZzK1mmUAjyMS 84Zv8otEKevB9/R/bDVYSpleZno9uruysDQzIpJDqx4KTnsD1gVRJwgl7zUtnrXcjzc8 V4mOwzai2wVnfdejxh2/ZaLnaHuyZ0Q5smKvwNxTWJOWlaf6BBfUcKndM17kO5qTmuaU trWg== ARC-Authentication-Results: i=1; mx.google.com; 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 c62-v6si986193pfb.98.2018.07.17.06.31.33; Tue, 17 Jul 2018 06:31:49 -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; 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 S1731678AbeGQODK (ORCPT + 99 others); Tue, 17 Jul 2018 10:03:10 -0400 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:47820 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1731551AbeGQODK (ORCPT ); Tue, 17 Jul 2018 10:03:10 -0400 Received: from pps.filterd (m0046661.ppops.net [127.0.0.1]) by mx08-.pphosted.com (8.16.0.21/8.16.0.21) with SMTP id w6HDT12x026341; Tue, 17 Jul 2018 15:30:10 +0200 Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx08-00178001.pphosted.com with ESMTP id 2k88qvs1au-1 (version=TLSv1 cipher=ECDHE-RSA-AES256-SHA bits=256 verify=NOT); Tue, 17 Jul 2018 15:30:10 +0200 Received: from zeta.dmz-eu.st.com (zeta.dmz-eu.st.com [164.129.230.9]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id E21C034; Tue, 17 Jul 2018 13:30:09 +0000 (GMT) Received: from Webmail-eu.st.com (sfhdag3node2.st.com [10.75.127.8]) by zeta.dmz-eu.st.com (STMicroelectronics) with ESMTP id AF6145497; Tue, 17 Jul 2018 13:30:09 +0000 (GMT) Received: from [10.201.21.58] (10.75.127.51) by SFHDAG3NODE2.st.com (10.75.127.8) with Microsoft SMTP Server (TLS) id 15.0.1347.2; Tue, 17 Jul 2018 15:30:08 +0200 Subject: Re: [PATCH 2/2] pinctrl: stm32: add syscfg mask parameter To: Ludovic BARRE , Linus Walleij , Rob Herring CC: Maxime Coquelin , , , References: <1531821387-29845-1-git-send-email-ludovic.Barre@st.com> <1531821387-29845-3-git-send-email-ludovic.Barre@st.com> <4acc415d-f162-67a2-57d6-0a7defda434f@st.com> From: Alexandre Torgue Message-ID: Date: Tue, 17 Jul 2018 15:30:08 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.8.0 MIME-Version: 1.0 In-Reply-To: <4acc415d-f162-67a2-57d6-0a7defda434f@st.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.75.127.51] X-ClientProxiedBy: SFHDAG8NODE3.st.com (10.75.127.24) To SFHDAG3NODE2.st.com (10.75.127.8) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:,, definitions=2018-07-17_03:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 07/17/2018 03:11 PM, Ludovic BARRE wrote: > Hi > > add Rob, I forgotten rob's mail. > > On 07/17/2018 11:56 AM, Ludovic Barre wrote: >> From: Ludovic Barre >> >> This patch adds mask parameter to define IRQ mux field. >> This field could vary depend of IRQ mux selection register. >> To avoid backward compatibility, the drivers set >> the legacy value by default. >> >> Signed-off-by: Ludovic Barre Acked-by: Alexandre TORGUE >> --- >>   drivers/pinctrl/stm32/pinctrl-stm32.c | 16 ++++++++++++++-- >>   1 file changed, 14 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/pinctrl/stm32/pinctrl-stm32.c >> b/drivers/pinctrl/stm32/pinctrl-stm32.c >> index dfed609..f756232 100644 >> --- a/drivers/pinctrl/stm32/pinctrl-stm32.c >> +++ b/drivers/pinctrl/stm32/pinctrl-stm32.c >> @@ -46,6 +46,8 @@ >>   #define STM32_GPIO_PINS_PER_BANK 16 >>   #define STM32_GPIO_IRQ_LINE     16 >> +#define SYSCFG_IRQMUX_MASK GENMASK(3, 0) >> + >>   #define gpio_range_to_bank(chip) \ >>           container_of(chip, struct stm32_gpio_bank, range) >> @@ -1033,6 +1035,7 @@ static int stm32_pctrl_dt_setup_irq(struct >> platform_device *pdev, >>       struct device *dev = &pdev->dev; >>       struct regmap *rm; >>       int offset, ret, i; >> +    int mask, mask_width; >>       parent = of_irq_find_parent(np); >>       if (!parent) >> @@ -1052,12 +1055,21 @@ static int stm32_pctrl_dt_setup_irq(struct >> platform_device *pdev, >>       if (ret) >>           return ret; >> +    ret = of_property_read_u32_index(np, "st,syscfg", 2, &mask); >> +    if (ret) >> +        mask = SYSCFG_IRQMUX_MASK; >> + >> +    mask_width = fls(mask); >> + >>       for (i = 0; i < STM32_GPIO_PINS_PER_BANK; i++) { >>           struct reg_field mux; >>           mux.reg = offset + (i / 4) * 4; >> -        mux.lsb = (i % 4) * 4; >> -        mux.msb = mux.lsb + 3; >> +        mux.lsb = (i % 4) * mask_width; >> +        mux.msb = mux.lsb + mask_width - 1; >> + >> +        dev_dbg(dev, "irqmux%d: reg:%#x, lsb:%d, msb:%d\n", >> +            i, mux.reg, mux.lsb, mux.msb); >>           pctl->irqmux[i] = devm_regmap_field_alloc(dev, rm, mux); >>           if (IS_ERR(pctl->irqmux[i])) >>