Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit c906a48a authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman
Browse files

driver core: add init_name to struct device



This gives us a way to handle both the bus_id and init_name values being
used for a while during the transition period.

Cc: Kay Sievers <kay.sievers@vrfy.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 3b98aeaf
Loading
Loading
Loading
Loading
+13 −7
Original line number Diff line number Diff line
@@ -844,13 +844,19 @@ int device_add(struct device *dev)
{
	struct device *parent = NULL;
	struct class_interface *class_intf;
	int error;
	int error = -EINVAL;

	dev = get_device(dev);
	if (!dev || !strlen(dev->bus_id)) {
		error = -EINVAL;
		goto Done;
	}
	if (!dev)
		goto done;

	/* Temporarily support init_name if it is set.
	 * It will override bus_id for now */
	if (dev->init_name)
		dev_set_name(dev, "%s", dev->init_name);

	if (!strlen(dev->bus_id))
		goto done;

	pr_debug("device: '%s': %s\n", dev->bus_id, __func__);

@@ -919,7 +925,7 @@ int device_add(struct device *dev)
				class_intf->add_dev(dev, class_intf);
		mutex_unlock(&dev->class->p->class_mutex);
	}
 Done:
done:
	put_device(dev);
	return error;
 DPMError:
@@ -946,7 +952,7 @@ int device_add(struct device *dev)
	cleanup_device_parent(dev);
	if (parent)
		put_device(parent);
	goto Done;
	goto done;
}

/**
+1 −0
Original line number Diff line number Diff line
@@ -358,6 +358,7 @@ struct device {

	struct kobject kobj;
	char	bus_id[BUS_ID_SIZE];	/* position on parent bus */
	const char		*init_name; /* initial name of the device */
	struct device_type	*type;
	unsigned		uevent_suppress:1;