Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in / Register
Toggle navigation
F
ffmpeg.wasm-core
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Linshizhi
ffmpeg.wasm-core
Commits
4d31f420
Commit
4d31f420
authored
Oct 23, 2011
by
Michael Niedermayer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
sws: port to thw new 1 plane API and add back yuv2yuv1_ar().
Signed-off-by:
Michael Niedermayer
<
michaelni@gmx.at
>
parent
f1535972
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
49 deletions
+24
-49
swscale_template.c
libswscale/x86/swscale_template.c
+24
-49
No files found.
libswscale/x86/swscale_template.c
View file @
4d31f420
...
@@ -40,7 +40,7 @@
...
@@ -40,7 +40,7 @@
#if !COMPILE_TEMPLATE_MMX2
#if !COMPILE_TEMPLATE_MMX2
static
av_always_inline
void
static
av_always_inline
void
dither_8to16
(
SwsContext
*
c
,
const
uint8_t
*
srcDither
,
int
rot
)
dither_8to16
(
const
uint8_t
*
srcDither
,
int
rot
)
{
{
if
(
rot
)
{
if
(
rot
)
{
__asm__
volatile
(
"pxor %%mm0, %%mm0
\n\t
"
__asm__
volatile
(
"pxor %%mm0, %%mm0
\n\t
"
...
@@ -52,11 +52,7 @@ dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
...
@@ -52,11 +52,7 @@ dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
"movq %%mm3, %%mm4
\n\t
"
"movq %%mm3, %%mm4
\n\t
"
"punpcklbw %%mm0, %%mm3
\n\t
"
"punpcklbw %%mm0, %%mm3
\n\t
"
"punpckhbw %%mm0, %%mm4
\n\t
"
"punpckhbw %%mm0, %%mm4
\n\t
"
"psraw $4, %%mm3
\n\t
"
::
"r"
(
srcDither
)
"psraw $4, %%mm4
\n\t
"
"movq %%mm3, "
DITHER16
"+0(%1)
\n\t
"
"movq %%mm4, "
DITHER16
"+8(%1)
\n\t
"
::
"r"
(
srcDither
),
"r"
(
&
c
->
redDither
)
);
);
}
else
{
}
else
{
__asm__
volatile
(
"pxor %%mm0, %%mm0
\n\t
"
__asm__
volatile
(
"pxor %%mm0, %%mm0
\n\t
"
...
@@ -64,11 +60,7 @@ dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
...
@@ -64,11 +60,7 @@ dither_8to16(SwsContext *c, const uint8_t *srcDither, int rot)
"movq %%mm3, %%mm4
\n\t
"
"movq %%mm3, %%mm4
\n\t
"
"punpcklbw %%mm0, %%mm3
\n\t
"
"punpcklbw %%mm0, %%mm3
\n\t
"
"punpckhbw %%mm0, %%mm4
\n\t
"
"punpckhbw %%mm0, %%mm4
\n\t
"
"psraw $4, %%mm3
\n\t
"
::
"r"
(
srcDither
)
"psraw $4, %%mm4
\n\t
"
"movq %%mm3, "
DITHER16
"+0(%1)
\n\t
"
"movq %%mm4, "
DITHER16
"+8(%1)
\n\t
"
::
"r"
(
srcDither
),
"r"
(
&
c
->
redDither
)
);
);
}
}
}
}
...
@@ -108,45 +100,27 @@ static void RENAME(yuv2yuv1)(SwsContext *c, const int16_t *lumSrc,
...
@@ -108,45 +100,27 @@ static void RENAME(yuv2yuv1)(SwsContext *c, const int16_t *lumSrc,
}
}
}
}
static
void
RENAME
(
yuv2yuv1_ar
)(
SwsContext
*
c
,
const
int16_t
*
lumSrc
,
static
void
RENAME
(
yuv2yuv1_ar
)(
const
int16_t
*
src
,
uint8_t
*
dst
,
int
dstW
,
const
uint8_t
*
dither
,
int
offset
)
const
int16_t
*
chrUSrc
,
const
int16_t
*
chrVSrc
,
const
int16_t
*
alpSrc
,
uint8_t
*
dst
[
4
],
int
dstW
,
int
chrDstW
)
{
{
int
p
=
4
;
dither_8to16
(
dither
,
offset
);
const
int16_t
*
src
[
4
]
=
{
__asm__
volatile
(
lumSrc
+
dstW
,
chrUSrc
+
chrDstW
,
"mov %2, %%"
REG_a
"
\n\t
"
chrVSrc
+
chrDstW
,
alpSrc
+
dstW
".p2align 4
\n\t
"
/* FIXME Unroll? */
};
"1:
\n\t
"
x86_reg
counter
[
4
]
=
{
dstW
,
chrDstW
,
chrDstW
,
dstW
};
"movq (%0, %%"
REG_a
", 2), %%mm0
\n\t
"
const
uint8_t
*
lumDither
=
c
->
lumDither8
,
*
chrDither
=
c
->
chrDither8
;
"movq 8(%0, %%"
REG_a
", 2), %%mm1
\n\t
"
"paddsw %%mm3, %%mm0
\n\t
"
while
(
p
--
)
{
"paddsw %%mm4, %%mm1
\n\t
"
if
(
dst
[
p
])
{
"psraw $7, %%mm0
\n\t
"
int
i
;
"psraw $7, %%mm1
\n\t
"
for
(
i
=
0
;
i
<
8
;
i
++
)
c
->
dither16
[
i
]
=
(
p
==
2
||
p
==
3
)
?
lumDither
[
i
]
:
chrDither
[
i
];
"packuswb %%mm1, %%mm0
\n\t
"
__asm__
volatile
(
MOVNTQ
(
%%
mm0
,
(
%
1
,
%%
REGa
))
"mov %2, %%"
REG_a
"
\n\t
"
"add $8, %%"
REG_a
"
\n\t
"
"movq "
DITHER16
"+0(%3), %%mm6
\n\t
"
"jnc 1b
\n\t
"
"movq "
DITHER16
"+8(%3), %%mm7
\n\t
"
::
"r"
(
src
+
dstW
),
"r"
(
dst
+
dstW
),
".p2align 4
\n\t
"
/* FIXME Unroll? */
"g"
((
long
)
-
dstW
)
"1:
\n\t
"
:
"%"
REG_a
"movq (%0, %%"
REG_a
", 2), %%mm0
\n\t
"
);
"movq 8(%0, %%"
REG_a
", 2), %%mm1
\n\t
"
"paddsw %%mm6, %%mm0
\n\t
"
"paddsw %%mm7, %%mm1
\n\t
"
"psraw $7, %%mm0
\n\t
"
"psraw $7, %%mm1
\n\t
"
"packuswb %%mm1, %%mm0
\n\t
"
MOVNTQ
(
%%
mm0
,
(
%
1
,
%%
REGa
))
"add $8, %%"
REG_a
"
\n\t
"
"jnc 1b
\n\t
"
::
"r"
(
src
[
p
]),
"r"
(
dst
[
p
]
+
counter
[
p
]),
"g"
(
-
counter
[
p
]),
"r"
(
&
c
->
redDither
)
:
"%"
REG_a
);
}
}
}
}
#define YSCALEYUV2PACKEDX_UV \
#define YSCALEYUV2PACKEDX_UV \
...
@@ -1898,6 +1872,7 @@ static av_cold void RENAME(sws_init_swScale)(SwsContext *c)
...
@@ -1898,6 +1872,7 @@ static av_cold void RENAME(sws_init_swScale)(SwsContext *c)
if
(
!
is16BPS
(
dstFormat
)
&&
!
is9_OR_10BPS
(
dstFormat
)
&&
dstFormat
!=
PIX_FMT_NV12
if
(
!
is16BPS
(
dstFormat
)
&&
!
is9_OR_10BPS
(
dstFormat
)
&&
dstFormat
!=
PIX_FMT_NV12
&&
dstFormat
!=
PIX_FMT_NV21
&&
!
(
c
->
flags
&
SWS_BITEXACT
))
{
&&
dstFormat
!=
PIX_FMT_NV21
&&
!
(
c
->
flags
&
SWS_BITEXACT
))
{
c
->
yuv2plane1
=
RENAME
(
yuv2yuv1_ar
);
if
(
c
->
flags
&
SWS_ACCURATE_RND
)
{
if
(
c
->
flags
&
SWS_ACCURATE_RND
)
{
//c->yuv2yuv1 = RENAME(yuv2yuv1_ar );
//c->yuv2yuv1 = RENAME(yuv2yuv1_ar );
if
(
!
(
c
->
flags
&
SWS_FULL_CHR_H_INT
))
{
if
(
!
(
c
->
flags
&
SWS_FULL_CHR_H_INT
))
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment