From: Yu Watanabe Date: Thu, 26 Sep 2019 12:33:59 +0000 (+0900) Subject: udevadm trigger: do not propagate EACCES and ENODEV X-Git-Tag: v244-rc1~239 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=67acde4869a9505f9721e31fa5167c82445e0e12;p=thirdparty%2Fsystemd.git udevadm trigger: do not propagate EACCES and ENODEV Inside container, writing file returns EACCESS. Moreover, some devices return ENODEV rather than EACCES. So, let's also ignore these two error causes. Closes #13652. --- diff --git a/src/udev/udevadm-trigger.c b/src/udev/udevadm-trigger.c index 77d95e513fb..11f2f1c9851 100644 --- a/src/udev/udevadm-trigger.c +++ b/src/udev/udevadm-trigger.c @@ -45,9 +45,11 @@ static int exec_list(sd_device_enumerator *e, const char *action, Set *settle_se r = write_string_file(filename, action, WRITE_STRING_FILE_DISABLE_BUFFER); if (r < 0) { - log_full_errno(r == -ENOENT ? LOG_DEBUG : LOG_ERR, r, + bool ignore = IN_SET(r, -ENOENT, -EACCES, -ENODEV); + + log_full_errno(ignore ? LOG_DEBUG : LOG_ERR, r, "Failed to write '%s' to '%s': %m", action, filename); - if (ret == 0 && r != -ENOENT) + if (ret == 0 && !ignore) ret = r; continue; }