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
167029a7
Commit
167029a7
authored
Aug 30, 2008
by
David Conrad
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use ff_pw_8 in MMX/SSE VP3 IDCT
Originally committed as revision 15053 to
svn://svn.ffmpeg.org/ffmpeg/trunk
parent
21383da8
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
5 additions
and
16 deletions
+5
-16
vp3dsp_mmx.c
libavcodec/i386/vp3dsp_mmx.c
+3
-7
vp3dsp_sse2.c
libavcodec/i386/vp3dsp_sse2.c
+2
-9
No files found.
libavcodec/i386/vp3dsp_mmx.c
View file @
167029a7
...
@@ -24,16 +24,15 @@
...
@@ -24,16 +24,15 @@
*/
*/
#include "libavcodec/dsputil.h"
#include "libavcodec/dsputil.h"
#include "dsputil_mmx.h"
#include "mmx.h"
#include "mmx.h"
#define IdctAdjustBeforeShift 8
/* (12 * 4) 2-byte memory locations ( = 96 bytes total)
/* (12 * 4) 2-byte memory locations ( = 96 bytes total)
* idct_constants[0..15] = Mask table (M(I))
* idct_constants[0..15] = Mask table (M(I))
* idct_constants[16..43] = Cosine table (C(I))
* idct_constants[16..43] = Cosine table (C(I))
* idct_constants[44..47] = 8
* idct_constants[44..47] = 8
*/
*/
static
uint16_t
idct_constants
[(
4
+
7
+
1
)
*
4
];
static
uint16_t
idct_constants
[(
4
+
7
)
*
4
];
static
const
uint16_t
idct_cosine_table
[
7
]
=
{
static
const
uint16_t
idct_cosine_table
[
7
]
=
{
64277
,
60547
,
54491
,
46341
,
36410
,
25080
,
12785
64277
,
60547
,
54491
,
46341
,
36410
,
25080
,
12785
};
};
...
@@ -269,9 +268,6 @@ void ff_vp3_dsp_init_mmx(void)
...
@@ -269,9 +268,6 @@ void ff_vp3_dsp_init_mmx(void)
p
=
idct_constants
+
((
j
+
3
)
<<
2
);
p
=
idct_constants
+
((
j
+
3
)
<<
2
);
p
[
0
]
=
p
[
1
]
=
p
[
2
]
=
p
[
3
]
=
idct_cosine_table
[
j
-
1
];
p
[
0
]
=
p
[
1
]
=
p
[
2
]
=
p
[
3
]
=
idct_cosine_table
[
j
-
1
];
}
while
(
++
j
<=
7
);
}
while
(
++
j
<=
7
);
idct_constants
[
44
]
=
idct_constants
[
45
]
=
idct_constants
[
46
]
=
idct_constants
[
47
]
=
IdctAdjustBeforeShift
;
}
}
void
ff_vp3_idct_mmx
(
int16_t
*
output_data
)
void
ff_vp3_idct_mmx
(
int16_t
*
output_data
)
...
@@ -286,7 +282,7 @@ void ff_vp3_idct_mmx(int16_t *output_data)
...
@@ -286,7 +282,7 @@ void ff_vp3_idct_mmx(int16_t *output_data)
*/
*/
#define C(x) (idct_constants + 16 + (x - 1) * 4)
#define C(x) (idct_constants + 16 + (x - 1) * 4)
#define Eight (
idct_constants + 44
)
#define Eight (
&ff_pw_8
)
/* at this point, function has completed dequantization + dezigzag +
/* at this point, function has completed dequantization + dezigzag +
* partial transposition; now do the idct itself */
* partial transposition; now do the idct itself */
...
...
libavcodec/i386/vp3dsp_sse2.c
View file @
167029a7
...
@@ -24,6 +24,7 @@
...
@@ -24,6 +24,7 @@
*/
*/
#include "libavcodec/dsputil.h"
#include "libavcodec/dsputil.h"
#include "dsputil_mmx.h"
#include "mmx.h"
#include "mmx.h"
static
DECLARE_ALIGNED_16
(
const
unsigned
short
,
SSE2_dequant_const
[])
=
static
DECLARE_ALIGNED_16
(
const
unsigned
short
,
SSE2_dequant_const
[])
=
...
@@ -37,14 +38,6 @@ static DECLARE_ALIGNED_16(const unsigned short, SSE2_dequant_const[]) =
...
@@ -37,14 +38,6 @@ static DECLARE_ALIGNED_16(const unsigned short, SSE2_dequant_const[]) =
0
,
0
,
65535
,
65535
,
0
,
0
,
0
,
0
// 0x0000 0000 0000 0000 FFFF FFFF 0000 0000
0
,
0
,
65535
,
65535
,
0
,
0
,
0
,
0
// 0x0000 0000 0000 0000 FFFF FFFF 0000 0000
};
};
static
DECLARE_ALIGNED_16
(
const
unsigned
int
,
eight_data
[])
=
{
0x00080008
,
0x00080008
,
0x00080008
,
0x00080008
};
static
DECLARE_ALIGNED_16
(
const
unsigned
short
,
SSE2_idct_data
[
7
*
8
])
=
static
DECLARE_ALIGNED_16
(
const
unsigned
short
,
SSE2_idct_data
[
7
*
8
])
=
{
{
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
64277
,
...
@@ -803,7 +796,7 @@ void ff_vp3_idct_sse2(int16_t *input_data)
...
@@ -803,7 +796,7 @@ void ff_vp3_idct_sse2(int16_t *input_data)
unsigned
char
*
input_bytes
=
(
unsigned
char
*
)
input_data
;
unsigned
char
*
input_bytes
=
(
unsigned
char
*
)
input_data
;
unsigned
char
*
output_data_bytes
=
(
unsigned
char
*
)
input_data
;
unsigned
char
*
output_data_bytes
=
(
unsigned
char
*
)
input_data
;
const
unsigned
char
*
idct_data_bytes
=
(
const
unsigned
char
*
)
SSE2_idct_data
;
const
unsigned
char
*
idct_data_bytes
=
(
const
unsigned
char
*
)
SSE2_idct_data
;
const
unsigned
char
*
Eight
=
(
const
unsigned
char
*
)
eight_data
;
const
unsigned
char
*
Eight
=
(
const
unsigned
char
*
)
&
ff_pw_8
;
#define eax input_bytes
#define eax input_bytes
//#define ebx dequant_matrix_bytes
//#define ebx dequant_matrix_bytes
...
...
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