From: Kay Sievers <kay.sievers@vrfy.org>
To: linux-hotplug@vger.kernel.org
Subject: Re: [patch] Fix naming ethernet devices in udevstart
Date: Tue, 07 Sep 2004 16:56:49 +0000 [thread overview]
Message-ID: <20040907165649.GA3543@vrfy.org> (raw)
In-Reply-To: <20040907031839.GA20951@smtp.west.cox.net>
[-- Attachment #1: Type: text/plain, Size: 1391 bytes --]
On Tue, Sep 07, 2004 at 12:46:43PM +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 20:18 -0700, Tom Rini wrote:
> > I noticed somewhat recently that my enet devices weren't being renamed
> > on boot anymore. I don't quite know when this got broken (or rather, if
> > it was supposed to be working. I swear it worked for me once..), but
> > the following seems to do it.
>
> I think it never worked in the udevstart case. It worked only with the
> hotplug-event-udev, I expect.
>
> > In udev_scan_class(), look for not just
> > %s/%s/dev (which everything with a dev node has), but %s/%s/dev* (both
> > of my enet devices, sis900 & 3c59x only have device) and if that
> > exists, pass this along to udev.
>
> Yeah, network devices don't have a devnode and therefore no "dev", but
> they are all in /sys/class/net/. We may just test if we are there
> instead of the "device" match.
How about something like this. It adds all the net devices without
looking at the attributes and keeps the remaining logic like it is.
It also removes certain levels of indirection and much simplifies the
udevstart process. We surely don't need to open and close the udevdb
for every node while iterating over the list. (We are about 5% faster on
my box)
It's not well tested, so it would be nice if someone can have a look
at it, before a broken udevstart renders any system unbootable.
Thanks,
Kay
[-- Attachment #2: udevstart-cleanup-01.patch --]
[-- Type: text/plain, Size: 7535 bytes --]
===== udev.c 1.60 vs edited =====
--- 1.60/udev.c 2004-08-10 17:11:56 +02:00
+++ edited/udev.c 2004-09-07 17:48:42 +02:00
@@ -40,9 +40,6 @@
char **main_argv;
char **main_envp;
-/* local variables */
-static int is_udevstart;
-
#ifdef LOG
unsigned char logname[LOGNAME_SIZE];
void log_message(int level, const char *format, ...)
@@ -79,36 +76,72 @@ static char *subsystem_blacklist[] = {
""
};
-int __udev_hotplug(char *action, const char *devpath, const char *subsystem)
+int main(int argc, char *argv[], char *envp[])
{
- int retval = -EINVAL;
- int i;
+ main_argv = argv;
+ main_envp = envp;
struct sigaction act;
- const int nofake = 0;
+ char *action;
+ char *devpath = "";
+ char *subsystem = "";
+ int i;
+ int retval = -EINVAL;
+ enum {
+ ADD,
+ REMOVE,
+ UDEVSTART,
+ } act_type;
- dbg("looking at '%s'", devpath);
+ dbg("version %s", UDEV_VERSION);
- /* we only care about class devices and block stuff */
- if (!strstr(devpath, "class") &&
- !strstr(devpath, "block")) {
- dbg("not a block or class device");
- goto exit;
- }
+ /* initialize our configuration */
+ udev_init_config();
- i = 0;
- while (subsystem_blacklist[i][0] != '\0') {
- if (strcmp(subsystem, subsystem_blacklist[i]) == 0) {
- dbg("don't care about '%s' devices", subsystem);
+ if (strstr(argv[0], "udevstart")) {
+ act_type = UDEVSTART;
+ } else {
+ action = get_action();
+ if (!action) {
+ dbg("no action?");
+ goto exit;
+ }
+ if (strcmp(action, "add") == 0) {
+ act_type = ADD;
+ } else if (strcmp(action, "remove") == 0) {
+ act_type = REMOVE;
+ } else {
+ dbg("unknown action '%s'", action);
goto exit;
}
- i++;
- }
- /* initialize udev database */
- retval = udevdb_init(UDEVDB_DEFAULT);
- if (retval != 0) {
- dbg("unable to initialize database");
- goto exit;
+ devpath = get_devpath();
+ if (!devpath) {
+ dbg("no devpath?");
+ goto exit;
+ }
+ dbg("looking at '%s'", devpath);
+
+ /* we only care about class devices and block stuff */
+ if (strstr(devpath, "class") && strstr(devpath, "block")) {
+ dbg("not a block or class device");
+ goto exit;
+ }
+
+ subsystem = get_subsystem(main_argv[1]);
+ if (!subsystem) {
+ dbg("no subsystem?");
+ goto exit;
+ }
+
+ /* skip blacklisted subsystems */
+ i = 0;
+ while (subsystem_blacklist[i][0] != '\0') {
+ if (strcmp(subsystem, subsystem_blacklist[i]) == 0) {
+ dbg("don't care about '%s' devices", subsystem);
+ goto exit;
+ }
+ i++;
+ }
}
/* set signal handlers */
@@ -118,76 +151,31 @@ int __udev_hotplug(char *action, const c
sigaction(SIGINT, &act, NULL);
sigaction(SIGTERM, &act, NULL);
- if (strcmp(action, "add") == 0) {
- /* Already done. */
- if (!is_udevstart)
- namedev_init();
- retval = udev_add_device(devpath, subsystem, nofake);
- goto action_done;
+ /* initialize udev database */
+ if (udevdb_init(UDEVDB_DEFAULT) != 0) {
+ dbg("unable to initialize database");
+ goto exit;
}
- if (strcmp(action, "remove") == 0) {
+ switch(act_type) {
+ case UDEVSTART:
+ dbg("udevstart");
+ namedev_init();
+ udev_sleep = 0;
+ retval = udev_start();
+ break;
+ case ADD:
+ dbg("udev add");
+ namedev_init();
+ retval = udev_add_device(devpath, subsystem, NOFAKE);
+ break;
+ case REMOVE:
+ dbg("udev remove");
retval = udev_remove_device(devpath, subsystem);
- goto action_done;
}
- dbg("unknown action '%s'", action);
- retval = -EINVAL;
-
-action_done:
udevdb_exit();
exit:
return retval;
-}
-
-static int udev_hotplug(void)
-{
- char *action;
- char *devpath;
- char *subsystem;
-
- action = get_action();
- if (!action) {
- dbg("no action?");
- return -EINVAL;
- }
-
- devpath = get_devpath();
- if (!devpath) {
- dbg("no devpath?");
- return -EINVAL;
- }
-
- /* skip blacklisted subsystems */
- subsystem = get_subsystem(main_argv[1]);
- if (!subsystem) {
- dbg("no subsystem?");
- return -EINVAL;
- }
-
- return __udev_hotplug(action, devpath, subsystem);
-}
-
-int main(int argc, char *argv[], char *envp[])
-{
- main_argv = argv;
- main_envp = envp;
-
- if (strstr(argv[0], "udevstart")) {
- /* Setup env variables. */
- setenv("UDEV_NO_SLEEP", "1", 1);
- is_udevstart = 1;
- }
-
- /* initialize our configuration */
- udev_init_config();
-
- dbg("version %s", UDEV_VERSION);
-
- if (is_udevstart) {
- namedev_init();
- return udev_start();
- } else
- return udev_hotplug();
}
===== udev.h 1.58 vs edited =====
--- 1.58/udev.h 2004-08-05 00:43:58 +02:00
+++ edited/udev.h 2004-09-07 13:16:50 +02:00
@@ -37,6 +37,9 @@
#define DEVPATH_SIZE 255
#define SUBSYSTEM_SIZE 30
+#define FAKE 1
+#define NOFAKE 0
+
/* length of public data */
#define UDEVICE_LEN (offsetof(struct udevice, bus_id))
===== udevstart.c 1.14 vs edited =====
--- 1.14/udevstart.c 2004-08-10 17:11:37 +02:00
+++ edited/udevstart.c 2004-09-07 18:34:14 +02:00
@@ -70,18 +70,10 @@ static int device_list_insert(char *path
strfieldcpy(new_device->path, path);
strfieldcpy(new_device->subsys, subsystem);
list_add_tail(&new_device->list, &loop_device->list);
+ dbg("add '%s' from subsys '%s'", new_device->path, new_device->subsys);
return 0;
}
-static void udev_exec(const char *path, const char* subsystem)
-{
- /* Now call __udev_hotplug(). */
- if (__udev_hotplug("add", path, subsystem)) {
- dbg("Calling of udev_hotplug failed");
- exit(1);
- }
-}
-
/* list of devices that we should run last due to any one of a number of reasons */
static char *last_list[] = {
"/block/dm", /* on here because dm wants to have the block devices around before it */
@@ -106,14 +98,14 @@ static void exec_list(struct list_head *
if (found)
continue;
- udev_exec(loop_device->path, loop_device->subsys);
+ udev_add_device(loop_device->path, loop_device->subsys, NOFAKE);
list_del(&loop_device->list);
free(loop_device);
}
/* handle the rest of the devices left over, if any */
list_for_each_entry_safe(loop_device, tmp_device, device_list, list) {
- udev_exec(loop_device->path, loop_device->subsys);
+ udev_add_device(loop_device->path, loop_device->subsys, NOFAKE);
list_del(&loop_device->list);
free(loop_device);
}
@@ -209,19 +201,27 @@ static void udev_scan_class(void)
(strcmp(dent2->d_name, "..") == 0))
continue;
+ /* pass the net class as it is */
+ if (strcmp(dent->d_name, "net") == 0) {
+ snprintf(dirname2, MAX_PATHLEN, "/class/net/%s", dent2->d_name);
+ device_list_insert(dirname2, "net", &device_list);
+ continue;
+ }
+
snprintf(dirname2, MAX_PATHLEN, "%s/%s", dirname, dent2->d_name);
dirname2[MAX_PATHLEN-1] = '\0';
-
dir3 = opendir(dirname2);
if (dir3 != NULL) {
for (dent3 = readdir(dir3); dent3 != NULL; dent3 = readdir(dir3)) {
char filename[MAX_PATHLEN];
+ /* pass devices with a "dev" file */
if (strcmp(dent3->d_name, "dev") == 0) {
snprintf(filename, MAX_PATHLEN, "/class/%s/%s",
dent->d_name, dent2->d_name);
filename[MAX_PATHLEN-1] = '\0';
device_list_insert(filename, dent->d_name, &device_list);
+ break;
}
}
closedir(dir3);
===== udevtest.c 1.9 vs edited =====
--- 1.9/udevtest.c 2004-04-01 23:46:07 +02:00
+++ edited/udevtest.c 2004-09-07 13:17:19 +02:00
@@ -102,7 +102,7 @@ int main(int argc, char *argv[], char *e
subsystem = argv[2];
/* simulate node creation with fake flag */
- udev_add_device(devpath, subsystem, fake);
+ udev_add_device(devpath, subsystem, FAKE);
exit:
return 0;
next prev parent reply other threads:[~2004-09-07 16:56 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-09-07 3:18 [patch] Fix naming ethernet devices in udevstart Tom Rini
2004-09-07 10:46 ` Kay Sievers
2004-09-07 16:56 ` Kay Sievers [this message]
2004-09-07 17:23 ` Tom Rini
2004-09-07 22:54 ` Tom Rini
2004-09-10 20:19 ` Greg KH
2004-09-10 20:21 ` Greg KH
2004-09-10 21:25 ` Kevin P. Fleming
2004-09-10 23:00 ` Greg KH
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20040907165649.GA3543@vrfy.org \
--to=kay.sievers@vrfy.org \
--cc=linux-hotplug@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).