xref: /OK3568_Linux_fs/external/mpp/mpp/vproc/iep2/iep2.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright 2020 Rockchip Electronics Co. LTD
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Licensed under the Apache License, Version 2.0 (the "License");
5*4882a593Smuzhiyun  * you may not use this file except in compliance with the License.
6*4882a593Smuzhiyun  * You may obtain a copy of the License at
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  *      http://www.apache.org/licenses/LICENSE-2.0
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  * Unless required by applicable law or agreed to in writing, software
11*4882a593Smuzhiyun  * distributed under the License is distributed on an "AS IS" BASIS,
12*4882a593Smuzhiyun  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4882a593Smuzhiyun  * See the License for the specific language governing permissions and
14*4882a593Smuzhiyun  * limitations under the License.
15*4882a593Smuzhiyun  */
16*4882a593Smuzhiyun 
17*4882a593Smuzhiyun #ifndef __IEP2_H__
18*4882a593Smuzhiyun #define __IEP2_H__
19*4882a593Smuzhiyun 
20*4882a593Smuzhiyun #include <stdint.h>
21*4882a593Smuzhiyun 
22*4882a593Smuzhiyun #include "rk_type.h"
23*4882a593Smuzhiyun 
24*4882a593Smuzhiyun #include "iep2_pd.h"
25*4882a593Smuzhiyun #include "iep2_ff.h"
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun #define TILE_W                  16
28*4882a593Smuzhiyun #define TILE_H                  4
29*4882a593Smuzhiyun #define MVL                     28
30*4882a593Smuzhiyun #define MVR                     27
31*4882a593Smuzhiyun 
32*4882a593Smuzhiyun #define TEST_DBG                //printf
33*4882a593Smuzhiyun #define FLOOR(v, r)             (((v) / (r)) * (r))
34*4882a593Smuzhiyun 
35*4882a593Smuzhiyun #define RKCLIP(a, min, max)     ((a < min) ? (min) : ((a > max) ? max : a))
36*4882a593Smuzhiyun #define RKABS(a)                (RK_U32)(((a) >= 0) ? (a) : -(a))
37*4882a593Smuzhiyun #define RKMIN(a, b)             (((a) < (b)) ? (a) : (b))
38*4882a593Smuzhiyun #define RKMAX(a, b)             (((a) > (b)) ? (a) : (b))
39*4882a593Smuzhiyun 
40*4882a593Smuzhiyun struct iep2_addr {
41*4882a593Smuzhiyun     uint32_t y;
42*4882a593Smuzhiyun     uint32_t cbcr;
43*4882a593Smuzhiyun     uint32_t cr;
44*4882a593Smuzhiyun };
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun struct iep2_params {
47*4882a593Smuzhiyun     uint32_t src_fmt;
48*4882a593Smuzhiyun     uint32_t src_yuv_swap;
49*4882a593Smuzhiyun     uint32_t dst_fmt;
50*4882a593Smuzhiyun     uint32_t dst_yuv_swap;
51*4882a593Smuzhiyun     uint32_t tile_cols;
52*4882a593Smuzhiyun     uint32_t tile_rows;
53*4882a593Smuzhiyun     uint32_t src_y_stride;
54*4882a593Smuzhiyun     uint32_t src_uv_stride;
55*4882a593Smuzhiyun     uint32_t dst_y_stride;
56*4882a593Smuzhiyun 
57*4882a593Smuzhiyun     struct iep2_addr src[3]; // current, next, previous
58*4882a593Smuzhiyun     struct iep2_addr dst[2]; // top/bottom field reconstructed frame
59*4882a593Smuzhiyun     uint32_t mv_addr;
60*4882a593Smuzhiyun     uint32_t md_addr;
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun     uint32_t dil_mode;
63*4882a593Smuzhiyun     uint32_t dil_out_mode;
64*4882a593Smuzhiyun     uint32_t dil_field_order;
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun     uint32_t md_theta;
67*4882a593Smuzhiyun     uint32_t md_r;
68*4882a593Smuzhiyun     uint32_t md_lambda;
69*4882a593Smuzhiyun 
70*4882a593Smuzhiyun     uint32_t dect_resi_thr;
71*4882a593Smuzhiyun     uint32_t osd_area_num;
72*4882a593Smuzhiyun     uint32_t osd_gradh_thr;
73*4882a593Smuzhiyun     uint32_t osd_gradv_thr;
74*4882a593Smuzhiyun 
75*4882a593Smuzhiyun     uint32_t osd_pos_limit_en;
76*4882a593Smuzhiyun     uint32_t osd_pos_limit_num;
77*4882a593Smuzhiyun 
78*4882a593Smuzhiyun     uint32_t osd_limit_area[2];
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun     uint32_t osd_line_num;
81*4882a593Smuzhiyun     uint32_t osd_pec_thr;
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun     uint32_t osd_x_sta[8];
84*4882a593Smuzhiyun     uint32_t osd_x_end[8];
85*4882a593Smuzhiyun     uint32_t osd_y_sta[8];
86*4882a593Smuzhiyun     uint32_t osd_y_end[8];
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun     uint32_t me_pena;
89*4882a593Smuzhiyun     uint32_t mv_bonus;
90*4882a593Smuzhiyun     uint32_t mv_similar_thr;
91*4882a593Smuzhiyun     uint32_t mv_similar_num_thr0;
92*4882a593Smuzhiyun     int32_t me_thr_offset;
93*4882a593Smuzhiyun 
94*4882a593Smuzhiyun     uint32_t mv_left_limit;
95*4882a593Smuzhiyun     uint32_t mv_right_limit;
96*4882a593Smuzhiyun 
97*4882a593Smuzhiyun     int8_t mv_tru_list[8];
98*4882a593Smuzhiyun     uint32_t mv_tru_vld[8];
99*4882a593Smuzhiyun 
100*4882a593Smuzhiyun     uint32_t eedi_thr0;
101*4882a593Smuzhiyun 
102*4882a593Smuzhiyun     uint32_t ble_backtoma_num;
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun     uint32_t comb_cnt_thr;
105*4882a593Smuzhiyun     uint32_t comb_feature_thr;
106*4882a593Smuzhiyun     uint32_t comb_t_thr;
107*4882a593Smuzhiyun     uint32_t comb_osd_vld[8];
108*4882a593Smuzhiyun 
109*4882a593Smuzhiyun     uint32_t mtn_en;
110*4882a593Smuzhiyun     uint32_t mtn_tab[16];
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun     uint32_t pd_mode;
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun     uint32_t roi_en;
115*4882a593Smuzhiyun     uint32_t roi_layer_num;
116*4882a593Smuzhiyun     uint32_t roi_mode[8];
117*4882a593Smuzhiyun     uint32_t xsta[8];
118*4882a593Smuzhiyun     uint32_t xend[8];
119*4882a593Smuzhiyun     uint32_t ysta[8];
120*4882a593Smuzhiyun     uint32_t yend[8];
121*4882a593Smuzhiyun };
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun struct iep2_output {
124*4882a593Smuzhiyun     uint32_t mv_hist[MVL + MVR + 1];
125*4882a593Smuzhiyun     uint32_t dect_pd_tcnt;
126*4882a593Smuzhiyun     uint32_t dect_pd_bcnt;
127*4882a593Smuzhiyun     uint32_t dect_ff_cur_tcnt;
128*4882a593Smuzhiyun     uint32_t dect_ff_cur_bcnt;
129*4882a593Smuzhiyun     uint32_t dect_ff_nxt_tcnt;
130*4882a593Smuzhiyun     uint32_t dect_ff_nxt_bcnt;
131*4882a593Smuzhiyun     uint32_t dect_ff_ble_tcnt;
132*4882a593Smuzhiyun     uint32_t dect_ff_ble_bcnt;
133*4882a593Smuzhiyun     uint32_t dect_ff_nz;
134*4882a593Smuzhiyun     uint32_t dect_ff_comb_f;
135*4882a593Smuzhiyun     uint32_t dect_osd_cnt;
136*4882a593Smuzhiyun     uint32_t out_comb_cnt;
137*4882a593Smuzhiyun     uint32_t out_osd_comb_cnt;
138*4882a593Smuzhiyun     uint32_t ff_gradt_tcnt;
139*4882a593Smuzhiyun     uint32_t ff_gradt_bcnt;
140*4882a593Smuzhiyun     uint32_t x_sta[8];
141*4882a593Smuzhiyun     uint32_t x_end[8];
142*4882a593Smuzhiyun     uint32_t y_sta[8];
143*4882a593Smuzhiyun     uint32_t y_end[8];
144*4882a593Smuzhiyun };
145*4882a593Smuzhiyun 
146*4882a593Smuzhiyun struct iep2_api_ctx {
147*4882a593Smuzhiyun     struct iep2_params params;
148*4882a593Smuzhiyun     struct iep2_output output;
149*4882a593Smuzhiyun     struct iep2_ff_info ff_inf;
150*4882a593Smuzhiyun     struct iep2_pd_info pd_inf;
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun     MppBufferGroup memGroup;
153*4882a593Smuzhiyun     MppBuffer mv_buf;
154*4882a593Smuzhiyun     MppBuffer md_buf;
155*4882a593Smuzhiyun     int first_cfg;
156*4882a593Smuzhiyun     int fd;
157*4882a593Smuzhiyun };
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun #endif
160