xref: /linux/drivers/media/platform/chips-media/wave5/wave5.h (revision e6a901a00822659181c93c86d8bbc2a17779fddc)
1 /* SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause) */
2 /*
3  * Wave5 series multi-standard codec IP - wave5 backend definitions
4  *
5  * Copyright (C) 2021-2023 CHIPS&MEDIA INC
6  */
7 
8 #ifndef __WAVE5_FUNCTION_H__
9 #define __WAVE5_FUNCTION_H__
10 
11 #define WAVE5_SUBSAMPLED_ONE_SIZE(_w, _h)	(ALIGN((_w) / 4, 16) * ALIGN((_h) / 4, 8))
12 #define WAVE5_SUBSAMPLED_ONE_SIZE_AVC(_w, _h)	(ALIGN((_w) / 4, 32) * ALIGN((_h) / 4, 4))
13 
14 /*
15  * Bitstream buffer option: Explicit End
16  * When set to 1 the VPU assumes that the bitstream has at least one frame and
17  * will read until the end of the bitstream buffer.
18  * When set to 0 the VPU will not read the last few bytes.
19  * This option can be set anytime but cannot be cleared during processing.
20  * It can be set to force finish decoding even though there is not enough
21  * bitstream data for a full frame.
22  */
23 #define BSOPTION_ENABLE_EXPLICIT_END		BIT(0)
24 #define BSOPTION_HIGHLIGHT_STREAM_END		BIT(1)
25 
26 /*
27  * Currently the driver only supports hardware with little endian but for source
28  * picture format, the bitstream and the report parameter the hardware works
29  * with the opposite endianness, thus hard-code big endian for the register
30  * writes
31  */
32 #define PIC_SRC_ENDIANNESS_BIG_ENDIAN		0xf
33 #define BITSTREAM_ENDIANNESS_BIG_ENDIAN		0xf
34 #define REPORT_PARAM_ENDIANNESS_BIG_ENDIAN	0xf
35 
36 #define WTL_RIGHT_JUSTIFIED          0
37 #define WTL_LEFT_JUSTIFIED           1
38 #define WTL_PIXEL_8BIT               0
39 #define WTL_PIXEL_16BIT              1
40 #define WTL_PIXEL_32BIT              2
41 
42 /* Mirror & rotation modes of the PRP (pre-processing) module */
43 #define NONE_ROTATE		0x0
44 #define ROT_CLOCKWISE_90	0x3
45 #define ROT_CLOCKWISE_180	0x5
46 #define ROT_CLOCKWISE_270	0x7
47 #define MIR_HOR_FLIP		0x11
48 #define MIR_VER_FLIP		0x9
49 #define MIR_HOR_VER_FLIP	(MIR_HOR_FLIP | MIR_VER_FLIP)
50 
51 bool wave5_vpu_is_init(struct vpu_device *vpu_dev);
52 
53 unsigned int wave5_vpu_get_product_id(struct vpu_device *vpu_dev);
54 
55 int wave5_vpu_get_version(struct vpu_device *vpu_dev, u32 *revision);
56 
57 int wave5_vpu_init(struct device *dev, u8 *fw, size_t size);
58 
59 int wave5_vpu_reset(struct device *dev, enum sw_reset_mode reset_mode);
60 
61 int wave5_vpu_build_up_dec_param(struct vpu_instance *inst, struct dec_open_param *param);
62 
63 int wave5_vpu_dec_set_bitstream_flag(struct vpu_instance *inst, bool eos);
64 
65 int wave5_vpu_hw_flush_instance(struct vpu_instance *inst);
66 
67 int wave5_vpu_dec_register_framebuffer(struct vpu_instance *inst,
68 				       struct frame_buffer *fb_arr, enum tiled_map_type map_type,
69 				       unsigned int count);
70 
71 int wave5_vpu_re_init(struct device *dev, u8 *fw, size_t size);
72 
73 int wave5_vpu_dec_init_seq(struct vpu_instance *inst);
74 
75 int wave5_vpu_dec_get_seq_info(struct vpu_instance *inst, struct dec_initial_info *info);
76 
77 int wave5_vpu_decode(struct vpu_instance *inst, u32 *fail_res);
78 
79 int wave5_vpu_dec_get_result(struct vpu_instance *inst, struct dec_output_info *result);
80 
81 int wave5_vpu_dec_finish_seq(struct vpu_instance *inst, u32 *fail_res);
82 
83 int wave5_dec_clr_disp_flag(struct vpu_instance *inst, unsigned int index);
84 
85 int wave5_dec_set_disp_flag(struct vpu_instance *inst, unsigned int index);
86 
87 int wave5_vpu_clear_interrupt(struct vpu_instance *inst, u32 flags);
88 
89 dma_addr_t wave5_dec_get_rd_ptr(struct vpu_instance *inst);
90 
91 int wave5_dec_set_rd_ptr(struct vpu_instance *inst, dma_addr_t addr);
92 
93 /***< WAVE5 encoder >******/
94 
95 int wave5_vpu_build_up_enc_param(struct device *dev, struct vpu_instance *inst,
96 				 struct enc_open_param *open_param);
97 
98 int wave5_vpu_enc_init_seq(struct vpu_instance *inst);
99 
100 int wave5_vpu_enc_get_seq_info(struct vpu_instance *inst, struct enc_initial_info *info);
101 
102 int wave5_vpu_enc_register_framebuffer(struct device *dev, struct vpu_instance *inst,
103 				       struct frame_buffer *fb_arr, enum tiled_map_type map_type,
104 				       unsigned int count);
105 
106 int wave5_vpu_encode(struct vpu_instance *inst, struct enc_param *option, u32 *fail_res);
107 
108 int wave5_vpu_enc_get_result(struct vpu_instance *inst, struct enc_output_info *result);
109 
110 int wave5_vpu_enc_finish_seq(struct vpu_instance *inst, u32 *fail_res);
111 
112 int wave5_vpu_enc_check_open_param(struct vpu_instance *inst, struct enc_open_param *open_param);
113 
114 #endif /* __WAVE5_FUNCTION_H__ */
115