Received: by 2002:a05:7412:e794:b0:fa:551:50a7 with SMTP id o20csp176748rdd; Mon, 8 Jan 2024 23:56:06 -0800 (PST) X-Google-Smtp-Source: AGHT+IEIScd03/Y4HiiMoarwSn8Ofee+zqdMMczcR3DVji0a5AqAavhTHIqoZIx1rrfC0nQCEXUD X-Received: by 2002:a05:6a20:e117:b0:199:8510:de02 with SMTP id kr23-20020a056a20e11700b001998510de02mr1954948pzb.27.1704786965925; Mon, 08 Jan 2024 23:56:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1704786965; cv=none; d=google.com; s=arc-20160816; b=ItQKyyKaKaK487euvwmfv2QreyiIe7tQyhUqhA12G0bOne4onifOtP119XTDTHyyyy nqnJkYlPeXC7BmxZ0uh1cKQDXM445kG8Ud65cPmUIjeQ89yG8MwnYUmjUnTK5tLZn/Vl /VNEClnMTTbJ9H1m/BEVpQ3b8n+1x3dncpO7fDA/UcvniuM8EQK1zGeV/jNT8iKga8BA 7QQJOecF5+SxKDuUcFm/ct5z7j5fz6GraatZGxv7PpNaSh/+EE6zQ+aT7ThXbhlnSTna Uhx4OvP8GOqnLMp5ac/SlYPOI3WUjug2vN6DhOYZf119L311KBrIQAhehf9/qSDfFN9u Okaw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=mime-version:list-unsubscribe:list-subscribe:list-id:precedence :references:in-reply-to:message-id:date:subject:cc:to:from; bh=b5hJMYV7D1sONogkVDrnIX5Uxr8cwea0ntN8HsoSeyM=; fh=C9TL9yCnGisUiZfdvbqmpU1FLQkakKnDf/rl0GO1YOw=; b=QJUmaGEtSWhi+5x60sZ8O0UlkLXCB27Sl75yRNHLKqIH/85ICK5Pd90PhSnal17XO+ 7tO9vIU7949dcHkKXpROky/BOPJloQutXM3dns9zHUD6BnnFlsmAcBzadllKQOuPLA+j e3QvfSwn7EOWzbxvk52ri34SsCbtb9mYvJhK/l2EENCocVcax8aL3bchg0ottltPc49k +q2c2bHO+yVOfULRswfydToyvUWQJ5fYyJatE79bJLh4W+E+mzsO3Rj2NM9tcGy41fQz cwoEqUkduTdADYhI88rRN4VkMrOCQ2Hifb3TJtPJrv/yTqagLfzeZGHV8M6tsZR7sQKf NImw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-20483-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-20483-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id h3-20020a170902f70300b001d43cfe9772si1109869plo.571.2024.01.08.23.56.05 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 08 Jan 2024 23:56:05 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-20483-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel+bounces-20483-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-20483-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 9BC5EB23BE4 for ; Tue, 9 Jan 2024 07:40:03 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id C240BB669; Tue, 9 Jan 2024 07:39:51 +0000 (UTC) Received: from SHSQR01.spreadtrum.com (unknown [222.66.158.135]) (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 D74F39455 for ; Tue, 9 Jan 2024 07:39:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=unisoc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=unisoc.com Received: from dlp.unisoc.com ([10.29.3.86]) by SHSQR01.spreadtrum.com with ESMTP id 4097d95D027979; Tue, 9 Jan 2024 15:39:09 +0800 (+08) (envelope-from Wenhua.Lin@unisoc.com) Received: from SHDLP.spreadtrum.com (shmbx06.spreadtrum.com [10.0.1.11]) by dlp.unisoc.com (SkyGuard) with ESMTPS id 4T8N1C2qB7z2Qvpgg; Tue, 9 Jan 2024 15:32:15 +0800 (CST) Received: from xm9614pcu.spreadtrum.com (10.13.2.29) by shmbx06.spreadtrum.com (10.0.1.11) with Microsoft SMTP Server (TLS) id 15.0.1497.23; Tue, 9 Jan 2024 15:39:08 +0800 From: Wenhua Lin To: Linus Walleij , Andy Shevchenko , Bartosz Golaszewski CC: Orson Zhai , Baolin Wang , Chunyan Zhang , , , wenhua lin , Wenhua Lin , Xiongpeng Wu Subject: [PATCH V4 2/2] gpio: eic-sprd: Optimize the calculation method of eic number Date: Tue, 9 Jan 2024 15:38:49 +0800 Message-ID: <20240109073849.10791-3-Wenhua.Lin@unisoc.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20240109073849.10791-1-Wenhua.Lin@unisoc.com> References: <20240109073849.10791-1-Wenhua.Lin@unisoc.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain X-ClientProxiedBy: SHCAS03.spreadtrum.com (10.0.1.207) To shmbx06.spreadtrum.com (10.0.1.11) X-MAIL:SHSQR01.spreadtrum.com 4097d95D027979 The num_eics is a default value, but some SoCs support more than 8. In order to adapt to all projects, the total number of eics is automatically calculated through dts. Signed-off-by: Wenhua Lin --- drivers/gpio/gpio-eic-sprd.c | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/drivers/gpio/gpio-eic-sprd.c b/drivers/gpio/gpio-eic-sprd.c index 806b88d8dfb7..2dd0e46c42ad 100644 --- a/drivers/gpio/gpio-eic-sprd.c +++ b/drivers/gpio/gpio-eic-sprd.c @@ -108,7 +108,6 @@ static struct sprd_eic *to_sprd_eic(struct notifier_block *nb) struct sprd_eic_variant_data { enum sprd_eic_type type; - u32 num_eics; }; static const char *sprd_eic_label_name[SPRD_EIC_MAX] = { @@ -118,22 +117,18 @@ static const char *sprd_eic_label_name[SPRD_EIC_MAX] = { static const struct sprd_eic_variant_data sc9860_eic_dbnc_data = { .type = SPRD_EIC_DEBOUNCE, - .num_eics = 8, }; static const struct sprd_eic_variant_data sc9860_eic_latch_data = { .type = SPRD_EIC_LATCH, - .num_eics = 8, }; static const struct sprd_eic_variant_data sc9860_eic_async_data = { .type = SPRD_EIC_ASYNC, - .num_eics = 8, }; static const struct sprd_eic_variant_data sc9860_eic_sync_data = { .type = SPRD_EIC_SYNC, - .num_eics = 8, }; static inline void __iomem *sprd_eic_offset_base(struct sprd_eic *sprd_eic, @@ -619,6 +614,7 @@ static int sprd_eic_probe(struct platform_device *pdev) struct gpio_irq_chip *irq; struct sprd_eic *sprd_eic; struct resource *res; + u16 num_banks = 0; int ret, i; pdata = of_device_get_match_data(dev); @@ -652,10 +648,12 @@ static int sprd_eic_probe(struct platform_device *pdev) sprd_eic->base[i] = devm_ioremap_resource(dev, res); if (IS_ERR(sprd_eic->base[i])) return PTR_ERR(sprd_eic->base[i]); + + num_banks++; } sprd_eic->chip.label = sprd_eic_label_name[sprd_eic->type]; - sprd_eic->chip.ngpio = pdata->num_eics; + sprd_eic->chip.ngpio = num_banks * SPRD_EIC_PER_BANK_NR; sprd_eic->chip.base = -1; sprd_eic->chip.parent = dev; sprd_eic->chip.direction_input = sprd_eic_direction_input; -- 2.17.1