1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Copyright (c) 2021 Loongson Technology Corporation Limited 3cabdff1aSopenharmony_ci * Contributed by Shiyou Yin <yinshiyou-hf@loongson.cn> 4cabdff1aSopenharmony_ci * Xiwei Gu <guxiwei-hf@loongson.cn> 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * This file is part of FFmpeg. 7cabdff1aSopenharmony_ci * 8cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 9cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 10cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 11cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 12cabdff1aSopenharmony_ci * 13cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 14cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 15cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16cabdff1aSopenharmony_ci * Lesser General Public License for more details. 17cabdff1aSopenharmony_ci * 18cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 19cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 20cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21cabdff1aSopenharmony_ci */ 22cabdff1aSopenharmony_ci 23cabdff1aSopenharmony_ci#include "libavutil/loongarch/cpu.h" 24cabdff1aSopenharmony_ci#include "h264dsp_lasx.h" 25cabdff1aSopenharmony_ci 26cabdff1aSopenharmony_ciav_cold void ff_h264dsp_init_loongarch(H264DSPContext *c, const int bit_depth, 27cabdff1aSopenharmony_ci const int chroma_format_idc) 28cabdff1aSopenharmony_ci{ 29cabdff1aSopenharmony_ci int cpu_flags = av_get_cpu_flags(); 30cabdff1aSopenharmony_ci 31cabdff1aSopenharmony_ci if (have_lasx(cpu_flags)) { 32cabdff1aSopenharmony_ci if (chroma_format_idc <= 1) 33cabdff1aSopenharmony_ci c->h264_loop_filter_strength = ff_h264_loop_filter_strength_lasx; 34cabdff1aSopenharmony_ci if (bit_depth == 8) { 35cabdff1aSopenharmony_ci c->h264_add_pixels4_clear = ff_h264_add_pixels4_8_lasx; 36cabdff1aSopenharmony_ci c->h264_add_pixels8_clear = ff_h264_add_pixels8_8_lasx; 37cabdff1aSopenharmony_ci c->h264_v_loop_filter_luma = ff_h264_v_lpf_luma_8_lasx; 38cabdff1aSopenharmony_ci c->h264_h_loop_filter_luma = ff_h264_h_lpf_luma_8_lasx; 39cabdff1aSopenharmony_ci c->h264_v_loop_filter_luma_intra = ff_h264_v_lpf_luma_intra_8_lasx; 40cabdff1aSopenharmony_ci c->h264_h_loop_filter_luma_intra = ff_h264_h_lpf_luma_intra_8_lasx; 41cabdff1aSopenharmony_ci c->h264_v_loop_filter_chroma = ff_h264_v_lpf_chroma_8_lasx; 42cabdff1aSopenharmony_ci 43cabdff1aSopenharmony_ci if (chroma_format_idc <= 1) 44cabdff1aSopenharmony_ci c->h264_h_loop_filter_chroma = ff_h264_h_lpf_chroma_8_lasx; 45cabdff1aSopenharmony_ci c->h264_v_loop_filter_chroma_intra = ff_h264_v_lpf_chroma_intra_8_lasx; 46cabdff1aSopenharmony_ci 47cabdff1aSopenharmony_ci if (chroma_format_idc <= 1) 48cabdff1aSopenharmony_ci c->h264_h_loop_filter_chroma_intra = ff_h264_h_lpf_chroma_intra_8_lasx; 49cabdff1aSopenharmony_ci 50cabdff1aSopenharmony_ci /* Weighted MC */ 51cabdff1aSopenharmony_ci c->weight_h264_pixels_tab[0] = ff_weight_h264_pixels16_8_lasx; 52cabdff1aSopenharmony_ci c->weight_h264_pixels_tab[1] = ff_weight_h264_pixels8_8_lasx; 53cabdff1aSopenharmony_ci c->weight_h264_pixels_tab[2] = ff_weight_h264_pixels4_8_lasx; 54cabdff1aSopenharmony_ci 55cabdff1aSopenharmony_ci c->biweight_h264_pixels_tab[0] = ff_biweight_h264_pixels16_8_lasx; 56cabdff1aSopenharmony_ci c->biweight_h264_pixels_tab[1] = ff_biweight_h264_pixels8_8_lasx; 57cabdff1aSopenharmony_ci c->biweight_h264_pixels_tab[2] = ff_biweight_h264_pixels4_8_lasx; 58cabdff1aSopenharmony_ci 59cabdff1aSopenharmony_ci c->h264_idct_add = ff_h264_idct_add_lasx; 60cabdff1aSopenharmony_ci c->h264_idct8_add = ff_h264_idct8_addblk_lasx; 61cabdff1aSopenharmony_ci c->h264_idct_dc_add = ff_h264_idct4x4_addblk_dc_lasx; 62cabdff1aSopenharmony_ci c->h264_idct8_dc_add = ff_h264_idct8_dc_addblk_lasx; 63cabdff1aSopenharmony_ci c->h264_idct_add16 = ff_h264_idct_add16_lasx; 64cabdff1aSopenharmony_ci c->h264_idct8_add4 = ff_h264_idct8_add4_lasx; 65cabdff1aSopenharmony_ci 66cabdff1aSopenharmony_ci if (chroma_format_idc <= 1) 67cabdff1aSopenharmony_ci c->h264_idct_add8 = ff_h264_idct_add8_lasx; 68cabdff1aSopenharmony_ci else 69cabdff1aSopenharmony_ci c->h264_idct_add8 = ff_h264_idct_add8_422_lasx; 70cabdff1aSopenharmony_ci 71cabdff1aSopenharmony_ci c->h264_idct_add16intra = ff_h264_idct_add16_intra_lasx; 72cabdff1aSopenharmony_ci c->h264_luma_dc_dequant_idct = ff_h264_deq_idct_luma_dc_lasx; 73cabdff1aSopenharmony_ci } 74cabdff1aSopenharmony_ci } 75cabdff1aSopenharmony_ci} 76