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
a3e9bb5d
Commit
a3e9bb5d
authored
Jun 03, 2011
by
Ronald S. Bultje
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
swscale: remove indirections in ppc/swscale_template.c.
parent
0e5d31b1
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
24 additions
and
72 deletions
+24
-72
swscale_altivec_template.c
libswscale/ppc/swscale_altivec_template.c
+21
-4
swscale_template.c
libswscale/ppc/swscale_template.c
+0
-66
yuv2rgb_altivec.c
libswscale/ppc/yuv2rgb_altivec.c
+2
-1
swscale.c
libswscale/swscale.c
+1
-1
No files found.
libswscale/ppc/swscale_altivec_template.c
View file @
a3e9bb5d
...
...
@@ -85,12 +85,15 @@ altivec_packIntArrayToCharArray(int *val, uint8_t* dest, int dstW)
}
}
static
inline
void
yuv2yuvX_altivec_real
(
const
int16_t
*
lumFilter
,
const
int16_t
**
lumSrc
,
static
void
yuv2yuvX_altivec_real
(
SwsContext
*
c
,
const
int16_t
*
lumFilter
,
const
int16_t
**
lumSrc
,
int
lumFilterSize
,
const
int16_t
*
chrFilter
,
const
int16_t
**
chrUSrc
,
const
int16_t
**
chrVSrc
,
int
chrFilterSize
,
uint8_t
*
dest
,
uint8_t
*
uDest
,
uint8_t
*
vDest
,
int
dstW
,
int
chrDstW
)
int
chrFilterSize
,
const
int16_t
**
alpSrc
,
uint8_t
*
dest
,
uint8_t
*
uDest
,
uint8_t
*
vDest
,
uint8_t
*
aDest
,
int
dstW
,
int
chrDstW
)
{
const
vector
signed
int
vini
=
{(
1
<<
18
),
(
1
<<
18
),
(
1
<<
18
),
(
1
<<
18
)};
register
int
i
,
j
;
...
...
@@ -390,3 +393,17 @@ static inline void hScale_altivec_real(int16_t *dst, int dstW,
}
}
}
static
void
RENAME
(
sws_init_swScale
)(
SwsContext
*
c
)
{
c
->
yuv2yuvX
=
yuv2yuvX_altivec_real
;
/* The following list of supported dstFormat values should
* match what's found in the body of ff_yuv2packedX_altivec() */
if
(
!
(
c
->
flags
&
SWS_BITEXACT
)
&&
!
c
->
alpPixBuf
&&
(
c
->
dstFormat
==
PIX_FMT_ABGR
||
c
->
dstFormat
==
PIX_FMT_BGRA
||
c
->
dstFormat
==
PIX_FMT_BGR24
||
c
->
dstFormat
==
PIX_FMT_RGB24
||
c
->
dstFormat
==
PIX_FMT_RGBA
||
c
->
dstFormat
==
PIX_FMT_ARGB
))
{
c
->
yuv2packedX
=
ff_yuv2packedX_altivec
;
}
}
libswscale/ppc/swscale_template.c
deleted
100644 → 0
View file @
0e5d31b1
/*
* Copyright (C) 2001-2003 Michael Niedermayer <michaelni@gmx.at>
*
* This file is part of Libav.
*
* Libav 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.
*
* Libav 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 Libav; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "swscale_altivec_template.c"
static
inline
void
RENAME
(
yuv2yuvX
)(
SwsContext
*
c
,
const
int16_t
*
lumFilter
,
const
int16_t
**
lumSrc
,
int
lumFilterSize
,
const
int16_t
*
chrFilter
,
const
int16_t
**
chrUSrc
,
const
int16_t
**
chrVSrc
,
int
chrFilterSize
,
const
int16_t
**
alpSrc
,
uint8_t
*
dest
,
uint8_t
*
uDest
,
uint8_t
*
vDest
,
uint8_t
*
aDest
,
int
dstW
,
int
chrDstW
)
{
yuv2yuvX_altivec_real
(
lumFilter
,
lumSrc
,
lumFilterSize
,
chrFilter
,
chrUSrc
,
chrVSrc
,
chrFilterSize
,
dest
,
uDest
,
vDest
,
dstW
,
chrDstW
);
}
/**
* vertical scale YV12 to RGB
*/
static
inline
void
RENAME
(
yuv2packedX
)(
SwsContext
*
c
,
const
int16_t
*
lumFilter
,
const
int16_t
**
lumSrc
,
int
lumFilterSize
,
const
int16_t
*
chrFilter
,
const
int16_t
**
chrUSrc
,
const
int16_t
**
chrVSrc
,
int
chrFilterSize
,
const
int16_t
**
alpSrc
,
uint8_t
*
dest
,
int
dstW
,
int
dstY
)
{
/* The following list of supported dstFormat values should
match what's found in the body of ff_yuv2packedX_altivec() */
if
(
!
(
c
->
flags
&
SWS_BITEXACT
)
&&
!
c
->
alpPixBuf
&&
(
c
->
dstFormat
==
PIX_FMT_ABGR
||
c
->
dstFormat
==
PIX_FMT_BGRA
||
c
->
dstFormat
==
PIX_FMT_BGR24
||
c
->
dstFormat
==
PIX_FMT_RGB24
||
c
->
dstFormat
==
PIX_FMT_RGBA
||
c
->
dstFormat
==
PIX_FMT_ARGB
))
ff_yuv2packedX_altivec
(
c
,
lumFilter
,
lumSrc
,
lumFilterSize
,
chrFilter
,
chrUSrc
,
chrVSrc
,
chrFilterSize
,
dest
,
dstW
,
dstY
);
else
yuv2packedXinC
(
c
,
lumFilter
,
lumSrc
,
lumFilterSize
,
chrFilter
,
chrUSrc
,
chrVSrc
,
chrFilterSize
,
alpSrc
,
dest
,
dstW
,
dstY
);
}
static
void
RENAME
(
sws_init_swScale
)(
SwsContext
*
c
)
{
c
->
yuv2yuvX
=
RENAME
(
yuv2yuvX
);
c
->
yuv2packedX
=
RENAME
(
yuv2packedX
);
}
libswscale/ppc/yuv2rgb_altivec.c
View file @
a3e9bb5d
...
...
@@ -630,7 +630,8 @@ ff_yuv2packedX_altivec(SwsContext *c, const int16_t *lumFilter,
const
int16_t
**
lumSrc
,
int
lumFilterSize
,
const
int16_t
*
chrFilter
,
const
int16_t
**
chrUSrc
,
const
int16_t
**
chrVSrc
,
int
chrFilterSize
,
uint8_t
*
dest
,
int
dstW
,
int
dstY
)
const
int16_t
**
alpSrc
,
uint8_t
*
dest
,
int
dstW
,
int
dstY
)
{
int
i
,
j
;
vector
signed
short
X
,
X0
,
X1
,
Y0
,
U0
,
V0
,
Y1
,
U1
,
V1
,
U
,
V
;
...
...
libswscale/swscale.c
View file @
a3e9bb5d
...
...
@@ -1192,7 +1192,7 @@ static inline void monoblack2Y(uint8_t *dst, const uint8_t *src, int width, uint
#if HAVE_ALTIVEC
#undef RENAME
#define RENAME(a) a ## _altivec
#include "ppc/swscale_template.c"
#include "ppc/swscale_
altivec_
template.c"
#endif
//MMX versions
...
...
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