Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756924AbdIHTda (ORCPT ); Fri, 8 Sep 2017 15:33:30 -0400 Received: from mx0a-00082601.pphosted.com ([67.231.145.42]:34682 "EHLO mx0a-00082601.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756581AbdIHTd1 (ORCPT ); Fri, 8 Sep 2017 15:33:27 -0400 From: Chris Mason Subject: [GIT PULL] zstd support (lib, btrfs, squashfs) To: Linus Torvalds , Linux Kernel Mailing List , linux-btrfs , Herbert Xu , Nick Terrell , Phillip Lougher , Sean Purcell CC: David Sterba Message-ID: Date: Fri, 8 Sep 2017 15:33:05 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [2620:10d:c091:180::1:a2b2] X-ClientProxiedBy: DM5PR13CA0007.namprd13.prod.outlook.com (10.168.112.17) To BN6PR15MB1651.namprd15.prod.outlook.com (10.175.131.144) X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: e25547c5-2283-4d48-d78c-08d4f6f070b7 X-Microsoft-Antispam: UriScan:;BCL:0;PCL:0;RULEID:(300000500095)(300135000095)(300000501095)(300135300095)(22001)(300000502095)(300135100095)(2017030254152)(300000503095)(300135400095)(2017052603199)(201703131423075)(201703031133081)(201702281549075)(300000504095)(300135200095)(300000505095)(300135600095)(300000506095)(300135500095);SRVR:BN6PR15MB1651; X-Microsoft-Exchange-Diagnostics: 1;BN6PR15MB1651;3:sVN/IlM8DdKFVsxUMLyfzn7/EDNFsL0LZtDxl1rlocJOwht9JnNLihin+OIJB18AEW4sV1dV+IQB6XMw1pG5oB0jIEyjSuqvVfut87mGSWDkJniDUFJ3oY0Yx+bJ9x33D8yTOA6sfVXO6GmOijAO5Yt9iBK2ej4bCDwTXH7J9QZCR6V3LM31Rx676PKDJejg0UVuUXQg2vYsvygm2TqXw+3ZvOWMfeamtwiWAmZXdJdiO2oGi/7mWRs/Tf1NApJt;25:onqjR07VqmN1Aqijyi2YGZ3M7kH3EkEXVveN6nRGYpFt7F03EHWorOA5HeBZLNGo7DM1TezJsHUlDw0X/VJ61F3vbFaz96F5tjqxe/S7dm05t/kBYYzWeYBrC5q9JvtQv9HZBhaRiW72NvdC4FbMDjl/uMaxmWicXmkHoqN6vfv7s8fJdsfUoredqdqVJ94ddCDReVSN7LuTN++zFKL6nIgS2sAiF07EDEkHuAN6OUCEEaLy5Fq5Ixxp+BEeHNeKDj9+YRmY0M6xXU+6zvtvdMRwTYc0eI/UNtqsSnLQGZzU8cnZ3PUnaknVq41m04hNv73KidCX0HGHqOB+U4I5aQ==;31:h5UW0gTyThteceMltvnYdsMXDIU4w+V194rpNpAuHgHnsWv2a8pGsffbdUd2wrCQkc3suarX5yjInIibVAHzbgjjAwXAoKyy55kl1dxpjKk4LB0s3RFEG3SVLO2TrTppltTcoX3IB4WM0DTD0xnm3rkIIN9DPox22jBEPRI8qjtSrzD+3xC286TLuBwXSPQ/n86kGfL/LOEKtEDQHWpMN1zyDHtxO86B5VC8W6tY1p4= X-MS-TrafficTypeDiagnostic: BN6PR15MB1651: X-Microsoft-Exchange-Diagnostics: 1;BN6PR15MB1651;20:kSPVmIvjY0XRX0ttShD+DcB1FjbVuQiJyWTeqdABuIMTRtKZqhSLHUjr0RJTNzTxQvUWT4nOfAWHoLJdZ2mQaLB/hA+Hy6s9ChpSp2LXPOIaio4pkazbWtU/K0QRyGqFhPI+2Yc7IDwqT3CO+xrRe/FdxOIJJAaCZn717Et5FyzW4Rh10auM/8g1X8C2y2ojzqfAi40BLnWyYAN+x1Xu9zvDtdr7xUBQ0zQBWu4Iks+hgBg9E87XTrVbgJ708cglrpU8BYwXYIuB4ATy6s389sYO1MtXxRrjabgzP39kQjbZw7d/pNpzU0cBq0TF2Y8jGh5NMTKpiFjwCt8UTY6Eca1xHQBzBhFZaqh0xigbwe/V2ddAFxoG1OJOFogfRDvlj6oG65ELnwUa6TZyPVNBvE6W/0S17y+Rk2iLfiVQ05o/gNFQHS9dQ0Qf3mfytVfmb1yEftxkSskAkdMc/3jioTgei13X5xUaH6Kqnqe9JGO+CyEZSrabRfDCY2JyjPzL;4:sQ9litJ9Q0PMSf1jkUMYy/lSW8kYnazZvUgBP4F8XtfeA6He7JzsVXRrBy+puoH3/LduIaqyw1/IPxITomBE+4Gt2T9p/Fiwo1UlEKELPpntzp+rSlIFOF9TxhQlx/tLu19Fm8e59tzn2GyEnad4l3o2ymnkfXcYytT1PniuMbW+J7z3BnJo1oDdkZELCKTfEAfTXx8CilOdq1ExPlCDPPwehWqYt0H6kxG0ATa2y7gBt3/q1kIgdTkKYeRZO65fyd9XeomO79UuLo4wgXpKG6Uxw9iVfGsC2vr6J+r697g= X-Exchange-Antispam-Report-Test: UriScan:(84791874153150); X-Microsoft-Antispam-PRVS: X-Exchange-Antispam-Report-CFA-Test: BCL:0;PCL:0;RULEID:(100000700101)(100105000095)(100000701101)(100105300095)(100000702101)(100105100095)(6040450)(2401047)(5005006)(8121501046)(3002001)(10201501046)(100000703101)(100105400095)(93006095)(93001095)(6041248)(20161123564025)(20161123558100)(20161123560025)(20161123555025)(20161123562025)(201703131423075)(201702281528075)(201703061421075)(201703061406153)(6072148)(201708071742011)(100000704101)(100105200095)(100000705101)(100105500095);SRVR:BN6PR15MB1651;BCL:0;PCL:0;RULEID:(100000800101)(100110000095)(100000801101)(100110300095)(100000802101)(100110100095)(100000803101)(100110400095)(100000804101)(100110200095)(100000805101)(100110500095);SRVR:BN6PR15MB1651; X-Forefront-PRVS: 04244E0DC5 X-Forefront-Antispam-Report: SFV:NSPM;SFS:(10019020)(6009001)(199003)(189002)(5660300001)(65806001)(65956001)(1706002)(31686004)(25786009)(4001350100001)(53936002)(47776003)(4326008)(86362001)(64126003)(6486002)(6116002)(230700001)(31696002)(478600001)(6666003)(50466002)(97736004)(42186005)(33646002)(2906002)(81156014)(8676002)(81166006)(65826007)(36756003)(101416001)(189998001)(8936002)(83506001)(50986999)(305945005)(54356999)(106356001)(7736002)(105586002)(68736007)(23676002)(42262002);DIR:OUT;SFP:1102;SCL:1;SRVR:BN6PR15MB1651;H:[IPv6:2620:10d:c0a1:1110:8000::2082];FPR:;SPF:None;PTR:InfoNoRecords;A:1;MX:1;LANG:en; X-Microsoft-Exchange-Diagnostics: =?utf-8?B?MTtCTjZQUjE1TUIxNjUxOzIzOkwwTzhBUjZrbTY3Y2loNFBBbU5wL2NyYmhl?= =?utf-8?B?V2pucW92cmtBa1ptWXBTaW0vSW1JVGtLZzdaNUlWNGZxZFluMC9oQzJkeTd0?= =?utf-8?B?TmhzVUNxNk9YaXRiMlgxUmVFZ2lmWVYrZUhCSHQ3aHMyUTNDejhOM3N3cDE4?= =?utf-8?B?N0IvZWhHbmJGSDZnMW1PTlplVkNSTTljS2pxL2xZWVdGVHUvME9HbzFIWDRv?= =?utf-8?B?SjdkUkFwUUNtRldFa1NGTFhQOWNXSld5bFR2aFVCaHBzdmJqaHY5OUZlODZn?= =?utf-8?B?VCtKOVFvNHhhT09mbms4V2JIZURYZ3dhbFV2V0gvRzQyMzRVYUpVOUJXUUJK?= =?utf-8?B?VXMrNDlzQkQ1aGt1NWozelNsVDdzdVc3MEttU3FvYXFaSERaYTVmeVRwRk5l?= =?utf-8?B?QnBJcllrRlcvNkZ6Uy9sSWU5bjl2QTVyMldsR0h3MjdRNC94WDhhdjBHQXN6?= =?utf-8?B?UmZuaEJPb2R5cjU2U0NqZERSM2hpU2RrVVgvVFJaYWVNOTJqb1Z5UDVWTThI?= =?utf-8?B?LzhqV0ozdDVvWVovbW5KUjhCN010Rm16MnQraElabU1mQjV0YWJYRzlDZ2h6?= =?utf-8?B?TGVGa0p4ekcwMGpKMzBFcEJDQVBKL2NYaDFWT1Y5a2tXbDFsb2ZsQWFLNFhh?= =?utf-8?B?WlROTEFvdTZiMkFiSTZ6RXRpTm11WGFqcGtvK01BZ3BTeWM0TkltUDFKSllQ?= =?utf-8?B?Y0pNWlpGQWEwRDYyRVg5ZldNdlZVVVZOdHYwNXBNR05iNWRzZHpHK3FncDFt?= =?utf-8?B?SDlTWUtWME5PcThxMUNoSldQb2Jxa2YzSHdhR0kwZ2hIMjBCdzM2S0o4dkwy?= =?utf-8?B?cy9YOXd4ekVZVWw3amxDalp4ZkpEai9KME9CRktsamdvc1pXQTFjTVpxaWdM?= =?utf-8?B?NU1lTERQR0hyNVBJbUxvdUxzTlhLTWpMbm1oc2pLSXR2VXVOWFdoRkQxdGJC?= =?utf-8?B?KzN3NSt1MmxTdDVJb3RXdnRLTERZSkdibjhENlVtdUlSWkRVZTVyWUp2WmE2?= =?utf-8?B?WEx4cXFmWkVJbk9uMGRFQXkrNEpjcFdyd0lOU3UydVZaTExyamZXbUNBUE5T?= =?utf-8?B?Z0g2cnAxYnRRL0xZWnh0aUQxZWd3NkV1SHZQUGxDNGI1b1hVSzdBelF1SDFF?= =?utf-8?B?YUJTUjh0YjVhZUZQVnlQN3hOMmJ3LzZGU1dGN0oxR1o4UkJYNGI2YWNDdnBl?= =?utf-8?B?SHNVV3ZFakpJSW13VGczeGp6aGdDWFUrbzI4dExieFZsdU9VZlg1YVdEdU10?= =?utf-8?B?dGRpSTRBN2NzTUl3bFdlNEp6OGJqVTlLaWQ3aVpMSWcxM3BndG4yR01VcUdH?= =?utf-8?B?eGZmb3craWRpcVRXZnYrWU9SQm1kNzRnSnhMbktkT0ZMMDAyc3RldnFVc05u?= =?utf-8?B?V3k0cWlUYzNMdnNoa0czN09UcmEzY3M1S3JsWlgrcTJudTV5WFRpQmhjUnJ6?= =?utf-8?Q?6P4Oc0VCu9l8vJHOUrSVVk9Wdrj?= X-Microsoft-Exchange-Diagnostics: 1;BN6PR15MB1651;6:MxuNJTgdqmXV6lfgScWXU8SWlOal+9HK6IXtOk3Ua2opZ+7MXV4J4zrVjtWf+2L1Hje37YM+RWW5JBdCGzBxp+GEr8f9dM3PywmxThLnMmrwKtrS8EpmeXwKyrTCFsxUcKoiKHqUEGz3f/uyiqJB3BPlReaReHX+GYLOViPKMdnpojdTSeJAWVLZ656oCsPvNhb/t8/m/rB1g5hREF1Nz0EtVCkepJX/7nSuRDXhO4JVDYqPAaaPspIqFS7fZnP37GyC/qeBZhG0Sh91OH/poLf8NM/uTLqaZTkWLodZVAOgm/SBKaANh5r5HGhMFJEzesjhCBFrJIdPEB7hR485Gw==;5:B7oVN8cRTPvE2pZtnQOfeYgeyY6PY6IZQEUCrBe8bgmlyHHFJmw5rm3P27ZY8O7l3Fq5kufkCi/BVUOn7kxyLlOPCKtWHPfEM96gS7bOYcaL9n+M3ZDWMIUukO7/Ebix67OaEcb3U5upDYKXjFQFOg==;24:E2cM80PctZg+HBmf9qONxnbr0Vp4vSR7TvpgloUvP6so/zhFE06aFrVBA9BsjJbhGys9hgQIRgWSElUEIuhPQI7UfLU6uZQa0nKWSWEloa8=;7:kY9xUYcko56fpeBmSDMBsJyAhEwhSdusP0BgqdDXvOZiOQzd+nlSeTfmzROfGhGgdxjzGSsuMKVEpVnlw+0eom5uorQ6oqZAe85nNvCUokelP/PMAk99772gP8MQqbt76rYapKtKDEWf08uaJzE/XfYEqDQcEBlcA8GVdaCUIJNQUjKjXjpypyBq2CfvBfbkkeRt3ggpGC/Ux5NepA0UcVDZp5gj/GvQgCuiFb7fGx8= SpamDiagnosticOutput: 1:99 SpamDiagnosticMetadata: NSPM X-Microsoft-Exchange-Diagnostics: 1;BN6PR15MB1651;20:9MttH55xrybLuD1PNwwR9A7jDgvTucU0dqTcjIjbGpUxHye4Cd3oJcYcA7d2qvIAHuCjdjnSpUVIXJiTzDeGIfhqWgY/Tg4fmR9JnBmxnk1B3dL979VAhkBK2+nsOTAnETYJOFV6qFGjW6LfrDLAvOnyjKVKHseL14K0HqEbN44= X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Sep 2017 19:33:09.4606 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 8ae927fe-1255-47a7-a2af-5f3a069daaa2 X-MS-Exchange-Transport-CrossTenantHeadersStamped: BN6PR15MB1651 X-OriginatorOrg: fb.com X-Proofpoint-Spam-Reason: safe X-FB-Internal: Safe X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10432:,, definitions=2017-09-08_12:,, signatures=0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 8719 Lines: 143 Hi Linus, Nick Terrell's patch series to add zstd support to the kernel has been floating around for a while. After talking with Dave Sterba, Herbert and Phillip, we decided to send the whole thing in as one pull request. I have it in my zstd branch: git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs.git zstd There's a trivial conflict with the main btrfs pull that Dave Sterba just sent. His pull deletes BTRFS_COMPRESS_LAST in fs/btrfs/compression.h, and I've put the sample resolution in a branch named zstd-4.14-merge. My idea was that you'd take our main btrfs pull first and this one second, but the conflicts are small enough it's not a big deal. zstd is a big win in speed over zlib and in compression ratio over lzo, and the compression team here at FB has gotten great results using it in production. Nick will continue to update the kernel side with new improvements from the open source zstd userland code. Nick has a number of benchmarks for the main zstd code in his lib/zstd commit: ============ I ran the benchmarks on a Ubuntu 14.04 VM with 2 cores and 4 GiB of RAM. The VM is running on a MacBook Pro with a 3.1 GHz Intel Core i7 processor, 16 GB of RAM, and a SSD. I benchmarked using `silesia.tar` [3], which is 211,988,480 B large. Run the following commands for the benchmark: sudo modprobe zstd_compress_test sudo mknod zstd_compress_test c 245 0 sudo cp silesia.tar zstd_compress_test The time is reported by the time of the userland `cp`. The MB/s is computed with 1,536,217,008 B / time(buffer size, hash) which includes the time to copy from userland. The Adjusted MB/s is computed with 1,536,217,088 B / (time(buffer size, hash) - time(buffer size, none)). The memory reported is the amount of memory the compressor requests. | Method | Size (B) | Time (s) | Ratio | MB/s | Adj MB/s | Mem (MB) | |----------|----------|----------|-------|---------|----------|----------| | none | 11988480 | 0.100 | 1 | 2119.88 | - | - | | zstd -1 | 73645762 | 1.044 | 2.878 | 203.05 | 224.56 | 1.23 | | zstd -3 | 66988878 | 1.761 | 3.165 | 120.38 | 127.63 | 2.47 | | zstd -5 | 65001259 | 2.563 | 3.261 | 82.71 | 86.07 | 2.86 | | zstd -10 | 60165346 | 13.242 | 3.523 | 16.01 | 16.13 | 13.22 | | zstd -15 | 58009756 | 47.601 | 3.654 | 4.45 | 4.46 | 21.61 | | zstd -19 | 54014593 | 102.835 | 3.925 | 2.06 | 2.06 | 60.15 | | zlib -1 | 77260026 | 2.895 | 2.744 | 73.23 | 75.85 | 0.27 | | zlib -3 | 72972206 | 4.116 | 2.905 | 51.50 | 52.79 | 0.27 | | zlib -6 | 68190360 | 9.633 | 3.109 | 22.01 | 22.24 | 0.27 | | zlib -9 | 67613382 | 22.554 | 3.135 | 9.40 | 9.44 | 0.27 | I benchmarked zstd decompression using the same method on the same machine. The benchmark file is located in the upstream zstd repo under `contrib/linux-kernel/zstd_decompress_test.c` [4]. The memory reported is the amount of memory required to decompress data compressed with the given compression level. If you know the maximum size of your input, you can reduce the memory usage of decompression irrespective of the compression level. | Method | Time (s) | MB/s | Adjusted MB/s | Memory (MB) | |----------|----------|---------|---------------|-------------| | none | 0.025 | 8479.54 | - | - | | zstd -1 | 0.358 | 592.15 | 636.60 | 0.84 | | zstd -3 | 0.396 | 535.32 | 571.40 | 1.46 | | zstd -5 | 0.396 | 535.32 | 571.40 | 1.46 | | zstd -10 | 0.374 | 566.81 | 607.42 | 2.51 | | zstd -15 | 0.379 | 559.34 | 598.84 | 4.61 | | zstd -19 | 0.412 | 514.54 | 547.77 | 8.80 | | zlib -1 | 0.940 | 225.52 | 231.68 | 0.04 | | zlib -3 | 0.883 | 240.08 | 247.07 | 0.04 | | zlib -6 | 0.844 | 251.17 | 258.84 | 0.04 | | zlib -9 | 0.837 | 253.27 | 287.64 | 0.04 | ======================= I ran a long series of tests and benchmarks on the btrfs side and the gains are very similar to the core benchmarks Nick ran. Nick Terrell (4) commits (+14578/-12): crypto: Add zstd support (+356/-0) btrfs: Add zstd support (+468/-12) lib: Add zstd modules (+13014/-0) lib: Add xxhash module (+740/-0) Sean Purcell (1) commits (+178/-0): squashfs: Add zstd support Total: (5) commits (+14756/-12) crypto/Kconfig | 9 + crypto/Makefile | 1 + crypto/testmgr.c | 10 + crypto/testmgr.h | 71 + crypto/zstd.c | 265 ++++ fs/btrfs/Kconfig | 2 + fs/btrfs/Makefile | 2 +- fs/btrfs/compression.c | 1 + fs/btrfs/compression.h | 6 +- fs/btrfs/ctree.h | 1 + fs/btrfs/disk-io.c | 2 + fs/btrfs/ioctl.c | 6 +- fs/btrfs/props.c | 6 + fs/btrfs/super.c | 12 +- fs/btrfs/sysfs.c | 2 + fs/btrfs/zstd.c | 432 ++++++ fs/squashfs/Kconfig | 14 + fs/squashfs/Makefile | 1 + fs/squashfs/decompressor.c | 7 + fs/squashfs/decompressor.h | 4 + fs/squashfs/squashfs_fs.h | 1 + fs/squashfs/zstd_wrapper.c | 151 ++ include/linux/xxhash.h | 236 +++ include/linux/zstd.h | 1157 +++++++++++++++ include/uapi/linux/btrfs.h | 8 +- lib/Kconfig | 11 + lib/Makefile | 3 + lib/xxhash.c | 500 +++++++ lib/zstd/Makefile | 18 + lib/zstd/bitstream.h | 374 +++++ lib/zstd/compress.c | 3484 ++++++++++++++++++++++++++++++++++++++++++++ lib/zstd/decompress.c | 2528 ++++++++++++++++++++++++++++++++ lib/zstd/entropy_common.c | 243 +++ lib/zstd/error_private.h | 53 + lib/zstd/fse.h | 575 ++++++++ lib/zstd/fse_compress.c | 795 ++++++++++ lib/zstd/fse_decompress.c | 332 +++++ lib/zstd/huf.h | 212 +++ lib/zstd/huf_compress.c | 770 ++++++++++ lib/zstd/huf_decompress.c | 960 ++++++++++++ lib/zstd/mem.h | 151 ++ lib/zstd/zstd_common.c | 75 + lib/zstd/zstd_internal.h | 263 ++++ lib/zstd/zstd_opt.h | 1014 +++++++++++++ 44 files changed, 14756 insertions(+), 12 deletions(-)