Received: by 2002:a25:d7c1:0:0:0:0:0 with SMTP id o184csp2490000ybg; Sun, 27 Oct 2019 19:52:48 -0700 (PDT) X-Google-Smtp-Source: APXvYqwYZ6LBcFFYH7hlTqvWlKaOhWeMVt02E4ZCkT1vYFkNDwaltd2ncrkakXHsAakUH2NMfNiV X-Received: by 2002:a05:6402:2d2:: with SMTP id b18mr17247569edx.264.1572231168767; Sun, 27 Oct 2019 19:52:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572231168; cv=none; d=google.com; s=arc-20160816; b=reE/NHfeMeSMbyw8GdbQuaGUFsxUYlm/PUamr47SZ7B8PiFtkLdzF5KFdG9rUYWw0R LxQ+XM8pNNxPzR5Xe7ycm9iF/gUE0lSg5tZFbFfdti2anDJ7n0kWcum2SXEivxTsmDpj pDcHyc3rcC6newUVImQvjim1riX85txVSMIGlgytB2mcc1ZJsdGCKO01+LBBU9iBDPND mrrTYJ32u6B8SsiBEVYUWj/CyUXSnhVuYTraOatCRdw4jAgtwUlMoy7Vrll9A8AEkbSE WhrhhiE7M46a4zQEouA31RV0rpWaDaHNpTzaxVgc9mNND4RRTcyHX2FbSUxY9Y2lms/p sgow== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=3y/nXstK8Ar70xfModZ1ceqzEzC9pJmMihX33kaBheQ=; b=oePc84HxNhLRehvp9FABtVP9C+D73chXOuTcy0f07pGzvvXzR45pjDiBVuzakdbgMx OG5yQhBEoE34q+JcM2zH2NER4Jn3CnKfpsTu61/93VAstO0OIiWbkfKVodUgiQeWurFA 7wa7eugl4wv7xx5GiwO4OHMoD+Ypau0sVFzyJPKUtPsOIXTh85uYQziRCIkZ9DHTzZVx y2Yb+zY57/dbpY4oDyhs/R1jzM2qObJDZ11CpUTgGR0ZTdrQoLFSDbplHBhVwW+Jl36S 82Uv+Kh6hH690RaRv5s2AHO1RRZ/Kevo2TVpR/hqhf2Rvq2WOyBOsh7uz7BOSeTU0xTF HFzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=tXkuTnlh; 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 21si5864513ejz.268.2019.10.27.19.52.24; Sun, 27 Oct 2019 19:52:48 -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; dkim=pass header.i=@kernel.org header.s=default header.b=tXkuTnlh; 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 S1729935AbfJ0VLt (ORCPT + 99 others); Sun, 27 Oct 2019 17:11:49 -0400 Received: from mail.kernel.org ([198.145.29.99]:58340 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729949AbfJ0VLn (ORCPT ); Sun, 27 Oct 2019 17:11:43 -0400 Received: from localhost (100.50.158.77.rev.sfr.net [77.158.50.100]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 4A66E20873; Sun, 27 Oct 2019 21:11:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1572210702; bh=1tKYSiWTqoHWtVLkEPs/umdJ6PaYxhphNZuujMFXNV4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=tXkuTnlhRiSfaEFidQhouUhQCLhlb5pw4oKr4B1zOvTHwDeLy9n4Lf90AuSP6JM4i zEyEEdwNAX6KmYClb1JoTnTDSKgB0BoHDW2wQ69H70YpZ9/oqal3GpA5JMGn6Lb0L5 Cm1mHl8ntThH9U2zrhY9knKpwRQlDl+zxprF86Xo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Patrick Williams , Gregory CLEMENT , Linus Walleij Subject: [PATCH 4.14 108/119] pinctrl: armada-37xx: fix control of pins 32 and up Date: Sun, 27 Oct 2019 22:01:25 +0100 Message-Id: <20191027203349.410358325@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191027203259.948006506@linuxfoundation.org> References: <20191027203259.948006506@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Patrick Williams commit 20504fa1d2ffd5d03cdd9dc9c9dd4ed4579b97ef upstream. The 37xx configuration registers are only 32 bits long, so pins 32-35 spill over into the next register. The calculation for the register address was done, but the bitmask was not, so any configuration to pin 32 or above resulted in a bitmask that overflowed and performed no action. Fix the register / offset calculation to also adjust the offset. Fixes: 5715092a458c ("pinctrl: armada-37xx: Add gpio support") Signed-off-by: Patrick Williams Acked-by: Gregory CLEMENT Cc: Link: https://lore.kernel.org/r/20191001154634.96165-1-alpawi@amazon.com Signed-off-by: Linus Walleij Signed-off-by: Greg Kroah-Hartman --- drivers/pinctrl/mvebu/pinctrl-armada-37xx.c | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) --- a/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c +++ b/drivers/pinctrl/mvebu/pinctrl-armada-37xx.c @@ -205,11 +205,11 @@ static const struct armada_37xx_pin_data }; static inline void armada_37xx_update_reg(unsigned int *reg, - unsigned int offset) + unsigned int *offset) { /* We never have more than 2 registers */ - if (offset >= GPIO_PER_REG) { - offset -= GPIO_PER_REG; + if (*offset >= GPIO_PER_REG) { + *offset -= GPIO_PER_REG; *reg += sizeof(u32); } } @@ -373,7 +373,7 @@ static inline void armada_37xx_irq_updat { int offset = irqd_to_hwirq(d); - armada_37xx_update_reg(reg, offset); + armada_37xx_update_reg(reg, &offset); } static int armada_37xx_gpio_direction_input(struct gpio_chip *chip, @@ -383,7 +383,7 @@ static int armada_37xx_gpio_direction_in unsigned int reg = OUTPUT_EN; unsigned int mask; - armada_37xx_update_reg(®, offset); + armada_37xx_update_reg(®, &offset); mask = BIT(offset); return regmap_update_bits(info->regmap, reg, mask, 0); @@ -396,7 +396,7 @@ static int armada_37xx_gpio_get_directio unsigned int reg = OUTPUT_EN; unsigned int val, mask; - armada_37xx_update_reg(®, offset); + armada_37xx_update_reg(®, &offset); mask = BIT(offset); regmap_read(info->regmap, reg, &val); @@ -410,7 +410,7 @@ static int armada_37xx_gpio_direction_ou unsigned int reg = OUTPUT_EN; unsigned int mask, val, ret; - armada_37xx_update_reg(®, offset); + armada_37xx_update_reg(®, &offset); mask = BIT(offset); ret = regmap_update_bits(info->regmap, reg, mask, mask); @@ -431,7 +431,7 @@ static int armada_37xx_gpio_get(struct g unsigned int reg = INPUT_VAL; unsigned int val, mask; - armada_37xx_update_reg(®, offset); + armada_37xx_update_reg(®, &offset); mask = BIT(offset); regmap_read(info->regmap, reg, &val); @@ -446,7 +446,7 @@ static void armada_37xx_gpio_set(struct unsigned int reg = OUTPUT_VAL; unsigned int mask, val; - armada_37xx_update_reg(®, offset); + armada_37xx_update_reg(®, &offset); mask = BIT(offset); val = value ? mask : 0;