aboutsummaryrefslogtreecommitdiff
path: root/drivers/w1-eeprom/w1-eeprom-uclass.c
diff options
context:
space:
mode:
authorKory Maincent <kory.maincent@bootlin.com>2021-05-04 19:31:26 +0200
committerTom Rini <trini@konsulko.com>2021-05-13 13:09:09 -0400
commitc9dffc971957e5fd18d64aa17a95e8d82a59d273 (patch)
tree287136ba55d66eeca44f3d7996ccc5544b8a0b30 /drivers/w1-eeprom/w1-eeprom-uclass.c
parent0705e25cd05a9772d1ae8de8debd3b424b03b59d (diff)
downloadu-boot-c9dffc971957e5fd18d64aa17a95e8d82a59d273.zip
u-boot-c9dffc971957e5fd18d64aa17a95e8d82a59d273.tar.gz
u-boot-c9dffc971957e5fd18d64aa17a95e8d82a59d273.tar.bz2
w1: replace dt detection by automatic detection
This patch changes the functioning of the detection of w1 devices. The old way was a comparison between detected w1 and the ones described in the device tree. Now it will just look for the driver matching the family id of the w1 detected. The patch is inspired from Maxime Ripard code. Signed-off-by: Kory Maincent <kory.maincent@bootlin.com> Reviewed-by: Maxime Ripard <maxime@cerno.tech>
Diffstat (limited to 'drivers/w1-eeprom/w1-eeprom-uclass.c')
-rw-r--r--drivers/w1-eeprom/w1-eeprom-uclass.c31
1 files changed, 0 insertions, 31 deletions
diff --git a/drivers/w1-eeprom/w1-eeprom-uclass.c b/drivers/w1-eeprom/w1-eeprom-uclass.c
index 97a9d43..7a02af3 100644
--- a/drivers/w1-eeprom/w1-eeprom-uclass.c
+++ b/drivers/w1-eeprom/w1-eeprom-uclass.c
@@ -37,37 +37,6 @@ int w1_eeprom_read_buf(struct udevice *dev, unsigned int offset,
return ops->read_buf(dev, offset, buf, count);
}
-int w1_eeprom_register_new_device(u64 id)
-{
- u8 family = id & 0xff;
- int ret;
- struct udevice *dev;
-
- for (ret = uclass_first_device(UCLASS_W1_EEPROM, &dev);
- !ret && dev;
- uclass_next_device(&dev)) {
- if (ret || !dev) {
- debug("cannot find w1 eeprom dev\n");
- return ret;
- }
- if (dev_get_driver_data(dev) == family) {
- struct w1_device *w1;
-
- w1 = dev_get_parent_plat(dev);
- if (w1->id) /* device already in use */
- continue;
- w1->id = id;
- debug("%s: Match found: %s:%s %llx\n", __func__,
- dev->name, dev->driver->name, id);
- return 0;
- }
- }
-
- debug("%s: No matches found: error %d\n", __func__, ret);
-
- return ret;
-}
-
int w1_eeprom_get_id(struct udevice *dev, u64 *id)
{
struct w1_device *w1 = dev_get_parent_plat(dev);