Re: [PATCH 2/4] Squashfs: Generalise paging handling in the decompressors (V3)

2013-11-19 Thread Minchan Kim
On Thu, Nov 14, 2013 at 05:14:17AM +, Phillip Lougher wrote:
> Further generalise 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.
> 
> This allows different types of output buffer to be passed
> to the decompressors, with the implementation specific
> aspects handled at decompression time, but without the
> knowledge being held in the decompressor wrapper code.
> 
> This will allow the decompressors to handle Squashfs
> cache buffers, and page cache pages.
> 
> This patch adds the abstraction and an implementation for
> the caches.
> 
> V3: slightly optimise code in page_actor.h
> 
> Signed-off-by: Phillip Lougher 
Reviewed-by: Minchan Kim 

-- 
Kind regards,
Minchan Kim
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


Re: [PATCH 2/4] Squashfs: Generalise paging handling in the decompressors (V3)

2013-11-19 Thread Minchan Kim
On Thu, Nov 14, 2013 at 05:14:17AM +, Phillip Lougher wrote:
 Further generalise 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.
 
 This allows different types of output buffer to be passed
 to the decompressors, with the implementation specific
 aspects handled at decompression time, but without the
 knowledge being held in the decompressor wrapper code.
 
 This will allow the decompressors to handle Squashfs
 cache buffers, and page cache pages.
 
 This patch adds the abstraction and an implementation for
 the caches.
 
 V3: slightly optimise code in page_actor.h
 
 Signed-off-by: Phillip Lougher phil...@squashfs.org.uk
Reviewed-by: Minchan Kim minc...@kernel.org

-- 
Kind regards,
Minchan Kim
--
To unsubscribe from this list: send the line unsubscribe linux-kernel in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/


[PATCH 2/4] Squashfs: Generalise paging handling in the decompressors (V3)

2013-11-13 Thread Phillip Lougher
Further generalise 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.

This allows different types of output buffer to be passed
to the decompressors, with the implementation specific
aspects handled at decompression time, but without the
knowledge being held in the decompressor wrapper code.

This will allow the decompressors to handle Squashfs
cache buffers, and page cache pages.

This patch adds the abstraction and an implementation for
the caches.

V3: slightly optimise code in page_actor.h

Signed-off-by: Phillip Lougher 
---
 fs/squashfs/block.c |   27 +
 fs/squashfs/cache.c |   28 ++
 fs/squashfs/decompressor.c  |   14 +++--
 fs/squashfs/decompressor.h  |5 ++--
 fs/squashfs/decompressor_multi.c|7 ++---
 fs/squashfs/decompressor_multi_percpu.c |9 +++---
 fs/squashfs/decompressor_single.c   |9 +++---
 fs/squashfs/lzo_wrapper.c   |   27 +++--
 fs/squashfs/page_actor.h|   49 +++
 fs/squashfs/squashfs.h  |8 ++---
 fs/squashfs/squashfs_fs_sb.h|1 +
 fs/squashfs/xz_wrapper.c|   22 --
 fs/squashfs/zlib_wrapper.c  |   24 +--
 13 files changed, 163 insertions(+), 67 deletions(-)
 create mode 100644 fs/squashfs/page_actor.h

diff --git a/fs/squashfs/block.c b/fs/squashfs/block.c
index 4dd4025..0cea9b9 100644
--- a/fs/squashfs/block.c
+++ b/fs/squashfs/block.c
@@ -36,6 +36,7 @@
 #include "squashfs_fs_sb.h"
 #include "squashfs.h"
 #include "decompressor.h"
+#include "page_actor.h"
 
 /*
  * Read the metadata block length, this is stored in the first two
@@ -86,16 +87,16 @@ static struct buffer_head *get_block_length(struct 
super_block *sb,
  * generated a larger block - this does occasionally happen with compression
  * algorithms).
  */
-int squashfs_read_data(struct super_block *sb, void **buffer, u64 index,
-   int length, u64 *next_index, int srclength, int pages)
+int squashfs_read_data(struct super_block *sb, u64 index, int length,
+   u64 *next_index, struct squashfs_page_actor *output)
 {
struct squashfs_sb_info *msblk = sb->s_fs_info;
struct buffer_head **bh;
int offset = index & ((1 << msblk->devblksize_log2) - 1);
u64 cur_index = index >> msblk->devblksize_log2;
-   int bytes, compressed, b = 0, k = 0, page = 0, avail, i;
+   int bytes, compressed, b = 0, k = 0, avail, i;
 
-   bh = kcalloc(((srclength + msblk->devblksize - 1)
+   bh = kcalloc(((output->length + msblk->devblksize - 1)
>> msblk->devblksize_log2) + 1, sizeof(*bh), GFP_KERNEL);
if (bh == NULL)
return -ENOMEM;
@@ -111,9 +112,9 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
*next_index = index + length;
 
TRACE("Block @ 0x%llx, %scompressed size %d, src size %d\n",
-   index, compressed ? "" : "un", length, srclength);
+   index, compressed ? "" : "un", length, output->length);
 
-   if (length < 0 || length > srclength ||
+   if (length < 0 || length > output->length ||
(index + length) > msblk->bytes_used)
goto read_failure;
 
@@ -145,7 +146,7 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
TRACE("Block @ 0x%llx, %scompressed size %d\n", index,
compressed ? "" : "un", length);
 
-   if (length < 0 || length > srclength ||
+   if (length < 0 || length > output->length ||
(index + length) > msblk->bytes_used)
goto block_release;
 
@@ -165,8 +166,8 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
}
 
if (compressed) {
-   length = squashfs_decompress(msblk, buffer, bh, b, offset,
-length, srclength, pages);
+   length = squashfs_decompress(msblk, bh, b, offset, length,
+   output);
if (length < 0)
goto read_failure;
} else {
@@ -174,19 +175,20 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
 * Block is uncompressed.
 */
int in, pg_offset = 0;
+   void *data = squashfs_first_page(output);
 
for (bytes = length; k < b; k++) {
in = min(bytes, msblk->devblksize - offset);
bytes -= in;
while (in) {
if 

[PATCH 2/4] Squashfs: Generalise paging handling in the decompressors (V3)

2013-11-13 Thread Phillip Lougher
Further generalise 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.

This allows different types of output buffer to be passed
to the decompressors, with the implementation specific
aspects handled at decompression time, but without the
knowledge being held in the decompressor wrapper code.

This will allow the decompressors to handle Squashfs
cache buffers, and page cache pages.

This patch adds the abstraction and an implementation for
the caches.

V3: slightly optimise code in page_actor.h

Signed-off-by: Phillip Lougher phil...@squashfs.org.uk
---
 fs/squashfs/block.c |   27 +
 fs/squashfs/cache.c |   28 ++
 fs/squashfs/decompressor.c  |   14 +++--
 fs/squashfs/decompressor.h  |5 ++--
 fs/squashfs/decompressor_multi.c|7 ++---
 fs/squashfs/decompressor_multi_percpu.c |9 +++---
 fs/squashfs/decompressor_single.c   |9 +++---
 fs/squashfs/lzo_wrapper.c   |   27 +++--
 fs/squashfs/page_actor.h|   49 +++
 fs/squashfs/squashfs.h  |8 ++---
 fs/squashfs/squashfs_fs_sb.h|1 +
 fs/squashfs/xz_wrapper.c|   22 --
 fs/squashfs/zlib_wrapper.c  |   24 +--
 13 files changed, 163 insertions(+), 67 deletions(-)
 create mode 100644 fs/squashfs/page_actor.h

diff --git a/fs/squashfs/block.c b/fs/squashfs/block.c
index 4dd4025..0cea9b9 100644
--- a/fs/squashfs/block.c
+++ b/fs/squashfs/block.c
@@ -36,6 +36,7 @@
 #include squashfs_fs_sb.h
 #include squashfs.h
 #include decompressor.h
+#include page_actor.h
 
 /*
  * Read the metadata block length, this is stored in the first two
@@ -86,16 +87,16 @@ static struct buffer_head *get_block_length(struct 
super_block *sb,
  * generated a larger block - this does occasionally happen with compression
  * algorithms).
  */
-int squashfs_read_data(struct super_block *sb, void **buffer, u64 index,
-   int length, u64 *next_index, int srclength, int pages)
+int squashfs_read_data(struct super_block *sb, u64 index, int length,
+   u64 *next_index, struct squashfs_page_actor *output)
 {
struct squashfs_sb_info *msblk = sb-s_fs_info;
struct buffer_head **bh;
int offset = index  ((1  msblk-devblksize_log2) - 1);
u64 cur_index = index  msblk-devblksize_log2;
-   int bytes, compressed, b = 0, k = 0, page = 0, avail, i;
+   int bytes, compressed, b = 0, k = 0, avail, i;
 
-   bh = kcalloc(((srclength + msblk-devblksize - 1)
+   bh = kcalloc(((output-length + msblk-devblksize - 1)
 msblk-devblksize_log2) + 1, sizeof(*bh), GFP_KERNEL);
if (bh == NULL)
return -ENOMEM;
@@ -111,9 +112,9 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
*next_index = index + length;
 
TRACE(Block @ 0x%llx, %scompressed size %d, src size %d\n,
-   index, compressed ?  : un, length, srclength);
+   index, compressed ?  : un, length, output-length);
 
-   if (length  0 || length  srclength ||
+   if (length  0 || length  output-length ||
(index + length)  msblk-bytes_used)
goto read_failure;
 
@@ -145,7 +146,7 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
TRACE(Block @ 0x%llx, %scompressed size %d\n, index,
compressed ?  : un, length);
 
-   if (length  0 || length  srclength ||
+   if (length  0 || length  output-length ||
(index + length)  msblk-bytes_used)
goto block_release;
 
@@ -165,8 +166,8 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
}
 
if (compressed) {
-   length = squashfs_decompress(msblk, buffer, bh, b, offset,
-length, srclength, pages);
+   length = squashfs_decompress(msblk, bh, b, offset, length,
+   output);
if (length  0)
goto read_failure;
} else {
@@ -174,19 +175,20 @@ int squashfs_read_data(struct super_block *sb, void 
**buffer, u64 index,
 * Block is uncompressed.
 */
int in, pg_offset = 0;
+   void *data = squashfs_first_page(output);
 
for (bytes = length; k  b; k++) {
in = min(bytes, msblk-devblksize - offset);
bytes -= in;
while (in) {
if (pg_offset == PAGE_CACHE_SIZE) {
-