Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp583123pxj; Thu, 17 Jun 2021 09:10:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxhds61UAsPrykdKD15WKQDPxGfmkz49mZbh+0DufKVroir+4A981K0uFxzY7qJ1ep9m5OJ X-Received: by 2002:a5d:5107:: with SMTP id s7mr6703696wrt.12.1623946199882; Thu, 17 Jun 2021 09:09:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623946199; cv=none; d=google.com; s=arc-20160816; b=0CUnnZXUsD9OYSRq5rWDtnM6muKHeU099ECFs8u/bdXLRb7HbDAl/LRW8jPZktUGwP HSD20Uzo/XRtpjV+RYSesyBcf8imoVepoZ07AJroO2vQTnGmGsEz1EtJ5mlizWx7CRIE Dmi58OxEV0Pcct1fxKaa+aioJzdbdVsnwAb3r+YCj3ARrSg4E2jbWEadgS1xpnj4+kzM rLfIdZ4JBht97kTxkVrprwg4mCDwccK4Qhlb5SlDVeE+8ifE2AiNZfKaQdteNjU0ob6v NTZQSvC3IjKddcuoKwffr5fgLm7FGdVsTteK0Be9DhSGiFCM9/GopwKqmi78lIVnN+ey glWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=avLfCjHnAKA4LJReou8M+UnwauUV5c1NRmYnNmCKNw0=; b=Gir+yfaPsK4ipKiAgi2bYSvpR6VxGYdP+Kav1fa//ob5YuDdr55npBJZ8ex61szjQN qkcfEDF0GYoDDk+pumDPYddYAsZ8Myzb9jKauJdtzByGXyLnJeOAGtcpGHL4z0FliZZk iUDl58r5hB0DX0ugqOmNQFLr62/r1YwUxDI3ZwCTHgr8MIZazfmIgBLJHzG0xeHZeGvu LacWJXLgD6kHW5k/fSQQoabU2Xj8JdihI4XduaSppzz5IGIdWKzmwUxjR/+IvIly0z5q mmAD6ghTaCvZMm6nuDUNKSJkSRXZ4b7TBh86A63/O6BA1NNtU+ToMY46udgG0oBwsVW1 ljwg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@foss.st.com header.s=selector1 header.b=vmUHd9hT; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=foss.st.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jz17si1348219ejc.709.2021.06.17.09.09.36; Thu, 17 Jun 2021 09:09:59 -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=@foss.st.com header.s=selector1 header.b=vmUHd9hT; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=foss.st.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232841AbhFQOs5 (ORCPT + 99 others); Thu, 17 Jun 2021 10:48:57 -0400 Received: from mx08-00178001.pphosted.com ([91.207.212.93]:8540 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S231648AbhFQOs4 (ORCPT ); Thu, 17 Jun 2021 10:48:56 -0400 Received: from pps.filterd (m0046660.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.43/8.16.0.43) with SMTP id 15HEgirB011994; Thu, 17 Jun 2021 16:46:39 +0200 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=foss.st.com; h=from : to : cc : subject : date : message-id : mime-version : content-transfer-encoding : content-type; s=selector1; bh=avLfCjHnAKA4LJReou8M+UnwauUV5c1NRmYnNmCKNw0=; b=vmUHd9hTT3DdQQMeMQwLMqg8ZYI/MJP3Yh5wIg5wJDRuKFKNDhlfd/CGb3I8RKVOSO2F I73ehuN2wdFC0QU9EIZrNncbSlRN8vqOjWMjhRRI1BBAjYIpHYWpOLmijCDZBp7EWGU/ dMg+PchjDGw2nOY8yFsRhfnJLU0D161AACHkPoaHv3TpN6T3HKPiAeSOHAtfJDSFgD++ mxyID76w8eipPzlqG3ggiVOgViykqhWLF2g0leDEi+UG704T0nbTwiYoLQanAEwp+94U MG1IkR1xiIOAUxsuRLjCczzkWagkoEz6MlFGCp2vsRm5/cQ2Dxq6usisVG9N4x4Eq5lZ 0w== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 3984bm1kny-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 17 Jun 2021 16:46:39 +0200 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id 0B560100038; Thu, 17 Jun 2021 16:46:39 +0200 (CEST) Received: from Webmail-eu.st.com (sfhdag2node3.st.com [10.75.127.6]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id EB33522D619; Thu, 17 Jun 2021 16:46:38 +0200 (CEST) Received: from localhost (10.75.127.46) by SFHDAG2NODE3.st.com (10.75.127.6) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Thu, 17 Jun 2021 16:46:38 +0200 From: Fabien Dessenne To: Linus Walleij , Maxime Coquelin , Alexandre Torgue , , , , CC: Fabien Dessenne Subject: [PATCH] pinctrl: stm32: fix the reported number of GPIO lines per bank Date: Thu, 17 Jun 2021 16:46:29 +0200 Message-ID: <20210617144629.2557693-1-fabien.dessenne@foss.st.com> X-Mailer: git-send-email 2.25.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-Originating-IP: [10.75.127.46] X-ClientProxiedBy: SFHDAG1NODE3.st.com (10.75.127.3) To SFHDAG2NODE3.st.com (10.75.127.6) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.391,18.0.790 definitions=2021-06-17_13:2021-06-15,2021-06-17 signatures=0 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Each GPIO bank supports a variable number of lines which is usually 16, but is less in some cases : this is specified by the last argument of the "gpio-ranges" bank node property. Report to the framework, the actual number of lines, so the libgpiod gpioinfo command lists the actually existing GPIO lines. Fixes: 1dc9d289154b ("pinctrl: stm32: add possibility to use gpio-ranges to declare bank range") Signed-off-by: Fabien Dessenne --- drivers/pinctrl/stm32/pinctrl-stm32.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/pinctrl/stm32/pinctrl-stm32.c b/drivers/pinctrl/stm32/pinctrl-stm32.c index ad9eb5ed8e81..c14d12d54cc5 100644 --- a/drivers/pinctrl/stm32/pinctrl-stm32.c +++ b/drivers/pinctrl/stm32/pinctrl-stm32.c @@ -1224,7 +1224,7 @@ static int stm32_gpiolib_register_bank(struct stm32_pinctrl *pctl, struct device *dev = pctl->dev; struct resource res; int npins = STM32_GPIO_PINS_PER_BANK; - int bank_nr, err; + int bank_nr, err, i = 0; if (!IS_ERR(bank->rstc)) reset_control_deassert(bank->rstc); @@ -1246,9 +1246,14 @@ static int stm32_gpiolib_register_bank(struct stm32_pinctrl *pctl, of_property_read_string(np, "st,bank-name", &bank->gpio_chip.label); - if (!of_parse_phandle_with_fixed_args(np, "gpio-ranges", 3, 0, &args)) { + if (!of_parse_phandle_with_fixed_args(np, "gpio-ranges", 3, i, &args)) { bank_nr = args.args[1] / STM32_GPIO_PINS_PER_BANK; bank->gpio_chip.base = args.args[1]; + + npins = args.args[2]; + while (!of_parse_phandle_with_fixed_args(np, "gpio-ranges", 3, + ++i, &args)) + npins += args.args[2]; } else { bank_nr = pctl->nbanks; bank->gpio_chip.base = bank_nr * STM32_GPIO_PINS_PER_BANK; -- 2.25.1