From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id EC9C41DB541; Tue, 3 Sep 2024 20:42:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725396142; cv=none; b=VULwWpdg4SKPdRFeM2aJy3naJOL5VPESdxL31Xc2x3f0VVEqboS9bXV7WAXwlP7k8ACdZVDq78erw5IBXkui7/SAgIaHePNOd/Y3CR+JxgHam1IE60scfk7EWfEsCg794+ai5LwqVhRFNxOjYLWn85tvm1D3eUANLNnvPG75s3s= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1725396142; c=relaxed/simple; bh=1NT3ymMvILMxnvK95kMhEA8DndvXoQqwoMWx6VcRJkA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=drmD9X4WXfwZJ49AqXpfbIHsuQYKg77zk5DFVVSVkDyORNcAGTSwanVP5Iw5roIuTG1Tl2Izw8yA/rucZEv/J/Wsg78aT/SDLsFJ6ZF8goSFvFmBqIbUsYJetc4lu/ZtLWKWrza4+duEXf8p/G3EaGfsTQUNv84hRTb6aYjxbs0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=W5eU9XLC; arc=none smtp.client-ip=10.30.226.201 Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="W5eU9XLC" Received: by smtp.kernel.org (Postfix) with ESMTPSA id 4F0F0C4CECA; Tue, 3 Sep 2024 20:42:20 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1725396141; bh=1NT3ymMvILMxnvK95kMhEA8DndvXoQqwoMWx6VcRJkA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=W5eU9XLC37zrDfjqC+53VLRuNTXfNjHoFItg0fQVwCwvyh1oy05EIY50rwKMF8lQq X9n1KsfwtQ95TNQwNx1hujJ2r2mWn4aXGRP7w7nvsHhR4mj1GBxsIs/0U9i4qYwlhM 94lImSfS0aoCV+tbnW73opqvaJoVxk5AihRFStGuUOdRaNHtEBiJi4+cP6V3/onws3 GBTVvSdXiZ66ntsiD35edQ3oqo87jB/TsLGCuJYOLv4qSUx4aP5MMKL0AgBskIGerV 9QXgDPJBQhnG9fw4iGY8AUAMLEM4kkpY+aHV0NzAu0l6YTgleXVGgZn/Kmtfd1mnqc uNrOx3TGxHbnA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Thomas Blocher , Linus Walleij , Sasha Levin , ludovic.desroches@microchip.com, nicolas.ferre@microchip.com, alexandre.belloni@bootlin.com, claudiu.beznea@tuxon.dev, linux-arm-kernel@lists.infradead.org, linux-gpio@vger.kernel.org Subject: [PATCH AUTOSEL 6.10 08/22] pinctrl: at91: make it work with current gpiolib Date: Tue, 3 Sep 2024 15:21:55 -0400 Message-ID: <20240903192243.1107016-8-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240903192243.1107016-1-sashal@kernel.org> References: <20240903192243.1107016-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.10.7 Content-Transfer-Encoding: 8bit From: Thomas Blocher [ Upstream commit 752f387faaae0ae2e84d3f496922524785e77d60 ] pinctrl-at91 currently does not support the gpio-groups devicetree property and has no pin-range. Because of this at91 gpios stopped working since patch commit 2ab73c6d8323fa1e ("gpio: Support GPIO controllers without pin-ranges") This was discussed in the patches commit fc328a7d1fcce263 ("gpio: Revert regression in sysfs-gpio (gpiolib.c)") commit 56e337f2cf132632 ("Revert "gpio: Revert regression in sysfs-gpio (gpiolib.c)"") As a workaround manually set pin-range via gpiochip_add_pin_range() until a) pinctrl-at91 is reworked to support devicetree gpio-groups b) another solution as mentioned in commit 56e337f2cf132632 ("Revert "gpio: Revert regression in sysfs-gpio (gpiolib.c)"") is found Signed-off-by: Thomas Blocher Link: https://lore.kernel.org/5b992862-355d-f0de-cd3d-ff99e67a4ff1@ek-dev.de Signed-off-by: Linus Walleij Signed-off-by: Sasha Levin --- drivers/pinctrl/pinctrl-at91.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/drivers/pinctrl/pinctrl-at91.c b/drivers/pinctrl/pinctrl-at91.c index 5aa9d5c533c6a..d7b66928a4e50 100644 --- a/drivers/pinctrl/pinctrl-at91.c +++ b/drivers/pinctrl/pinctrl-at91.c @@ -1409,8 +1409,11 @@ static int at91_pinctrl_probe(struct platform_device *pdev) /* We will handle a range of GPIO pins */ for (i = 0; i < gpio_banks; i++) - if (gpio_chips[i]) + if (gpio_chips[i]) { pinctrl_add_gpio_range(info->pctl, &gpio_chips[i]->range); + gpiochip_add_pin_range(&gpio_chips[i]->chip, dev_name(info->pctl->dev), 0, + gpio_chips[i]->range.pin_base, gpio_chips[i]->range.npins); + } dev_info(dev, "initialized AT91 pinctrl driver\n"); -- 2.43.0