2004-03-25 05:46:58 +01:00
|
|
|
/*
|
2004-03-27 10:21:46 +01:00
|
|
|
* dev_d.c - dev.d/ multiplexer
|
2004-03-25 05:46:58 +01:00
|
|
|
*
|
|
|
|
* Copyright (C) 2004 Greg Kroah-Hartman <greg@kroah.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation version 2 of the License.
|
|
|
|
*/
|
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
/*
|
2004-03-25 05:46:58 +01:00
|
|
|
* This essentially emulates the following shell script logic in C:
|
2004-03-27 10:21:46 +01:00
|
|
|
* DIR="/etc/dev.d"
|
2004-04-09 03:48:56 +02:00
|
|
|
* export DEVNAME="whatever_dev_name_udev_just_gave"
|
|
|
|
* for I in "${DIR}/$DEVNAME/"*.dev "${DIR}/$1/"*.dev "${DIR}/default/"*.dev ; do
|
2004-03-27 10:21:46 +01:00
|
|
|
* if [ -f $I ]; then $I $1 ; fi
|
|
|
|
* done
|
|
|
|
* exit 1;
|
2004-03-25 05:46:58 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/wait.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include "udev.h"
|
|
|
|
#include "udev_lib.h"
|
|
|
|
#include "logging.h"
|
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
#define DEVD_DIR "/etc/dev.d/"
|
|
|
|
#define DEVD_SUFFIX ".dev"
|
2004-03-25 05:46:58 +01:00
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
static int run_program(char *name)
|
2004-03-25 05:46:58 +01:00
|
|
|
{
|
|
|
|
pid_t pid;
|
|
|
|
|
|
|
|
dbg("running %s", name);
|
|
|
|
|
|
|
|
pid = fork();
|
2004-03-27 10:21:46 +01:00
|
|
|
switch (pid) {
|
|
|
|
case 0:
|
|
|
|
/* child */
|
|
|
|
execv(name, main_argv);
|
|
|
|
dbg("exec of child failed");
|
|
|
|
exit(1);
|
|
|
|
case -1:
|
|
|
|
dbg("fork of child failed");
|
|
|
|
break;
|
|
|
|
return -1;
|
|
|
|
default:
|
2004-03-25 05:46:58 +01:00
|
|
|
wait(NULL);
|
|
|
|
}
|
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
return 0;
|
2004-03-25 05:46:58 +01:00
|
|
|
}
|
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
/*
|
|
|
|
* runs files in these directories in order:
|
|
|
|
* <node name given by udev>/
|
|
|
|
* subsystem/
|
|
|
|
* default/
|
2004-03-25 05:46:58 +01:00
|
|
|
*/
|
2004-04-01 10:59:58 +02:00
|
|
|
void dev_d_send(struct udevice *dev, char *subsystem, char *devpath)
|
2004-03-25 05:46:58 +01:00
|
|
|
{
|
|
|
|
char dirname[256];
|
[PATCH] netdev - udevdb+dev.d changes
Here is a patch to change the netdev handling in the database and for
the dev.d/ calls. I applies on top of the udevd.patch, cause klibc has
no sysinfo().
o netdev's are also put into our database now. I want this for the
udevruler gui to get a list of all handled devices.
All devices in the db are stamped with the system uptime value at
the creation time. 'udevinfo -d' prints it.
o the DEVPATH value is the key for udevdb, but if we rename
a netdev, the name is replaced in the kernel, so we add
the changed name to the db to match with the remove event.
NOTE: The dev.d/ scripts still get the original name from the
hotplug call. Should we replace DEVPATH with the new name too?
o We now only add a device to the db, if we have successfully created
the main node or successfully renamed a netdev. This is the main part
of the patch, cause I needed to clean the retval passing trough all
the functions used for node creation.
o DEVNODE sounds a bit ugly for netdev's so I exported DEVNAME too.
Can we change the name?
o I've added a UDEV_NO_DEVD to possibly skip the script execution
and used it in udev-test.pl.
udevstart is the same horror now, if you have scripts with logging
statements in dev.d/ it takes minutes to finish, can we skip the
scripts here too?
o The get_device_type() function is changed to be more strict, cause
'udevinfo -a -p /block/' gets a class device for it and tries to
print the major/minor values.
o bugfix, the RESULT value has now a working newline removal and a test
for this case.
2004-04-01 09:12:57 +02:00
|
|
|
char devname[NAME_SIZE];
|
2004-03-25 05:46:58 +01:00
|
|
|
|
[PATCH] netdev - udevdb+dev.d changes
Here is a patch to change the netdev handling in the database and for
the dev.d/ calls. I applies on top of the udevd.patch, cause klibc has
no sysinfo().
o netdev's are also put into our database now. I want this for the
udevruler gui to get a list of all handled devices.
All devices in the db are stamped with the system uptime value at
the creation time. 'udevinfo -d' prints it.
o the DEVPATH value is the key for udevdb, but if we rename
a netdev, the name is replaced in the kernel, so we add
the changed name to the db to match with the remove event.
NOTE: The dev.d/ scripts still get the original name from the
hotplug call. Should we replace DEVPATH with the new name too?
o We now only add a device to the db, if we have successfully created
the main node or successfully renamed a netdev. This is the main part
of the patch, cause I needed to clean the retval passing trough all
the functions used for node creation.
o DEVNODE sounds a bit ugly for netdev's so I exported DEVNAME too.
Can we change the name?
o I've added a UDEV_NO_DEVD to possibly skip the script execution
and used it in udev-test.pl.
udevstart is the same horror now, if you have scripts with logging
statements in dev.d/ it takes minutes to finish, can we skip the
scripts here too?
o The get_device_type() function is changed to be more strict, cause
'udevinfo -a -p /block/' gets a class device for it and tries to
print the major/minor values.
o bugfix, the RESULT value has now a working newline removal and a test
for this case.
2004-04-01 09:12:57 +02:00
|
|
|
if (udev_dev_d == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (dev->type == 'b' || dev->type == 'c') {
|
|
|
|
strfieldcpy(devname, udev_root);
|
|
|
|
strfieldcat(devname, dev->name);
|
|
|
|
} else if (dev->type == 'n') {
|
|
|
|
strfieldcpy(devname, dev->name);
|
2004-04-01 10:59:58 +02:00
|
|
|
setenv("DEVPATH", devpath, 1);
|
[PATCH] netdev - udevdb+dev.d changes
Here is a patch to change the netdev handling in the database and for
the dev.d/ calls. I applies on top of the udevd.patch, cause klibc has
no sysinfo().
o netdev's are also put into our database now. I want this for the
udevruler gui to get a list of all handled devices.
All devices in the db are stamped with the system uptime value at
the creation time. 'udevinfo -d' prints it.
o the DEVPATH value is the key for udevdb, but if we rename
a netdev, the name is replaced in the kernel, so we add
the changed name to the db to match with the remove event.
NOTE: The dev.d/ scripts still get the original name from the
hotplug call. Should we replace DEVPATH with the new name too?
o We now only add a device to the db, if we have successfully created
the main node or successfully renamed a netdev. This is the main part
of the patch, cause I needed to clean the retval passing trough all
the functions used for node creation.
o DEVNODE sounds a bit ugly for netdev's so I exported DEVNAME too.
Can we change the name?
o I've added a UDEV_NO_DEVD to possibly skip the script execution
and used it in udev-test.pl.
udevstart is the same horror now, if you have scripts with logging
statements in dev.d/ it takes minutes to finish, can we skip the
scripts here too?
o The get_device_type() function is changed to be more strict, cause
'udevinfo -a -p /block/' gets a class device for it and tries to
print the major/minor values.
o bugfix, the RESULT value has now a working newline removal and a test
for this case.
2004-04-01 09:12:57 +02:00
|
|
|
}
|
|
|
|
setenv("DEVNAME", devname, 1);
|
|
|
|
dbg("DEVNAME='%s'", devname);
|
2004-03-25 05:46:58 +01:00
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
strcpy(dirname, DEVD_DIR);
|
|
|
|
strfieldcat(dirname, dev->name);
|
|
|
|
call_foreach_file(run_program, dirname, DEVD_SUFFIX);
|
2004-03-25 05:46:58 +01:00
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
strcpy(dirname, DEVD_DIR);
|
|
|
|
strfieldcat(dirname, subsystem);
|
|
|
|
call_foreach_file(run_program, dirname, DEVD_SUFFIX);
|
2004-03-25 05:46:58 +01:00
|
|
|
|
2004-03-27 10:21:46 +01:00
|
|
|
strcpy(dirname, DEVD_DIR "default");
|
|
|
|
call_foreach_file(run_program, dirname, DEVD_SUFFIX);
|
2004-03-25 05:46:58 +01:00
|
|
|
}
|