[PATCH v3 3/4] drivers: mci: Add mci_get_device_by_name function
Daniel Schultz
d.schultz at phytec.de
Tue Sep 1 23:28:52 PDT 2015
Get a 'struct mci' by search after the device name.
Signed-off-by: Daniel Schultz <d.schultz at phytec.de>
---
Changes:
v3:
New with patch v3
drivers/mci/mci-core.c | 16 ++++++++++++++++
include/mci.h | 8 ++++++++
2 files changed, 24 insertions(+)
diff --git a/drivers/mci/mci-core.c b/drivers/mci/mci-core.c
index c22f932..d6865d1 100644
--- a/drivers/mci/mci-core.c
+++ b/drivers/mci/mci-core.c
@@ -53,6 +53,8 @@
__res & __mask; \
})
+LIST_HEAD(mci_list);
+
/**
* @file
* @brief Memory Card framework
@@ -1753,6 +1755,8 @@ int mci_register(struct mci_host *host)
mci->dev.id = DEVICE_ID_DYNAMIC;
}
+ list_add_tail(&mci->list, &mci_list);
+
mci->dev.platform_data = host;
mci->dev.parent = host->hw_dev;
mci->host = host;
@@ -1844,3 +1848,15 @@ void mci_of_parse(struct mci_host *host)
host->non_removable = of_property_read_bool(np, "non-removable");
}
+
+struct mci *mci_get_device_by_name(const char *name)
+{
+ struct mci *dev;
+
+ for_each_mci_device(dev) {
+ if (!strcmp(dev->cdevname, name))
+ return dev;
+ }
+
+ return NULL;
+}
diff --git a/include/mci.h b/include/mci.h
index 9e4d18b..3c7b407 100644
--- a/include/mci.h
+++ b/include/mci.h
@@ -466,6 +466,8 @@ struct mci {
struct mci_part *part_curr;
u8 ext_csd_part_config;
+
+ struct list_head list; /* The list of all mci devices */
};
int mci_register(struct mci_host*);
@@ -483,4 +485,10 @@ static inline int mmc_host_is_spi(struct mci_host *host)
return 0;
}
+/* Iterate over all mci devices
+ */
+#define for_each_mci_device(dev) list_for_each_entry(dev, &mci_list, list)
+
+struct mci *mci_get_device_by_name(const char *name);
+
#endif /* _MCI_H_ */
--
1.9.1
More information about the barebox
mailing list