mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-04 06:02:12 +00:00
98eb1ac901
This patch adds MSA (MIPS-SIMD-Arch) optimizations for qpel functions in new file qpeldsp_msa.c Adds new generic macros (needed for this patch) in libavutil/mips/generic_macros_msa.h Signed-off-by: Shivraj Patil <shivraj.patil@imgtec.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
6519 lines
297 KiB
C
6519 lines
297 KiB
C
/*
|
|
* Copyright (c) 2015 Parag Salasakar (Parag.Salasakar@imgtec.com)
|
|
*
|
|
* This file is part of FFmpeg.
|
|
*
|
|
* FFmpeg is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* FFmpeg is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with FFmpeg; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "libavutil/mips/generic_macros_msa.h"
|
|
#include "qpeldsp_mips.h"
|
|
|
|
#define APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask, coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 out, tmp0, tmp1; \
|
|
v16u8 data0, data1, data2, data3, data4, data5; \
|
|
v8i16 res_r, res_l; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum0_l, sum1_l, sum2_l, sum3_l; \
|
|
\
|
|
VSHF_B2_UB(inp0, inp0, inp1, inp1, mask, mask, tmp0, tmp1); \
|
|
ILVRL_B2_UH(inp1, inp0, sum0_r, sum0_l); \
|
|
data0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 15); \
|
|
data3 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 1); \
|
|
HADD_UB2_UH(sum0_r, sum0_l, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(data3, data0, sum1_r, sum1_l); \
|
|
data1 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 14); \
|
|
data4 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 2); \
|
|
sum0_r *= (v8u16) (coef0); \
|
|
sum0_l *= (v8u16) (coef0); \
|
|
ILVRL_B2_UH(data4, data1, sum2_r, sum2_l); \
|
|
data2 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 13); \
|
|
data5 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 3); \
|
|
DPADD_UB2_UH(sum2_r, sum2_l, coef2, coef2, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(data5, data2, sum3_r, sum3_l); \
|
|
HADD_UB2_UH(sum3_r, sum3_l, sum3_r, sum3_l); \
|
|
DPADD_UB2_UH(sum1_r, sum1_l, coef1, coef1, sum3_r, sum3_l); \
|
|
res_r = (v8i16) (sum0_r - sum3_r); \
|
|
res_l = (v8i16) (sum0_l - sum3_l); \
|
|
SRARI_H2_SH(res_r, res_l, 5); \
|
|
CLIP_SH2_0_255(res_r, res_l); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res_l, (v16i8) res_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, \
|
|
mask0, mask1, mask2, mask3, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 out; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum4_r, sum5_r, sum6_r, sum7_r; \
|
|
v8i16 res0_r, res1_r; \
|
|
\
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask0, mask0, sum0_r, sum4_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask3, mask3, sum3_r, sum7_r); \
|
|
HADD_UB2_UH(sum3_r, sum7_r, sum3_r, sum7_r); \
|
|
DOTP_UB2_UH(sum0_r, sum4_r, coef0, coef0, sum0_r, sum4_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask2, mask2, sum2_r, sum6_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask1, mask1, sum1_r, sum5_r); \
|
|
DPADD_UB2_UH(sum2_r, sum6_r, coef2, coef2, sum0_r, sum4_r); \
|
|
DPADD_UB2_UH(sum1_r, sum5_r, coef1, coef1, sum3_r, sum7_r); \
|
|
res0_r = (v8i16) (sum0_r - sum3_r); \
|
|
res1_r = (v8i16) (sum4_r - sum7_r); \
|
|
SRARI_H2_SH(res0_r, res1_r, 5); \
|
|
CLIP_SH2_0_255(res0_r, res1_r); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res1_r, (v16i8) res0_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, \
|
|
mask0, mask1, mask2, mask3, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 out; \
|
|
v8i16 res0_r; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
\
|
|
VSHF_B2_UH(inp0, inp0, inp0, inp0, mask0, mask3, sum0_r, sum3_r); \
|
|
sum3_r = __msa_hadd_u_h((v16u8) sum3_r, (v16u8) sum3_r); \
|
|
sum0_r = __msa_dotp_u_h((v16u8) sum0_r, (v16u8) coef0); \
|
|
VSHF_B2_UH(inp0, inp0, inp0, inp0, mask2, mask1, sum2_r, sum1_r); \
|
|
DPADD_UB2_UH(sum2_r, sum1_r, coef2, coef1, sum0_r, sum3_r); \
|
|
res0_r = (v8i16) (sum0_r - sum3_r); \
|
|
res0_r = __msa_srari_h(res0_r, 5); \
|
|
res0_r = CLIP_SH_0_255(res0_r); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res0_r, (v16i8) res0_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1, \
|
|
mask2, mask3, coef0, \
|
|
coef1, coef2) \
|
|
( { \
|
|
v16u8 out; \
|
|
v8i16 res0_r; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
\
|
|
VSHF_B2_UH(inp0, inp0, inp0, inp0, mask0, mask3, sum0_r, sum3_r); \
|
|
sum3_r = __msa_hadd_u_h((v16u8) sum3_r, (v16u8) sum3_r); \
|
|
sum0_r = __msa_dotp_u_h((v16u8) sum0_r, (v16u8) coef0); \
|
|
VSHF_B2_UH(inp0, inp0, inp0, inp0, mask2, mask1, sum2_r, sum1_r); \
|
|
DPADD_UB2_UH(sum2_r, sum1_r, coef2, coef1, sum0_r, sum3_r); \
|
|
res0_r = (v8i16) (sum0_r - sum3_r); \
|
|
res0_r += 15; \
|
|
res0_r >>= 5; \
|
|
res0_r = CLIP_SH_0_255(res0_r); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res0_r, (v16i8) res0_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 out, tmp0, tmp1; \
|
|
v16u8 data0, data1, data2, data3, data4, data5; \
|
|
v8i16 res_r, res_l; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum0_l, sum1_l, sum2_l, sum3_l; \
|
|
\
|
|
VSHF_B2_UB(inp0, inp0, inp1, inp1, mask, mask, tmp0, tmp1); \
|
|
ILVRL_B2_UH(inp1, inp0, sum0_r, sum0_l); \
|
|
data0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 15); \
|
|
data3 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 1); \
|
|
HADD_UB2_UH(sum0_r, sum0_l, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(data3, data0, sum1_r, sum1_l); \
|
|
data1 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 14); \
|
|
data4 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 2); \
|
|
sum0_r *= (v8u16) (coef0); \
|
|
sum0_l *= (v8u16) (coef0); \
|
|
ILVRL_B2_UH(data4, data1, sum2_r, sum2_l); \
|
|
data2 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) tmp0, 13); \
|
|
data5 = (v16u8) __msa_sldi_b((v16i8) tmp1, (v16i8) inp1, 3); \
|
|
DPADD_UB2_UH(sum2_r, sum2_l, coef2, coef2, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(data5, data2, sum3_r, sum3_l); \
|
|
HADD_UB2_UH(sum3_r, sum3_l, sum3_r, sum3_l); \
|
|
DPADD_UB2_UH(sum1_r, sum1_l, coef1, coef1, sum3_r, sum3_l); \
|
|
res_r = (v8i16) (sum0_r - sum3_r); \
|
|
res_l = (v8i16) (sum0_l - sum3_l); \
|
|
res_r += 15; \
|
|
res_l += 15; \
|
|
res_r >>= 5; \
|
|
res_l >>= 5; \
|
|
CLIP_SH2_0_255(res_r, res_l); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res_l, (v16i8) res_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, \
|
|
mask0, mask1, mask2, mask3, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 out; \
|
|
v8i16 res0_r, res1_r; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum4_r, sum5_r, sum6_r, sum7_r; \
|
|
\
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask0, mask0, sum0_r, sum4_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask3, mask3, sum3_r, sum7_r); \
|
|
HADD_UB2_UH(sum3_r, sum7_r, sum3_r, sum7_r); \
|
|
DOTP_UB2_UH(sum0_r, sum4_r, coef0, coef0, sum0_r, sum4_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask2, mask2, sum2_r, sum6_r); \
|
|
VSHF_B2_UH(inp0, inp0, inp1, inp1, mask1, mask1, sum1_r, sum5_r); \
|
|
DPADD_UB2_UH(sum2_r, sum6_r, coef2, coef2, sum0_r, sum4_r); \
|
|
DPADD_UB2_UH(sum1_r, sum5_r, coef1, coef1, sum3_r, sum7_r); \
|
|
res0_r = (v8i16) (sum0_r - sum3_r); \
|
|
res1_r = (v8i16) (sum4_r - sum7_r); \
|
|
res0_r += 15; \
|
|
res1_r += 15; \
|
|
res0_r >>= 5; \
|
|
res1_r >>= 5; \
|
|
CLIP_SH2_0_255(res0_r, res1_r); \
|
|
out = (v16u8) __msa_pckev_b((v16i8) res1_r, (v16i8) res0_r); \
|
|
\
|
|
out; \
|
|
} )
|
|
|
|
#define APPLY_VERT_QPEL_FILTER(inp0, inp1, inp2, inp3, \
|
|
inp4, inp5, inp6, inp7, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 res; \
|
|
v8i16 res_r, res_l; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum0_l, sum1_l, sum2_l, sum3_l; \
|
|
\
|
|
ILVRL_B2_UH(inp4, inp0, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(inp7, inp3, sum3_r, sum3_l); \
|
|
DOTP_UB2_UH(sum0_r, sum0_l, coef0, coef0, sum0_r, sum0_l); \
|
|
HADD_UB2_UH(sum3_r, sum3_l, sum3_r, sum3_l); \
|
|
ILVRL_B2_UH(inp6, inp2, sum2_r, sum2_l); \
|
|
ILVRL_B2_UH(inp5, inp1, sum1_r, sum1_l); \
|
|
DPADD_UB2_UH(sum2_r, sum2_l, coef2, coef2, sum0_r, sum0_l); \
|
|
DPADD_UB2_UH(sum1_r, sum1_l, coef1, coef1, sum3_r, sum3_l); \
|
|
res_r = (v8i16) (sum0_r - sum3_r); \
|
|
res_l = (v8i16) (sum0_l - sum3_l); \
|
|
SRARI_H2_SH(res_r, res_l, 5); \
|
|
CLIP_SH2_0_255(res_r, res_l); \
|
|
res = (v16u8) __msa_pckev_b((v16i8) res_l, (v16i8) res_r); \
|
|
\
|
|
res; \
|
|
} )
|
|
|
|
#define APPLY_VERT_QPEL_FILTER_8BYTE(inp00, inp01, inp02, inp03, \
|
|
inp04, inp05, inp06, inp07, \
|
|
inp10, inp11, inp12, inp13, \
|
|
inp14, inp15, inp16, inp17, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 res; \
|
|
v8i16 val0, val1; \
|
|
v8u16 sum00, sum01, sum02, sum03; \
|
|
v8u16 sum10, sum11, sum12, sum13; \
|
|
\
|
|
ILVR_B4_UH(inp04, inp00, inp14, inp10, inp07, inp03, inp17, inp13, \
|
|
sum00, sum10, sum03, sum13); \
|
|
DOTP_UB2_UH(sum00, sum10, coef0, coef0, sum00, sum10); \
|
|
HADD_UB2_UH(sum03, sum13, sum03, sum13); \
|
|
ILVR_B4_UH(inp06, inp02, inp16, inp12, inp05, inp01, inp15, inp11, \
|
|
sum02, sum12, sum01, sum11); \
|
|
DPADD_UB2_UH(sum02, sum12, coef2, coef2, sum00, sum10); \
|
|
DPADD_UB2_UH(sum01, sum11, coef1, coef1, sum03, sum13); \
|
|
val0 = (v8i16) (sum00 - sum03); \
|
|
val1 = (v8i16) (sum10 - sum13); \
|
|
SRARI_H2_SH(val0, val1, 5); \
|
|
CLIP_SH2_0_255(val0, val1); \
|
|
res = (v16u8) __msa_pckev_b((v16i8) val1, (v16i8) val0); \
|
|
\
|
|
res; \
|
|
} )
|
|
|
|
#define APPLY_VERT_QPEL_NO_ROUND_FILTER(inp0, inp1, inp2, inp3, \
|
|
inp4, inp5, inp6, inp7, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 res; \
|
|
v8i16 res_r, res_l; \
|
|
v8u16 sum0_r, sum1_r, sum2_r, sum3_r; \
|
|
v8u16 sum0_l, sum1_l, sum2_l, sum3_l; \
|
|
\
|
|
ILVRL_B2_UH(inp4, inp0, sum0_r, sum0_l); \
|
|
ILVRL_B2_UH(inp7, inp3, sum3_r, sum3_l); \
|
|
DOTP_UB2_UH(sum0_r, sum0_l, coef0, coef0, sum0_r, sum0_l); \
|
|
HADD_UB2_UH(sum3_r, sum3_l, sum3_r, sum3_l); \
|
|
ILVRL_B2_UH(inp6, inp2, sum2_r, sum2_l); \
|
|
ILVRL_B2_UH(inp5, inp1, sum1_r, sum1_l); \
|
|
DPADD_UB2_UH(sum2_r, sum2_l, coef2, coef2, sum0_r, sum0_l); \
|
|
DPADD_UB2_UH(sum1_r, sum1_l, coef1, coef1, sum3_r, sum3_l); \
|
|
res_r = (v8i16) (sum0_r - sum3_r); \
|
|
res_l = (v8i16) (sum0_l - sum3_l); \
|
|
res_r += 15; \
|
|
res_l += 15; \
|
|
res_r >>= 5; \
|
|
res_l >>= 5; \
|
|
CLIP_SH2_0_255(res_r, res_l); \
|
|
res = (v16u8) __msa_pckev_b((v16i8) res_l, (v16i8) res_r); \
|
|
\
|
|
res; \
|
|
} )
|
|
|
|
#define APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp00, inp01, inp02, inp03, \
|
|
inp04, inp05, inp06, inp07, \
|
|
inp10, inp11, inp12, inp13, \
|
|
inp14, inp15, inp16, inp17, \
|
|
coef0, coef1, coef2) \
|
|
( { \
|
|
v16u8 res; \
|
|
v8i16 val0, val1; \
|
|
v8u16 sum00, sum01, sum02, sum03; \
|
|
v8u16 sum10, sum11, sum12, sum13; \
|
|
\
|
|
ILVR_B4_UH(inp04, inp00, inp14, inp10, inp07, inp03, inp17, inp13, \
|
|
sum00, sum10, sum03, sum13); \
|
|
DOTP_UB2_UH(sum00, sum10, coef0, coef0, sum00, sum10); \
|
|
HADD_UB2_UH(sum03, sum13, sum03, sum13); \
|
|
ILVR_B4_UH(inp06, inp02, inp16, inp12, inp05, inp01, inp15, inp11, \
|
|
sum02, sum12, sum01, sum11); \
|
|
DPADD_UB2_UH(sum02, sum12, coef2, coef2, sum00, sum10); \
|
|
DPADD_UB2_UH(sum01, sum11, coef1, coef1, sum03, sum13); \
|
|
val0 = (v8i16) (sum00 - sum03); \
|
|
val1 = (v8i16) (sum10 - sum13); \
|
|
val0 += 15; \
|
|
val1 += 15; \
|
|
val0 >>= 5; \
|
|
val1 >>= 5; \
|
|
CLIP_SH2_0_255(val0, val1); \
|
|
res = (v16u8) __msa_pckev_b((v16i8) val1, (v16i8) val0); \
|
|
\
|
|
res; \
|
|
} )
|
|
|
|
static void horiz_mc_qpel_aver_src0_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
AVER_UB2_UB(inp0, res0, inp2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_aver_src0_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp2, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp4, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp6, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_aver_src1_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
AVER_UB2_UB(inp0, res0, inp2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_aver_src1_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp1);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp5);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp7);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_aver_src0_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
res0 = __msa_ave_u_b(inp0, res0);
|
|
res1 = __msa_ave_u_b(inp2, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_aver_src0_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp2, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp4, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp6, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_aver_src1_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
res0 = __msa_ave_u_b(inp0, res0);
|
|
res1 = __msa_ave_u_b(inp2, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_no_rnd_aver_src1_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp1);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp5);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp7);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_aver_src0_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(inp0, res0, inp2, res1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_aver_src0_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res0, res1;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(inp0, res0, inp2, res1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(inp4, res0, inp6, res1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res0, res1;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_aver_src1_8width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 res0, res1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(inp0, res0, inp2, res1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void horiz_mc_qpel_avg_dst_aver_src1_16width_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res0, res1, dst0, dst1;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp1, res1, inp3, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp5, res1, inp7, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst1, res1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
}
|
|
}
|
|
|
|
|
|
static void vert_mc_qpel_aver_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp4, 1, (v2i64) inp5);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp6, 1, (v2i64) inp7);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_aver_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp0);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp1);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp2);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
LD_UB2(src, src_stride, inp8, inp9);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp4);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp5);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
LD_UB2(src, src_stride, inp10, inp11);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp6);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp7);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
LD_UB2(src, src_stride, inp12, inp13);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp8);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp9);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
LD_UB2(src, src_stride, inp14, inp15);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp10);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp11);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp12);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp13);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp14);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp15);
|
|
ST_UB(res0, dst);
|
|
}
|
|
|
|
static void vert_mc_qpel_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
inp4 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
static void vert_mc_qpel_aver_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp1, 1, (v2i64) inp2);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp3, 1, (v2i64) inp4);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp5, 1, (v2i64) inp6);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp7, 1, (v2i64) inp8);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_aver_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
inp4 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp1);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp2);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp4);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp5);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp6);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp7);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp8);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp9);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp10);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp11);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp12);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp13);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp14);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp15);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(res0, inp16);
|
|
ST_UB(res0, dst);
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_aver_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
res0 = __msa_ave_u_b(res0, tmp0);
|
|
res1 = __msa_ave_u_b(res1, tmp1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp4, 1, (v2i64) inp5);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp6, 1, (v2i64) inp7);
|
|
res0 = __msa_ave_u_b(res0, tmp0);
|
|
res1 = __msa_ave_u_b(res1, tmp1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_aver_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp0);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp1);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp2);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp4);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp5);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp6);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp7);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp8);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp9);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp10);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp11);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp12);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp13);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp14);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp15);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
ST_UB(res0, dst);
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_aver_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp1, 1, (v2i64) inp2);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp3, 1, (v2i64) inp4);
|
|
res0 = __msa_ave_u_b(res0, tmp0);
|
|
res1 = __msa_ave_u_b(res1, tmp1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp5, 1, (v2i64) inp6);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp7, 1, (v2i64) inp8);
|
|
res0 = __msa_ave_u_b(res0, tmp0);
|
|
res1 = __msa_ave_u_b(res1, tmp1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_no_rnd_aver_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp1);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp2);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp3);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp4);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp5);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp6);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp7);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp8);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp9);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp10);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp11);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp12);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp13);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp14);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp15);
|
|
ST_UB(res0, dst);
|
|
dst += dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
res0 = __msa_ave_u_b(res0, inp16);
|
|
ST_UB(res0, dst);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_aver_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp4, 1, (v2i64) inp5);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp6, 1, (v2i64) inp7);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_aver_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0, res1, dst0, dst1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp0, res1, inp1, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp2, res1, inp3, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp8, inp9);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp4, res1, inp5, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp10, inp11);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp6, res1, inp7, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp12, inp13);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp8, res1, inp9, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp14, inp15);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp10, res1, inp11, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp12, res1, inp13, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp14, res1, inp15, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0, res1, dst0, dst1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_aver_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
v16u8 tmp0, tmp1, res0, res1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
LD_UB2(src, src_stride, inp4, inp5);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp6, inp7);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp1, 1, (v2i64) inp2);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp3, 1, (v2i64) inp4);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp8, inp7,
|
|
inp7, inp6, inp5, inp4,
|
|
inp8, inp8, inp7, inp6,
|
|
const20, const6, const3);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
tmp0 = (v16u8) __msa_insve_d((v2i64) inp5, 1, (v2i64) inp6);
|
|
tmp1 = (v16u8) __msa_insve_d((v2i64) inp7, 1, (v2i64) inp8);
|
|
dst0 = (v16u8) __msa_insve_d((v2i64) dst0, 1, (v2i64) dst1);
|
|
dst2 = (v16u8) __msa_insve_d((v2i64) dst2, 1, (v2i64) dst3);
|
|
AVER_UB2_UB(res0, tmp0, res1, tmp1, res0, res1);
|
|
AVER_UB2_UB(dst0, res0, dst2, res1, res0, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void vert_mc_qpel_avg_dst_aver_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7, inp8;
|
|
v16u8 inp9, inp10, inp11, inp12, inp13, inp14, inp15, inp16;
|
|
v16u8 res0, res1, dst0, dst1;
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB5(src, src_stride, inp0, inp1, inp2, inp3, inp4);
|
|
src += (5 * src_stride);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp0, inp0, inp1, inp2,
|
|
inp1, inp2, inp3, inp4,
|
|
const20, const6, const3);
|
|
inp5 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp1, inp0, inp0, inp1,
|
|
inp2, inp3, inp4, inp5,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp1, res1, inp2, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp6 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp2, inp1, inp0, inp0,
|
|
inp3, inp4, inp5, inp6,
|
|
const20, const6, const3);
|
|
inp7 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp3, inp2, inp1, inp0,
|
|
inp4, inp5, inp6, inp7,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp3, res1, inp4, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp8 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp4, inp3, inp2, inp1,
|
|
inp5, inp6, inp7, inp8,
|
|
const20, const6, const3);
|
|
inp9 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp5, inp4, inp3, inp2,
|
|
inp6, inp7, inp8, inp9,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp5, res1, inp6, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp10 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp6, inp5, inp4, inp3,
|
|
inp7, inp8, inp9, inp10,
|
|
const20, const6, const3);
|
|
inp11 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp7, inp6, inp5, inp4,
|
|
inp8, inp9, inp10, inp11,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp7, res1, inp8, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp12 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp8, inp7, inp6, inp5,
|
|
inp9, inp10, inp11, inp12,
|
|
const20, const6, const3);
|
|
inp13 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp9, inp8, inp7, inp6,
|
|
inp10, inp11, inp12, inp13,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp9, res1, inp10, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp14 = LD_UB(src);
|
|
src += src_stride;
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp10, inp9, inp8, inp7,
|
|
inp11, inp12, inp13, inp14,
|
|
const20, const6, const3);
|
|
inp15 = LD_UB(src);
|
|
src += src_stride;
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp11, inp10, inp9, inp8,
|
|
inp12, inp13, inp14, inp15,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp11, res1, inp12, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp16 = LD_UB(src);
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp12, inp11, inp10, inp9,
|
|
inp13, inp14, inp15, inp16,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp13, inp12, inp11, inp10,
|
|
inp14, inp15, inp16, inp16,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp13, res1, inp14, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER(inp14, inp13, inp12, inp11,
|
|
inp15, inp16, inp16, inp15,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER(inp15, inp14, inp13, inp12,
|
|
inp16, inp16, inp15, inp14,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
AVER_UB2_UB(res0, inp15, res1, inp16, res0, res1);
|
|
AVER_UB2_UB(res0, dst0, res1, dst1, res0, res1);
|
|
ST_UB2(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_horiz_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp2, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp4, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp6, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src00_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src00_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_horiz_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_v_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_v_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_horiz_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp1);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp5);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(res, inp7);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_NO_ROUND_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_ave_u_b(inp1, res);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src10_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src10_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_h_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_h_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
horiz6 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_h_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_h_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src01_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src01_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_v_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_v_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
horiz6 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src11_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_no_rnd_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_no_rnd_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_no_rnd_aver_hv_src11_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_ave_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_ave_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp0, inp1, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_ave_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE(inp2, inp3, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_ave_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_NO_ROUND_FILTER_8BYTE_1ROW(inp0, mask0, mask1,
|
|
mask2, mask3, const20,
|
|
const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_ave_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_NO_ROUND_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_ave_u_b(avg0, res0);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_ave_u_b(avg1, res1);
|
|
ST8x4_UB(res0, res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_horiz_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp2, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp4, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(inp6, res);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask, const20, const6, const3);
|
|
res = __msa_aver_u_b(inp0, res);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src00_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src00_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_horiz_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask, const20, const6, const3);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_v_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_v_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_horiz_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
uint8_t loop_count;
|
|
v16u8 inp0, inp1, inp2, inp3, inp4, inp5, inp6, inp7;
|
|
v16u8 res;
|
|
v16u8 mask = { 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
v8u16 const20 = (v8u16) __msa_ldi_h(20);
|
|
|
|
for (loop_count = (height >> 2); loop_count--;) {
|
|
LD_UB4(src, src_stride, inp0, inp2, inp4, inp6);
|
|
LD_UB4((src + 1), src_stride, inp1, inp3, inp5, inp7);
|
|
src += (4 * src_stride);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp1);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp2, inp3, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp3);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp4, inp5, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp5);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp6, inp7, mask,
|
|
const20, const6, const3);
|
|
res = __msa_aver_u_b(res, inp7);
|
|
ST_UB(res, dst);
|
|
dst += dst_stride;
|
|
}
|
|
|
|
LD_UB2(src, 1, inp0, inp1);
|
|
res = APPLY_HORIZ_QPEL_FILTER(inp0, inp1, mask, const20, const6, const3);
|
|
res = __msa_aver_u_b(inp1, res);
|
|
ST_UB(res, dst);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src10_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src10_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_h_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_h_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_8x8_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_h_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_h_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src01_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src01_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_insve_d((v2i64) horiz1, 1, (v2i64) horiz2);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_insve_d((v2i64) horiz3, 1, (v2i64) horiz4);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_insve_d((v2i64) horiz5, 1, (v2i64) horiz6);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_insve_d((v2i64) horiz7, 1, (v2i64) horiz8);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_v_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_v_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_insve_d((v2i64) horiz1, 1, (v2i64) horiz2);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_insve_d((v2i64) horiz3, 1, (v2i64) horiz4);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
avg0 = (v16u8) __msa_insve_d((v2i64) horiz5, 1, (v2i64) horiz6);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
avg1 = (v16u8) __msa_insve_d((v2i64) horiz7, 1, (v2i64) horiz8);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src11_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_aver_hv_src11_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB4(src, src_stride, inp0, inp1, inp2, inp3);
|
|
src += (4 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_insve_d((v2i64) inp0, 1, (v2i64) inp1);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_insve_d((v2i64) inp2, 1, (v2i64) inp3);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += 2 * dst_stride;
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src00_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src00_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_v_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_v_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src10_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src0_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src10_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz1, (v2i64) horiz0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz3, (v2i64) horiz2);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz5, (v2i64) horiz4);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz7, (v2i64) horiz6);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_h_src0_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_h_src0_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_16x16_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_16x16_msa(buff, 16, dst, dst_stride);
|
|
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_8x8_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_h_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_h_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src01_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src0_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src01_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1,
|
|
horiz5, horiz6, horiz7, horiz8,
|
|
horiz5, horiz4, horiz3, horiz2,
|
|
horiz6, horiz7, horiz8, horiz8,
|
|
const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3,
|
|
horiz7, horiz8, horiz8, horiz7,
|
|
horiz7, horiz6, horiz5, horiz4,
|
|
horiz8, horiz8, horiz7, horiz6,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_v_src1_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_v_src1_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz2 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
horiz4 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2,
|
|
horiz1, horiz2, horiz3, horiz4,
|
|
horiz1, horiz0, horiz0, horiz1,
|
|
horiz2, horiz3, horiz4, horiz5,
|
|
const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
horiz6 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0,
|
|
horiz3, horiz4, horiz5, horiz6,
|
|
horiz3, horiz2, horiz1, horiz0,
|
|
horiz4, horiz5, horiz6, horiz7,
|
|
const20, const6, const3);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
horiz8 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0,
|
|
mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1, horiz5,
|
|
horiz6, horiz7, horiz8, horiz5, horiz4,
|
|
horiz3, horiz2, horiz6, horiz7, horiz8,
|
|
horiz8, const20, const6, const3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3, horiz7,
|
|
horiz8, horiz8, horiz7, horiz7, horiz6,
|
|
horiz5, horiz4, horiz8, horiz8, horiz7,
|
|
horiz6, const20, const6, const3);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src11_16x16_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
uint8_t buff[272];
|
|
|
|
hv_mc_qpel_aver_horiz_src1_16x16_msa(src, src_stride, buff, 16, 16);
|
|
vert_mc_qpel_avg_dst_aver_src1_16x16_msa(buff, 16, dst, dst_stride);
|
|
}
|
|
|
|
static void hv_mc_qpel_avg_dst_aver_hv_src11_8x8_msa(const uint8_t *src,
|
|
int32_t src_stride,
|
|
uint8_t *dst,
|
|
int32_t dst_stride)
|
|
{
|
|
v16u8 inp0, inp1, inp2, inp3;
|
|
v16u8 res0, res1, avg0, avg1;
|
|
v16u8 horiz0, horiz1, horiz2, horiz3;
|
|
v16u8 horiz4, horiz5, horiz6, horiz7, horiz8;
|
|
v16u8 dst0, dst1;
|
|
v16u8 mask0 = { 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8 };
|
|
v16u8 mask1 = { 0, 2, 0, 3, 1, 4, 2, 5, 3, 6, 4, 7, 5, 8, 6, 8 };
|
|
v16u8 mask2 = { 1, 3, 0, 4, 0, 5, 1, 6, 2, 7, 3, 8, 4, 8, 5, 7 };
|
|
v16u8 mask3 = { 2, 4, 1, 5, 0, 6, 0, 7, 1, 8, 2, 8, 3, 7, 4, 6 };
|
|
v16u8 const20 = (v16u8) __msa_ldi_b(20);
|
|
v16u8 const6 = (v16u8) __msa_ldi_b(6);
|
|
v16u8 const3 = (v16u8) __msa_ldi_b(3);
|
|
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz0 = __msa_aver_u_b(inp0, res0);
|
|
horiz1 = (v16u8) __msa_splati_d((v2i64) horiz0, 1);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
LD_UB2(src, src_stride, inp0, inp1);
|
|
src += (2 * src_stride);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz2 = __msa_aver_u_b(inp2, res1);
|
|
horiz3 = (v16u8) __msa_splati_d((v2i64) horiz2, 1);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp0, inp1, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp0, inp1, inp0, inp1, inp0, inp1, 1);
|
|
|
|
inp0 = (v16u8) __msa_ilvr_d((v2i64) inp1, (v2i64) inp0);
|
|
horiz4 = __msa_aver_u_b(inp0, res0);
|
|
horiz5 = (v16u8) __msa_splati_d((v2i64) horiz4, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz2, (v2i64) horiz1);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz0, horiz0, horiz1, horiz2, horiz1,
|
|
horiz2, horiz3, horiz4, horiz1, horiz0,
|
|
horiz0, horiz1, horiz2, horiz3, horiz4,
|
|
horiz5, const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(src, src_stride, inp2, inp3);
|
|
src += (2 * src_stride);
|
|
res1 = APPLY_HORIZ_QPEL_FILTER_8BYTE(inp2, inp3, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
SLDI_B2_UB(inp2, inp3, inp2, inp3, inp2, inp3, 1);
|
|
|
|
inp2 = (v16u8) __msa_ilvr_d((v2i64) inp3, (v2i64) inp2);
|
|
horiz6 = __msa_aver_u_b(inp2, res1);
|
|
horiz7 = (v16u8) __msa_splati_d((v2i64) horiz6, 1);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz4, (v2i64) horiz3);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz2, horiz1, horiz0, horiz0, horiz3,
|
|
horiz4, horiz5, horiz6, horiz3, horiz2,
|
|
horiz1, horiz0, horiz4, horiz5, horiz6,
|
|
horiz7, const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
inp0 = LD_UB(src);
|
|
res0 = APPLY_HORIZ_QPEL_FILTER_8BYTE_1ROW(inp0, mask0, mask1, mask2, mask3,
|
|
const20, const6, const3);
|
|
inp0 = (v16u8) __msa_sldi_b((v16i8) inp0, (v16i8) inp0, 1);
|
|
horiz8 = __msa_aver_u_b(inp0, res0);
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) horiz6, (v2i64) horiz5);
|
|
res0 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz4, horiz3, horiz2, horiz1, horiz5,
|
|
horiz6, horiz7, horiz8, horiz5, horiz4,
|
|
horiz3, horiz2, horiz6, horiz7, horiz8,
|
|
horiz8, const20, const6, const3);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
avg0 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res0 = __msa_aver_u_b(avg0, res0);
|
|
ST8x2_UB(res0, dst, dst_stride);
|
|
dst += (2 * dst_stride);
|
|
|
|
LD_UB2(dst, dst_stride, dst0, dst1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) horiz8, (v2i64) horiz7);
|
|
res1 = APPLY_VERT_QPEL_FILTER_8BYTE(horiz6, horiz5, horiz4, horiz3, horiz7,
|
|
horiz8, horiz8, horiz7, horiz7, horiz6,
|
|
horiz5, horiz4, horiz8, horiz8, horiz7,
|
|
horiz6, const20, const6, const3);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
avg1 = (v16u8) __msa_ilvr_d((v2i64) dst1, (v2i64) dst0);
|
|
res1 = __msa_aver_u_b(avg1, res1);
|
|
ST8x2_UB(res1, dst, dst_stride);
|
|
}
|
|
|
|
static void copy_8x8_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
uint64_t src0, src1;
|
|
int32_t loop_cnt;
|
|
|
|
for (loop_cnt = 4; loop_cnt--;) {
|
|
src0 = LD(src);
|
|
src += src_stride;
|
|
src1 = LD(src);
|
|
src += src_stride;
|
|
|
|
SD(src0, dst);
|
|
dst += dst_stride;
|
|
SD(src1, dst);
|
|
dst += dst_stride;
|
|
}
|
|
}
|
|
|
|
static void copy_16x16_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride)
|
|
{
|
|
v16u8 src0, src1, src2, src3, src4, src5, src6, src7;
|
|
v16u8 src8, src9, src10, src11, src12, src13, src14, src15;
|
|
|
|
LD_UB8(src, src_stride, src0, src1, src2, src3, src4, src5, src6, src7);
|
|
src += (8 * src_stride);
|
|
LD_UB8(src, src_stride,
|
|
src8, src9, src10, src11, src12, src13, src14, src15);
|
|
|
|
ST_UB8(src0, src1, src2, src3, src4, src5, src6, src7, dst, dst_stride);
|
|
dst += (8 * dst_stride);
|
|
ST_UB8(src8, src9, src10, src11, src12, src13, src14, src15,
|
|
dst, dst_stride);
|
|
}
|
|
|
|
static void avg_width8_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
int32_t cnt;
|
|
uint64_t out0, out1, out2, out3;
|
|
v16u8 src0, src1, src2, src3;
|
|
v16u8 dst0, dst1, dst2, dst3;
|
|
|
|
for (cnt = (height / 4); cnt--;) {
|
|
LD_UB4(src, src_stride, src0, src1, src2, src3);
|
|
src += (4 * src_stride);
|
|
LD_UB4(dst, dst_stride, dst0, dst1, dst2, dst3);
|
|
|
|
AVER_UB4_UB(src0, dst0, src1, dst1, src2, dst2, src3, dst3,
|
|
dst0, dst1, dst2, dst3);
|
|
|
|
out0 = __msa_copy_u_d((v2i64) dst0, 0);
|
|
out1 = __msa_copy_u_d((v2i64) dst1, 0);
|
|
out2 = __msa_copy_u_d((v2i64) dst2, 0);
|
|
out3 = __msa_copy_u_d((v2i64) dst3, 0);
|
|
SD4(out0, out1, out2, out3, dst, dst_stride);
|
|
dst += (4 * dst_stride);
|
|
}
|
|
}
|
|
|
|
static void avg_width16_msa(const uint8_t *src, int32_t src_stride,
|
|
uint8_t *dst, int32_t dst_stride,
|
|
int32_t height)
|
|
{
|
|
int32_t cnt;
|
|
v16u8 src0, src1, src2, src3, src4, src5, src6, src7;
|
|
v16u8 dst0, dst1, dst2, dst3, dst4, dst5, dst6, dst7;
|
|
|
|
for (cnt = (height / 8); cnt--;) {
|
|
LD_UB8(src, src_stride, src0, src1, src2, src3, src4, src5, src6, src7);
|
|
src += (8 * src_stride);
|
|
LD_UB8(dst, dst_stride, dst0, dst1, dst2, dst3, dst4, dst5, dst6, dst7);
|
|
|
|
AVER_UB4_UB(src0, dst0, src1, dst1, src2, dst2, src3, dst3,
|
|
dst0, dst1, dst2, dst3);
|
|
AVER_UB4_UB(src4, dst4, src5, dst5, src6, dst6, src7, dst7,
|
|
dst4, dst5, dst6, dst7);
|
|
ST_UB8(dst0, dst1, dst2, dst3, dst4, dst5, dst6, dst7, dst, dst_stride);
|
|
dst += (8 * dst_stride);
|
|
}
|
|
}
|
|
|
|
void ff_copy_16x16_msa(uint8_t *dest, const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
copy_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_copy_8x8_msa(uint8_t *dest, const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
copy_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_aver_src0_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_aver_src0_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_aver_src0_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_aver_src0_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_8width_msa(uint8_t *dest, const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_16width_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_aver_src1_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_aver_src1_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_aver_src1_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_aver_src1_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_aver_src0_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_aver_src0_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_aver_src0_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_aver_src0_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_8width_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_16width_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_aver_src1_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_aver_src1_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_no_rnd_aver_src1_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_no_rnd_aver_src1_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_avg_width8_msa(uint8_t *dest, const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
avg_width8_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_avg_width16_msa(uint8_t *dest, const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
avg_width16_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_aver_src0_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_aver_src0_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_aver_src0_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_aver_src0_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_8width_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_16width_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_aver_src1_8width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_aver_src1_8width_msa(src, stride, dest, stride, 8);
|
|
}
|
|
|
|
void ff_horiz_mc_qpel_avg_dst_aver_src1_16width_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
horiz_mc_qpel_avg_dst_aver_src1_16width_msa(src, stride, dest, stride, 16);
|
|
}
|
|
|
|
|
|
void ff_vert_mc_qpel_aver_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_aver_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_aver_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_aver_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_8x8_msa(uint8_t *dest, const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_16x16_msa(uint8_t *dest, const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_aver_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_aver_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_aver_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_aver_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_aver_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_aver_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_aver_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_aver_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_aver_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_aver_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_no_rnd_aver_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_no_rnd_aver_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_aver_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_aver_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_aver_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_aver_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_aver_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_aver_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_vert_mc_qpel_avg_dst_aver_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
vert_mc_qpel_avg_dst_aver_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
/* HV cases */
|
|
void ff_hv_mc_qpel_aver_hv_src00_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src00_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src00_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src00_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_v_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_v_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_v_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_v_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src10_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src10_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src10_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src10_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_h_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_h_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_h_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_h_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_16x16_msa(uint8_t *dest, const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_8x8_msa(uint8_t *dest, const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_h_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_h_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_h_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_h_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src01_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src01_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src01_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src01_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_v_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_v_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_v_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_v_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src11_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src11_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_aver_hv_src11_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_aver_hv_src11_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src00_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src00_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src00_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src00_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_v_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_v_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_v_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_v_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src10_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src10_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src10_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src10_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_h_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_h_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_h_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_h_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_h_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_h_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_h_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_h_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src01_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src01_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src01_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src01_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_v_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_v_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_v_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_v_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src11_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src11_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_avg_dst_aver_hv_src11_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_avg_dst_aver_hv_src11_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src00_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src00_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src00_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src00_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_v_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_v_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_v_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_v_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src10_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src10_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src10_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src10_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_h_src0_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_h_src0_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_h_src0_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_h_src0_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src, ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_h_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_h_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_h_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_h_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src01_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src01_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src01_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src01_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_v_src1_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_v_src1_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_v_src1_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_v_src1_8x8_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src11_16x16_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src11_16x16_msa(src, stride, dest, stride);
|
|
}
|
|
|
|
void ff_hv_mc_qpel_no_rnd_aver_hv_src11_8x8_msa(uint8_t *dest,
|
|
const uint8_t *src,
|
|
ptrdiff_t stride)
|
|
{
|
|
hv_mc_qpel_no_rnd_aver_hv_src11_8x8_msa(src, stride, dest, stride);
|
|
}
|