From: Libing Zhou <libing.zhou@xxxxxxxxxxxxxxx> Subject: ROMFS: support inode blocks calculation When use 'stat' tool to display file status, the 'Blocks' field always in '0', this is not good for tool 'du'(e.g.: busybox 'du'), it always output '0' size for the files under ROMFS since such tool calculates number of 512B Blocks. This patch calculates approx. number of 512B blocks based on inode size. Link: http://lkml.kernel.org/r/20200811052606.4243-1-libing.zhou@xxxxxxxxxxxxxxx Signed-off-by: Libing Zhou <libing.zhou@xxxxxxxxxxxxxxx> Cc: David Howells <dhowells@xxxxxxxxxx> Cc: Al Viro <viro@xxxxxxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- fs/romfs/super.c | 1 + 1 file changed, 1 insertion(+) --- a/fs/romfs/super.c~romfs-support-inode-blocks-calculation +++ a/fs/romfs/super.c @@ -356,6 +356,7 @@ static struct inode *romfs_iget(struct s } i->i_mode = mode; + i->i_blocks = (i->i_size + 511) >> 9; unlock_new_inode(i); return i; _