1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker *
3*495ae853SAndroid Build Coastguard Worker * Copyright (C) 2022 The Android Open Source Project
4*495ae853SAndroid Build Coastguard Worker *
5*495ae853SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
6*495ae853SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
7*495ae853SAndroid Build Coastguard Worker * You may obtain a copy of the License at:
8*495ae853SAndroid Build Coastguard Worker *
9*495ae853SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
10*495ae853SAndroid Build Coastguard Worker *
11*495ae853SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
12*495ae853SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
13*495ae853SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*495ae853SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
15*495ae853SAndroid Build Coastguard Worker * limitations under the License.
16*495ae853SAndroid Build Coastguard Worker *
17*495ae853SAndroid Build Coastguard Worker *****************************************************************************
18*495ae853SAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*495ae853SAndroid Build Coastguard Worker */
20*495ae853SAndroid Build Coastguard Worker
21*495ae853SAndroid Build Coastguard Worker /**
22*495ae853SAndroid Build Coastguard Worker *******************************************************************************
23*495ae853SAndroid Build Coastguard Worker * @file
24*495ae853SAndroid Build Coastguard Worker * isvce_rc_utils.c
25*495ae853SAndroid Build Coastguard Worker *
26*495ae853SAndroid Build Coastguard Worker * @brief
27*495ae853SAndroid Build Coastguard Worker * Contains get gpp function required by the SVC encoder
28*495ae853SAndroid Build Coastguard Worker *
29*495ae853SAndroid Build Coastguard Worker * @author
30*495ae853SAndroid Build Coastguard Worker * ittiam
31*495ae853SAndroid Build Coastguard Worker *
32*495ae853SAndroid Build Coastguard Worker * @par List of Functions:
33*495ae853SAndroid Build Coastguard Worker * - isvce_get_gpp()
34*495ae853SAndroid Build Coastguard Worker * - isvce_rc_utils_init()
35*495ae853SAndroid Build Coastguard Worker * - isvce_get_rc_utils_data_size()
36*495ae853SAndroid Build Coastguard Worker * - isvce_compute_gpp()
37*495ae853SAndroid Build Coastguard Worker * - isvce_get_gpp_function_selector()
38*495ae853SAndroid Build Coastguard Worker *
39*495ae853SAndroid Build Coastguard Worker * @remarks
40*495ae853SAndroid Build Coastguard Worker * None
41*495ae853SAndroid Build Coastguard Worker *
42*495ae853SAndroid Build Coastguard Worker *******************************************************************************
43*495ae853SAndroid Build Coastguard Worker */
44*495ae853SAndroid Build Coastguard Worker
45*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h"
46*495ae853SAndroid Build Coastguard Worker #include "ih264_macros.h"
47*495ae853SAndroid Build Coastguard Worker #include "isvc_structs.h"
48*495ae853SAndroid Build Coastguard Worker #include "isvce_rc_utils.h"
49*495ae853SAndroid Build Coastguard Worker #include "isvce_rc_utils_private_defs.h"
50*495ae853SAndroid Build Coastguard Worker
51*495ae853SAndroid Build Coastguard Worker /**
52*495ae853SAndroid Build Coastguard Worker *******************************************************************************
53*495ae853SAndroid Build Coastguard Worker *
54*495ae853SAndroid Build Coastguard Worker * @brief
55*495ae853SAndroid Build Coastguard Worker * get gpp function
56*495ae853SAndroid Build Coastguard Worker *
57*495ae853SAndroid Build Coastguard Worker * @par Description:
58*495ae853SAndroid Build Coastguard Worker * computes gradient per pixel value for a given frame
59*495ae853SAndroid Build Coastguard Worker *
60*495ae853SAndroid Build Coastguard Worker * @param[in] ps_input_buf
61*495ae853SAndroid Build Coastguard Worker * pointer to yuv buffer properties
62*495ae853SAndroid Build Coastguard Worker *
63*495ae853SAndroid Build Coastguard Worker * @returns
64*495ae853SAndroid Build Coastguard Worker * calculated gpp value
65*495ae853SAndroid Build Coastguard Worker *
66*495ae853SAndroid Build Coastguard Worker * @remarks
67*495ae853SAndroid Build Coastguard Worker * none
68*495ae853SAndroid Build Coastguard Worker *
69*495ae853SAndroid Build Coastguard Worker *******************************************************************************
70*495ae853SAndroid Build Coastguard Worker */
71*495ae853SAndroid Build Coastguard Worker
isvce_get_gpp(yuv_buf_props_t * ps_input_buf)72*495ae853SAndroid Build Coastguard Worker static DOUBLE isvce_get_gpp(yuv_buf_props_t *ps_input_buf)
73*495ae853SAndroid Build Coastguard Worker {
74*495ae853SAndroid Build Coastguard Worker UWORD32 i, j;
75*495ae853SAndroid Build Coastguard Worker
76*495ae853SAndroid Build Coastguard Worker DOUBLE d_gpp_y = 0;
77*495ae853SAndroid Build Coastguard Worker DOUBLE d_gpp_u = 0;
78*495ae853SAndroid Build Coastguard Worker DOUBLE d_gpp_v = 0;
79*495ae853SAndroid Build Coastguard Worker
80*495ae853SAndroid Build Coastguard Worker DOUBLE d_gpp = 0;
81*495ae853SAndroid Build Coastguard Worker
82*495ae853SAndroid Build Coastguard Worker UWORD32 u4_width = ps_input_buf->u4_width;
83*495ae853SAndroid Build Coastguard Worker UWORD32 u4_height = ps_input_buf->u4_height;
84*495ae853SAndroid Build Coastguard Worker
85*495ae853SAndroid Build Coastguard Worker UWORD8 *pu1_input_buf = (UWORD8 *) ps_input_buf->as_component_bufs[0].pv_data;
86*495ae853SAndroid Build Coastguard Worker WORD32 i4_input_stride = ps_input_buf->as_component_bufs[0].i4_data_stride;
87*495ae853SAndroid Build Coastguard Worker
88*495ae853SAndroid Build Coastguard Worker for(i = 0; i < u4_height - 1; i++)
89*495ae853SAndroid Build Coastguard Worker {
90*495ae853SAndroid Build Coastguard Worker for(j = 0; j < u4_width - 1; j++)
91*495ae853SAndroid Build Coastguard Worker {
92*495ae853SAndroid Build Coastguard Worker UWORD8 u1_cur_pix = pu1_input_buf[j];
93*495ae853SAndroid Build Coastguard Worker UWORD8 u1_bot_pix = pu1_input_buf[i4_input_stride + j];
94*495ae853SAndroid Build Coastguard Worker UWORD8 u1_right_pix = pu1_input_buf[j + 1];
95*495ae853SAndroid Build Coastguard Worker
96*495ae853SAndroid Build Coastguard Worker d_gpp_y += (ABS(u1_cur_pix - u1_bot_pix) + ABS(u1_cur_pix - u1_right_pix));
97*495ae853SAndroid Build Coastguard Worker }
98*495ae853SAndroid Build Coastguard Worker pu1_input_buf += i4_input_stride;
99*495ae853SAndroid Build Coastguard Worker }
100*495ae853SAndroid Build Coastguard Worker
101*495ae853SAndroid Build Coastguard Worker pu1_input_buf = (UWORD8 *) ps_input_buf->as_component_bufs[1].pv_data;
102*495ae853SAndroid Build Coastguard Worker i4_input_stride = ps_input_buf->as_component_bufs[1].i4_data_stride;
103*495ae853SAndroid Build Coastguard Worker
104*495ae853SAndroid Build Coastguard Worker for(i = 0; i < (u4_height >> 1) - 1; i++)
105*495ae853SAndroid Build Coastguard Worker {
106*495ae853SAndroid Build Coastguard Worker for(j = 0; j < u4_width - 2; j += 2)
107*495ae853SAndroid Build Coastguard Worker {
108*495ae853SAndroid Build Coastguard Worker UWORD8 u1_cur_pix = pu1_input_buf[j];
109*495ae853SAndroid Build Coastguard Worker UWORD8 u1_bot_pix = pu1_input_buf[i4_input_stride + j];
110*495ae853SAndroid Build Coastguard Worker UWORD8 u1_right_pix = pu1_input_buf[j + 2];
111*495ae853SAndroid Build Coastguard Worker
112*495ae853SAndroid Build Coastguard Worker d_gpp_u += (ABS(u1_cur_pix - u1_bot_pix) + ABS(u1_cur_pix - u1_right_pix));
113*495ae853SAndroid Build Coastguard Worker
114*495ae853SAndroid Build Coastguard Worker u1_cur_pix = pu1_input_buf[j + 1];
115*495ae853SAndroid Build Coastguard Worker u1_bot_pix = pu1_input_buf[i4_input_stride + j + 1];
116*495ae853SAndroid Build Coastguard Worker u1_right_pix = pu1_input_buf[j + 2 + 1];
117*495ae853SAndroid Build Coastguard Worker
118*495ae853SAndroid Build Coastguard Worker d_gpp_v += (ABS(u1_cur_pix - u1_bot_pix) + ABS(u1_cur_pix - u1_right_pix));
119*495ae853SAndroid Build Coastguard Worker }
120*495ae853SAndroid Build Coastguard Worker pu1_input_buf += i4_input_stride;
121*495ae853SAndroid Build Coastguard Worker }
122*495ae853SAndroid Build Coastguard Worker
123*495ae853SAndroid Build Coastguard Worker d_gpp_y /= (u4_width * u4_height);
124*495ae853SAndroid Build Coastguard Worker d_gpp_u /= ((u4_width >> 1) * (u4_height >> 1));
125*495ae853SAndroid Build Coastguard Worker d_gpp_v /= ((u4_width >> 1) * (u4_height >> 1));
126*495ae853SAndroid Build Coastguard Worker
127*495ae853SAndroid Build Coastguard Worker d_gpp = (DOUBLE) ((4 * d_gpp_y) + d_gpp_u + d_gpp_v) / 6;
128*495ae853SAndroid Build Coastguard Worker
129*495ae853SAndroid Build Coastguard Worker return d_gpp;
130*495ae853SAndroid Build Coastguard Worker }
131*495ae853SAndroid Build Coastguard Worker
132*495ae853SAndroid Build Coastguard Worker /**
133*495ae853SAndroid Build Coastguard Worker *******************************************************************************
134*495ae853SAndroid Build Coastguard Worker *
135*495ae853SAndroid Build Coastguard Worker * @brief
136*495ae853SAndroid Build Coastguard Worker * gets the memory size required for compute gpp
137*495ae853SAndroid Build Coastguard Worker *
138*495ae853SAndroid Build Coastguard Worker * @par Description:
139*495ae853SAndroid Build Coastguard Worker * returns the memory required by the rc utils context and state structs
140*495ae853SAndroid Build Coastguard Worker * for allocation.
141*495ae853SAndroid Build Coastguard Worker *
142*495ae853SAndroid Build Coastguard Worker * @returns
143*495ae853SAndroid Build Coastguard Worker *
144*495ae853SAndroid Build Coastguard Worker * @remarks
145*495ae853SAndroid Build Coastguard Worker *
146*495ae853SAndroid Build Coastguard Worker *
147*495ae853SAndroid Build Coastguard Worker *******************************************************************************
148*495ae853SAndroid Build Coastguard Worker */
149*495ae853SAndroid Build Coastguard Worker
isvce_get_rc_utils_data_size()150*495ae853SAndroid Build Coastguard Worker UWORD32 isvce_get_rc_utils_data_size() { return sizeof(svc_rc_utils_state_t); }
151*495ae853SAndroid Build Coastguard Worker
152*495ae853SAndroid Build Coastguard Worker /**
153*495ae853SAndroid Build Coastguard Worker *******************************************************************************
154*495ae853SAndroid Build Coastguard Worker *
155*495ae853SAndroid Build Coastguard Worker * @brief
156*495ae853SAndroid Build Coastguard Worker * compute gpp process
157*495ae853SAndroid Build Coastguard Worker *
158*495ae853SAndroid Build Coastguard Worker * @par Description:
159*495ae853SAndroid Build Coastguard Worker * calls the function to compute gpp
160*495ae853SAndroid Build Coastguard Worker *
161*495ae853SAndroid Build Coastguard Worker * @param[in] ps_svc_rc_utils_ctxt
162*495ae853SAndroid Build Coastguard Worker * pointer to svc rc utils context
163*495ae853SAndroid Build Coastguard Worker *
164*495ae853SAndroid Build Coastguard Worker * @param[in] ps_input_buf
165*495ae853SAndroid Build Coastguard Worker * pointer to yuv buffer properties
166*495ae853SAndroid Build Coastguard Worker *
167*495ae853SAndroid Build Coastguard Worker * @returns
168*495ae853SAndroid Build Coastguard Worker * calculated gpp value
169*495ae853SAndroid Build Coastguard Worker *
170*495ae853SAndroid Build Coastguard Worker * @remarks
171*495ae853SAndroid Build Coastguard Worker * none
172*495ae853SAndroid Build Coastguard Worker *
173*495ae853SAndroid Build Coastguard Worker *******************************************************************************
174*495ae853SAndroid Build Coastguard Worker */
175*495ae853SAndroid Build Coastguard Worker
isvce_compute_gpp(svc_rc_utils_ctxt_t * ps_svc_rc_utils_ctxt,yuv_buf_props_t * ps_input_buf)176*495ae853SAndroid Build Coastguard Worker DOUBLE isvce_compute_gpp(svc_rc_utils_ctxt_t *ps_svc_rc_utils_ctxt, yuv_buf_props_t *ps_input_buf)
177*495ae853SAndroid Build Coastguard Worker {
178*495ae853SAndroid Build Coastguard Worker svc_rc_utils_state_t *ps_rc_utils_state =
179*495ae853SAndroid Build Coastguard Worker (svc_rc_utils_state_t *) ps_svc_rc_utils_ctxt->pv_rc_utils_state;
180*495ae853SAndroid Build Coastguard Worker
181*495ae853SAndroid Build Coastguard Worker return ps_rc_utils_state->pf_get_gpp(ps_input_buf);
182*495ae853SAndroid Build Coastguard Worker }
183*495ae853SAndroid Build Coastguard Worker
184*495ae853SAndroid Build Coastguard Worker /**
185*495ae853SAndroid Build Coastguard Worker *******************************************************************************
186*495ae853SAndroid Build Coastguard Worker *
187*495ae853SAndroid Build Coastguard Worker * @brief
188*495ae853SAndroid Build Coastguard Worker * selects which function to call for get gpp based on e_arch
189*495ae853SAndroid Build Coastguard Worker *
190*495ae853SAndroid Build Coastguard Worker * @par Description:
191*495ae853SAndroid Build Coastguard Worker *
192*495ae853SAndroid Build Coastguard Worker * @param[in] ps_rc_utils_state
193*495ae853SAndroid Build Coastguard Worker * pointer to svc rc utils state
194*495ae853SAndroid Build Coastguard Worker *
195*495ae853SAndroid Build Coastguard Worker * @param[in] e_arch
196*495ae853SAndroid Build Coastguard Worker * architecure type
197*495ae853SAndroid Build Coastguard Worker *
198*495ae853SAndroid Build Coastguard Worker * @returns
199*495ae853SAndroid Build Coastguard Worker *
200*495ae853SAndroid Build Coastguard Worker * @remarks
201*495ae853SAndroid Build Coastguard Worker *
202*495ae853SAndroid Build Coastguard Worker *******************************************************************************
203*495ae853SAndroid Build Coastguard Worker */
204*495ae853SAndroid Build Coastguard Worker
isvce_get_gpp_function_selector(svc_rc_utils_state_t * ps_rc_utils_state,IV_ARCH_T e_arch)205*495ae853SAndroid Build Coastguard Worker static void isvce_get_gpp_function_selector(svc_rc_utils_state_t *ps_rc_utils_state,
206*495ae853SAndroid Build Coastguard Worker IV_ARCH_T e_arch)
207*495ae853SAndroid Build Coastguard Worker {
208*495ae853SAndroid Build Coastguard Worker switch(e_arch)
209*495ae853SAndroid Build Coastguard Worker {
210*495ae853SAndroid Build Coastguard Worker #if defined(X86)
211*495ae853SAndroid Build Coastguard Worker case ARCH_X86_SSE42:
212*495ae853SAndroid Build Coastguard Worker {
213*495ae853SAndroid Build Coastguard Worker ps_rc_utils_state->pf_get_gpp = isvce_get_gpp_sse42;
214*495ae853SAndroid Build Coastguard Worker
215*495ae853SAndroid Build Coastguard Worker break;
216*495ae853SAndroid Build Coastguard Worker }
217*495ae853SAndroid Build Coastguard Worker #elif defined(ARMV8)
218*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A53:
219*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A57:
220*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_V8_NEON:
221*495ae853SAndroid Build Coastguard Worker {
222*495ae853SAndroid Build Coastguard Worker ps_rc_utils_state->pf_get_gpp = isvce_get_gpp_neon;
223*495ae853SAndroid Build Coastguard Worker
224*495ae853SAndroid Build Coastguard Worker break;
225*495ae853SAndroid Build Coastguard Worker }
226*495ae853SAndroid Build Coastguard Worker #elif defined(ARM) && !defined(DISABLE_NEON)
227*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A9Q:
228*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A9A:
229*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A9:
230*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A7:
231*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A5:
232*495ae853SAndroid Build Coastguard Worker case ARCH_ARM_A15:
233*495ae853SAndroid Build Coastguard Worker {
234*495ae853SAndroid Build Coastguard Worker ps_rc_utils_state->pf_get_gpp = isvce_get_gpp_neon;
235*495ae853SAndroid Build Coastguard Worker
236*495ae853SAndroid Build Coastguard Worker break;
237*495ae853SAndroid Build Coastguard Worker }
238*495ae853SAndroid Build Coastguard Worker #endif
239*495ae853SAndroid Build Coastguard Worker default:
240*495ae853SAndroid Build Coastguard Worker {
241*495ae853SAndroid Build Coastguard Worker ps_rc_utils_state->pf_get_gpp = isvce_get_gpp;
242*495ae853SAndroid Build Coastguard Worker
243*495ae853SAndroid Build Coastguard Worker break;
244*495ae853SAndroid Build Coastguard Worker }
245*495ae853SAndroid Build Coastguard Worker }
246*495ae853SAndroid Build Coastguard Worker }
247*495ae853SAndroid Build Coastguard Worker
248*495ae853SAndroid Build Coastguard Worker /**
249*495ae853SAndroid Build Coastguard Worker *******************************************************************************
250*495ae853SAndroid Build Coastguard Worker *
251*495ae853SAndroid Build Coastguard Worker * @brief
252*495ae853SAndroid Build Coastguard Worker * initializes the rc utils context
253*495ae853SAndroid Build Coastguard Worker *
254*495ae853SAndroid Build Coastguard Worker * @par Description:
255*495ae853SAndroid Build Coastguard Worker * initializes the rc utils context
256*495ae853SAndroid Build Coastguard Worker *
257*495ae853SAndroid Build Coastguard Worker * @param[in] ps_svc_rc_utils_ctxt
258*495ae853SAndroid Build Coastguard Worker * pointer to svc rc utils context
259*495ae853SAndroid Build Coastguard Worker *
260*495ae853SAndroid Build Coastguard Worker * @param[in] ps_mem_rec
261*495ae853SAndroid Build Coastguard Worker * pointer to memory allocated to compute gpp process
262*495ae853SAndroid Build Coastguard Worker *
263*495ae853SAndroid Build Coastguard Worker * @param[in] e_arch
264*495ae853SAndroid Build Coastguard Worker * architecure type
265*495ae853SAndroid Build Coastguard Worker *
266*495ae853SAndroid Build Coastguard Worker * @returns
267*495ae853SAndroid Build Coastguard Worker *
268*495ae853SAndroid Build Coastguard Worker * @remarks
269*495ae853SAndroid Build Coastguard Worker * none
270*495ae853SAndroid Build Coastguard Worker *
271*495ae853SAndroid Build Coastguard Worker *******************************************************************************
272*495ae853SAndroid Build Coastguard Worker */
273*495ae853SAndroid Build Coastguard Worker
isvce_rc_utils_init(svc_rc_utils_ctxt_t * ps_svc_rc_utils_ctxt,iv_mem_rec_t * ps_mem_rec,IV_ARCH_T e_arch)274*495ae853SAndroid Build Coastguard Worker void isvce_rc_utils_init(svc_rc_utils_ctxt_t *ps_svc_rc_utils_ctxt, iv_mem_rec_t *ps_mem_rec,
275*495ae853SAndroid Build Coastguard Worker IV_ARCH_T e_arch)
276*495ae853SAndroid Build Coastguard Worker {
277*495ae853SAndroid Build Coastguard Worker svc_rc_utils_state_t *ps_rc_utils_state;
278*495ae853SAndroid Build Coastguard Worker
279*495ae853SAndroid Build Coastguard Worker UWORD8 *pu1_buf = (UWORD8 *) ps_mem_rec->pv_base;
280*495ae853SAndroid Build Coastguard Worker
281*495ae853SAndroid Build Coastguard Worker ps_rc_utils_state = (svc_rc_utils_state_t *) pu1_buf;
282*495ae853SAndroid Build Coastguard Worker
283*495ae853SAndroid Build Coastguard Worker ps_svc_rc_utils_ctxt->pv_rc_utils_state = ps_rc_utils_state;
284*495ae853SAndroid Build Coastguard Worker
285*495ae853SAndroid Build Coastguard Worker isvce_get_gpp_function_selector(ps_rc_utils_state, e_arch);
286*495ae853SAndroid Build Coastguard Worker }
287