summaryrefslogtreecommitdiff
path: root/udev_remove.c
diff options
context:
space:
mode:
authorGreg KH <greg@press.(none)>2005-06-21 16:36:29 -0700
committerGreg Kroah-Hartman <gregkh@suse.de>2005-06-21 16:36:29 -0700
commit972d318a3123b00d0ed6b78bbcf70a0965841a8e (patch)
tree8322245ad8e488ad3da9575e2d90b219a99880ea /udev_remove.c
parentae8d5e161fe916e39f226ce53f2c5f8b31f582a0 (diff)
parentd27d3bb05288fb5e70bc3f3fc7da1dc8ee5413a8 (diff)
Merge gregkh@ehlo.org:/home/kay/public_html/pub/scm/linux/hotplug/udev-kay
Diffstat (limited to 'udev_remove.c')
-rw-r--r--udev_remove.c26
1 files changed, 10 insertions, 16 deletions
diff --git a/udev_remove.c b/udev_remove.c
index 2df555327b..cf28ff37a9 100644
--- a/udev_remove.c
+++ b/udev_remove.c
@@ -140,26 +140,20 @@ static int delete_node(struct udevice *udev)
*/
int udev_remove_device(struct udevice *udev)
{
- const char *temp;
-
if (udev->type != DEV_BLOCK && udev->type != DEV_CLASS)
return 0;
- if (udev_db_get_device(udev, udev->devpath) == 0) {
- if (udev->ignore_remove) {
- dbg("remove event for '%s' requested to be ignored by rule", udev->name);
- return 0;
- }
- dbg("remove name='%s'", udev->name);
- udev_db_delete_device(udev);
- } else {
- /* fall back to kernel name */
- temp = strrchr(udev->devpath, '/');
- if (temp == NULL)
- return -ENODEV;
- strlcpy(udev->name, &temp[1], sizeof(udev->name));
- info("'%s' not found in database, falling back on default name", udev->name);
+ /* remove node only if we can find it in our database */
+ if (udev_db_get_device(udev, udev->devpath) != 0) {
+ dbg("'%s' not found in database, ignore event", udev->name);
+ return -1;
+ }
+ if (udev->ignore_remove) {
+ dbg("remove event for '%s' requested to be ignored by rule", udev->name);
+ return 0;
}
+ dbg("remove name='%s'", udev->name);
+ udev_db_delete_device(udev);
/* use full path to the environment */
snprintf(udev->devname, sizeof(udev->devname), "%s/%s", udev_root, udev->name);