summaryrefslogtreecommitdiff
path: root/udev.c
diff options
context:
space:
mode:
authorkay.sievers@vrfy.org <kay.sievers@vrfy.org>2003-12-30 22:31:37 -0800
committerGreg KH <gregkh@suse.de>2005-04-26 21:13:12 -0700
commitf4dc8d11c22ef72567a2e5c56ac9bae82867189b (patch)
tree9d7f00e254092ec7fe277c7db1dbc75abb5c9f9f /udev.c
parentc78cb204bc64bce32e705dead071bd4149b731ac (diff)
[PATCH] make udev user callable to query the database
Here is a slightly better version that prints the usage if a unknown option is given: kay@pim:~/src/udev.kay$ ./udev -x ./udev: invalid option -- x Usage: [-qrVh] -q arg query database -r print udev root -V print udev version -h print this help text > Here is a patch that makes it possible to call udev with options on the command line. > Valid options are for now: > > -V for the udev version: > kay@pim:~/src/udev.kay$ ./udev -V > udev, version 011_bk > > -r for the udev root: > kay@pim:~/src/udev.kay$ ./udev -r > /udev/ > > -q to query the database with the sysfs path for the name of the node: > kay@pim:~/src/udev.kay$ ./udev -q /class/video4linux/video0 > test/video/webcam0
Diffstat (limited to 'udev.c')
-rw-r--r--udev.c95
1 files changed, 82 insertions, 13 deletions
diff --git a/udev.c b/udev.c
index 17eade221e..1797e08273 100644
--- a/udev.c
+++ b/udev.c
@@ -29,6 +29,7 @@
#include <errno.h>
#include <ctype.h>
#include <signal.h>
+#include <stdarg.h>
#include "udev.h"
#include "udev_version.h"
@@ -81,23 +82,70 @@ static inline char *get_seqnum(void)
return seqnum;
}
-int main(int argc, char **argv, char **envp)
+static inline int udev_user(int argc, char **argv)
{
- char *action;
- char *devpath;
- char *subsystem;
+ static const char short_options[] = "q:rVh";
+ int option;
int retval = -EINVAL;
+ struct udevice dev;
- main_argv = argv;
- main_envp = envp;
+ while (1) {
+ option = getopt(argc, argv, short_options);
+ if (option == -1)
+ break;
- dbg("version %s", UDEV_VERSION);
+ dbg("option '%c'", option);
+ switch (option) {
+ case 'q':
+ dbg("udev query: %s\n", optarg);
+ retval = udevdb_open_ro();
+ if (retval != 0) {
+ printf("unable to open udev database\n");
+ return -1;
+ }
+ retval = udevdb_get_dev(optarg, &dev);
+ if (retval == 0) {
+ printf("%s\n", dev.name);
+ } else {
+ printf("device not found in udev database\n");
+ }
+ udevdb_exit();
+ return retval;
- if (argc != 2) {
- dbg ("unknown number of arguments");
- goto exit;
+ case 'r':
+ printf("%s\n", udev_root);
+ return 0;
+
+ case 'V':
+ printf("udev, version %s\n", UDEV_VERSION);
+ return 0;
+
+ case 'h':
+ retval = 0;
+ case '?':
+ default:
+ goto help;
+ }
}
+help:
+ printf("Usage: [-qrVh]\n"
+ " -q arg query database \n"
+ " -r print udev root\n"
+ " -V print udev version\n"
+ " -h print this help text\n"
+ "\n");
+
+ return retval;
+}
+
+static inline int udev_hotplug(int argc, char **argv)
+{
+ char *action;
+ char *devpath;
+ char *subsystem;
+ int retval = -EINVAL;
+
subsystem = argv[1];
devpath = get_devpath();
@@ -126,9 +174,6 @@ int main(int argc, char **argv, char **envp)
goto exit;
}
- /* initialize our configuration */
- udev_init_config();
-
/* connect to the system message bus */
sysbus_connect();
@@ -166,3 +211,27 @@ exit_sysbus:
exit:
return retval;
}
+
+int main(int argc, char **argv, char **envp)
+{
+ main_argv = argv;
+ main_envp = envp;
+ int retval;
+
+ dbg("version %s", UDEV_VERSION);
+
+ /* initialize our configuration */
+ udev_init_config();
+
+ if (argc == 2 && argv[1][0] != '-') {
+ dbg("called by hotplug");
+ retval = udev_hotplug(argc, argv);
+ } else {
+ dbg("called by user");
+ retval = udev_user(argc, argv);
+ }
+
+ return retval;
+}
+
+