1dd875c76Swdenk /*
2dd875c76Swdenk * uncompress.c
3dd875c76Swdenk *
4dd875c76Swdenk * Copyright (C) 1999 Linus Torvalds
5dd875c76Swdenk * Copyright (C) 2000-2002 Transmeta Corporation
6dd875c76Swdenk *
7dd875c76Swdenk * This program is free software; you can redistribute it and/or modify
8dd875c76Swdenk * it under the terms of the GNU General Public License (Version 2) as
9dd875c76Swdenk * published by the Free Software Foundation.
10dd875c76Swdenk *
11dd875c76Swdenk * cramfs interfaces to the uncompression library. There's really just
12dd875c76Swdenk * three entrypoints:
13dd875c76Swdenk *
14dd875c76Swdenk * - cramfs_uncompress_init() - called to initialize the thing.
15dd875c76Swdenk * - cramfs_uncompress_exit() - tell me when you're done
16dd875c76Swdenk * - cramfs_uncompress_block() - uncompress a block.
17dd875c76Swdenk *
18dd875c76Swdenk * NOTE NOTE NOTE! The uncompression is entirely single-threaded. We
19dd875c76Swdenk * only have one stream, and we'll initialize it only once even if it
20dd875c76Swdenk * then is used by multiple filesystems.
21dd875c76Swdenk */
22dd875c76Swdenk
23dd875c76Swdenk #include <common.h>
24dd875c76Swdenk #include <malloc.h>
25dd875c76Swdenk #include <watchdog.h>
26a31e091aSJean-Christophe PLAGNIOL-VILLARD #include <u-boot/zlib.h>
27dd875c76Swdenk
28dd875c76Swdenk static z_stream stream;
29dd875c76Swdenk
30dd875c76Swdenk /* Returns length of decompressed data. */
cramfs_uncompress_block(void * dst,void * src,int srclen)31dd875c76Swdenk int cramfs_uncompress_block (void *dst, void *src, int srclen)
32dd875c76Swdenk {
33dd875c76Swdenk int err;
34dd875c76Swdenk
35dd875c76Swdenk inflateReset (&stream);
36dd875c76Swdenk
37dd875c76Swdenk stream.next_in = src;
38dd875c76Swdenk stream.avail_in = srclen;
39dd875c76Swdenk
40dd875c76Swdenk stream.next_out = dst;
41dd875c76Swdenk stream.avail_out = 4096 * 2;
42dd875c76Swdenk
43dd875c76Swdenk err = inflate (&stream, Z_FINISH);
44dd875c76Swdenk
45dd875c76Swdenk if (err != Z_STREAM_END)
46dd875c76Swdenk goto err;
47dd875c76Swdenk return stream.total_out;
48dd875c76Swdenk
49dd875c76Swdenk err:
50dd875c76Swdenk /*printf ("Error %d while decompressing!\n", err); */
51dd875c76Swdenk /*printf ("%p(%d)->%p\n", src, srclen, dst); */
52dd875c76Swdenk return -1;
53dd875c76Swdenk }
54dd875c76Swdenk
cramfs_uncompress_init(void)55dd875c76Swdenk int cramfs_uncompress_init (void)
56dd875c76Swdenk {
57dd875c76Swdenk int err;
58dd875c76Swdenk
59*e3ed0575SMike Frysinger stream.zalloc = gzalloc;
60*e3ed0575SMike Frysinger stream.zfree = gzfree;
61dd875c76Swdenk stream.next_in = 0;
62dd875c76Swdenk stream.avail_in = 0;
63dd875c76Swdenk
64dd875c76Swdenk #if defined(CONFIG_HW_WATCHDOG) || defined(CONFIG_WATCHDOG)
65dd875c76Swdenk stream.outcb = (cb_func) WATCHDOG_RESET;
66dd875c76Swdenk #else
67dd875c76Swdenk stream.outcb = Z_NULL;
68dd875c76Swdenk #endif /* CONFIG_HW_WATCHDOG */
69dd875c76Swdenk
70dd875c76Swdenk err = inflateInit (&stream);
71dd875c76Swdenk if (err != Z_OK) {
72dd875c76Swdenk printf ("Error: inflateInit2() returned %d\n", err);
73dd875c76Swdenk return -1;
74dd875c76Swdenk }
75dd875c76Swdenk
76dd875c76Swdenk return 0;
77dd875c76Swdenk }
78dd875c76Swdenk
cramfs_uncompress_exit(void)79dd875c76Swdenk int cramfs_uncompress_exit (void)
80dd875c76Swdenk {
81dd875c76Swdenk inflateEnd (&stream);
82dd875c76Swdenk return 0;
83dd875c76Swdenk }
84