wok-next rev 1897

linux/initramfs: early desallocate input buffer for none and gzip compression too
author Pascal Bellard <pascal.bellard@slitaz.org>
date Sat Dec 20 14:23:46 2008 +0000 (2008-12-20)
parents 2eaab2a3a962
children 09747329b5d0
files linux/stuff/linux-lzma-2.6.25.5.u
line diff
     1.1 --- a/linux/stuff/linux-lzma-2.6.25.5.u	Sat Dec 20 00:17:52 2008 +0100
     1.2 +++ b/linux/stuff/linux-lzma-2.6.25.5.u	Sat Dec 20 14:23:46 2008 +0000
     1.3 @@ -2134,3 +2134,92 @@
     1.4  +	free_init_pages(NULL, start, end);
     1.5   }
     1.6   #endif
     1.7 +
     1.8 +--- linux-2.6.25.5/init/initramfs.c
     1.9 ++++ linux-2.6.25.5/init/initramfs.c
    1.10 +@@ -404,7 +404,32 @@
    1.11 + static unsigned outcnt;  /* bytes in output buffer */
    1.12 + static long bytes_out;
    1.13 + 
    1.14 +-#define get_byte()  (inptr < insize ? inbuf[inptr++] : -1)
    1.15 ++#define INITRD_PAGE ((PAGE_SIZE > 1024*1024) ? PAGE_SIZE : 1024*1024)
    1.16 ++static int fill_offset, fill_total;
    1.17 ++#include <linux/initrd.h>
    1.18 ++static void release_inbuf(int count)
    1.19 ++{
    1.20 ++	if (fill_total < 0) return;
    1.21 ++	fill_offset += count;
    1.22 ++	fill_total += count;
    1.23 ++	if (fill_offset >= INITRD_PAGE) {
    1.24 ++		unsigned rem = fill_offset % INITRD_PAGE;
    1.25 ++		unsigned end = initrd_start + fill_offset - rem;
    1.26 ++		free_initrd_mem(initrd_start, end);
    1.27 ++		printk(".");
    1.28 ++		initrd_start = end;
    1.29 ++		fill_offset = rem;
    1.30 ++	}
    1.31 ++}
    1.32 ++
    1.33 ++static uch get_byte(void)
    1.34 ++{
    1.35 ++	uch c;
    1.36 ++	if (inptr > insize) return -1;
    1.37 ++	c = inbuf[inptr++];
    1.38 ++	release_inbuf(1);
    1.39 ++	return c;
    1.40 ++}
    1.41 + 		
    1.42 + /* Diagnostic functions (stubbed out) */
    1.43 + #define Assert(cond,msg)
    1.44 +@@ -453,25 +478,13 @@
    1.45 + 	outcnt = 0;
    1.46 + }
    1.47 + 
    1.48 +-#include <linux/initrd.h>
    1.49 + #ifdef CONFIG_RD_LZMA
    1.50 +-#define INITRD_PAGE ((PAGE_SIZE > 1024*1024) ? PAGE_SIZE : 1024*1024)
    1.51 +-static int fill_offset, fill_total;
    1.52 + static int fill_buffer(void *buffer, unsigned size)
    1.53 + {
    1.54 + 	int max =  initrd_end - initrd_start - fill_offset;
    1.55 + 	if (size < max) max = size;
    1.56 + 	memcpy(buffer, (void *)(initrd_start + fill_offset), max);
    1.57 +-	fill_offset += max;
    1.58 +-	fill_total += max;
    1.59 +-	if (fill_offset >= INITRD_PAGE) {
    1.60 +-		unsigned rem = fill_offset % INITRD_PAGE;
    1.61 +-		unsigned end = initrd_start + fill_offset - rem;
    1.62 +-		free_initrd_mem(initrd_start, end);
    1.63 +-		printk(".");
    1.64 +-		initrd_start = end;
    1.65 +-		fill_offset = rem;
    1.66 +-	}
    1.67 ++	release_inbuf(max);
    1.68 + 	return max;
    1.69 + }
    1.70 + #endif
    1.71 +@@ -489,6 +502,8 @@
    1.72 + 	state = Start;
    1.73 + 	this_header = 0;
    1.74 + 	message = NULL;
    1.75 ++	fill_total = fill_offset = 0;
    1.76 ++	if(buf != (char *) initrd_start) fill_total = -1;
    1.77 + 	while (!message && len) {
    1.78 + #ifdef CONFIG_RD_LZMA
    1.79 + 		int status;
    1.80 +@@ -497,6 +512,7 @@
    1.81 + 		if (*buf == '0' && !(this_header & 3)) {
    1.82 + 			state = Start;
    1.83 + 			written = write_buffer(buf, len);
    1.84 ++			release_inbuf(written);
    1.85 + 			buf += written;
    1.86 + 			len -= written;
    1.87 + 			continue;
    1.88 +@@ -534,7 +550,6 @@
    1.89 + 		if(buf == (char *) initrd_start) {
    1.90 + 			char *work_buffer = malloc(LZMA_IOBUF_SIZE);
    1.91 + 			if (work_buffer) {
    1.92 +-				fill_total = fill_offset = 0;
    1.93 + 				fill_buffer(work_buffer, LZMA_IOBUF_SIZE);
    1.94 + 				status = unlzma(work_buffer, LZMA_IOBUF_SIZE,
    1.95 + 					fill_buffer, flush_buffer, NULL);