ref: 49b569a0183888342aa1041d029a739f9edb3ce8
parent: 9f0d51d8d28046fa9614f4eb5ea9a0f09d3fa847
author: Guangwei Wang <[email protected]>
date: Wed Jul 8 06:34:49 EDT 2015
Add new ARM AArch64 assembly functions to support sub8x8 mode
--- a/codec/common/arm64/mc_aarch64_neon.S
+++ b/codec/common/arm64/mc_aarch64_neon.S
@@ -1818,6 +1818,30 @@
WELS_ASM_AARCH64_FUNC_END
+WELS_ASM_AARCH64_FUNC_BEGIN McHorVer20Width5_AArch64_neon
+ sub x0, x0, #2
+ sub x3, x3, #4
+ mov x5, #4
+ movi v0.8h, #20, lsl #0
+ movi v1.8h, #5, lsl #0
+w5_h_mc_luma_loop:
+ ld1 {v2.16b}, [x0], x1 //only use 10(5+5); v2=src[-2]
+
+ ext v5.16b, v2.16b, v4.16b, #1 //v5=src[-1]
+ ext v6.16b, v2.16b, v4.16b, #2 //v6=src[0]
+ ext v7.16b, v2.16b, v4.16b, #3 //v7=src[1]
+ ext v16.16b, v2.16b, v4.16b, #4 //v16=src[2]
+ ext v17.16b, v2.16b, v4.16b, #5 //v17=src[3]
+
+ FILTER_6TAG_8BITS1 v2, v5, v6, v7, v16, v17, v20, v0, v1
+ st1 {v20.s}[0], [x2], x5 //write 4Byte
+ st1 {v20.b}[4], [x2], x3 //write 5th Byte
+
+ sub x4, x4, #1
+ cbnz x4, w5_h_mc_luma_loop
+WELS_ASM_AARCH64_FUNC_END
+
+
WELS_ASM_AARCH64_FUNC_BEGIN McHorVer22Width17_AArch64_neon
stp d8, d9, [sp,#-16]!
stp d10, d11, [sp,#-16]!
@@ -2116,6 +2140,98 @@
st1 {v26.b}[0], [x2], x3 //write 8th Byte : 0 line
WELS_ASM_AARCH64_FUNC_END
+
+WELS_ASM_AARCH64_FUNC_BEGIN McHorVer22Width5_AArch64_neon
+ sub x0, x0, #2
+ sub x0, x0, x1, lsl #1
+ movi v0.8h, #20, lsl #0
+ movi v1.8h, #5, lsl #0
+ sub x3, x3, #4
+ mov x5, #4
+ ldr q29, filter_para
+ sub x4, x4, #1
+
+ //prfm pldl1strm, [x0]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v2.16b}, [x0], x1 // v2=src[-2*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v3.16b}, [x0], x1 // v5=src[-1*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v4.16b}, [x0], x1 // v8=src[0*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v5.16b}, [x0], x1 // v11=src[1*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v6.16b}, [x0], x1 // v14=src[2*stride]
+
+w5_hv_mc_luma_loop:
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v7.16b}, [x0], x1 // v7=src[3*stride]
+ // vertical filtered into v20/v21
+ FILTER_6TAG_8BITS_TO_16BITS1 v2, v3, v4, v5, v6, v7, v20, v0, v1
+ FILTER_6TAG_8BITS_TO_16BITS2 v2, v3, v4, v5, v6, v7, v21, v0, v1
+ // horizon filtered
+ UNPACK_2_16BITS_TO_ABC v20, v21, v23, v24, v25
+ FILTER_3_IN_16BITS_TO_8BITS1 v23, v24, v25, v26 //output to v26[0]
+ st1 {v26.s}[0], [x2], x5 //write 0:3Byte : 0 line
+ st1 {v26.b}[4], [x2], x3 //write 5th Byte : 0 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v2.16b}, [x0], x1 // v2=src[4*stride]
+ // vertical filtered into v20/v21
+ FILTER_6TAG_8BITS_TO_16BITS1 v3, v4, v5, v6, v7, v2, v20, v0, v1
+ FILTER_6TAG_8BITS_TO_16BITS2 v3, v4, v5, v6, v7, v2, v21, v0, v1
+ // horizon filtered
+ UNPACK_2_16BITS_TO_ABC v20, v21, v23, v24, v25
+ FILTER_3_IN_16BITS_TO_8BITS1 v23, v24, v25, v26 //output to v26[0]
+ st1 {v26.s}[0], [x2], x5 //write 0:3Byte : 1 line
+ st1 {v26.b}[4], [x2], x3 //write 5th Byte : 1 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v3.16b}, [x0], x1 // v3=src[5*stride]
+ // vertical filtered into v20/v21
+ FILTER_6TAG_8BITS_TO_16BITS1 v4, v5, v6, v7, v2, v3, v20, v0, v1
+ FILTER_6TAG_8BITS_TO_16BITS2 v4, v5, v6, v7, v2, v3, v21, v0, v1
+ // horizon filtered
+ UNPACK_2_16BITS_TO_ABC v20, v21, v23, v24, v25
+ FILTER_3_IN_16BITS_TO_8BITS1 v23, v24, v25, v26 //output to v26[0]
+ st1 {v26.s}[0], [x2], x5 //write 0:3Byte : 2 line
+ st1 {v26.b}[4], [x2], x3 //write 5th Byte : 2 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v4.16b}, [x0], x1 // v4=src[6*stride]
+ // vertical filtered into v20/v21
+ FILTER_6TAG_8BITS_TO_16BITS1 v5, v6, v7, v2, v3, v4, v20, v0, v1
+ FILTER_6TAG_8BITS_TO_16BITS2 v5, v6, v7, v2, v3, v4, v21, v0, v1
+ // horizon filtered
+ UNPACK_2_16BITS_TO_ABC v20, v21, v23, v24, v25
+ FILTER_3_IN_16BITS_TO_8BITS1 v23, v24, v25, v26 //output to v26[0]
+ st1 {v26.s}[0], [x2], x5 //write 0:3Byte : 3 line
+ st1 {v26.b}[4], [x2], x3 //write 5th Byte : 3 line
+
+
+ mov v5.16b, v3.16b
+ mov v3.16b, v7.16b
+ mov v30.16b, v2.16b
+ mov v2.16b, v6.16b
+ mov v6.16b, v4.16b
+ mov v4.16b, v30.16b
+
+ sub x4, x4, #4
+ cbnz x4, w5_hv_mc_luma_loop
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v7.16b}, [x0], x1 // v7=src[3*stride]
+ // vertical filtered into v20/v21
+ FILTER_6TAG_8BITS_TO_16BITS1 v2, v3, v4, v5, v6, v7, v20, v0, v1
+ FILTER_6TAG_8BITS_TO_16BITS2 v2, v3, v4, v5, v6, v7, v21, v0, v1
+ // horizon filtered
+ UNPACK_2_16BITS_TO_ABC v20, v21, v23, v24, v25
+ FILTER_3_IN_16BITS_TO_8BITS1 v23, v24, v25, v26 //output to v26[0]
+ st1 {v26.s}[0], [x2], x5 //write 0:3Byte : 0 line
+ st1 {v26.b}[4], [x2], x3 //write 5th Byte : 0 line
+WELS_ASM_AARCH64_FUNC_END
+
+
WELS_ASM_AARCH64_FUNC_BEGIN McHorVer02Height17_AArch64_neon
sub x0, x0, x1, lsl #1
movi v0.8h, #20, lsl #0
@@ -2257,6 +2373,62 @@
ld1 {v7.8b}, [x0], x1 // v7=src[3*stride]
FILTER_6TAG_8BITS1 v2, v3, v4, v5, v6, v7, v20, v0, v1
st1 {v20.8b}, [x2], x3 //write 8Byte : 0 line
+WELS_ASM_AARCH64_FUNC_END
+
+
+WELS_ASM_AARCH64_FUNC_BEGIN McHorVer02Height5_AArch64_neon
+ sub x0, x0, x1, lsl #1
+ movi v0.8h, #20, lsl #0
+ movi v1.8h, #5, lsl #0
+ sub x4, x4, #1
+
+ //prfm pldl1strm, [x0]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v2.8b}, [x0], x1 // v2=src[-2*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v3.8b}, [x0], x1 // v3=src[-1*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v4.8b}, [x0], x1 // v4=src[0*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v5.8b}, [x0], x1 // v5=src[1*stride]
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v6.8b}, [x0], x1 // v6=src[2*stride]
+
+w5_v_mc_luma_loop:
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v7.8b}, [x0], x1 // v7=src[3*stride]
+ FILTER_6TAG_8BITS1 v2, v3, v4, v5, v6, v7, v20, v0, v1
+ st1 {v20.s}[0], [x2], x3 //write 4Byte : 0 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v2.8b}, [x0], x1 // v2=src[4*stride]
+ FILTER_6TAG_8BITS1 v3, v4, v5, v6, v7, v2, v20, v0, v1
+ st1 {v20.s}[0], [x2], x3 //write 4Byte : 1 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v3.8b}, [x0], x1 // v3=src[5*stride]
+ FILTER_6TAG_8BITS1 v4, v5, v6, v7, v2, v3, v20, v0, v1
+ st1 {v20.s}[0], [x2], x3 //write 4Byte : 2 line
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v4.8b}, [x0], x1 // v4=src[6*stride]
+ FILTER_6TAG_8BITS1 v5, v6, v7, v2, v3, v4, v20, v0, v1
+ st1 {v20.s}[0], [x2], x3 //write 4Byte : 3 line
+
+ mov v5.16b, v3.16b
+ mov v3.16b, v7.16b
+ mov v7.16b, v2.16b
+ mov v2.16b, v6.16b
+ mov v6.16b, v4.16b
+ mov v4.16b, v7.16b
+ sub x4, x4, #4
+ cbnz x4, w5_v_mc_luma_loop
+
+ //prfm pldl1strm, [x0, x1]
+ ld1 {v7.8b}, [x0], x1 // v7=src[3*stride]
+ FILTER_6TAG_8BITS1 v2, v3, v4, v5, v6, v7, v20, v0, v1
+ st1 {v20.s}[0], [x2], x3 //write 4Byte : 0 line
+
WELS_ASM_AARCH64_FUNC_END
#endif
--- a/codec/common/inc/mc.h
+++ b/codec/common/inc/mc.h
@@ -228,13 +228,19 @@
int32_t iHeight);// width+1
void McHorVer20Width9_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iHeight);// width+1
+void McHorVer20Width5_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
+ int32_t iHeight);// width+1
void McHorVer02Height17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iHeight);// height+1
void McHorVer02Height9_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iHeight);// height+1
+void McHorVer02Height5_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
+ int32_t iHeight);// height+1
void McHorVer22Width17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iHeight);//width+1&&height+1
void McHorVer22Width9_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
+ int32_t iHeight);//width+1&&height+1
+void McHorVer22Width5_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iHeight);//width+1&&height+1
#endif
--- a/codec/common/src/mc.cpp
+++ b/codec/common/src/mc.cpp
@@ -1004,27 +1004,33 @@
}
#endif
#if defined(HAVE_NEON_AARCH64)
-void McHorVer20Width9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
+void McHorVer20Width5Or9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iWidth, int32_t iHeight) {
if (iWidth == 17)
McHorVer20Width17_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
- else //if (iWidth == 9)
+ else if (iWidth == 9)
McHorVer20Width9_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
+ else //if (iWidth == 5)
+ McHorVer20Width5_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
}
-void McHorVer02Height9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
+void McHorVer02Height5Or9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iWidth, int32_t iHeight) {
if (iWidth == 16)
McHorVer02Height17_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
- else //if (iWidth == 8)
+ else if (iWidth == 8)
McHorVer02Height9_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
+ else //if (iWidth == 4)
+ McHorVer02Height5_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
}
-void McHorVer22Width9Or17Height9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst,
+void McHorVer22Width5Or9Or17Height5Or9Or17_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst,
int32_t iDstStride,
int32_t iWidth, int32_t iHeight) {
if (iWidth == 17)
McHorVer22Width17_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
- else //if (iWidth == 9)
+ else if (iWidth == 9)
McHorVer22Width9_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
+ else //if (iWidth == 5)
+ McHorVer22Width5_AArch64_neon (pSrc, iSrcStride, pDst, iDstStride, iHeight);
}
void McCopy_AArch64_neon (const uint8_t* pSrc, int32_t iSrcStride, uint8_t* pDst, int32_t iDstStride,
int32_t iWidth, int32_t iHeight) {
@@ -1327,9 +1333,9 @@
pMcFuncs->pMcLumaFunc = McLuma_AArch64_neon;
pMcFuncs->pMcChromaFunc = McChroma_AArch64_neon;
pMcFuncs->pfSampleAveraging = PixelAvg_AArch64_neon;
- pMcFuncs->pfLumaHalfpelHor = McHorVer20Width9Or17_AArch64_neon;//iWidth+1:8/16
- pMcFuncs->pfLumaHalfpelVer = McHorVer02Height9Or17_AArch64_neon;//heigh+1:8/16
- pMcFuncs->pfLumaHalfpelCen = McHorVer22Width9Or17Height9Or17_AArch64_neon;//iWidth+1/heigh+1
+ pMcFuncs->pfLumaHalfpelHor = McHorVer20Width5Or9Or17_AArch64_neon;//iWidth+1:4/8/16
+ pMcFuncs->pfLumaHalfpelVer = McHorVer02Height5Or9Or17_AArch64_neon;//heigh+1:4/8/16
+ pMcFuncs->pfLumaHalfpelCen = McHorVer22Width5Or9Or17Height5Or9Or17_AArch64_neon;//iWidth+1/heigh+1
}
#endif
}