Browse Source

lib: zlib: include deflate into zlib build

Add a new config CONFIG_GZIP_ENABLED, if enabled, the uboot bin would
include zlib's deflate method which could be used for compressing.

Signed-off-by: Lei Wen <leiwen@marvell.com>
Lei Wen 12 years ago
parent
commit
7a32b98dac
4 changed files with 51 additions and 9 deletions
  1. 35 5
      include/u-boot/zlib.h
  2. 4 4
      lib/zlib/trees.c
  3. 8 0
      lib/zlib/zlib.c
  4. 4 0
      lib/zlib/zutil.h

+ 35 - 5
include/u-boot/zlib.h

@@ -513,11 +513,41 @@ typedef gz_header FAR *gz_headerp;
    If the first character differs, the library code actually used is
    If the first character differs, the library code actually used is
    not compatible with the zlib.h header file used by the application.
    not compatible with the zlib.h header file used by the application.
    This check is automatically made by deflateInit and inflateInit.
    This check is automatically made by deflateInit and inflateInit.
- */
-
-ZEXTERN int ZEXPORT inflateInit_ OF((z_streamp strm, const char *version,
-				int stream_size));
-
+   */
+
+ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush));
+ZEXTERN int ZEXPORT deflateInit_ OF((z_streamp strm, int level,
+			const char *version, int stream_size));
+ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm));
+ZEXTERN int ZEXPORT deflateInit2_ OF((z_streamp strm, int  level, int  method,
+			int windowBits, int memLevel,
+			int strategy, const char *version,
+			int stream_size));
+ZEXTERN int ZEXPORT deflateReset OF((z_streamp strm));
+ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm,
+			const Bytef *dictionary,
+			uInt  dictLength));
+ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm,
+			gz_headerp head));
+ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm,
+			int bits,
+			int value));
+ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm,
+			int level,
+			int strategy));
+ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm,
+			int good_length,
+			int max_lazy,
+			int nice_length,
+			int max_chain));
+ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm,
+			uLong sourceLen));
+ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest,
+			z_streamp source));
+
+
+ZEXTERN int ZEXPORT inflateInit_ OF((z_streamp strm,
+			const char *version, int stream_size));
 ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush));
 ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush));
 /*
 /*
     inflate decompresses as much data as possible, and stops when the input
     inflate decompresses as much data as possible, and stops when the input

+ 4 - 4
lib/zlib/trees.c

@@ -1168,14 +1168,14 @@ local int detect_data_type(s)
  * method would use a table)
  * method would use a table)
  * IN assertion: 1 <= len <= 15
  * IN assertion: 1 <= len <= 15
  */
  */
-local unsigned bi_reverse(code, len)
-    unsigned code; /* the value to invert */
+local unsigned bi_reverse(value, len)
+    unsigned value; /* the value to invert */
     int len;       /* its bit length */
     int len;       /* its bit length */
 {
 {
     register unsigned res = 0;
     register unsigned res = 0;
     do {
     do {
-        res |= code & 1;
-        code >>= 1, res <<= 1;
+        res |= value & 1;
+        value >>= 1, res <<= 1;
     } while (--len > 0);
     } while (--len > 0);
     return res >> 1;
     return res >> 1;
 }
 }

+ 8 - 0
lib/zlib/zlib.c

@@ -12,6 +12,14 @@
  * - added inflateIncomp
  * - added inflateIncomp
  */
  */
 
 
+#include <common.h>
+
+#ifdef CONFIG_GZIP_COMPRESSED
+#define NO_DUMMY_DECL
+#include "deflate.c"
+#include "trees.c"
+#endif
+
 #include "zutil.h"
 #include "zutil.h"
 #include "inftrees.h"
 #include "inftrees.h"
 #include "inflate.h"
 #include "inflate.h"

+ 4 - 0
lib/zlib/zutil.h

@@ -83,6 +83,10 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */
 /* The minimum and maximum match lengths */
 /* The minimum and maximum match lengths */
 
 
 	 /* functions */
 	 /* functions */
+#ifdef CONFIG_GZIP_COMPRESSED
+#define PRESET_DICT 0x20 /* preset dictionary flag in zlib header */
+#  define OS_CODE  0x03  /* assume Unix */
+#endif
 
 
 #include <linux/string.h>
 #include <linux/string.h>
 #define zmemcpy memcpy
 #define zmemcpy memcpy