Commit e5e3abba authored by Gao Xiang's avatar Gao Xiang Committed by Greg Kroah-Hartman

staging: erofs: drop multiref support temporarily

Multiref support means that a compressed page could have
more than one reference, which is designed for on-disk data
deduplication. However, mkfs doesn't support this mode
at this moment, and the kernel implementation is also broken.

Let's drop multiref support. If it is fully implemented
in the future, it can be reverted later.
Signed-off-by: default avatarGao Xiang <gaoxiang25@huawei.com>
Reviewed-by: default avatarChao Yu <yuchao0@huawei.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent b27661cf
...@@ -301,12 +301,9 @@ z_erofs_vle_work_lookup(const struct z_erofs_vle_work_finder *f) ...@@ -301,12 +301,9 @@ z_erofs_vle_work_lookup(const struct z_erofs_vle_work_finder *f)
grp = container_of(egrp, struct z_erofs_vle_workgroup, obj); grp = container_of(egrp, struct z_erofs_vle_workgroup, obj);
*f->grp_ret = grp; *f->grp_ret = grp;
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
work = z_erofs_vle_grab_work(grp, f->pageofs); work = z_erofs_vle_grab_work(grp, f->pageofs);
/* if multiref is disabled, `primary' is always true */
primary = true; primary = true;
#else
BUG();
#endif
DBG_BUGON(work->pageofs != f->pageofs); DBG_BUGON(work->pageofs != f->pageofs);
...@@ -368,12 +365,9 @@ z_erofs_vle_work_register(const struct z_erofs_vle_work_finder *f, ...@@ -368,12 +365,9 @@ z_erofs_vle_work_register(const struct z_erofs_vle_work_finder *f,
struct z_erofs_vle_workgroup *grp = *f->grp_ret; struct z_erofs_vle_workgroup *grp = *f->grp_ret;
struct z_erofs_vle_work *work; struct z_erofs_vle_work *work;
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF /* if multiref is disabled, grp should never be nullptr */
BUG_ON(grp != NULL); BUG_ON(grp != NULL);
#else
if (grp != NULL)
goto skip;
#endif
/* no available workgroup, let's allocate one */ /* no available workgroup, let's allocate one */
grp = kmem_cache_zalloc(z_erofs_workgroup_cachep, GFP_NOFS); grp = kmem_cache_zalloc(z_erofs_workgroup_cachep, GFP_NOFS);
if (unlikely(grp == NULL)) if (unlikely(grp == NULL))
...@@ -396,13 +390,7 @@ z_erofs_vle_work_register(const struct z_erofs_vle_work_finder *f, ...@@ -396,13 +390,7 @@ z_erofs_vle_work_register(const struct z_erofs_vle_work_finder *f,
*f->hosted = true; *f->hosted = true;
gnew = true; gnew = true;
#ifdef CONFIG_EROFS_FS_ZIP_MULTIREF
skip:
/* currently unimplemented */
BUG();
#else
work = z_erofs_vle_grab_primary_work(grp); work = z_erofs_vle_grab_primary_work(grp);
#endif
work->pageofs = f->pageofs; work->pageofs = f->pageofs;
mutex_init(&work->lock); mutex_init(&work->lock);
...@@ -797,9 +785,7 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -797,9 +785,7 @@ static int z_erofs_vle_unzip(struct super_block *sb,
struct z_erofs_pagevec_ctor ctor; struct z_erofs_pagevec_ctor ctor;
unsigned int nr_pages; unsigned int nr_pages;
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
unsigned int sparsemem_pages = 0; unsigned int sparsemem_pages = 0;
#endif
struct page *pages_onstack[Z_EROFS_VLE_VMAP_ONSTACK_PAGES]; struct page *pages_onstack[Z_EROFS_VLE_VMAP_ONSTACK_PAGES];
struct page **pages, **compressed_pages, *page; struct page **pages, **compressed_pages, *page;
unsigned int i, llen; unsigned int i, llen;
...@@ -811,11 +797,7 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -811,11 +797,7 @@ static int z_erofs_vle_unzip(struct super_block *sb,
int err; int err;
might_sleep(); might_sleep();
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
work = z_erofs_vle_grab_primary_work(grp); work = z_erofs_vle_grab_primary_work(grp);
#else
BUG();
#endif
BUG_ON(!READ_ONCE(work->nr_pages)); BUG_ON(!READ_ONCE(work->nr_pages));
mutex_lock(&work->lock); mutex_lock(&work->lock);
...@@ -866,13 +848,11 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -866,13 +848,11 @@ static int z_erofs_vle_unzip(struct super_block *sb,
pagenr = z_erofs_onlinepage_index(page); pagenr = z_erofs_onlinepage_index(page);
BUG_ON(pagenr >= nr_pages); BUG_ON(pagenr >= nr_pages);
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
BUG_ON(pages[pagenr] != NULL); BUG_ON(pages[pagenr] != NULL);
++sparsemem_pages;
#endif
pages[pagenr] = page; pages[pagenr] = page;
} }
sparsemem_pages = i;
z_erofs_pagevec_ctor_exit(&ctor, true); z_erofs_pagevec_ctor_exit(&ctor, true);
...@@ -902,10 +882,8 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -902,10 +882,8 @@ static int z_erofs_vle_unzip(struct super_block *sb,
pagenr = z_erofs_onlinepage_index(page); pagenr = z_erofs_onlinepage_index(page);
BUG_ON(pagenr >= nr_pages); BUG_ON(pagenr >= nr_pages);
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
BUG_ON(pages[pagenr] != NULL); BUG_ON(pages[pagenr] != NULL);
++sparsemem_pages; ++sparsemem_pages;
#endif
pages[pagenr] = page; pages[pagenr] = page;
overlapped = true; overlapped = true;
...@@ -931,12 +909,10 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -931,12 +909,10 @@ static int z_erofs_vle_unzip(struct super_block *sb,
if (err != -ENOTSUPP) if (err != -ENOTSUPP)
goto out_percpu; goto out_percpu;
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
if (sparsemem_pages >= nr_pages) { if (sparsemem_pages >= nr_pages) {
BUG_ON(sparsemem_pages > nr_pages); BUG_ON(sparsemem_pages > nr_pages);
goto skip_allocpage; goto skip_allocpage;
} }
#endif
for (i = 0; i < nr_pages; ++i) { for (i = 0; i < nr_pages; ++i) {
if (pages[i] != NULL) if (pages[i] != NULL)
...@@ -945,9 +921,7 @@ static int z_erofs_vle_unzip(struct super_block *sb, ...@@ -945,9 +921,7 @@ static int z_erofs_vle_unzip(struct super_block *sb,
pages[i] = __stagingpage_alloc(page_pool, GFP_NOFS); pages[i] = __stagingpage_alloc(page_pool, GFP_NOFS);
} }
#ifndef CONFIG_EROFS_FS_ZIP_MULTIREF
skip_allocpage: skip_allocpage:
#endif
vout = erofs_vmap(pages, nr_pages); vout = erofs_vmap(pages, nr_pages);
err = z_erofs_vle_unzip_vmap(compressed_pages, err = z_erofs_vle_unzip_vmap(compressed_pages,
......
...@@ -47,13 +47,6 @@ static inline bool z_erofs_gather_if_stagingpage(struct list_head *page_pool, ...@@ -47,13 +47,6 @@ static inline bool z_erofs_gather_if_stagingpage(struct list_head *page_pool,
#define Z_EROFS_VLE_INLINE_PAGEVECS 3 #define Z_EROFS_VLE_INLINE_PAGEVECS 3
struct z_erofs_vle_work { struct z_erofs_vle_work {
/* struct z_erofs_vle_work *left, *right; */
#ifdef CONFIG_EROFS_FS_ZIP_MULTIREF
struct list_head list;
atomic_t refcount;
#endif
struct mutex lock; struct mutex lock;
/* I: decompression offset in page */ /* I: decompression offset in page */
...@@ -107,10 +100,8 @@ static inline void z_erofs_vle_set_workgrp_fmt( ...@@ -107,10 +100,8 @@ static inline void z_erofs_vle_set_workgrp_fmt(
grp->flags = fmt | (grp->flags & ~Z_EROFS_VLE_WORKGRP_FMT_MASK); grp->flags = fmt | (grp->flags & ~Z_EROFS_VLE_WORKGRP_FMT_MASK);
} }
#ifdef CONFIG_EROFS_FS_ZIP_MULTIREF
#error multiref decompression is unimplemented yet
#else
/* definitions if multiref is disabled */
#define z_erofs_vle_grab_primary_work(grp) (&(grp)->work) #define z_erofs_vle_grab_primary_work(grp) (&(grp)->work)
#define z_erofs_vle_grab_work(grp, pageofs) (&(grp)->work) #define z_erofs_vle_grab_work(grp, pageofs) (&(grp)->work)
#define z_erofs_vle_work_workgroup(wrk, primary) \ #define z_erofs_vle_work_workgroup(wrk, primary) \
...@@ -118,7 +109,6 @@ static inline void z_erofs_vle_set_workgrp_fmt( ...@@ -118,7 +109,6 @@ static inline void z_erofs_vle_set_workgrp_fmt(
struct z_erofs_vle_workgroup, work) : \ struct z_erofs_vle_workgroup, work) : \
({ BUG(); (void *)NULL; })) ({ BUG(); (void *)NULL; }))
#endif
#define Z_EROFS_WORKGROUP_SIZE sizeof(struct z_erofs_vle_workgroup) #define Z_EROFS_WORKGROUP_SIZE sizeof(struct z_erofs_vle_workgroup)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment