Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3455471pxu; Mon, 30 Nov 2020 03:40:15 -0800 (PST) X-Google-Smtp-Source: ABdhPJwYdcVI0B0OWIUpdTUYtz+H6AAXghCqyU1FyWm1kyhT2oB7xFAD+yVByZV5SwfDXYGrDXUM X-Received: by 2002:a17:906:118c:: with SMTP id n12mr4673307eja.167.1606736415321; Mon, 30 Nov 2020 03:40:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606736415; cv=none; d=google.com; s=arc-20160816; b=Srrzc9Xjxbe6DVtUNfou/c3FN9qOyXjPxLTach307+m70aK7+TVlDOJPORGWabf4c1 U8lp1M52cAu4EWqZSW++nAcMib/CW7C8eNjEN5zBdPqXfjwZOeMHOROWwcsz5jTzgTlE zmMmcJ2888RgIi7nkuWfe57gdQqfRKJkvKEfR6yF0/QF8JE1+tytloSR1d9bKNu77aHn E6MYiCAVzygYHT95L/4RHPkTxE+bXc0eFPczxnQIU5NIHxnEgdpr0xXD4K4brIcljRXW +lXq9Au58VuDgEcyzaHCxWAyh2jXbcT47LyFYGS+E4eQb9EfV70RNbqv+8uUN6XsiMhk 4Vpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=q1H7z927yZ23J5c3xO26CE+FIkFj8bWHfjWGxec7I3k=; b=H8Fi7yHVv48sERCmTMjAV3XHngO1XgHU+URf9/yaLsys/6ffj9eCXohoT5O6Jf8gER dIH82KjZqdSSvHQ/gSudZWK/MFS62UEk32Xot2CejKgZnCy73wJdIetanHNuMBCE9xRd kT8wzf62EBmMN3c/Q+5MNSmskeRmKTMknbFJpwuOFnZuaHwOBV4E9MGIA+Rz2N3eYD7V 2G0jQTIBHlclPdTzRq+VrTj7+imV1BaYIdGAYXUShEDHNswbPUCH+hnL+rc1SKkl/h8y SGul7tu8D+NGgB/wPcF450dslKk34U8/JLDR1rVtyIDxLD+dr3H24pbhUe+pu+YA2/Se ljPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FIXlkfrE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a5si10519406edu.121.2020.11.30.03.39.48; Mon, 30 Nov 2020 03:40:15 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=FIXlkfrE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727020AbgK3LgL (ORCPT + 99 others); Mon, 30 Nov 2020 06:36:11 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48698 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725902AbgK3LgK (ORCPT ); Mon, 30 Nov 2020 06:36:10 -0500 Received: from mail-vs1-xe42.google.com (mail-vs1-xe42.google.com [IPv6:2607:f8b0:4864:20::e42]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5E603C0613D3 for ; Mon, 30 Nov 2020 03:35:30 -0800 (PST) Received: by mail-vs1-xe42.google.com with SMTP id v8so6113157vso.2 for ; Mon, 30 Nov 2020 03:35:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=q1H7z927yZ23J5c3xO26CE+FIkFj8bWHfjWGxec7I3k=; b=FIXlkfrEiT5lJN9EPYs1mWKLYK17srN9XISmzJRcN20L6Dt8bvDbUs97z19G0sGHSO Q0eMej4BXXasTfymmOU2J5kTC80ba2GH3vLh1wVHxF9/w2feubM2gXQQ69x+VXYZBQqp Y4Ix29htPMNvYLRF4dg9m3ivQ5z0U8VCNfrc043fFb+WEk4tVvcpu7Kk1/3/lvOpc1Ls GPabQTJB6OOU/n3RgdWccyX0Oy4T4Gji0JEHRp8/mnjEA8lUVm0bQMT+76VqBGMy+TIq //phny+/xhhR9N/1wFJsNx63rs/1DFPIF5frwqv5qj7SdXsuMnAt/gYIW7jMS1B5Npj2 98sg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=q1H7z927yZ23J5c3xO26CE+FIkFj8bWHfjWGxec7I3k=; b=KYdE6nK1cx8Rzv9V0AZhzsSAMvUxjsqJPN2Za2mPZ1aYw0CfMOdSaWfBxIJzGXgN2z qXBiRDTzq47m4CVLzIDM3qXGsSCLxLcN11u9jp2QrEr2+dtr/eEGoV/D/urcDdQWxwj/ 5winzhQWbcTMDcfmsb8YGdhrSLUCk7zYexwEW2ljzI+JZaPzCRM0htUMsBb0b/yiy1u+ S/7qgcErzeWxNzIvqEhDQbWXOTRHmpJrNNvwEJRgZs7/jv6wkrGvhQHUJxTpdMrLB8zU o9CRDagmEuyM8yJp90Vj1MxrrAdqsKVTXybZey/jxL6hANRR6uwU159y8xlGEw9r/27y EtWw== X-Gm-Message-State: AOAM531ozezIH/bVlA2zReH3OKouOmsm8bpxm0P3dMsaX+2nj/ePCAeU kVh9k3f2Pd3z92qc/w613p50rO+zML5qvF4d08412UfAtKOivwf/ X-Received: by 2002:a67:2484:: with SMTP id k126mr14513444vsk.13.1606736129453; Mon, 30 Nov 2020 03:35:29 -0800 (PST) MIME-Version: 1.0 References: <20201130112648.95504-1-yuchao0@huawei.com> In-Reply-To: <20201130112648.95504-1-yuchao0@huawei.com> From: Ju Hyung Park Date: Mon, 30 Nov 2020 20:35:18 +0900 Message-ID: Subject: Re: [f2fs-dev] [PATCH] f2fs: compress: support lz4hc compression To: Chao Yu Cc: Jaegeuk Kim , open list , linux-f2fs-devel@lists.sourceforge.net Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Chao. On Mon, Nov 30, 2020 at 8:28 PM Chao Yu wrote: > > Add a new mount option "compress_lz4hc_clevel=%u" to enable lz4hc compress > algorithm and specify the compress level of lz4hc. Wouldn't it be better to introduce a generic mount option like "compress_level=%u" to allow other algorithms to use it as well? Or retire compress_algorithm altogether and follow btrfs format, which I quite like: compress=lzo:1, compress=zstd:4, etc. Just my two cents. > > Signed-off-by: Chao Yu > --- > Documentation/filesystems/f2fs.rst | 2 ++ > fs/f2fs/compress.c | 22 +++++++++++++++++----- > fs/f2fs/f2fs.h | 8 ++++++++ > fs/f2fs/inode.c | 4 ++++ > fs/f2fs/super.c | 15 +++++++++++++++ > 5 files changed, 46 insertions(+), 5 deletions(-) > > diff --git a/Documentation/filesystems/f2fs.rst b/Documentation/filesystems/f2fs.rst > index 8830a11a11be..cda30ea124ee 100644 > --- a/Documentation/filesystems/f2fs.rst > +++ b/Documentation/filesystems/f2fs.rst > @@ -264,6 +264,8 @@ compress_chksum Support verifying chksum of raw data in compressed cluster. > compress_cache Support to use address space of inner inode to cache > compressed block, in order to improve cache hit ratio of > random read. > +compress_lz4hc_clevel Support to enable LZ4 high compression algorithm, compress > + level range is [3, 16]. > inlinecrypt When possible, encrypt/decrypt the contents of encrypted > files using the blk-crypto framework rather than > filesystem-layer encryption. This allows the use of > diff --git a/fs/f2fs/compress.c b/fs/f2fs/compress.c > index 2ec34168adbb..233be7f71e48 100644 > --- a/fs/f2fs/compress.c > +++ b/fs/f2fs/compress.c > @@ -253,17 +253,24 @@ static const struct f2fs_compress_ops f2fs_lzo_ops = { > #ifdef CONFIG_F2FS_FS_LZ4 > static int lz4_init_compress_ctx(struct compress_ctx *cc) > { > - cc->private = f2fs_kvmalloc(F2FS_I_SB(cc->inode), > - LZ4_MEM_COMPRESS, GFP_NOFS); > + unsigned int size; > + > + size = F2FS_I(cc->inode)->i_lz4hc_clevel ? > + LZ4HC_MEM_COMPRESS : LZ4_MEM_COMPRESS; > + > + cc->private = f2fs_kvmalloc(F2FS_I_SB(cc->inode), size, GFP_NOFS); > if (!cc->private) > return -ENOMEM; > > /* > * we do not change cc->clen to LZ4_compressBound(inputsize) to > * adapt worst compress case, because lz4 compressor can handle > - * output budget properly. > + * output budget properly; for lz4hc case, keep it as it is. > */ > - cc->clen = cc->rlen - PAGE_SIZE - COMPRESS_HEADER_SIZE; > + if (F2FS_I(cc->inode)->i_lz4hc_clevel) > + cc->clen = LZ4_compressBound(cc->rlen); > + else > + cc->clen = cc->rlen - PAGE_SIZE - COMPRESS_HEADER_SIZE; > return 0; > } > > @@ -275,9 +282,14 @@ static void lz4_destroy_compress_ctx(struct compress_ctx *cc) > > static int lz4_compress_pages(struct compress_ctx *cc) > { > + unsigned char clevel = F2FS_I(cc->inode)->i_lz4hc_clevel; > int len; > > - len = LZ4_compress_default(cc->rbuf, cc->cbuf->cdata, cc->rlen, > + if (clevel) > + len = LZ4_compress_HC(cc->rbuf, cc->cbuf->cdata, cc->rlen, > + cc->clen, clevel, cc->private); > + else > + len = LZ4_compress_default(cc->rbuf, cc->cbuf->cdata, cc->rlen, > cc->clen, cc->private); > if (!len) > return -EAGAIN; > diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h > index d32065417616..d3d5583ea9e5 100644 > --- a/fs/f2fs/f2fs.h > +++ b/fs/f2fs/f2fs.h > @@ -149,6 +149,7 @@ struct f2fs_mount_info { > /* For compression */ > unsigned char compress_algorithm; /* algorithm type */ > unsigned char compress_log_size; /* cluster log size */ > + unsigned char lz4hc_clevel; /* lz4hc compress level */ > bool compress_chksum; /* compressed data chksum */ > unsigned char compress_ext_cnt; /* extension count */ > unsigned char extensions[COMPRESS_EXT_NUM][F2FS_EXTENSION_LEN]; /* extensions */ > @@ -736,6 +737,10 @@ struct f2fs_inode_info { > unsigned char i_log_cluster_size; /* log of cluster size */ > unsigned short i_compress_flag; /* compress flag */ > unsigned int i_cluster_size; /* cluster size */ > + unsigned char i_lz4hc_clevel; /* > + * lz4hc compress level, > + * range: 3-16, disable: 0 > + */ > }; > > static inline void get_extent_info(struct extent_info *ext, > @@ -3932,6 +3937,9 @@ static inline void set_compress_context(struct inode *inode) > 1 << COMPRESS_CHKSUM : 0; > F2FS_I(inode)->i_cluster_size = > 1 << F2FS_I(inode)->i_log_cluster_size; > + if (F2FS_I(inode)->i_compress_algorithm == COMPRESS_LZ4 && > + F2FS_OPTION(sbi).lz4hc_clevel) > + F2FS_I(inode)->i_lz4hc_clevel = F2FS_OPTION(sbi).lz4hc_clevel; > F2FS_I(inode)->i_flags |= F2FS_COMPR_FL; > set_inode_flag(inode, FI_COMPRESSED_FILE); > stat_inc_compr_inode(inode); > diff --git a/fs/f2fs/inode.c b/fs/f2fs/inode.c > index 39fad324ca52..98be4d87e067 100644 > --- a/fs/f2fs/inode.c > +++ b/fs/f2fs/inode.c > @@ -461,6 +461,10 @@ static int do_read_inode(struct inode *inode) > fi->i_compress_algorithm = ri->i_compress_algorithm; > fi->i_log_cluster_size = ri->i_log_cluster_size; > fi->i_compress_flag = le16_to_cpu(ri->i_compress_flag); > + if (fi->i_compress_algorithm == COMPRESS_LZ4 && > + F2FS_OPTION(sbi).lz4hc_clevel) > + fi->i_lz4hc_clevel = > + F2FS_OPTION(sbi).lz4hc_clevel; > fi->i_cluster_size = 1 << fi->i_log_cluster_size; > set_inode_flag(inode, FI_COMPRESSED_FILE); > } > diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c > index b0c6ef2df7b8..2cd7fcc400b8 100644 > --- a/fs/f2fs/super.c > +++ b/fs/f2fs/super.c > @@ -25,6 +25,7 @@ > #include > #include > #include > +#include > > #include "f2fs.h" > #include "node.h" > @@ -148,6 +149,7 @@ enum { > Opt_compress_extension, > Opt_compress_chksum, > Opt_compress_cache, > + Opt_compress_lz4hc_clevel, > Opt_atgc, > Opt_err, > }; > @@ -218,6 +220,7 @@ static match_table_t f2fs_tokens = { > {Opt_compress_extension, "compress_extension=%s"}, > {Opt_compress_chksum, "compress_chksum"}, > {Opt_compress_cache, "compress_cache"}, > + {Opt_compress_lz4hc_clevel, "compress_lz4hc_clevel=%u"}, > {Opt_atgc, "atgc"}, > {Opt_err, NULL}, > }; > @@ -944,12 +947,20 @@ static int parse_options(struct super_block *sb, char *options, bool is_remount) > case Opt_compress_cache: > set_opt(sbi, COMPRESS_CACHE); > break; > + case Opt_compress_lz4hc_clevel: > + if (args->from && match_int(args, &arg)) > + return -EINVAL; > + if (arg < LZ4HC_MIN_CLEVEL || arg > LZ4HC_MAX_CLEVEL) > + return -EINVAL; > + F2FS_OPTION(sbi).lz4hc_clevel = arg; > + break; > #else > case Opt_compress_algorithm: > case Opt_compress_log_size: > case Opt_compress_extension: > case Opt_compress_chksum: > case Opt_compress_cache: > + case Opt_compress_lz4hc_clevel: > f2fs_info(sbi, "compression options not supported"); > break; > #endif > @@ -1543,6 +1554,10 @@ static inline void f2fs_show_compress_options(struct seq_file *seq, > > if (test_opt(sbi, COMPRESS_CACHE)) > seq_puts(seq, ",compress_cache"); > + > + if (F2FS_OPTION(sbi).lz4hc_clevel) > + seq_printf(seq, ",compress_lz4hc_clevel=%u", > + F2FS_OPTION(sbi).lz4hc_clevel); > } > > static int f2fs_show_options(struct seq_file *seq, struct dentry *root) > -- > 2.26.2 > > > > _______________________________________________ > Linux-f2fs-devel mailing list > Linux-f2fs-devel@lists.sourceforge.net > https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel