Commit d9b59a57 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Fix initialization of bounce mempools

When they were converted to kvpmalloc pools they weren't converted to
pass the actual size of the allocation. Oops.

Also, validate the real length in the zstd decompression path.
Signed-off-by: default avatarKent Overstreet <kent.overstreet@gmail.com>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent c4dd7871
...@@ -191,20 +191,21 @@ static int __bio_uncompress(struct bch_fs *c, struct bio *src, ...@@ -191,20 +191,21 @@ static int __bio_uncompress(struct bch_fs *c, struct bio *src,
} }
case BCH_COMPRESSION_TYPE_zstd: { case BCH_COMPRESSION_TYPE_zstd: {
ZSTD_DCtx *ctx; ZSTD_DCtx *ctx;
size_t len; size_t real_src_len = le32_to_cpup(src_data.b);
if (real_src_len > src_len - 4)
goto err;
workspace = mempool_alloc(&c->decompress_workspace, GFP_NOIO); workspace = mempool_alloc(&c->decompress_workspace, GFP_NOIO);
ctx = zstd_init_dctx(workspace, zstd_dctx_workspace_bound()); ctx = zstd_init_dctx(workspace, zstd_dctx_workspace_bound());
src_len = le32_to_cpup(src_data.b); ret = zstd_decompress_dctx(ctx,
len = zstd_decompress_dctx(ctx,
dst_data, dst_len, dst_data, dst_len,
src_data.b + 4, src_len); src_data.b + 4, real_src_len);
mempool_free(workspace, &c->decompress_workspace); mempool_free(workspace, &c->decompress_workspace);
if (len != dst_len) if (ret != dst_len)
goto err; goto err;
break; break;
} }
...@@ -533,7 +534,6 @@ void bch2_fs_compress_exit(struct bch_fs *c) ...@@ -533,7 +534,6 @@ void bch2_fs_compress_exit(struct bch_fs *c)
static int __bch2_fs_compress_init(struct bch_fs *c, u64 features) static int __bch2_fs_compress_init(struct bch_fs *c, u64 features)
{ {
size_t max_extent = c->sb.encoded_extent_max << 9; size_t max_extent = c->sb.encoded_extent_max << 9;
size_t order = get_order(max_extent);
size_t decompress_workspace_size = 0; size_t decompress_workspace_size = 0;
bool decompress_workspace_needed; bool decompress_workspace_needed;
ZSTD_parameters params = zstd_get_params(0, max_extent); ZSTD_parameters params = zstd_get_params(0, max_extent);
...@@ -568,14 +568,14 @@ static int __bch2_fs_compress_init(struct bch_fs *c, u64 features) ...@@ -568,14 +568,14 @@ static int __bch2_fs_compress_init(struct bch_fs *c, u64 features)
if (!mempool_initialized(&c->compression_bounce[READ])) { if (!mempool_initialized(&c->compression_bounce[READ])) {
ret = mempool_init_kvpmalloc_pool(&c->compression_bounce[READ], ret = mempool_init_kvpmalloc_pool(&c->compression_bounce[READ],
1, order); 1, max_extent);
if (ret) if (ret)
goto out; goto out;
} }
if (!mempool_initialized(&c->compression_bounce[WRITE])) { if (!mempool_initialized(&c->compression_bounce[WRITE])) {
ret = mempool_init_kvpmalloc_pool(&c->compression_bounce[WRITE], ret = mempool_init_kvpmalloc_pool(&c->compression_bounce[WRITE],
1, order); 1, max_extent);
if (ret) if (ret)
goto out; goto out;
} }
......
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