diff options
author | Felix Fietkau <nbd@openwrt.org> | 2015-05-25 23:55:07 +0200 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2015-05-25 23:55:10 +0200 |
commit | 09027fc86babc3986027a0e677aca1b6999a9e14 (patch) | |
tree | 93653e8eeda8fdea0e26adc5463a123dd0572139 /libfstools/overlay.c | |
parent | e6004000ff15d7bd32cf5663e8690fc94d7ec747 (diff) | |
download | fstools-09027fc86babc3986027a0e677aca1b6999a9e14.tar.gz |
mount_root: use symlink instead of xattr to store initialization state
xattr seems to be unreliable with jffs2
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
Diffstat (limited to 'libfstools/overlay.c')
-rw-r--r-- | libfstools/overlay.c | 34 |
1 files changed, 18 insertions, 16 deletions
diff --git a/libfstools/overlay.c b/libfstools/overlay.c index 0677c34..62a99f8 100644 --- a/libfstools/overlay.c +++ b/libfstools/overlay.c @@ -14,7 +14,6 @@ #include <sys/stat.h> #include <sys/types.h> #include <sys/mount.h> -#include <sys/syscall.h> #include <asm/byteorder.h> @@ -35,18 +34,6 @@ static bool keep_sysupgrade; -static ssize_t -fs_getxattr(const char *path, const char *name, void *value, size_t size) -{ - return syscall(__NR_getxattr, path, name, value, size); -} - -static ssize_t -fs_setxattr(const char *path, const char *name, const void *value, size_t size, int flags) -{ - return syscall(__NR_setxattr, path, name, value, size, flags); -} - static int handle_rmdir(const char *dir) { @@ -290,11 +277,20 @@ static int overlay_mount_fs(struct volume *v) enum fs_state fs_state_get(const char *dir) { + char *path; + char valstr[16]; uint32_t val; + ssize_t len; - if (fs_getxattr(dir, "user.fs_state", &val, sizeof(val)) != sizeof(val)) + path = alloca(strlen(dir) + 1 + sizeof("/.fs_state")); + sprintf(path, "%s/.fs_state", dir); + len = readlink(path, valstr, sizeof(valstr) - 1); + if (len < 0) return FS_STATE_UNKNOWN; + valstr[len] = 0; + val = atoi(valstr); + if (val > __FS_STATE_LAST) return FS_STATE_UNKNOWN; @@ -304,9 +300,15 @@ enum fs_state fs_state_get(const char *dir) int fs_state_set(const char *dir, enum fs_state state) { - uint32_t val = state; + char valstr[16]; + char *path; + + path = alloca(strlen(dir) + 1 + sizeof("/.fs_state")); + sprintf(path, "%s/.fs_state", dir); + unlink(path); + snprintf(valstr, sizeof(valstr), "%d", state); - return fs_setxattr(dir, "user.fs_state", &val, sizeof(val), 0); + return symlink(valstr, path); } |