diff options
author | greg@kroah.com <greg@kroah.com> | 2003-08-04 21:20:19 -0700 |
---|---|---|
committer | Greg KH <gregkh@suse.de> | 2005-04-26 21:01:40 -0700 |
commit | ea256f901e30927591874ee3eb5b92e1ce5a5db1 (patch) | |
tree | 1df19835d772976ecfa21b3b5ea0e9f432adc1ed | |
parent | 615e05f84a36b948959a01c58738f00109f9de0a (diff) |
[PATCH] handle new major:minor format of dev files that showed up in 2.6.0-test2-bk3 or so.
-rw-r--r-- | udev-add.c | 17 |
1 files changed, 5 insertions, 12 deletions
diff --git a/udev-add.c b/udev-add.c index 45ffbf81b5..54af7e4d77 100644 --- a/udev-add.c +++ b/udev-add.c @@ -49,30 +49,23 @@ static char sysfs_path[SYSFS_PATH_MAX]; */ static int get_major_minor(struct sysfs_class_device *class_dev, int *major, int *minor) { - char temp[3]; - int retval = 0; + int retval = -ENODEV; char *dev; dev = sysfs_get_value_from_attributes(class_dev->directory->attributes, "dev"); if (dev == NULL) - return -ENODEV; + goto exit; dbg("dev = %s", dev); - temp[0] = dev[0]; - temp[1] = dev[1]; - temp[2] = 0x00; - *major = (int)strtol(&temp[0], NULL, 16); - - temp[0] = dev[2]; - temp[1] = dev[3]; - temp[2] = 0x00; - *minor = (int)strtol(&temp[0], NULL, 16); + if (sscanf(dev, "%u:%u", major, minor) != 2) + goto exit; dbg("found major = %d, minor = %d", *major, *minor); retval = 0; +exit: return retval; } |