[PATCH v4] DM: dm-inplace-compress: inplace compressed DM target
From: Ram Pai
Date: Mon Feb 13 2017 - 15:43:10 EST
This patch provides a generic device-mapper compression device.
Originally written by Shaohua Li.
I have optimized and hardened the code.
This compression block device is tested in the following scenarios
a) backing a ext4 filesystem
b) backing swap
Its further stress tested on PPC64 and x86 system.
fixed kbuild errors; hopefully they are all taken care off.
- no reference to zero_page
- convert all divide and mod operations to bit operations
Fixed sector alignment bugs exposed while testing on x86.
Explicitly set the maximum request size to 128K. Without which
range locking failed, causing I/Os to stamp each other.
Fixed an occasional data corruption caused by wrong size of the
Added a parameter while creation of the block device,
to not sleep during memory allocations. This can be useful
if the device is used as a swap device.
All patches are merged into a single patch.
Major code re-arrangement.
Data and metablocks allocated based on the length of the device
map rather than the size of the backing device.
Size of each entry in the bitmap array is explicitly set
Attempt to reuse the provided bio buffer space instead
of allocating a new one.
Comments from Alasdair have been incorporated.
Your comments to improve the code is very much appreciated. Will be
requesting for merge if I do not receive any comments.
Ram Pai (1):
From: Shaohua Li <shli@xxxxxxxxxx>
.../device-mapper/dm-inplace-compress.txt | 155 ++
drivers/md/Kconfig | 6 +
drivers/md/Makefile | 2 +
drivers/md/dm-inplace-compress.c | 2214 ++++++++++++++++++++
drivers/md/dm-inplace-compress.h | 187 ++
5 files changed, 2564 insertions(+)
create mode 100644 Documentation/device-mapper/dm-inplace-compress.txt
create mode 100644 drivers/md/dm-inplace-compress.c
create mode 100644 drivers/md/dm-inplace-compress.h