Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp37974pxb; Wed, 20 Jan 2021 00:10:32 -0800 (PST) X-Google-Smtp-Source: ABdhPJzmVRg6ybUp3qElmYGqzGvIJhjhHNSx+1VxxNMXA3jQFnlp/0gzjK9JyZwn54VZOovedge0 X-Received: by 2002:a17:906:144e:: with SMTP id q14mr5311192ejc.150.1611130231849; Wed, 20 Jan 2021 00:10:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611130231; cv=none; d=google.com; s=arc-20160816; b=JzbLgwXJOS6oodGcF73wb6hFakd/+UEms7I4hRA4UQ3umftk+igYxHP++yUoUIaoR1 V149Cd1zWuhDqb1GuS9IIRX5i9L5q6VhUf+nykB3Z+8xJZrqkU9uL1imMo7OuyZBeBgB DpYHznK8807AOxnVPavxse3FEt+N4wQz1nweruLqfhs+c4yPvVbHKsNWL994OuiitOMq GWcoIRJ1IIjpyKJyVp00olf9hkTfO6HQmS4/TEjo3z35Pa6KD8g4MByJT/ad0Xp3Kgfk 37CyaAVtLSLf664TUP8St461uEYEVDCY3k+1S3YLvF6ZgFM2u8BZFGixs8ERMjPbhSny xO5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:sender:dkim-signature; bh=uGaUoM+E9lfomuo5VcB6+FBCFYFJdpblUN9bMb0KEQ8=; b=GpMuYwQO5msDxLeeOtVz5GJVLUbIlQN3KRKGGI81pcGWPbFwPYK+i8YXakgsguyA+p QikreIoQrSJ0D0FEuuZIuzr4oHSwjktHvykT23f7xJp46ZQBKjl1qm94djRRoaHsOVM1 64fWVY24gEupIJ8NFbJlib0mo3wMzCKnzP77HuMsTjMD5Scip1uPIFxoOQ49SZWtlPxb zhQ7AkDKHDY5tYkKK84iLQPqP3qkn/d+q+068FNLA78uXM8assPclS/IDeAQBLF0C2WC Ig2M9XtWVB2IhWJcEf7frFl9gW1mPOMjT1zKHL2CWaGS7LijZyHuVsGTzettr4fimoYZ OZMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=WXFajYaC; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cy15si574943edb.10.2021.01.20.00.10.08; Wed, 20 Jan 2021 00:10:31 -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=@google.com header.s=20161025 header.b=WXFajYaC; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729882AbhATIIK (ORCPT + 99 others); Wed, 20 Jan 2021 03:08:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55344 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730530AbhATIGI (ORCPT ); Wed, 20 Jan 2021 03:06:08 -0500 Received: from mail-qk1-x74a.google.com (mail-qk1-x74a.google.com [IPv6:2607:f8b0:4864:20::74a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5F44DC0613D3 for ; Wed, 20 Jan 2021 00:05:28 -0800 (PST) Received: by mail-qk1-x74a.google.com with SMTP id q7so22906652qki.16 for ; Wed, 20 Jan 2021 00:05:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=sender:date:in-reply-to:message-id:mime-version:references:subject :from:to:cc; bh=uGaUoM+E9lfomuo5VcB6+FBCFYFJdpblUN9bMb0KEQ8=; b=WXFajYaCVStBAKnz0wmB2RrIJ38/1vH//mTVPlMPb41/IhwYJkh+lPTxY4cx0w0w50 fArOq6D2XgX0y4Bo3onEcnRQ9phEiUsLnrfusOxat89NlAdQQm9p93P4AzfVIha1z/t9 QrXpm97SWljygpeLIS6G+W41y/CcfX8285AT/dVcGidwhI6PKrlOmv2qv4FlYlavSNle NWQiSDPLVy4CkmQqIeKZWZ8Mf/hC7LcaRT7F21eDu4HbDZfynn4hElcSIADLjfVgAVwU hcl0k69nFgk6t4yypuOwqCqc3tFltgbbtbwL4pWshP+Xu6W7zX03ckMKncpS1/DDjMyo NDoQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=uGaUoM+E9lfomuo5VcB6+FBCFYFJdpblUN9bMb0KEQ8=; b=p4IGlqBB8yLroYm8/hE6Ii2oi1rPLwHQP8Tr7uopcUOgWLKUVL8Rx/53wKT7d+uWih Wgqiiz8bz7g6rhJ1VXPSVJoP1niehC4feMKgnWBYioSA/847e6G6Dvkb4lyAboEADgQJ p6Zi8pvgesfn7S223BpOmIKD+/0QsT85svtXUR76bT4fI3J0YjljyLmPYizI+Kx14Ot1 z2Ohl+bRh6ZIJRC63VAcFVpFgpf9FbfouVr8B06QtinkES+VY+/DMrV5zfPoWo2kulhM 7eJ+dTV9z6LNUr75/GHPiXtvoXVnPJ5zzff2GlxumR5Fy9PyL/7hwUK4j3vIpoEhYXu0 OzbA== X-Gm-Message-State: AOAM532J37y+rI4sIViUpMxX6QN/ScEU6CrJ6jYKNYEtbCkOF5RoxyLK bt8o+cZMU/SCYkoiC4G8freMGVQColJk7Fc= Sender: "saravanak via sendgmr" X-Received: from saravanak.san.corp.google.com ([2620:15c:2d:3:7220:84ff:fe09:fedc]) (user=saravanak job=sendgmr) by 2002:a0c:f107:: with SMTP id i7mr8384314qvl.35.1611129927528; Wed, 20 Jan 2021 00:05:27 -0800 (PST) Date: Wed, 20 Jan 2021 00:05:20 -0800 In-Reply-To: <20210120080522.471120-1-saravanak@google.com> Message-Id: <20210120080522.471120-2-saravanak@google.com> Mime-Version: 1.0 References: <20210120080522.471120-1-saravanak@google.com> X-Mailer: git-send-email 2.30.0.284.gd98b1dd5eaa7-goog Subject: [PATCH v1 1/2] of: property: Add fw_devlink support for "gpio" and "gpios" binding From: Saravana Kannan To: Rob Herring , Frank Rowand , Greg Kroah-Hartman , Saravana Kannan Cc: linux-tegra , devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Linus Walleij , Bartosz Golaszewski , Geert Uytterhoeven , Jon Hunter , Marc Zyngier , Kevin Hilman , kernel-team@android.com Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org To provide backward compatibility for boards that use deprecated DT bindings, we need to add fw_devlink support for "gpio" and "gpios". Cc: linux-tegra Cc: Linus Walleij Cc: Bartosz Golaszewski Cc: Greg Kroah-Hartman Cc: Geert Uytterhoeven Fixes: e590474768f1 ("driver core: Set fw_devlink=on by default") Tested-by: Jon Hunter Signed-off-by: Saravana Kannan --- drivers/of/property.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/drivers/of/property.c b/drivers/of/property.c index 5f9eed79a8aa..0b256ce9d7d5 100644 --- a/drivers/of/property.c +++ b/drivers/of/property.c @@ -1271,6 +1271,24 @@ static struct device_node *parse_iommu_maps(struct device_node *np, return of_parse_phandle(np, prop_name, (index * 4) + 1); } +static struct device_node *parse_gpio_compat(struct device_node *np, + const char *prop_name, int index) +{ + struct of_phandle_args sup_args; + + if (strcmp(prop_name, "gpio") && strcmp(prop_name, "gpios")) + return NULL; + + if (of_find_property(np, "gpio-hog", NULL)) + return NULL; + + if (of_parse_phandle_with_args(np, prop_name, "#gpio-cells", index, + &sup_args)) + return NULL; + + return sup_args.np; +} + static const struct supplier_bindings of_supplier_bindings[] = { { .parse_prop = parse_clocks, }, { .parse_prop = parse_interconnects, }, @@ -1296,6 +1314,7 @@ static const struct supplier_bindings of_supplier_bindings[] = { { .parse_prop = parse_pinctrl6, }, { .parse_prop = parse_pinctrl7, }, { .parse_prop = parse_pinctrl8, }, + { .parse_prop = parse_gpio_compat, }, { .parse_prop = parse_regulators, }, { .parse_prop = parse_gpio, }, { .parse_prop = parse_gpios, }, -- 2.30.0.284.gd98b1dd5eaa7-goog