Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp643816imm; Sat, 8 Sep 2018 06:16:42 -0700 (PDT) X-Google-Smtp-Source: ANB0VdZ/ro2rKj5xjWm5DRFKy+n5HK95DGRpETogYlLeJhF2w68XFdxpnhtEHisVe56tvyXkXjIu X-Received: by 2002:a17:902:8bc8:: with SMTP id r8-v6mr1803123plo.100.1536412602718; Sat, 08 Sep 2018 06:16:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1536412602; cv=none; d=google.com; s=arc-20160816; b=OSb1dL82LhaYFjLikgCBSYVnf4ov9bNJAyjZ3X2pjwHFFWDXGjqNLYt1rZE2w79b8e C0KHL5pkujM/SSFoFlNXE+EtNuWGCWZ+z0Z+kuEup8fmgzKwp2vQllC0WP3zzNPgx384 hauFY9RYA5UlxCE3UnAlwFqu6qq4XgOgHPjv/0Weho712aD0DjfHal/+Wk22jfbzHM/t rqAckmka0P6w7B9yNPPkqpomuOVAVMXZKI7fdtcyXy7eDeMQSFhq8F250FMaADNmwI9r vg3wyjoMMniZicTZ4IkHoZIR4p3MqBIhKmRlU4Wm57SEFuLbRP7F79xk0R3zATHP2cGD gkdw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature; bh=KKNvow+69WIinFVpWVF4EiDGXbeRhgfewo1YQpRXles=; b=sWroEdB75dof8m6Kr26P8Ot/kXL9RdERXkyb3rc5RpTg/bUVOunzhxbH9itfpD4S4i VCrZKlX1/Nd2rmfR09ddI2uozyoo5MuAp/4E+nxNIX+fPZ8W807/9ovXxLKfHoeG/E7q 0PcHAiCNSnxcdBJjbRd8rGJyQZyYoGOhZqUMMotTGahUQkCYOAo1HUFu1i+3uhyGklLk qhAHMq1UuNtq/m5JDYQNHJHSA7Cw6xAOGSlvAKQMLe1Oyk+7W597KNH8RSAPUjT1J0Qb Do7PyEY3YhocYSSqavnQKAJAv4fj66daJ1qToDlmYG1b8sCQNEnzTVI5Z2b1s0+3I8Iv uLew== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@obeliks.de header.s=jul2017 header.b=P9Ko+FkA; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=obeliks.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a12-v6si10512596pgv.680.2018.09.08.06.16.27; Sat, 08 Sep 2018 06:16:42 -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=fail header.i=@obeliks.de header.s=jul2017 header.b=P9Ko+FkA; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=obeliks.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726790AbeIHSBF (ORCPT + 99 others); Sat, 8 Sep 2018 14:01:05 -0400 Received: from scopuli.esotechnik.de ([79.143.188.15]:34604 "EHLO mail.esotechnik.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726351AbeIHSBF (ORCPT ); Sat, 8 Sep 2018 14:01:05 -0400 Received: by mail.esotechnik.net (Postfix) with ESMTPSA id B7F69AE0B81; Sat, 8 Sep 2018 15:14:04 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=obeliks.de; s=jul2017; t=1536412444; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:content-type: content-transfer-encoding:in-reply-to:in-reply-to: references:references; bh=KKNvow+69WIinFVpWVF4EiDGXbeRhgfewo1YQpRXles=; b=P9Ko+FkAO3tdX/86EPfFAhN5sSX26nJslEAVTWlDSq1jopLowW0cuRiJYcKSdZA8uL+0HK Ffgiso9bZUmWRg64e/IoNo+GAQu+ha8nPjNxDVcOjZzAL7ZGW1jlNaQL07l5fd3lbYDows dj99OdKSqvsUh7BIwMUzAx3b6CkU/GjvSfhX8zAf96f/KKtougZivCO00bQ21Ntq+62Qzk 9xHGORXFwfLii2/Gza69Motn9VFvuQbeqjV7obLQxwlFArOhu+W3czDR5PAMWO2/oHyOqk G9toib5cnLMq+7ZPZyAoUViwwnOiLDG4FRFdvzy53nFhyUhrfQNbpMfFNRkyzg== From: Bernhard Frauendienst To: David Woodhouse , Brian Norris , Boris Brezillon , Marek Vasut , Richard Weinberger , Rob Herring , Mark Rutland Cc: Bernhard Frauendienst , Miquel Raynal , linux-mtd@lists.infradead.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH v3 1/3] mtd: core: add get_mtd_device_by_node Date: Sat, 8 Sep 2018 15:13:43 +0200 Message-Id: <20180908131345.8145-2-kernel@nospam.obeliks.de> X-Mailer: git-send-email 2.18.0 In-Reply-To: <20180908131345.8145-1-kernel@nospam.obeliks.de> References: <20180908131345.8145-1-kernel@nospam.obeliks.de> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add function to retrieve a mtd device by its OF node. Since drivers can assign arbitrary names to mtd devices in the absence of a label property, there is no other reliable way to retrieve a mtd device for a given OF node. Signed-off-by: Bernhard Frauendienst Reviewed-by: Miquel Raynal --- drivers/mtd/mtdcore.c | 38 ++++++++++++++++++++++++++++++++++++++ include/linux/mtd/mtd.h | 2 ++ 2 files changed, 40 insertions(+) diff --git a/drivers/mtd/mtdcore.c b/drivers/mtd/mtdcore.c index 97ac219c082e..87dd63926bc9 100644 --- a/drivers/mtd/mtdcore.c +++ b/drivers/mtd/mtdcore.c @@ -926,6 +926,44 @@ struct mtd_info *get_mtd_device_nm(const char *name) } EXPORT_SYMBOL_GPL(get_mtd_device_nm); +/** + * get_mtd_device_by_node - obtain a validated handle for an MTD device + * by of_node + * @of_node: OF node of MTD device to open + * + * This function returns MTD device description structure in case of + * success and an error code in case of failure. + */ +struct mtd_info *get_mtd_device_by_node(const struct device_node *of_node) +{ + int err = -ENODEV; + struct mtd_info *mtd = NULL, *other; + + mutex_lock(&mtd_table_mutex); + + mtd_for_each_device(other) { + if (of_node == other->dev.of_node) { + mtd = other; + break; + } + } + + if (!mtd) + goto out_unlock; + + err = __get_mtd_device(mtd); + if (err) + goto out_unlock; + + mutex_unlock(&mtd_table_mutex); + return mtd; + +out_unlock: + mutex_unlock(&mtd_table_mutex); + return ERR_PTR(err); +} +EXPORT_SYMBOL_GPL(get_mtd_device_by_node); + void put_mtd_device(struct mtd_info *mtd) { mutex_lock(&mtd_table_mutex); diff --git a/include/linux/mtd/mtd.h b/include/linux/mtd/mtd.h index cd0be91bdefa..fe71358f8eaa 100644 --- a/include/linux/mtd/mtd.h +++ b/include/linux/mtd/mtd.h @@ -570,6 +570,8 @@ extern struct mtd_info *get_mtd_device(struct mtd_info *mtd, int num); extern int __get_mtd_device(struct mtd_info *mtd); extern void __put_mtd_device(struct mtd_info *mtd); extern struct mtd_info *get_mtd_device_nm(const char *name); +extern struct mtd_info *get_mtd_device_by_node( + const struct device_node *of_node); extern void put_mtd_device(struct mtd_info *mtd); -- 2.18.0