blob: 5e0d0ec07fbccb7a14862efea44495e57619a7d0 [file] [log] [blame]
Simon Glass0c670fc2019-08-01 09:46:36 -06001/* SPDX-License-Identifier: GPL-2.0+ */
2/*
3 * (C) Copyright 2000-2009
4 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5 */
6
7#ifndef __GZIP_H
8#define __GZIP_H
9
Tom Rini03de3052024-05-20 13:35:03 -060010#include <linux/types.h>
11
Simon Glasse6f6f9e2020-05-10 11:39:58 -060012struct blk_desc;
13
Simon Glass0c670fc2019-08-01 09:46:36 -060014/**
15 * gzip_parse_header() - Parse a header from a gzip file
16 *
17 * This returns the length of the header.
18 *
19 * @src: Pointer to gzip file
20 * @len: Length of data
Heinrich Schuchardt185f8122022-01-19 18:05:50 +010021 * Return: length of header in bytes, or -1 if not enough data
Simon Glass0c670fc2019-08-01 09:46:36 -060022 */
23int gzip_parse_header(const unsigned char *src, unsigned long len);
24
25/**
26 * gunzip() - Decompress gzipped data
27 *
28 * @dst: Destination for uncompressed data
29 * @dstlen: Size of destination buffer
30 * @src: Source data to decompress
31 * @lenp: Returns length of uncompressed data
Heinrich Schuchardt185f8122022-01-19 18:05:50 +010032 * Return: 0 if OK, -1 on error
Simon Glass0c670fc2019-08-01 09:46:36 -060033 */
34int gunzip(void *dst, int dstlen, unsigned char *src, unsigned long *lenp);
35
36/**
37 * zunzip() - Uncompress blocks compressed with zlib without headers
38 *
39 * @dst: Destination for uncompressed data
40 * @dstlen: Size of destination buffer
41 * @src: Source data to decompress
42 * @lenp: On entry, length data at @src. On exit, number of bytes used from @src
43 * @stoponerr: 0 to continue when a decode error is found, 1 to stop
44 * @offset: start offset within the src buffer
Heinrich Schuchardt185f8122022-01-19 18:05:50 +010045 * Return: 0 if OK, -1 on error
Simon Glass0c670fc2019-08-01 09:46:36 -060046 */
47int zunzip(void *dst, int dstlen, unsigned char *src, unsigned long *lenp,
48 int stoponerr, int offset);
49
50/**
51 * gzwrite progress indicators: defined weak to allow board-specific
52 * overrides:
53 *
54 * gzwrite_progress_init called on startup
55 * gzwrite_progress called during decompress/write loop
56 * gzwrite_progress_finish called at end of loop to
57 * indicate success (retcode=0) or failure
58 */
Simon Glass5a4f10d2021-09-25 07:03:13 -060059void gzwrite_progress_init(ulong expected_size);
Simon Glass0c670fc2019-08-01 09:46:36 -060060
Simon Glass5a4f10d2021-09-25 07:03:13 -060061void gzwrite_progress(int iteration, ulong bytes_written, ulong total_bytes);
Simon Glass0c670fc2019-08-01 09:46:36 -060062
Simon Glass5a4f10d2021-09-25 07:03:13 -060063void gzwrite_progress_finish(int retcode, ulong totalwritten, ulong totalsize,
Simon Glass0c670fc2019-08-01 09:46:36 -060064 u32 expected_crc, u32 calculated_crc);
65
66/**
67 * gzwrite() - decompress and write gzipped image from memory to block device
68 *
69 * @src: compressed image address
70 * @len: compressed image length in bytes
71 * @dev: block device descriptor
72 * @szwritebuf: bytes per write (pad to erase size)
73 * @startoffs: offset in bytes of first write
74 * @szexpected: expected uncompressed length, may be zero to use gzip trailer
75 * for files under 4GiB
Heinrich Schuchardt185f8122022-01-19 18:05:50 +010076 * Return: 0 if OK, -1 on error
Simon Glass0c670fc2019-08-01 09:46:36 -060077 */
78int gzwrite(unsigned char *src, int len, struct blk_desc *dev, ulong szwritebuf,
Simon Glass5a4f10d2021-09-25 07:03:13 -060079 ulong startoffs, ulong szexpected);
Simon Glass0c670fc2019-08-01 09:46:36 -060080
81/**
82 * gzip()- Compress data into a buffer using the gzip algorithm
83 *
84 * @dst: Destination buffer for compressed data
85 * @lenp: On entry, space available in destination buffer (in bytes). On exit,
86 * number of bytes used in the buffer
87 * @src: Source data to compress
88 * @srclen: Size of source data
Heinrich Schuchardt185f8122022-01-19 18:05:50 +010089 * Return: 0 if OK, -1 on error
Simon Glass0c670fc2019-08-01 09:46:36 -060090 */
91int gzip(void *dst, unsigned long *lenp, unsigned char *src, ulong srclen);
92
93/**
94 * zzip() - Compress blocks with zlib
95 *
96 * @dst: Destination for compressed data
97 * @lenp: On entry, length data at @dst. On exit, number of bytes written to
98 * @dst
99 * @src: Source data to compress
100 * @srclen: Size of source data
101 * @stoponerr: 0 to continue when a decode error is found, 1 to stop
102 * @func: Some sort of function that is called to do something. !ADD DOCS HERE!
103 */
104int zzip(void *dst, ulong *lenp, unsigned char *src, ulong srclen,
105 int stoponerr, int (*func)(ulong, ulong));
106
107#endif