]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
tmpfiles: downgrade errors when a file system does not support file attributes 663/head
authorLennart Poettering <lennart@poettering.net>
Wed, 22 Jul 2015 20:02:14 +0000 (22:02 +0200)
committerLennart Poettering <lennart@poettering.net>
Wed, 22 Jul 2015 20:02:14 +0000 (22:02 +0200)
This downgrades errors from setting file attributes via tmpfiles to
warnings and makes them non-fatal.

Also, as a special case, if a file system does not support file
attributes at all, then the message is downgraded to debug, so that it
is not seen at all.

With this change reiserfs should not see any messages at all anymore
(since it apparently does not implement file attributes at all), but XFS
will still get a warning but no failure. The warning is something the
XFS kernel folks should fix though, by adjusting their file attributes
behaviour to be identical to ext234's.

Fixes #560.

src/tmpfiles/tmpfiles.c

index 42f757c4b701d637c0dfe2cd1ca7f8a3528092aa..271984b5a845c361b8dd819eec824c3775f8a016 100644 (file)
@@ -955,9 +955,10 @@ static int path_set_attribute(Item *item, const char *path) {
 
         r = chattr_fd(fd, f, item->attribute_mask);
         if (r < 0)
-                return log_error_errno(r,
-                        "Cannot set file attribute for '%s', value=0x%08x, mask=0x%08x: %m",
-                        path, item->attribute_value, item->attribute_mask);
+                log_full_errno(r == -ENOTTY ? LOG_DEBUG : LOG_WARNING,
+                               r,
+                               "Cannot set file attribute for '%s', value=0x%08x, mask=0x%08x: %m",
+                               path, item->attribute_value, item->attribute_mask);
 
         return 0;
 }