This optimizes code: drops unneeded calls to the volume_find and checks.
Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
+jffs2_mount(struct volume *v)
if (mkdir("/tmp/overlay", 0755)) {
fprintf(stderr, "failed to mkdir /tmp/overlay: %s\n", strerror(errno));
return -1;
}
if (mkdir("/tmp/overlay", 0755)) {
fprintf(stderr, "failed to mkdir /tmp/overlay: %s\n", strerror(errno));
return -1;
}
- v = volume_find("rootfs_data");
- if (!v) {
- fprintf(stderr, "rootfs_data does not exist\n");
- return -1;
- }
-
if (mount(v->blk, "/tmp/overlay", "jffs2", MS_NOATIME, NULL)) {
fprintf(stderr, "failed to mount -t jffs2 %s /tmp/overlay: %s\n", v->blk, strerror(errno));
return -1;
if (mount(v->blk, "/tmp/overlay", "jffs2", MS_NOATIME, NULL)) {
fprintf(stderr, "failed to mount -t jffs2 %s /tmp/overlay: %s\n", v->blk, strerror(errno));
return -1;
+switch2jffs(struct volume *v)
- struct volume *v = volume_find("rootfs_data");
- if (!v) {
- fprintf(stderr, "no rootfs_data was found\n");
- return -1;
- }
-
creat("/tmp/.switch_jffs2", 0600);
ret = mount(v->blk, "/rom/overlay", "jffs2", MS_NOATIME, NULL);
unlink("/tmp/.switch_jffs2");
creat("/tmp/.switch_jffs2", 0600);
ret = mount(v->blk, "/rom/overlay", "jffs2", MS_NOATIME, NULL);
unlink("/tmp/.switch_jffs2");
-jffs2_switch(int argc, char **argv)
+jffs2_switch(struct volume *v)
- v = volume_find("rootfs_data");
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
/* fall through */
case FS_DEADCODE:
/* fall through */
case FS_DEADCODE:
if (!ret) {
fprintf(stderr, "doing fo cleanup\n");
umount2("/tmp/root", MNT_DETACH);
if (!ret) {
fprintf(stderr, "doing fo cleanup\n");
umount2("/tmp/root", MNT_DETACH);
if (ret)
break;
if (mount_move("/tmp", "", "/overlay") || fopivot("/overlay", "/rom")) {
if (ret)
break;
if (mount_move("/tmp", "", "/overlay") || fopivot("/overlay", "/rom")) {
-static int mount_overlay_fs(void)
+static int mount_overlay_fs(struct volume *v)
if (mkdir("/tmp/overlay", 0755)) {
fprintf(stderr, "failed to mkdir /tmp/overlay: %s\n", strerror(errno));
return -1;
}
if (mkdir("/tmp/overlay", 0755)) {
fprintf(stderr, "failed to mkdir /tmp/overlay: %s\n", strerror(errno));
return -1;
}
- v = volume_find("rootfs_data");
- if (!v) {
- fprintf(stderr, "rootfs_data does not exist\n");
- return -1;
- }
-
if (mount(v->blk, "/tmp/overlay", "jffs2", MS_NOATIME, NULL)) {
fprintf(stderr, "failed to mount -t jffs2 %s /tmp/overlay: %s\n",
v->blk, strerror(errno));
if (mount(v->blk, "/tmp/overlay", "jffs2", MS_NOATIME, NULL)) {
fprintf(stderr, "failed to mount -t jffs2 %s /tmp/overlay: %s\n",
v->blk, strerror(errno));
+int mount_overlay(struct volume *v)
- struct volume *v = volume_find("rootfs_data");;
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
return -1;
}
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
return -1;
}
extroot_prefix = "/tmp/overlay";
if (!mount_extroot()) {
extroot_prefix = "/tmp/overlay";
if (!mount_extroot()) {
#include <libubox/list.h>
#include <libubox/blob.h>
#include <libubox/list.h>
#include <libubox/blob.h>
enum {
FS_NONE,
FS_SNAPSHOT,
enum {
FS_NONE,
FS_SNAPSHOT,
extern char const *extroot_prefix;
extern int mount_extroot(void);
extern char const *extroot_prefix;
extern int mount_extroot(void);
-extern int mount_snapshot(void);
-extern int mount_overlay(void);
+extern int mount_snapshot(struct volume *v);
+extern int mount_overlay(struct volume *v);
extern int mount_move(char *oldroot, char *newroot, char *dir);
extern int pivot(char *new, char *old);
extern int mount_move(char *oldroot, char *newroot, char *dir);
extern int pivot(char *new, char *old);
extern int find_mtd_char(char *name, char *part, int plen);
extern int jffs2_ready(char *mtd);
extern int find_mtd_char(char *name, char *part, int plen);
extern int jffs2_ready(char *mtd);
-extern int jffs2_switch(int argc, char **argv);
+extern int jffs2_switch(struct volume *v);
extern int handle_whiteout(const char *dir);
extern void foreachdir(const char *dir, int (*cb)(const char*));
extern int handle_whiteout(const char *dir);
extern void foreachdir(const char *dir, int (*cb)(const char*));
-jffs2_switch(int argc, char **argv)
+jffs2_switch(struct volume *v)
- v = volume_find("rootfs_data");
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
mp = find_mount_point(v->blk, 0);
if (mp) {
fprintf(stderr, "rootfs_data:%s is already mounted as %s\n", v->blk, mp);
-static int overlay_mount_fs(void)
+static int overlay_mount_fs(struct volume *v)
char *fstype;
if (mkdir("/tmp/overlay", 0755)) {
char *fstype;
if (mkdir("/tmp/overlay", 0755)) {
- v = volume_find("rootfs_data");
- if (!v) {
- fprintf(stderr, "rootfs_data does not exist\n");
- return -1;
- }
-
fstype = "jffs2";
switch (volume_identify(v)) {
fstype = "jffs2";
switch (volume_identify(v)) {
+int mount_overlay(struct volume *v)
- struct volume *v = volume_find("rootfs_data");;
extroot_prefix = "/tmp/overlay";
if (!mount_extroot()) {
extroot_prefix = "/tmp/overlay";
if (!mount_extroot()) {
+snapshot_sync(struct volume *v)
- struct volume *v = volume_find("rootfs_data");
struct file_header sentinel, conf;
int next, block = 0;
uint32_t seq;
struct file_header sentinel, conf;
int next, block = 0;
uint32_t seq;
next = snapshot_next_free(v, &seq);
block = config_find(v, &conf, &sentinel);
if (is_config(&conf) && conf.seq != seq) {
next = snapshot_next_free(v, &seq);
block = config_find(v, &conf, &sentinel);
if (is_config(&conf) && conf.seq != seq) {
+mount_snapshot(struct volume *v)
setenv("SNAPSHOT", "magic", 1);
_ramoverlay("/rom", "/overlay");
system("/sbin/snapshot unpack");
setenv("SNAPSHOT", "magic", 1);
_ramoverlay("/rom", "/overlay");
system("/sbin/snapshot unpack");
case FS_JFFS2:
case FS_UBIFS:
case FS_JFFS2:
case FS_UBIFS:
switch (volume_identify(v)) {
case FS_NONE:
case FS_DEADCODE:
switch (volume_identify(v)) {
case FS_NONE:
case FS_DEADCODE:
- return jffs2_switch(argc, argv);
+ return jffs2_switch(v);