Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp542613pxb; Sat, 6 Mar 2021 08:05:44 -0800 (PST) X-Google-Smtp-Source: ABdhPJwsg59EQjTB4GaL2dXYy3+FXs3aEWZypBQMF7ZZCaExYLqSnq/ZsFr3kjYhw5vhe8yvvCG2 X-Received: by 2002:a17:906:a106:: with SMTP id t6mr7500809ejy.63.1615046744520; Sat, 06 Mar 2021 08:05:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615046744; cv=none; d=google.com; s=arc-20160816; b=K30oWpsPrMpT/LOqJPgzFcotssf4xbVqfwpO65XfB47tU4Dvl+u8DEGD8lmesTU3XM 8GXDXcSnRuyb6msIEkxBRI0BMq37/ORxdShmdkB7lAKUCp2zIBgV0rNuLNbn7stOstsA vaEEVEsMZ0SHldDjH5DC0x5gsUk/Yb/oMP2Cs4ER7JEASDiYvu0YH4CijtWLR/kglh+m JS51m6Re25QTB7KkpKaGLeoBKTSgLoQt9vSbxebQlJnJBzt45pXjbvVvOcTzsdEJTif/ aAhMotxYDHVp3oVPm7IQ0InStDdf71C5xYOChXDWWsJCO3vA3juMDTDNmP+rMVvKiLR+ MswQ== 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 :references:in-reply-to:message-id:date:subject:to:from :dkim-signature; bh=i2/CD8od2LVeeQI8j9cSShPFvLURIkZli5+jweOumGs=; b=iqog9r1+MOuKjP7UJXbefav1hJhjmV5SxzWDlehgouUtcwDml1i0GTKU4N+7Haux2R AHBmkW2C1/bnMzD8cjSinh6ctKEbLXhm7SWLYklGO5vf/ctobYIpgUdHVoXYFxxHzRp/ siKDbchAUIna7PKjZKzERwOcj2MT/bebPrjOFazp14hcqt6StVvZ2GQOG5OX7NhhIZW/ oapFzzLK9Plel2Qkr4MjvMqb2zgbUFabY65+Wa9jG6oWP95PT9Jh0LHhgITv3ACzu08m TKvtvVyCKaYV6+6e7XjmrqgNlUzXgqEdyj5cdL1fSk8qoAy9jrCB170zxBOK4RUtzRV1 a57w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=BC8Unkuu; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jg13si3529788ejc.669.2021.03.06.08.05.21; Sat, 06 Mar 2021 08:05:44 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=BC8Unkuu; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231222AbhCFP5w (ORCPT + 99 others); Sat, 6 Mar 2021 10:57:52 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50918 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230449AbhCFP5R (ORCPT ); Sat, 6 Mar 2021 10:57:17 -0500 Received: from mail-wr1-x42a.google.com (mail-wr1-x42a.google.com [IPv6:2a00:1450:4864:20::42a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id DE1DEC06174A; Sat, 6 Mar 2021 07:57:16 -0800 (PST) Received: by mail-wr1-x42a.google.com with SMTP id w11so5930636wrr.10; Sat, 06 Mar 2021 07:57:16 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=i2/CD8od2LVeeQI8j9cSShPFvLURIkZli5+jweOumGs=; b=BC8UnkuuvYHiJYmTRuzg2weD9srUtY6Pj3ykzemMW7rA1pcoDHbmTMeM3FGJugFbHZ Vs7DMi6gchiknFBReddn2WSuMXt6DmCo+wViu+nHnLr0Abos3Jo+SmQMoPws0pT/lmVT NM46VbWhLqEgEYtMv8zoEsZfpqR7fJjyMVuT0DC4z084RDMkd5nYZ/jZ0ce0IWLilORq XeTxn+5zPRq9/7MNR6cTP4d+p1ArYXLCLgPTY/CqqX7HzO6P6UueM3miCAhRCmQt+/Es 4w4B037kd8hs5rBe3XUEQW3ki+BMK+VsBxNuNpvPcbRmDPRJPUYmntp19vjQLG3UO7/z 3UGg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=i2/CD8od2LVeeQI8j9cSShPFvLURIkZli5+jweOumGs=; b=fr6bmT+MTiOoG7ajNTgDpaQe/gAVBfoGYgwFDowwCGYAjB4WVj8g/ABGvlUO5GaJGT hFBUK4E9FE51hvWlHsJ2b6zNsU5SrnFk+SnP59vfgkKuC64sFrBK4vXYBjJKD2rNUYhA UqtVzWH9CDFbrOu06SHBsW6yttU/ri+llcNcoN11ZPMj5tzARrxbISwWDRQJdUIYHHRw VEsadf2wuHq8hkaZCoOxacZdETbGwraCtkly40tyZN56q3UmnT35gZk6j+icmGdL+wXv 2Wj4uhnjkd3GpIdsYwaKhtx33a0RLFa1bzyrmLk7o3gSV5MupW/DxUq+X7W6HItN8q2A xOfQ== X-Gm-Message-State: AOAM530/5QxyhUTSXichd+hxPRZK0Q/L2HX3kaNTGM1vqBJWFAXpq5sC Ru05NU0P/mjg4do9yGoDQIk= X-Received: by 2002:a5d:6a86:: with SMTP id s6mr15070069wru.307.1615046235687; Sat, 06 Mar 2021 07:57:15 -0800 (PST) Received: from skynet.lan (224.red-2-138-103.dynamicip.rima-tde.net. [2.138.103.224]) by smtp.gmail.com with ESMTPSA id p6sm9315188wru.2.2021.03.06.07.57.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 06 Mar 2021 07:57:15 -0800 (PST) From: =?UTF-8?q?=C3=81lvaro=20Fern=C3=A1ndez=20Rojas?= To: Linus Walleij , Rob Herring , Michael Walle , Bartosz Golaszewski , Florian Fainelli , bcm-kernel-feedback-list@broadcom.com, Jonas Gorski , =?UTF-8?q?=C3=81lvaro=20Fern=C3=A1ndez=20Rojas?= , Necip Fazil Yildiran , Andy Shevchenko , linux-gpio@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH v5 02/15] gpio: regmap: set gpio_chip of_node Date: Sat, 6 Mar 2021 16:56:59 +0100 Message-Id: <20210306155712.4298-3-noltari@gmail.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210306155712.4298-1-noltari@gmail.com> References: <20210306155712.4298-1-noltari@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is needed for properly registering GPIO regmap as a child of a regmap pin controller. Signed-off-by: Álvaro Fernández Rojas Reviewed-by: Michael Walle --- v5: switch to fwnode v4: fix documentation v3: introduce patch needed for properly parsing gpio-range drivers/gpio/gpio-regmap.c | 4 ++++ include/linux/gpio/regmap.h | 3 +++ 2 files changed, 7 insertions(+) diff --git a/drivers/gpio/gpio-regmap.c b/drivers/gpio/gpio-regmap.c index 5412cb3b0b2a..626433934d69 100644 --- a/drivers/gpio/gpio-regmap.c +++ b/drivers/gpio/gpio-regmap.c @@ -249,6 +249,10 @@ struct gpio_regmap *gpio_regmap_register(const struct gpio_regmap_config *config chip = &gpio->gpio_chip; chip->parent = config->parent; + if (config->fwnode) + chip->of_node = to_of_node(config->fwnode); + else + chip->of_node = dev_of_node(config->parent); chip->base = -1; chip->ngpio = config->ngpio; chip->names = config->names; diff --git a/include/linux/gpio/regmap.h b/include/linux/gpio/regmap.h index ad76f3d0a6ba..c12e8d1d171b 100644 --- a/include/linux/gpio/regmap.h +++ b/include/linux/gpio/regmap.h @@ -4,6 +4,7 @@ #define _LINUX_GPIO_REGMAP_H struct device; +struct fwnode_handle; struct gpio_regmap; struct irq_domain; struct regmap; @@ -16,6 +17,7 @@ struct regmap; * @parent: The parent device * @regmap: The regmap used to access the registers * given, the name of the device is used + * @fwnode: (Optional) The firmware node * @label: (Optional) Descriptive name for GPIO controller. * If not given, the name of the device is used. * @ngpio: Number of GPIOs @@ -57,6 +59,7 @@ struct regmap; struct gpio_regmap_config { struct device *parent; struct regmap *regmap; + struct fwnode_handle *fwnode; const char *label; int ngpio; -- 2.20.1