ubifs: Use dirty_writeback_interval value for wbuf timer
authorRafał Miłecki <rafal@milecki.pl>
Tue, 20 Sep 2016 08:36:15 +0000 (10:36 +0200)
committerRichard Weinberger <richard@nod.at>
Mon, 12 Dec 2016 22:06:24 +0000 (23:06 +0100)
commit1b7fc2c0069f3864a3dda15430b7aded31c0bfcc
tree9b1b153d98787d49d557db53495f6f5359720374
parent854826c9d526fd81077742c3b000e3f7fcaef3ce
ubifs: Use dirty_writeback_interval value for wbuf timer

Right now wbuf timer has hardcoded timeouts and there is no place for
manual adjustments. Some projects / cases many need that though. Few
file systems allow doing that by respecting dirty_writeback_interval
that can be set using sysctl (dirty_writeback_centisecs).

Lowering dirty_writeback_interval could be some way of dealing with user
space apps lacking proper fsyncs. This is definitely *not* a perfect
solution but we don't have ideal (user space) world. There were already
advanced discussions on this matter, mostly when ext4 was introduced and
it wasn't behaving as ext3. Anyway, the final decision was to add some
hacks to the ext4, as trying to fix whole user space or adding new API
was pointless.

We can't (and shouldn't?) just follow ext4. We can't e.g. sync on close
as this would cause too many commits and flash wearing. On the other
hand we still should allow some trade-off between -o sync and default
wbuf timeout. Respecting dirty_writeback_interval should allow some sane
cutomizations if used warily.

Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
Reviewed-by: Boris Brezillon <boris.brezillon@free-electrons.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
fs/ubifs/io.c
fs/ubifs/ubifs.h