[PATCH 2/2] erofs-utils: introduce tarerofs

Gao Xiang hsiangkao at linux.alibaba.com
Thu Jul 13 17:18:52 AEST 2023



On 2023/7/11 14:12, Jingbo Xu wrote:
> From: Gao Xiang <hsiangkao at linux.alibaba.com>
> 
> Let's try to add a new mode "tarerofs" for mkfs.erofs.
> 
> It mainly aims at two use cases:
>   - Convert a tarball (or later tarballs with a merged view) into
>     a full EROFS image [--tar=f];
> 
>   - Generate an EROFS manifest image to reuse tar data [--tar=i],
>     which also enables EROFS 512-byte blocks.
> 
> The second use case is mainly prepared for OCI direct mount without
> OCI blob unpacking.  This also adds another `--aufs` option to
> transform aufs special files into overlayfs metadata.
> 
> [ Note that `--tar=f` generates lots of temporary files for now which
>    can impact performance since the original tar stream(s) may be
>    non-seekable. ]
> 
> Signed-off-by: Gao Xiang <hsiangkao at linux.alibaba.com>
> Signed-off-by: Jingbo Xu <jefflexu at linux.alibaba.com>
> ---
> change log:
> 1. don't return prematurely for special device files (in
> erofs_mkfs_build_tree()).  Otherwise erofs_mkfs_build_tree() may
> mistakenly return a positive integer number returned from
> erofs_prepare_xattr_ibody(), and mistakenly make it as the pointer to
> the root inode, which will cause mkfs.erofs segmentation fault.
> 2. automatically create parent directory if it's not included as an
> entry in the tarball stream. (refer to tarerofs_init_default_dir())


struct erofs_dentry *tarerofs_mkdir(struct erofs_inode *dir, const char *s)
{
	struct inode *inode;

	inode = erofs_new_inode();
	if (IS_ERR(inode))
		return inode;

	inode->i_mode = S_IFDIR | 0755;
	inode->i_parent = dir;
	inode->i_uid = getuid();
	inode->i_gid = getgid();
	inode->i_mtime = sbi.build_time;
	inode->i_mtime_nsec = sbi.build_time_nsec;
	tarerofs_init_empty_dir(inode);

	d = erofs_d_alloc(pwd, s);
	d->type = EROFS_FT_DIR;
	d->inode = inode;
	return d;

}
?


Otherwise it looks good to me.

Thanks,
Gao Xiang


More information about the Linux-erofs mailing list