blob: 529ac55151acf3352e5486930ea81732b33936f5 [file] [log] [blame]
Colin Cross3f774362017-04-20 16:42:47 -07001cc_library_static {
2 name: "libhevcdec",
Jiyong Park0323e532017-08-07 13:15:09 +09003 vendor_available: true,
Mitch Phillips84e41b12019-06-17 14:49:49 -07004 host_supported: true,
Colin Cross3f774362017-04-20 16:42:47 -07005
6 cflags: [
7 "-D_LIB",
8 "-DMULTICORE",
9 "-fPIC",
10
11 "-O3",
12 "-DANDROID",
Chih-Hung Hsieh3dcae232017-09-28 14:24:46 -070013 "-Wall",
14 "-Werror",
15 // common/x86/ihevc_sao_ssse3_intr.c: implicit conversion from
16 // 'int' to 'char' changes value from 128 to -128
17 "-Wno-error=constant-conversion",
Colin Cross3f774362017-04-20 16:42:47 -070018 ],
19
20 export_include_dirs: [
21 "decoder",
22 "common",
23 ],
24
25 srcs: [
26 "common/ihevc_quant_tables.c",
27 "common/ihevc_inter_pred_filters.c",
28 "common/ihevc_weighted_pred.c",
29 "common/ihevc_padding.c",
30 "common/ihevc_deblk_edge_filter.c",
31 "common/ihevc_deblk_tables.c",
32 "common/ihevc_cabac_tables.c",
33 "common/ihevc_common_tables.c",
34 "common/ihevc_intra_pred_filters.c",
35 "common/ihevc_chroma_intra_pred_filters.c",
36 "common/ihevc_mem_fns.c",
37 "common/ihevc_sao.c",
38 "common/ihevc_trans_tables.c",
39 "common/ihevc_recon.c",
40 "common/ihevc_itrans.c",
41 "common/ihevc_itrans_recon.c",
42 "common/ihevc_iquant_recon.c",
43 "common/ihevc_iquant_itrans_recon.c",
44 "common/ihevc_itrans_recon_32x32.c",
45 "common/ihevc_itrans_recon_16x16.c",
46 "common/ihevc_itrans_recon_8x8.c",
47 "common/ihevc_chroma_itrans_recon.c",
48 "common/ihevc_chroma_iquant_recon.c",
49 "common/ihevc_chroma_iquant_itrans_recon.c",
50 "common/ihevc_chroma_recon.c",
51 "common/ihevc_chroma_itrans_recon_16x16.c",
52 "common/ihevc_chroma_itrans_recon_8x8.c",
53 "common/ihevc_buf_mgr.c",
54 "common/ihevc_disp_mgr.c",
55 "common/ihevc_dpb_mgr.c",
56 "common/ithread.c",
57 "decoder/ihevcd_version.c",
58 "decoder/ihevcd_api.c",
59 "decoder/ihevcd_decode.c",
60 "decoder/ihevcd_nal.c",
61 "decoder/ihevcd_bitstream.c",
62 "decoder/ihevcd_parse_headers.c",
63 "decoder/ihevcd_parse_slice_header.c",
64 "decoder/ihevcd_parse_slice.c",
65 "decoder/ihevcd_parse_residual.c",
66 "decoder/ihevcd_cabac.c",
67 "decoder/ihevcd_intra_pred_mode_prediction.c",
68 "decoder/ihevcd_process_slice.c",
69 "decoder/ihevcd_utils.c",
70 "decoder/ihevcd_job_queue.c",
71 "decoder/ihevcd_ref_list.c",
72 "decoder/ihevcd_get_mv.c",
73 "decoder/ihevcd_mv_pred.c",
74 "decoder/ihevcd_mv_merge.c",
75 "decoder/ihevcd_iquant_itrans_recon_ctb.c",
76 "decoder/ihevcd_itrans_recon_dc.c",
77 "decoder/ihevcd_common_tables.c",
78 "decoder/ihevcd_boundary_strength.c",
79 "decoder/ihevcd_deblk.c",
80 "decoder/ihevcd_inter_pred.c",
81 "decoder/ihevcd_sao.c",
82 "decoder/ihevcd_ilf_padding.c",
83 "decoder/ihevcd_fmt_conv.c",
84 ],
85
86 arch: {
87 arm64: {
88 cflags: [
89 "-DARMV8",
90 "-DDISABLE_NEONINTR",
91 "-DARM",
92 "-DARMGCC",
93
94 "-DDEFAULT_ARCH=D_ARCH_ARMV8_GENERIC",
95 ],
96 local_include_dirs: [
97 "decoder/arm",
98 "common/arm",
99 "decoder/arm64",
100 "common/arm64",
101 ],
102
103 srcs: [
104 "decoder/arm/ihevcd_function_selector.c",
105 "decoder/arm/ihevcd_function_selector_noneon.c",
106 "decoder/arm64/ihevcd_function_selector_av8.c",
107 "common/arm/ihevc_intra_pred_filters_neon_intr.c",
108 "common/arm/ihevc_weighted_pred_neon_intr.c",
109 "common/arm64/ihevc_mem_fns.s",
110 "common/arm64/ihevc_itrans_recon_32x32.s",
111 "common/arm64/ihevc_weighted_pred_bi_default.s",
112 "common/arm64/ihevc_weighted_pred_bi.s",
113 "common/arm64/ihevc_weighted_pred_uni.s",
114 "common/arm64/ihevc_deblk_luma_horz.s",
115 "common/arm64/ihevc_deblk_luma_vert.s",
116 "common/arm64/ihevc_deblk_chroma_vert.s",
117 "common/arm64/ihevc_deblk_chroma_horz.s",
118 "common/arm64/ihevc_sao_band_offset_luma.s",
119 "common/arm64/ihevc_sao_band_offset_chroma.s",
120 "common/arm64/ihevc_sao_edge_offset_class0.s",
121 "common/arm64/ihevc_sao_edge_offset_class0_chroma.s",
122 "common/arm64/ihevc_sao_edge_offset_class1.s",
123 "common/arm64/ihevc_sao_edge_offset_class1_chroma.s",
124 "common/arm64/ihevc_sao_edge_offset_class2.s",
125 "common/arm64/ihevc_sao_edge_offset_class2_chroma.s",
126 "common/arm64/ihevc_sao_edge_offset_class3.s",
127 "common/arm64/ihevc_sao_edge_offset_class3_chroma.s",
128 "common/arm64/ihevc_inter_pred_luma_horz_w16out.s",
129 "common/arm64/ihevc_inter_pred_filters_luma_horz.s",
130 "common/arm64/ihevc_inter_pred_filters_luma_vert.s",
131 "common/arm64/ihevc_inter_pred_chroma_horz.s",
132 "common/arm64/ihevc_inter_pred_chroma_horz_w16out.s",
133 "common/arm64/ihevc_inter_pred_chroma_vert.s",
134 "common/arm64/ihevc_inter_pred_chroma_vert_w16out.s",
135 "common/arm64/ihevc_inter_pred_chroma_vert_w16inp.s",
136 "common/arm64/ihevc_inter_pred_chroma_vert_w16inp_w16out.s",
137 "common/arm64/ihevc_inter_pred_filters_luma_vert_w16inp.s",
138 "common/arm64/ihevc_inter_pred_filters_luma_vert_w16out.s",
139 "common/arm64/ihevc_inter_pred_luma_vert_w16inp_w16out.s",
140 "common/arm64/ihevc_inter_pred_luma_copy_w16out.s",
141 "common/arm64/ihevc_inter_pred_luma_copy.s",
142 "common/arm64/ihevc_inter_pred_chroma_copy.s",
143 "common/arm64/ihevc_inter_pred_chroma_copy_w16out.s",
144 "common/arm64/ihevc_itrans_recon_4x4_ttype1.s",
145 "common/arm64/ihevc_itrans_recon_4x4.s",
146 "common/arm64/ihevc_itrans_recon_8x8.s",
147 "common/arm64/ihevc_itrans_recon_16x16.s",
148 "common/arm64/ihevc_intra_pred_chroma_planar.s",
149 "common/arm64/ihevc_intra_pred_chroma_dc.s",
150 "common/arm64/ihevc_intra_pred_chroma_horz.s",
151 "common/arm64/ihevc_intra_pred_chroma_ver.s",
152 "common/arm64/ihevc_intra_pred_chroma_mode2.s",
153 "common/arm64/ihevc_intra_pred_chroma_mode_18_34.s",
154 "common/arm64/ihevc_intra_pred_filters_chroma_mode_11_to_17.s",
155 "common/arm64/ihevc_intra_pred_filters_chroma_mode_19_to_25.s",
156 "common/arm64/ihevc_intra_pred_chroma_mode_3_to_9.s",
157 "common/arm64/ihevc_intra_pred_chroma_mode_27_to_33.s",
158 "common/arm64/ihevc_intra_pred_luma_planar.s",
159 "common/arm64/ihevc_intra_pred_luma_horz.s",
160 "common/arm64/ihevc_intra_pred_luma_mode2.s",
161 "common/arm64/ihevc_intra_pred_luma_mode_27_to_33.s",
162 "common/arm64/ihevc_intra_pred_luma_mode_18_34.s",
163 "common/arm64/ihevc_intra_pred_luma_vert.s",
164 "common/arm64/ihevc_intra_pred_luma_dc.s",
165 "common/arm64/ihevc_intra_pred_filters_luma_mode_11_to_17.s",
166 "common/arm64/ihevc_intra_pred_filters_luma_mode_19_to_25.s",
167 "common/arm64/ihevc_intra_pred_luma_mode_3_to_9.s",
168 "common/arm64/ihevc_padding.s",
169 "decoder/arm64/ihevcd_itrans_recon_dc_luma.s",
170 "decoder/arm64/ihevcd_itrans_recon_dc_chroma.s",
171 "decoder/arm64/ihevcd_fmt_conv_420sp_to_420p.s",
172 "decoder/arm64/ihevcd_fmt_conv_420sp_to_420sp.s",
173 "decoder/arm64/ihevcd_fmt_conv_420sp_to_rgba8888.s",
174 ],
175 },
176
177 arm: {
178 local_include_dirs: [
179 "decoder/arm",
180 "common/arm",
181 ],
182
183 srcs: [
184 "decoder/arm/ihevcd_function_selector.c",
185 "decoder/arm/ihevcd_function_selector_noneon.c",
186 ],
187
188 cflags: [
189 "-DDISABLE_NEONINTR",
190 "-DARM",
191 "-DARMGCC",
192 "-fno-tree-vectorize",
193
194 // These will be overriden by armv7_a_neon
195 "-DDISABLE_NEON",
196 "-DDEFAULT_ARCH=D_ARCH_ARM_NONEON",
197 ],
198
199 instruction_set: "arm",
200
Isaac Chen36ff7b62017-09-12 16:58:19 +0800201 neon: {
Colin Cross3f774362017-04-20 16:42:47 -0700202 srcs: [
203 "decoder/arm/ihevcd_function_selector_a9q.c",
204 "common/arm/ihevc_intra_ref_substitution_a9q.c",
205 "common/arm/ihevc_intra_pred_filters_neon_intr.c",
206 "common/arm/ihevc_weighted_pred_neon_intr.c",
207 "common/arm/ihevc_mem_fns.s",
208 "common/arm/ihevc_itrans_recon_32x32.s",
209 "common/arm/ihevc_weighted_pred_bi_default.s",
210 "common/arm/ihevc_weighted_pred_bi.s",
211 "common/arm/ihevc_weighted_pred_uni.s",
212 "common/arm/ihevc_deblk_luma_horz.s",
213 "common/arm/ihevc_deblk_luma_vert.s",
214 "common/arm/ihevc_deblk_chroma_vert.s",
215 "common/arm/ihevc_deblk_chroma_horz.s",
216 "common/arm/ihevc_sao_band_offset_luma.s",
217 "common/arm/ihevc_sao_band_offset_chroma.s",
218 "common/arm/ihevc_sao_edge_offset_class0.s",
219 "common/arm/ihevc_sao_edge_offset_class0_chroma.s",
220 "common/arm/ihevc_sao_edge_offset_class1.s",
221 "common/arm/ihevc_sao_edge_offset_class1_chroma.s",
222 "common/arm/ihevc_sao_edge_offset_class2.s",
223 "common/arm/ihevc_sao_edge_offset_class2_chroma.s",
224 "common/arm/ihevc_sao_edge_offset_class3.s",
225 "common/arm/ihevc_sao_edge_offset_class3_chroma.s",
226 "common/arm/ihevc_inter_pred_luma_horz_w16out.s",
227 "common/arm/ihevc_inter_pred_filters_luma_horz.s",
228 "common/arm/ihevc_inter_pred_filters_luma_vert.s",
229 "common/arm/ihevc_inter_pred_chroma_horz.s",
230 "common/arm/ihevc_inter_pred_chroma_horz_w16out.s",
231 "common/arm/ihevc_inter_pred_chroma_vert.s",
232 "common/arm/ihevc_inter_pred_chroma_vert_w16out.s",
233 "common/arm/ihevc_inter_pred_chroma_vert_w16inp.s",
234 "common/arm/ihevc_inter_pred_chroma_vert_w16inp_w16out.s",
235 "common/arm/ihevc_inter_pred_filters_luma_vert_w16inp.s",
236 "common/arm/ihevc_inter_pred_luma_vert_w16inp_w16out.s",
237 "common/arm/ihevc_inter_pred_luma_copy_w16out.s",
238 "common/arm/ihevc_inter_pred_luma_copy.s",
239 "common/arm/ihevc_inter_pred_chroma_copy.s",
240 "common/arm/ihevc_inter_pred_chroma_copy_w16out.s",
241 "common/arm/ihevc_itrans_recon_4x4_ttype1.s",
242 "common/arm/ihevc_itrans_recon_4x4.s",
243 "common/arm/ihevc_itrans_recon_8x8.s",
244 "common/arm/ihevc_itrans_recon_16x16.s",
245 "common/arm/ihevc_intra_pred_chroma_planar.s",
246 "common/arm/ihevc_intra_pred_chroma_dc.s",
247 "common/arm/ihevc_intra_pred_chroma_horz.s",
248 "common/arm/ihevc_intra_pred_chroma_ver.s",
249 "common/arm/ihevc_intra_pred_chroma_mode2.s",
250 "common/arm/ihevc_intra_pred_chroma_mode_18_34.s",
251 "common/arm/ihevc_intra_pred_filters_chroma_mode_11_to_17.s",
252 "common/arm/ihevc_intra_pred_filters_chroma_mode_19_to_25.s",
253 "common/arm/ihevc_intra_pred_chroma_mode_3_to_9.s",
254 "common/arm/ihevc_intra_pred_chroma_mode_27_to_33.s",
255 "common/arm/ihevc_intra_pred_luma_planar.s",
256 "common/arm/ihevc_intra_pred_luma_horz.s",
257 "common/arm/ihevc_intra_pred_luma_mode2.s",
258 "common/arm/ihevc_intra_pred_luma_mode_27_to_33.s",
259 "common/arm/ihevc_intra_pred_luma_mode_18_34.s",
260 "common/arm/ihevc_intra_pred_luma_vert.s",
261 "common/arm/ihevc_intra_pred_luma_dc.s",
262 "common/arm/ihevc_intra_pred_filters_luma_mode_11_to_17.s",
263 "common/arm/ihevc_intra_pred_filters_luma_mode_19_to_25.s",
264 "common/arm/ihevc_intra_pred_luma_mode_3_to_9.s",
265 "common/arm/ihevc_padding.s",
266 "decoder/arm/ihevcd_itrans_recon_dc_luma.s",
267 "decoder/arm/ihevcd_itrans_recon_dc_chroma.s",
268 "decoder/arm/ihevcd_fmt_conv_420sp_to_420p.s",
269 "decoder/arm/ihevcd_fmt_conv_420sp_to_420sp.s",
270 "decoder/arm/ihevcd_fmt_conv_420sp_to_rgba8888.s",
271 ],
272 cflags: [
273 "-UDISABLE_NEON",
274 "-UDEFAULT_ARCH",
275 "-DDEFAULT_ARCH=D_ARCH_ARM_A9Q",
276 ],
277 },
278 },
279
280 mips64: {
281 local_include_dirs: [
282 "decoder/mips",
283 "common/mips",
284 ],
285
286 srcs: [
287 "decoder/mips/ihevcd_function_selector.c",
288 "decoder/mips/ihevcd_function_selector_mips_generic.c",
289 ],
290 },
291
292 mips: {
293 local_include_dirs: [
294 "decoder/mips",
295 "common/mips",
296 ],
297
298 srcs: [
299 "decoder/mips/ihevcd_function_selector.c",
300 "decoder/mips/ihevcd_function_selector_mips_generic.c",
301 ],
302 },
303
304 x86_64: {
305 cflags: [
306 "-DX86",
307 "-DDISABLE_AVX2",
308 "-msse4.2",
309 "-mno-avx",
310 "-DDEFAULT_ARCH=D_ARCH_X86_SSE42",
311 ],
312
313 local_include_dirs: [
314 "decoder/x86",
315 "common/x86",
316 ],
317
318 srcs: [
319 "decoder/x86/ihevcd_function_selector.c",
320 "decoder/x86/ihevcd_function_selector_generic.c",
321 "decoder/x86/ihevcd_function_selector_ssse3.c",
322 "decoder/x86/ihevcd_function_selector_sse42.c",
323 "common/x86/ihevc_inter_pred_filters_ssse3_intr.c",
324 "common/x86/ihevc_weighted_pred_ssse3_intr.c",
325 "common/x86/ihevc_intra_pred_filters_ssse3_intr.c",
326 "common/x86/ihevc_chroma_intra_pred_filters_ssse3_intr.c",
327 "common/x86/ihevc_itrans_recon_ssse3_intr.c",
328 "common/x86/ihevc_itrans_recon_16x16_ssse3_intr.c",
329 "common/x86/ihevc_itrans_recon_32x32_ssse3_intr.c",
330 "common/x86/ihevc_sao_ssse3_intr.c",
331 "common/x86/ihevc_deblk_ssse3_intr.c",
332 "common/x86/ihevc_padding_ssse3_intr.c",
333 "common/x86/ihevc_mem_fns_ssse3_intr.c",
334 "decoder/x86/ihevcd_fmt_conv_ssse3_intr.c",
335 "decoder/x86/ihevcd_it_rec_dc_ssse3_intr.c",
336 "common/x86/ihevc_inter_pred_filters_sse42_intr.c",
337 "common/x86/ihevc_weighted_pred_sse42_intr.c",
338 "common/x86/ihevc_intra_pred_filters_sse42_intr.c",
339 "common/x86/ihevc_chroma_intra_pred_filters_sse42_intr.c",
340 "common/x86/ihevc_itrans_recon_sse42_intr.c",
341 "common/x86/ihevc_16x16_itrans_recon_sse42_intr.c",
342 "common/x86/ihevc_32x32_itrans_recon_sse42_intr.c",
343 "decoder/x86/ihevcd_it_rec_dc_sse42_intr.c",
344 "common/x86/ihevc_tables_x86_intr.c",
345 ],
346 },
347
348 x86: {
349 cflags: [
350 "-DX86",
351 "-DDISABLE_AVX2",
352 "-msse4.2",
353 "-mno-avx",
354 "-DDEFAULT_ARCH=D_ARCH_X86_SSE42",
355 ],
356
357 local_include_dirs: [
358 "decoder/x86",
359 "common/x86",
360 ],
361
362 srcs: [
363 "decoder/x86/ihevcd_function_selector.c",
364 "decoder/x86/ihevcd_function_selector_generic.c",
365 "decoder/x86/ihevcd_function_selector_ssse3.c",
366 "decoder/x86/ihevcd_function_selector_sse42.c",
367 "common/x86/ihevc_inter_pred_filters_ssse3_intr.c",
368 "common/x86/ihevc_weighted_pred_ssse3_intr.c",
369 "common/x86/ihevc_intra_pred_filters_ssse3_intr.c",
370 "common/x86/ihevc_chroma_intra_pred_filters_ssse3_intr.c",
371 "common/x86/ihevc_itrans_recon_ssse3_intr.c",
372 "common/x86/ihevc_itrans_recon_16x16_ssse3_intr.c",
373 "common/x86/ihevc_itrans_recon_32x32_ssse3_intr.c",
374 "common/x86/ihevc_sao_ssse3_intr.c",
375 "common/x86/ihevc_deblk_ssse3_intr.c",
376 "common/x86/ihevc_padding_ssse3_intr.c",
377 "common/x86/ihevc_mem_fns_ssse3_intr.c",
378 "decoder/x86/ihevcd_fmt_conv_ssse3_intr.c",
379 "decoder/x86/ihevcd_it_rec_dc_ssse3_intr.c",
380 "common/x86/ihevc_inter_pred_filters_sse42_intr.c",
381 "common/x86/ihevc_weighted_pred_sse42_intr.c",
382 "common/x86/ihevc_intra_pred_filters_sse42_intr.c",
383 "common/x86/ihevc_chroma_intra_pred_filters_sse42_intr.c",
384 "common/x86/ihevc_itrans_recon_sse42_intr.c",
385 "common/x86/ihevc_16x16_itrans_recon_sse42_intr.c",
386 "common/x86/ihevc_32x32_itrans_recon_sse42_intr.c",
387 "decoder/x86/ihevcd_it_rec_dc_sse42_intr.c",
388 "common/x86/ihevc_tables_x86_intr.c",
389 ],
390 },
391 },
bohu174b57b2018-03-20 12:19:22 -0700392
393 sanitize: {
Ivan Lozano11b93ed2018-07-10 12:01:23 -0700394 integer_overflow: true,
Ivan Lozanob61b5232018-10-04 11:00:20 -0700395 misc_undefined: ["bounds"],
Ivan Lozano20a0df12018-07-17 09:49:44 -0700396 // Enable CFI if this becomes a shared library.
397 // cfi: true,
Ivan Lozano11b93ed2018-07-10 12:01:23 -0700398 blacklist: "libhevc_blacklist.txt",
bohu174b57b2018-03-20 12:19:22 -0700399 },
Colin Cross3f774362017-04-20 16:42:47 -0700400}
Ivan Lozano662b2472018-07-16 12:39:37 -0700401
402cc_test {
403 name: "hevcdec",
Harish Mahendrakar9ae7f252019-08-15 17:53:12 -0700404 host_supported: true,
Ivan Lozano662b2472018-07-16 12:39:37 -0700405 cflags: [
406 "-DPROFILE_ENABLE",
407 "-DARM",
408 "-fPIC",
409 "-DMD5_DISABLE",
410 "-Wall",
411 "-Werror",
412 ],
413 srcs: ["test/decoder/main.c"],
414 static_libs: ["libhevcdec"],
Harish Mahendrakar96bcc2c2019-09-09 10:27:12 -0700415 target: {
416 darwin: {
417 enabled: false,
418 },
419 },
Ivan Lozano662b2472018-07-16 12:39:37 -0700420}
Ram Mohan69da5e22018-10-05 18:05:06 +0530421
422cc_library_static {
423 name: "libhevcenc",
424 vendor_available: true,
425
426 cflags: [
427 "-DENABLE_MAIN_REXT_PROFILE",
428 "-fPIC",
429 "-O3",
430 "-Wall",
431 "-Wno-unused-variable",
432 "-Wno-unused-parameter",
433 "-Wno-switch",
434 ],
435
436 export_include_dirs: [
437 "encoder",
438 "common",
439 ],
440
441 srcs: [
442 "common/ihevc_cabac_tables.c",
443 "common/ihevc_chroma_intra_pred_filters.c",
444 "common/ihevc_chroma_itrans_recon.c",
445 "common/ihevc_chroma_itrans_recon_16x16.c",
446 "common/ihevc_chroma_itrans_recon_8x8.c",
447 "common/ihevc_common_tables.c",
448 "common/ihevc_deblk_edge_filter.c",
449 "common/ihevc_deblk_tables.c",
450 "common/ihevc_hbd_deblk_edge_filter.c",
451 "common/ihevc_inter_pred_filters.c",
452 "common/ihevc_intra_pred_filters.c",
453 "common/ihevc_iquant_recon.c",
454 "common/ihevc_itrans_recon.c",
455 "common/ihevc_itrans_recon_16x16.c",
456 "common/ihevc_itrans_recon_32x32.c",
457 "common/ihevc_itrans_recon_8x8.c",
458 "common/ihevc_mem_fns.c",
459 "common/ihevc_padding.c",
460 "common/ihevc_quant_iquant_ssd.c",
461 "common/ihevc_quant_tables.c",
462 "common/ihevc_resi_trans.c",
463 "common/ihevc_sao.c",
464 "common/ihevc_trans_tables.c",
465 "common/ihevc_weighted_pred.c",
466 "encoder/bit_allocation.c",
467 "encoder/cbr_buffer_control.c",
468 "encoder/common_rom.c",
469 "encoder/convert_float_to_fix.c",
470 "encoder/est_sad.c",
471 "encoder/fixed_point_error_bits.c",
472 "encoder/frame_info_collector.c",
473 "encoder/hme_coarse.c",
474 "encoder/hme_common_utils.c",
475 "encoder/hme_err_compute.c",
476 "encoder/hme_fullpel.c",
477 "encoder/hme_function_selector.c",
478 "encoder/hme_globals.c",
479 "encoder/hme_interface.c",
480 "encoder/hme_refine.c",
481 "encoder/hme_search_algo.c",
482 "encoder/hme_subpel.c",
483 "encoder/hme_utils.c",
484 "encoder/ihevce_bitstream.c",
485 "encoder/ihevce_bs_compute_ctb.c",
486 "encoder/ihevce_buffer_que.c",
487 "encoder/ihevce_cabac.c",
488 "encoder/ihevce_cabac_cu_pu.c",
489 "encoder/ihevce_cabac_rdo.c",
490 "encoder/ihevce_cabac_tu.c",
491 "encoder/ihevce_chroma_had_satd.c",
492 "encoder/ihevce_cmn_utils_instr_set_router.c",
493 "encoder/ihevce_coarse_me_pass.c",
494 "encoder/ihevce_common_utils.c",
495 "encoder/ihevce_deblk.c",
496 "encoder/ihevce_decomp_pre_intra_pass.c",
497 "encoder/ihevce_dep_mngr.c",
498 "encoder/ihevce_enc_cu_recursion.c",
499 "encoder/ihevce_enc_loop_inter_mode_sifter.c",
500 "encoder/ihevce_enc_loop_pass.c",
501 "encoder/ihevce_enc_loop_utils.c",
502 "encoder/ihevce_enc_sbh_funcs.c",
503 "encoder/ihevce_enc_subpel_gen.c",
504 "encoder/ihevce_encode_header.c",
505 "encoder/ihevce_encode_header_sei_vui.c",
506 "encoder/ihevce_entropy_cod.c",
507 "encoder/ihevce_entropy_interface.c",
508 "encoder/ihevce_error_check.c",
509 "encoder/ihevce_frame_process.c",
510 "encoder/ihevce_frame_process_utils.c",
511 "encoder/ihevce_function_selector.c",
512 "encoder/ihevce_global_tables.c",
513 "encoder/ihevce_had_satd.c",
514 "encoder/ihevce_hle_interface.c",
515 "encoder/ihevce_hle_q_func.c",
516 "encoder/ihevce_inter_pred.c",
517 "encoder/ihevce_ipe_instr_set_router.c",
518 "encoder/ihevce_ipe_pass.c",
519 "encoder/ihevce_lap_interface.c",
520 "encoder/ihevce_me_instr_set_router.c",
521 "encoder/ihevce_me_pass.c",
522 "encoder/ihevce_memory_init.c",
523 "encoder/ihevce_multi_thrd_funcs.c",
524 "encoder/ihevce_mv_pred.c",
525 "encoder/ihevce_mv_pred_merge.c",
526 "encoder/ihevce_nbr_avail.c",
527 "encoder/ihevce_plugin.c",
528 "encoder/ihevce_profile.c",
529 "encoder/ihevce_rc_interface.c",
530 "encoder/ihevce_recur_bracketing.c",
531 "encoder/ihevce_sao.c",
532 "encoder/ihevce_stasino_helpers.c",
533 "encoder/ihevce_sub_pic_rc.c",
534 "encoder/ihevce_sys_api.c",
535 "encoder/ihevce_tile_interface.c",
536 "encoder/ihevce_trace.c",
537 "encoder/ihevce_tu_tree_selector.c",
538 "encoder/init_qp.c",
539 "encoder/mb_model_based.c",
540 "encoder/osal.c",
541 "encoder/osal_cond_var.c",
542 "encoder/osal_error.c",
543 "encoder/osal_mutex.c",
544 "encoder/osal_semaphore.c",
545 "encoder/osal_thread.c",
546 "encoder/picture_type.c",
547 "encoder/rate_control_api.c",
548 "encoder/rc_rd_model.c",
549 "encoder/rc_rd_model_fix.c",
550 "encoder/rc_sad_acc.c",
551 "encoder/sqrt_interp.c",
552 "encoder/var_q_operator.c",
553 "encoder/vbr_storage_vbv.c",
554 "encoder/vbr_str_prms.c",
555 ],
556
557 arch: {
558 arm64: {
559
560 local_include_dirs: [
561 "encoder/arm",
562 "common/arm",
563 "common/arm64",
564 ],
565
566 srcs: [
567 "encoder/arm/ihevce_coarse_layer_sad_neon.c",
568 "encoder/arm/ihevce_common_utils_neon.c",
569 "encoder/arm/ihevce_copy_neon.c",
Ram Mohan69da5e22018-10-05 18:05:06 +0530570 "encoder/arm/ihevce_had_compute_neon.c",
571 "encoder/arm/ihevce_hme_utils_neon.c",
572 "encoder/arm/ihevce_itrans_recon_neon.c",
573 "encoder/arm/ihevce_me_neon.c",
574 "encoder/arm/ihevce_sad_compute_neon.c",
575 "encoder/arm/ihevce_scale_by_2_neon.c",
576 "encoder/arm/ihevce_scan_coeffs_neon.c",
577 "encoder/arm/ihevce_ssd_and_sad_calculator_neon.c",
578 "encoder/arm/ihevce_ssd_calculator_neon.c",
579 "encoder/arm/ihevce_subpel_neon.c",
580 "common/arm/ihevc_resi_trans_neon.c",
581 "common/arm/ihevc_resi_trans_neon_32x32.c",
582 "common/arm/ihevc_quant_iquant_ssd_neon_intr.c",
583 "common/arm/ihevc_intra_pred_filters_neon_intr.c",
584 "common/arm/ihevc_weighted_pred_neon_intr.c",
585 "common/arm/ihevc_intra_ref_substitution_a9q.c",
586 "common/arm64/ihevc_deblk_chroma_horz.s",
587 "common/arm64/ihevc_deblk_chroma_vert.s",
588 "common/arm64/ihevc_deblk_luma_horz.s",
589 "common/arm64/ihevc_deblk_luma_vert.s",
590 "common/arm64/ihevc_inter_pred_chroma_copy.s",
591 "common/arm64/ihevc_inter_pred_chroma_copy_w16out.s",
592 "common/arm64/ihevc_inter_pred_chroma_horz.s",
593 "common/arm64/ihevc_inter_pred_chroma_horz_w16out.s",
594 "common/arm64/ihevc_inter_pred_chroma_vert.s",
595 "common/arm64/ihevc_inter_pred_chroma_vert_w16inp.s",
596 "common/arm64/ihevc_inter_pred_chroma_vert_w16inp_w16out.s",
597 "common/arm64/ihevc_inter_pred_chroma_vert_w16out.s",
598 "common/arm64/ihevc_inter_pred_filters_luma_horz.s",
599 "common/arm64/ihevc_inter_pred_filters_luma_vert.s",
600 "common/arm64/ihevc_inter_pred_filters_luma_vert_w16inp.s",
601 "common/arm64/ihevc_inter_pred_filters_luma_vert_w16out.s",
602 "common/arm64/ihevc_inter_pred_luma_copy.s",
603 "common/arm64/ihevc_inter_pred_luma_copy_w16out.s",
604 "common/arm64/ihevc_inter_pred_luma_horz_w16out.s",
605 "common/arm64/ihevc_inter_pred_luma_vert_w16inp_w16out.s",
606 "common/arm64/ihevc_intra_pred_chroma_dc.s",
607 "common/arm64/ihevc_intra_pred_chroma_horz.s",
608 "common/arm64/ihevc_intra_pred_chroma_mode2.s",
609 "common/arm64/ihevc_intra_pred_chroma_mode_18_34.s",
610 "common/arm64/ihevc_intra_pred_chroma_mode_27_to_33.s",
611 "common/arm64/ihevc_intra_pred_chroma_mode_3_to_9.s",
612 "common/arm64/ihevc_intra_pred_chroma_planar.s",
613 "common/arm64/ihevc_intra_pred_chroma_ver.s",
614 "common/arm64/ihevc_intra_pred_filters_chroma_mode_11_to_17.s",
615 "common/arm64/ihevc_intra_pred_filters_chroma_mode_19_to_25.s",
616 "common/arm64/ihevc_intra_pred_filters_luma_mode_11_to_17.s",
617 "common/arm64/ihevc_intra_pred_filters_luma_mode_19_to_25.s",
618 "common/arm64/ihevc_intra_pred_luma_dc.s",
619 "common/arm64/ihevc_intra_pred_luma_horz.s",
620 "common/arm64/ihevc_intra_pred_luma_mode2.s",
621 "common/arm64/ihevc_intra_pred_luma_mode_18_34.s",
622 "common/arm64/ihevc_intra_pred_luma_mode_27_to_33.s",
623 "common/arm64/ihevc_intra_pred_luma_mode_3_to_9.s",
624 "common/arm64/ihevc_intra_pred_luma_planar.s",
625 "common/arm64/ihevc_intra_pred_luma_vert.s",
626 "common/arm64/ihevc_itrans_recon_16x16.s",
627 "common/arm64/ihevc_itrans_recon_32x32.s",
628 "common/arm64/ihevc_itrans_recon_4x4.s",
629 "common/arm64/ihevc_itrans_recon_4x4_ttype1.s",
630 "common/arm64/ihevc_itrans_recon_8x8.s",
631 "common/arm64/ihevc_mem_fns.s",
632 "common/arm64/ihevc_padding.s",
633 "common/arm64/ihevc_sao_band_offset_chroma.s",
634 "common/arm64/ihevc_sao_band_offset_luma.s",
635 "common/arm64/ihevc_sao_edge_offset_class0.s",
636 "common/arm64/ihevc_sao_edge_offset_class0_chroma.s",
637 "common/arm64/ihevc_sao_edge_offset_class1.s",
638 "common/arm64/ihevc_sao_edge_offset_class1_chroma.s",
639 "common/arm64/ihevc_sao_edge_offset_class2.s",
640 "common/arm64/ihevc_sao_edge_offset_class2_chroma.s",
641 "common/arm64/ihevc_sao_edge_offset_class3.s",
642 "common/arm64/ihevc_sao_edge_offset_class3_chroma.s",
643 "common/arm64/ihevc_weighted_pred_bi.s",
644 "common/arm64/ihevc_weighted_pred_bi_default.s",
645 "common/arm64/ihevc_weighted_pred_uni.s",
646 ],
647
648 cflags: [
649 "-DENABLE_NEON", "-DARMV8", "-DARM",
650 ],
651 },
652
653 arm: {
654 local_include_dirs: [
655 "encoder/arm",
656 "common/arm",
657 ],
658
659 instruction_set: "arm",
660
661 neon: {
662 srcs: [
663 "encoder/arm/ihevce_coarse_layer_sad_neon.c",
664 "encoder/arm/ihevce_common_utils_neon.c",
665 "encoder/arm/ihevce_copy_neon.c",
Ram Mohan69da5e22018-10-05 18:05:06 +0530666 "encoder/arm/ihevce_had_compute_neon.c",
667 "encoder/arm/ihevce_hme_utils_neon.c",
668 "encoder/arm/ihevce_itrans_recon_neon.c",
669 "encoder/arm/ihevce_me_neon.c",
670 "encoder/arm/ihevce_sad_compute_neon.c",
671 "encoder/arm/ihevce_scale_by_2_neon.c",
672 "encoder/arm/ihevce_scan_coeffs_neon.c",
673 "encoder/arm/ihevce_ssd_and_sad_calculator_neon.c",
674 "encoder/arm/ihevce_ssd_calculator_neon.c",
675 "encoder/arm/ihevce_subpel_neon.c",
676 "common/arm/ihevc_resi_trans_neon.c",
677 "common/arm/ihevc_resi_trans_neon_32x32.c",
678 "common/arm/ihevc_quant_iquant_ssd_neon_intr.c",
679 "common/arm/ihevc_intra_pred_filters_neon_intr.c",
680 "common/arm/ihevc_weighted_pred_neon_intr.c",
681 "common/arm/ihevc_intra_ref_substitution_a9q.c",
682 "common/arm/ihevc_deblk_chroma_horz.s",
683 "common/arm/ihevc_deblk_chroma_vert.s",
684 "common/arm/ihevc_deblk_luma_horz.s",
685 "common/arm/ihevc_deblk_luma_vert.s",
686 "common/arm/ihevc_inter_pred_chroma_copy.s",
687 "common/arm/ihevc_inter_pred_chroma_copy_w16out.s",
688 "common/arm/ihevc_inter_pred_chroma_horz.s",
689 "common/arm/ihevc_inter_pred_chroma_horz_w16out.s",
690 "common/arm/ihevc_inter_pred_chroma_vert.s",
691 "common/arm/ihevc_inter_pred_chroma_vert_w16inp.s",
692 "common/arm/ihevc_inter_pred_chroma_vert_w16inp_w16out.s",
693 "common/arm/ihevc_inter_pred_chroma_vert_w16out.s",
694 "common/arm/ihevc_inter_pred_filters_luma_horz.s",
695 "common/arm/ihevc_inter_pred_filters_luma_vert.s",
696 "common/arm/ihevc_inter_pred_filters_luma_vert_w16inp.s",
697 "common/arm/ihevc_inter_pred_luma_copy.s",
698 "common/arm/ihevc_inter_pred_luma_copy_w16out.s",
699 "common/arm/ihevc_inter_pred_luma_horz_w16out.s",
700 "common/arm/ihevc_inter_pred_luma_vert_w16inp_w16out.s",
701 "common/arm/ihevc_intra_pred_chroma_dc.s",
702 "common/arm/ihevc_intra_pred_chroma_horz.s",
703 "common/arm/ihevc_intra_pred_chroma_mode2.s",
704 "common/arm/ihevc_intra_pred_chroma_mode_18_34.s",
705 "common/arm/ihevc_intra_pred_chroma_mode_27_to_33.s",
706 "common/arm/ihevc_intra_pred_chroma_mode_3_to_9.s",
707 "common/arm/ihevc_intra_pred_chroma_planar.s",
708 "common/arm/ihevc_intra_pred_chroma_ver.s",
709 "common/arm/ihevc_intra_pred_filters_chroma_mode_11_to_17.s",
710 "common/arm/ihevc_intra_pred_filters_chroma_mode_19_to_25.s",
711 "common/arm/ihevc_intra_pred_filters_luma_mode_11_to_17.s",
712 "common/arm/ihevc_intra_pred_filters_luma_mode_19_to_25.s",
713 "common/arm/ihevc_intra_pred_luma_dc.s",
714 "common/arm/ihevc_intra_pred_luma_horz.s",
715 "common/arm/ihevc_intra_pred_luma_mode2.s",
716 "common/arm/ihevc_intra_pred_luma_mode_18_34.s",
717 "common/arm/ihevc_intra_pred_luma_mode_27_to_33.s",
718 "common/arm/ihevc_intra_pred_luma_mode_3_to_9.s",
719 "common/arm/ihevc_intra_pred_luma_planar.s",
720 "common/arm/ihevc_intra_pred_luma_vert.s",
721 "common/arm/ihevc_itrans_recon_16x16.s",
722 "common/arm/ihevc_itrans_recon_32x32.s",
723 "common/arm/ihevc_itrans_recon_4x4.s",
724 "common/arm/ihevc_itrans_recon_4x4_ttype1.s",
725 "common/arm/ihevc_itrans_recon_8x8.s",
726 "common/arm/ihevc_resi_trans.s",
727 "common/arm/ihevc_resi_trans_32x32_a9q.s",
728 "common/arm/ihevc_mem_fns.s",
729 "common/arm/ihevc_padding.s",
730 "common/arm/ihevc_sao_band_offset_chroma.s",
731 "common/arm/ihevc_sao_band_offset_luma.s",
732 "common/arm/ihevc_sao_edge_offset_class0.s",
733 "common/arm/ihevc_sao_edge_offset_class0_chroma.s",
734 "common/arm/ihevc_sao_edge_offset_class1.s",
735 "common/arm/ihevc_sao_edge_offset_class1_chroma.s",
736 "common/arm/ihevc_sao_edge_offset_class2.s",
737 "common/arm/ihevc_sao_edge_offset_class2_chroma.s",
738 "common/arm/ihevc_sao_edge_offset_class3.s",
739 "common/arm/ihevc_sao_edge_offset_class3_chroma.s",
740 "common/arm/ihevc_weighted_pred_bi_default.s",
741 "common/arm/ihevc_weighted_pred_bi.s",
742 "common/arm/ihevc_weighted_pred_uni.s",
743 ],
744
745 cflags: [
746 "-DENABLE_NEON", "-DARM",
747 ],
748 },
749 },
750
751 x86_64: {
752 local_include_dirs: [
753 "common/x86",
754 ],
755 },
756
757 x86: {
758 local_include_dirs: [
759 "common/x86",
760 ],
761 }
762
763 },
764 sanitize: {
765 integer_overflow: true,
766 misc_undefined: ["bounds"],
767 // Enable CFI if this becomes a shared library.
768 // cfi: true,
769 diag: {
770 integer_overflow: true,
771 misc_undefined: ["bounds"],
772 },
773 blacklist: "libhevc_blacklist.txt",
774 },
775}
776
777cc_test {
778 name: "hevcenc",
779 cflags: [
780 "-DARM",
781 "-fPIC",
782 "-Wall",
783 "-Werror",
784 ],
785 srcs: ["test/encoder/main.c"],
786 static_libs: ["libhevcenc"],
787 sanitize: {
788 integer_overflow: true,
789 misc_undefined: ["bounds"],
790 diag: {
791 integer_overflow: true,
792 misc_undefined: ["bounds"],
793 },
794 },
795}