hc
2024-11-01 7e970c18f85f99acc678d90128b6e01dce1bf273
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/* SPDX-License-Identifier: GPL-2.0+ */
/* Copyright (c) 2020 Rockchip Electronics Co., Ltd */
 
#ifndef _ROCKCHIP_DECOMPRESS
#define _ROCKCHIP_DECOMPRESS
 
enum decom_mod {
   LZ4_MOD,
   GZIP_MOD,
   ZLIB_MOD,
};
 
/* The high 16 bits indicate whether decompression is non-blocking */
#define DECOM_NOBLOCKING        (0x00010000)
 
static inline u32 rk_get_decom_mode(u32 mode)
{
   return mode & 0x0000ffff;
}
 
static inline bool rk_get_noblocking_flag(u32 mode)
{
   return !!(mode & DECOM_NOBLOCKING);
}
 
#ifdef CONFIG_ROCKCHIP_HW_DECOMPRESS
int rk_decom_start(u32 mode, phys_addr_t src, phys_addr_t dst, u32 dst_max_size);
/* timeout in seconds */
int rk_decom_wait_done(u32 timeout, u64 *decom_len);
#else
static inline int rk_decom_start(u32 mode, phys_addr_t src, phys_addr_t dst, u32 dst_max_size)
{
   return -EINVAL;
}
 
static inline int rk_decom_wait_done(u32 timeout, u64 *decom_len)
{
   return -EINVAL;
}
#endif
 
#endif