summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
26347a4)
These retry loops are required where create_path() could race with
delete_path(). But only the main udevd process writes to the queue,
so no races will happen here.
Signed-off-by: Alan Jenkins <alan-jenkins@tuffmail.co.uk>
{
struct udev *udev = udev_device_get_udev(udev_device);
char filename[UTIL_PATH_SIZE];
{
struct udev *udev = udev_device_get_udev(udev_device);
char filename[UTIL_PATH_SIZE];
if (state != DEVICE_FAILED && udev_queue_export->failed_count == 0)
return;
if (state != DEVICE_FAILED && udev_queue_export->failed_count == 0)
return;
case DEVICE_FAILED:
/* record event in the failed directory */
udev_queue_export->failed_count++;
case DEVICE_FAILED:
/* record event in the failed directory */
udev_queue_export->failed_count++;
- do {
- err = util_create_path(udev, filename);
- if (err != 0 && err != -ENOENT)
- break;
- udev_selinux_setfscreatecon(udev, filename, S_IFLNK);
- err = symlink(udev_device_get_devpath(udev_device), filename);
- if (err != 0)
- err = -errno;
- udev_selinux_resetfscreatecon(udev);
- } while (err == -ENOENT);
+ util_create_path(udev, filename);
+ udev_selinux_setfscreatecon(udev, filename, S_IFLNK);
+ symlink(udev_device_get_devpath(udev_device), filename);
+ udev_selinux_resetfscreatecon(udev);
break;
case DEVICE_QUEUED:
break;
case DEVICE_QUEUED: