linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/3] Squashfs: Directly decompress into the page cache for file data
@ 2013-10-11  6:19 Phillip Lougher
  2013-10-11  6:19 ` [PATCH 1/3] Squashfs: Generalise paging handling in the decompressors Phillip Lougher
                   ` (3 more replies)
  0 siblings, 4 replies; 6+ messages in thread
From: Phillip Lougher @ 2013-10-11  6:19 UTC (permalink / raw)
  To: linux-kernel; +Cc: minchan, Phillip Lougher

This patch-set introduces an implementation of
squashfs_readpage() that directly decompresses into the
page cache.

It first generalises the decompressors by adding a page handler
abstraction.  This adds helpers to allow the decompressors
to access and process the output buffers in an implementation
independant manner.

It then adds a read_page() implementation for file data that
uses the page handler abstraction to push down the necessary
kmap_atomic/kunmap_atomic operations on the page cache buffers into
the decompressors.  This enables direct copying into the page cache
without using the slow kmap/kunmap calls.

The code detects when multiple threads are racing in
squashfs_readpage() to decompress the same block, and avoids
this regression by falling back to using an intermediate
buffer.

This patch enhances the performance of Squashfs significantly
when multiple processes are accessing the filesystem simultaneously
because it not only reduces memcopying, but it more importantly
eliminates the lock contention on the intermediate buffer.

Using single-threaded decompression.

        dd if=file1 of=/dev/null bs=4096 &
        dd if=file2 of=/dev/null bs=4096 &
        dd if=file3 of=/dev/null bs=4096 &
        dd if=file4 of=/dev/null bs=4096

Before:

629145600 bytes (629 MB) copied, 45.8046 s, 13.7 MB/s

After:

629145600 bytes (629 MB) copied, 9.29414 s, 67.7 MB/s

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2013-10-14  1:43 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-11  6:19 [PATCH 0/3] Squashfs: Directly decompress into the page cache for file data Phillip Lougher
2013-10-11  6:19 ` [PATCH 1/3] Squashfs: Generalise paging handling in the decompressors Phillip Lougher
2013-10-11  6:19 ` [PATCH 2/3] Squashfs: restructure squashfs_readpage() Phillip Lougher
2013-10-11  6:19 ` [PATCH 3/3] Squashfs: Directly decompress into the page cache for file data Phillip Lougher
2013-10-14  1:43   ` Minchan Kim
2013-10-11  8:03 ` [PATCH 0/3] " Minchan Kim

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).