On Thu, Jun 13, 2024 at 04:03:53PM +1000, Dave Chinner wrote: > I disagree, there was a very good reason for this behaviour: > preventing append-only log files from getting excessively fragmented > because speculative prealloc would get removed on close(). Where is that very clear intent documented? Not in the original commit message (which is very sparse) and no where in any documentation I can find. > i.e. applications that slowly log messages to append only files > with the pattern open(O_APPEND); write(a single line to the log); > close(); caused worst case file fragmentation because the close() > always removed the speculative prealloc beyond EOF. That case should be covered by the XFS_IDIRTY_RELEASE, at least except for O_SYNC workloads. > > The fix for this pessimisitic XFS behaviour is for the application > to use chattr +A (like they would for ext3/4) hence triggering the > existence of XFS_DIFLAG_APPEND and that avoided the removal > speculative delalloc removed when the file is closed. hence the > fragmentation problems went away. For ext4 the EXT4_APPEND_FL flag does not cause any difference in allocation behavior. For the historic ext2 driver it apparently did just, with an XXX comment marking this as a bug, but for ext3 it also never did looking back quite a bit in history.