summaryrefslogtreecommitdiff
path: root/libfstools/overlay.c
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2015-05-25 23:55:07 +0200
committerFelix Fietkau <nbd@openwrt.org>2015-05-25 23:55:10 +0200
commit09027fc86babc3986027a0e677aca1b6999a9e14 (patch)
tree93653e8eeda8fdea0e26adc5463a123dd0572139 /libfstools/overlay.c
parente6004000ff15d7bd32cf5663e8690fc94d7ec747 (diff)
downloadfstools-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.c34
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);
}