On Sat, Dec 19, 2015 at 10:56:26AM +0100, Matthieu Bouron wrote: > On Sat, Dec 19, 2015 at 03:24:17AM +0100, Michael Niedermayer wrote: > > On Fri, Dec 18, 2015 at 04:33:37PM +0100, Matthieu Bouron wrote: > > > On Fri, Dec 18, 2015 at 3:59 PM, Matthieu Bouron > > > <matthieu.bou...@gmail.com> > > > wrote: > > > > > > > From: Matthieu Bouron <matthieu.bou...@stupeflix.com> > > > > > > > > --- > > > > libswscale/arm/swscale_unscaled.c | 52 +++++++++++++++++++++++--- > > > > libswscale/arm/yuv2rgb_neon.S | 77 > > > > ++++++++++++++++++++++++++++++++++++--- > > > > 2 files changed, 118 insertions(+), 11 deletions(-) > > > > > > > > diff --git a/libswscale/arm/swscale_unscaled.c > > > > b/libswscale/arm/swscale_unscaled.c > > > > index 8aa6432..dce987e 100644 > > > > --- a/libswscale/arm/swscale_unscaled.c > > > > +++ b/libswscale/arm/swscale_unscaled.c > > > > @@ -63,6 +63,50 @@ static int rgbx_to_nv12_neon_16_wrapper(SwsContext > > > > *context, const uint8_t *src[ > > > > } > > > > #endif > > > > > > > > +#define YUV_TO_RGB_TABLE(precision) > > > > \ > > > > + c->yuv2rgb_v2r_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > + c->yuv2rgb_u2g_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > + c->yuv2rgb_v2g_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > + c->yuv2rgb_u2b_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > + > > > > +#define DECLARE_FF_YUV420P_TO_RGBX_FUNCS(ofmt, precision) > > > > \ > > > > +int ff_yuv420p_to_##ofmt##_neon_##precision(int w, int h, > > > > \ > > > > + uint8_t *dst, int linesize, > > > > \ > > > > + const uint8_t *srcY, int linesizeY, > > > > \ > > > > + const uint8_t *srcU, int linesizeU, > > > > \ > > > > + const uint8_t *srcV, int linesizeV, > > > > \ > > > > + const int16_t *table, > > > > \ > > > > + int y_offset, > > > > \ > > > > + int y_coeff); > > > > \ > > > > + > > > > \ > > > > +static int yuv420p_to_##ofmt##_neon_wrapper_##precision(SwsContext *c, > > > > const uint8_t *src[],\ > > > > + int srcStride[], int > > > > srcSliceY, int srcSliceH, \ > > > > + uint8_t *dst[], int > > > > dstStride[]) { \ > > > > + const int16_t yuv2rgb_table[] = { YUV_TO_RGB_TABLE(precision) }; > > > > \ > > > > + > > > > \ > > > > + ff_yuv420p_to_##ofmt##_neon_##precision(c->srcW, srcSliceH, > > > > \ > > > > + dst[0] + srcSliceY * > > > > dstStride[0], > > > > dstStride[0], \ > > > > + src[0] + srcSliceY * > > > > srcStride[0], > > > > srcStride[0], \ > > > > + src[1] + (srcSliceY / 2) * > > > > srcStride[1], > > > > srcStride[1], \ > > > > + src[2] + (srcSliceY / 2) * > > > > srcStride[2], > > > > srcStride[2], \ > > > > + yuv2rgb_table, > > > > \ > > > > + c->yuv2rgb_y_offset >> 9, > > > > \ > > > > + c->yuv2rgb_y_coeff / ((precision) == > > > > 16 > > > > ? 1 << 7 : 1)); \ > > > > + > > > > \ > > > > + return 0; > > > > \ > > > > +} > > > > \ > > > > + > > > > +#define DECLARE_FF_YUV420P_TO_ALL_RGBX_FUNCS(precision) > > > > \ > > > > +DECLARE_FF_YUV420P_TO_RGBX_FUNCS(argb, precision) > > > > \ > > > > +DECLARE_FF_YUV420P_TO_RGBX_FUNCS(rgba, precision) > > > > \ > > > > +DECLARE_FF_YUV420P_TO_RGBX_FUNCS(abgr, precision) > > > > \ > > > > +DECLARE_FF_YUV420P_TO_RGBX_FUNCS(bgra, precision) > > > > \ > > > > + > > > > +#define DECLARE_FF_YUV420P_TO_ALL_RGBX_ALL_PRECISION_FUNCS > > > > \ > > > > +DECLARE_FF_YUV420P_TO_ALL_RGBX_FUNCS(16) > > > > \ > > > > + > > > > +DECLARE_FF_YUV420P_TO_ALL_RGBX_ALL_PRECISION_FUNCS > > > > + > > > > #define DECLARE_FF_NVX_TO_RGBX_FUNCS(ifmt, ofmt, precision) > > > > \ > > > > int ff_##ifmt##_to_##ofmt##_neon_##precision(int w, int h, > > > > \ > > > > uint8_t *dst, int linesize, > > > > \ > > > > @@ -75,12 +119,7 @@ int ff_##ifmt##_to_##ofmt##_neon_##precision(int w, > > > > int h, > > > > static int ifmt##_to_##ofmt##_neon_wrapper_##precision(SwsContext *c, > > > > const uint8_t *src[], \ > > > > int srcStride[], int > > > > srcSliceY, int srcSliceH, \ > > > > uint8_t *dst[], int > > > > dstStride[]) { \ > > > > - const int16_t yuv2rgb_table[] = { > > > > \ > > > > - c->yuv2rgb_v2r_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > - c->yuv2rgb_u2g_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > - c->yuv2rgb_v2g_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > - c->yuv2rgb_u2b_coeff / ((precision) == 16 ? 1 << 7 : 1), > > > > \ > > > > - }; > > > > \ > > > > + const int16_t yuv2rgb_table[] = { YUV_TO_RGB_TABLE(precision) }; > > > > \ > > > > > > > > \ > > > > ff_##ifmt##_to_##ofmt##_neon_##precision(c->srcW, srcSliceH, > > > > \ > > > > dst[0] + srcSliceY * > > > > dstStride[0], > > > > dstStride[0], \ > > > > @@ -139,6 +178,7 @@ static void get_unscaled_swscale_neon(SwsContext > > > > *c) { > > > > > > > > SET_FF_NVX_TO_ALL_RGBX_FUNC(nv12, NV12, accurate_rnd); > > > > SET_FF_NVX_TO_ALL_RGBX_FUNC(nv21, NV21, accurate_rnd); > > > > + SET_FF_NVX_TO_ALL_RGBX_FUNC(yuv420p, YUV420P, accurate_rnd); > > > > } > > > > > > > > void ff_get_unscaled_swscale_arm(SwsContext *c) > > > > diff --git a/libswscale/arm/yuv2rgb_neon.S > > > > b/libswscale/arm/yuv2rgb_neon.S > > > > index 9f9dd2a..dd00246 100644 > > > > --- a/libswscale/arm/yuv2rgb_neon.S > > > > +++ b/libswscale/arm/yuv2rgb_neon.S > > > > @@ -103,7 +103,8 @@ > > > > vmovl.u8 q15, \y1 > > > > @ > > > > 8px of y > > > > > > > > vdup.16 q5, r9 > > > > @ > > > > q5 = y_offset > > > > - vdup.16 q7, r10 > > > > @ > > > > q7 = y_coeff > > > > + vmov d14, d0 > > > > @ > > > > q7 = y_coeff > > > > + vmov d15, d0 > > > > @ > > > > q7 = y_coeff > > > > > > > > vsub.s16 q14, q5 > > > > vsub.s16 q15, q5 > > > > @@ -184,7 +185,7 @@ > > > > compute_8px_32 r11, d30, \ofmt > > > > .endm > > > > > > > > -.macro load_args > > > > +.macro load_args_nvx > > > > push {r4-r12, lr} > > > > vpush {q4-q7} > > > > ldr r4, [sp, #104] > > > > @ > > > > r4 = srcY > > > > @@ -206,9 +207,42 @@ > > > > sub r7, r7, r0 > > > > @ > > > > r7 = linesizeC - width (paddingC) > > > > .endm > > > > > > > > +.macro load_args_yuv420p > > > > + push {r4-r12, lr} > > > > + vpush {q4-q7} > > > > + ldr r4, [sp, #104] > > > > @ > > > > r4 = srcY > > > > + ldr r5, [sp, #108] > > > > @ > > > > r5 = linesizeY > > > > + ldr r6, [sp, #112] > > > > @ > > > > r6 = srcU > > > > + ldr r8, [sp, #128] > > > > @ > > > > r8 = table > > > > + ldr r9, [sp, #132] > > > > @ > > > > r9 = y_offset > > > > + ldr r10,[sp, #136] > > > > @ > > > > r10 = y_coeff > > > > + vdup.16 d0, r10 > > > > @ > > > > d0 = y_coeff > > > > + vld1.16 {d1}, [r8] > > > > @ > > > > d1 = *table > > > > + add r11, r2, r3 > > > > @ > > > > r11 = dst + linesize (dst2) > > > > + add r12, r4, r5 > > > > @ > > > > r12 = srcY + linesizeY (srcY2) > > > > + lsl r3, r3, #1 > > > > + lsl r5, r5, #1 > > > > + lsl r8, r0, #2 > > > > + sub r3, r3, r8 > > > > @ > > > > r3 = linesize * 2 - width * 4 (padding) > > > > + sub r5, r5, r0 > > > > @ > > > > r5 = linesizeY * 2 - width (paddingY) > > > > + ldr r10,[sp, #120] > > > > @ > > > > r10 = srcV > > > > +.endm > > > > + > > > > .macro declare_func ifmt ofmt precision > > > > function ff_\ifmt\()_to_\ofmt\()_neon_\precision\(), export=1 > > > > - load_args > > > > + > > > > +.ifc \ifmt,nv12 > > > > + load_args_nvx > > > > +.endif > > > > + > > > > +.ifc \ifmt,nv21 > > > > + load_args_nvx > > > > +.endif > > > > + > > > > +.ifc \ifmt,yuv420p > > > > + load_args_yuv420p > > > > +.endif > > > > + > > > > 1: > > > > mov r8, r0 > > > > @ > > > > r8 = width > > > > 2: > > > > @@ -216,16 +250,30 @@ function > > > > ff_\ifmt\()_to_\ofmt\()_neon_\precision\(), > > > > export=1 > > > > pld [r4, #64*3] > > > > pld [r12, #64*3] > > > > > > > > - vld2.8 {d2, d3}, [r6]! > > > > @ > > > > q1: interleaved chroma line > > > > vmov.i8 d10, #128 > > > > + > > > > .ifc \ifmt,nv12 > > > > + vld2.8 {d2, d3}, [r6]! > > > > @ > > > > q1: interleaved chroma line > > > > vsubl.u8 q14, d2, d10 > > > > @ > > > > q14 = U - 128 > > > > vsubl.u8 q15, d3, d10 > > > > @ > > > > q15 = V - 128 > > > > -.else > > > > +.endif > > > > + > > > > +.ifc \ifmt,nv21 > > > > + vld2.8 {d2, d3}, [r6]! > > > > @ > > > > q1: interleaved chroma line > > > > vsubl.u8 q14, d3, d10 > > > > @ > > > > q14 = U - 128 > > > > vsubl.u8 q15, d2, d10 > > > > @ > > > > q15 = V - 128 > > > > .endif > > > > > > > > +.ifc \ifmt,yuv420p > > > > + pld [r10, #64*3] > > > > + > > > > + vld1.8 d2, [r6]! > > > > @ > > > > d2: chroma red line > > > > + vld1.8 d3, [r10]! > > > > @ > > > > d3: chroma blue line > > > > + vsubl.u8 q14, d2, d10 > > > > @ > > > > q14 = U - 128 > > > > + vsubl.u8 q15, d3, d10 > > > > @ > > > > q15 = V - 128 > > > > +.endif > > > > + > > > > + > > > > process_16px_\precision \ofmt > > > > > > > > subs r8, r8, #16 > > > > @ > > > > width -= 16 > > > > @@ -235,7 +283,24 @@ function > > > > ff_\ifmt\()_to_\ofmt\()_neon_\precision\(), > > > > export=1 > > > > add r4, r4, r5 > > > > @ > > > > srcY += paddingY > > > > add r11, r11, r3 > > > > @ > > > > dst2 += padding > > > > add r12, r12, r5 > > > > @ > > > > srcY2 += paddingY > > > > + > > > > +.ifc \ifmt,nv12 > > > > add r6, r6, r7 > > > > @ > > > > srcC += paddingC > > > > +.endif > > > > + > > > > +.ifc \ifmt,nv21 > > > > + add r6, r6, r7 > > > > @ > > > > srcC += paddingC > > > > +.endif > > > > + > > > > +.ifc \ifmt,yuv420p > > > > + ldr r7, [sp, #116] > > > > @ > > > > r7 = linesizeU > > > > + sub r7, r7, r0, lsr #1 > > > > @ > > > > r7 = linesizeU - width / 2 (paddingU) > > > > + add r6, r6, r7 > > > > @ > > > > srcU += paddingU > > > > + > > > > + ldr r7, [sp, #124] > > > > @ > > > > r7 = linesizeV > > > > + sub r7, r7, r0, lsr #1 > > > > @ > > > > r7 = linesizeV - width / 2 (paddingV) > > > > + add r10, r10, r7 > > > > @ > > > > srcU += paddingV > > > > +.endif > > > > > > > > subs r1, r1, #2 > > > > @ > > > > height -= 2 > > > > bgt 1b > > > > @@ -257,3 +322,5 @@ declare_rgb_funcs nv12, 16 > > > > declare_rgb_funcs nv21, 16 > > > > declare_rgb_funcs nv12, 32 > > > > declare_rgb_funcs nv21, 32 > > > > +declare_rgb_funcs yuv420p, 16 > > > > +declare_rgb_funcs yuv420p, 32 > > > > -- > > > > 2.6.4 > > > > > > > > > > > New patch attached, fixing a slicing issue (see > > > 91b4afd58d7858bfbee10d3e115418f3a9543720). > > > > > swscale_unscaled.c | 52 +++++++++++++++++++++++++++++++---- > > > yuv2rgb_neon.S | 77 > > > +++++++++++++++++++++++++++++++++++++++++++++++++---- > > > 2 files changed, 118 insertions(+), 11 deletions(-) > > > 504b6279baa900aa776b016f3cca37105cc2a802 > > > 0001-swscale-arm-yuv2rgb-add-ff_yuv420p_to_-argb-rgba-abg.patch > > > From e8d58b232f88c3dc409b2ba088aba845569497b5 Mon Sep 17 00:00:00 2001 > > > From: Matthieu Bouron <matthieu.bou...@stupeflix.com> > > > Date: Tue, 15 Dec 2015 14:42:22 +0100 > > > Subject: [PATCH] swscale/arm/yuv2rgb: add > > > ff_yuv420p_to_{argb,rgba,abgr,bgra}_neon_{16,32} > > > > > > --- > > > libswscale/arm/swscale_unscaled.c | 52 +++++++++++++++++++++++--- > > > libswscale/arm/yuv2rgb_neon.S | 77 > > > ++++++++++++++++++++++++++++++++++++--- > > > 2 files changed, 118 insertions(+), 11 deletions(-) > > > > seems this doesnt apply cleanly > > It should apply cleanly (I just tried locally) on top of > [PATCH 1/2] swscale/arm/yuv2rgb: disable neon if accurate_rnd is enabled
hmm, seems not working here, do you have a public git tree with this applied ? Applying: swscale/arm/yuv2rgb: add ff_yuv420p_to_{argb,rgba,abgr,bgra}_neon_{16,32} Using index info to reconstruct a base tree... Falling back to patching base and 3-way merge... Auto-merging libswscale/arm/yuv2rgb_neon.S CONFLICT (content): Merge conflict in libswscale/arm/yuv2rgb_neon.S Failed to merge in the changes. Patch failed at 0001 swscale/arm/yuv2rgb: add ff_yuv420p_to_{argb,rgba,abgr,bgra}_neon_{16,32} When you have resolved this problem run "git am --resolved". If you would prefer to skip this patch, instead run "git am --skip". To restore the original branch and stop patching run "git am --abort". git show commit c821c82b601f6d50b504e5195fee1b0a1294b526 Author: Matthieu Bouron <matthieu.bou...@stupeflix.com> Date: Fri Dec 18 15:59:45 2015 +0100 swscale/arm/yuv2rgb: disable neon if accurate_rnd is enabled This disables the 32bit precision neon code path in favor of the default C one and avoids breaking fate if accurate_rnd is enabled. Signed-off-by: Michael Niedermayer <mich...@niedermayer.cc> [...] -- Michael GnuPG fingerprint: 9FF2128B147EF6730BADF133611EC787040B0FAB If a bugfix only changes things apparently unrelated to the bug with no further explanation, that is a good sign that the bugfix is wrong.
signature.asc
Description: Digital signature
_______________________________________________ ffmpeg-devel mailing list ffmpeg-devel@ffmpeg.org http://ffmpeg.org/mailman/listinfo/ffmpeg-devel