zstd/contrib/linux-kernel
2020-12-02 11:07:38 -08:00
..
test [contrib][linux-kernel] Fix test warnings 2020-12-02 01:12:42 -08:00
.gitignore fix gitignore 2017-04-04 18:15:21 -07:00
btrfs-benchmark.sh Add BtrFS benchmarks 2017-04-11 12:40:53 -07:00
btrfs-extract-benchmark.sh [linux] Write all the patch summaries 2017-06-21 20:23:44 -07:00
decompress_sources.h [contrib][linux] Add wrapper API 2020-12-02 01:08:08 -08:00
linux_zstd.h [contrib][linux] Follow style guide more closely 2020-12-02 11:07:38 -08:00
linux.mk Add linux-kernel freestanding 2020-09-09 14:35:57 -07:00
Makefile [contrib][linux] Add a make target to import upstream 2020-12-02 10:42:33 -08:00
mem.h Reorganize zstd_deps.h and mem.h + replace mem.h for the kernel 2020-09-24 19:41:59 -07:00
README.md [linux-kernel] Update README with initial instructions on how to update zstd in the kernel 2020-09-09 14:36:22 -07:00
squashfs-benchmark.sh [kernel] Update README with SquashFS patch 2017-05-03 11:07:39 -07:00
zstd_compress_module.c [contrib][linux] Follow style guide more closely 2020-12-02 11:07:38 -08:00
zstd_decompress_module.c [contrib][linux] Follow style guide more closely 2020-12-02 11:07:38 -08:00
zstd_deps.h Reorganize zstd_deps.h and mem.h + replace mem.h for the kernel 2020-09-24 19:41:59 -07:00

Zstd in the Linux Kernel

This directory contains the scripts needed to transform upstream zstd into the version imported into the kernel. All the transforms are automated and tested by our continuous integration.

Upgrading Zstd in the Linux Kernel

  1. cd into this directory.
  2. Run make libzstd and read the output. Make sure that all the diffs printed and changes made by the script are correct.
  3. Run make test and ensure that it passes.
  4. Import zstd into the Linux Kernel make import LINUX=/path/to/linux/repo
  5. Inspect the diff for sanity.
  6. Check the Linux Kernel history for zstd. If any patches were made to the kernel version of zstd, but not to upstream zstd, then port them upstream if necessary.
  7. Test the diff. Benchmark if necessary. Make sure to test multiple architectures: At least x86, i386, and arm.
  8. Submit the patch to the LKML.