openwrt/package
Rafał Miłecki f44f8b07b0 base-files: call "sync" after initial setup
OpenWrt uses a lot of (b)ash scripts for initial setup. This isn't the
best solution as they almost never consider syncing files / data. Still
this is what we have and we need to try living with it.

Without proper syncing OpenWrt can easily get into an inconsistent state
on power cut. It's because:
1. Actual (flash) inode and data writes are not synchronized
2. Data writeback can take up to 30 seconds (dirty_expire_centisecs)
3. ubifs adds extra 5 seconds (dirty_writeback_centisecs) "delay"

Some possible cases (examples) for new files:
1. Power cut during 5 seconds after write() can result in all data loss
2. Power cut happening between 5 and 35 seconds after write() can result
   in empty file (inode flushed after 5 seconds, data flush queued)

Above affects e.g. uci-defaults. After executing some migration script
it may get deleted (whited out) without generated data getting actually
written. Power cut will result in missing data and deleted file.

There are three ways of dealing with that:
1. Rewriting all user-space init to proper C with syncs
2. Trying bash hacks (like creating tmp files & moving them)
3. Adding sync and hoping for no power cut during critical section

This change introduces the last solution that is the simplest. It
reduces time during which things may go wrong from ~35 seconds to
probably less than a second. Of course it applies only to IO operations
performed before /etc/init.d/boot . It's probably the stage when the
most new files get created.

All later changes are usually done using smarter C apps (e.g. busybox or
uci) that creates tmp files and uses rename() that is expected to be
atomic.

Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
Acked-by: Hauke Mehrtens <hauke@hauke-m.de>
Acked-by: Sergey Ryazanov <ryazanov.s.a@gmail.com>
(cherry picked from commit 9851d4b6ce)
2022-03-14 08:51:02 +01:00
..
base-files base-files: call "sync" after initial setup 2022-03-14 08:51:02 +01:00
boot uboot-bcm4908: add package with BCM4908 U-Boot 2022-03-14 08:51:01 +01:00
devel binutils: fix libbfd missing DSO dependency if NLS enabled 2021-04-10 14:22:28 +02:00
firmware linux-firmware: amd: consolidate amd's linux-firmware entries 2021-12-29 23:45:37 +01:00
kernel kernel: add kmod-ledtrig-pattern 2022-01-08 21:31:15 +01:00
libs wolfssl: fix API breakage of SSL_get_verify_result 2022-02-22 20:29:39 +01:00
network hostapd: fix radius problem due to invalid attributes 2022-02-26 09:27:15 +01:00
system rpcd: backport 802.11ax support 2022-02-19 10:01:03 +01:00
utils busybox: backport dd support for iflag=count_bytes 2022-01-03 14:28:13 +01:00
Makefile build: fix opkg install step for large package selection 2021-12-31 17:55:29 +01:00