FFmpeg
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
Examples
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
tests
checkasm
g722dsp.c
Go to the documentation of this file.
1
/*
2
* This file is part of FFmpeg.
3
*
4
* FFmpeg is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation; either version 2 of the License, or
7
* (at your option) any later version.
8
*
9
* FFmpeg is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License along
15
* with FFmpeg; if not, write to the Free Software Foundation, Inc.,
16
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
17
*/
18
19
#include <string.h>
20
#include "
checkasm.h
"
21
#include "
libavcodec/g722.h
"
22
#include "
libavcodec/g722dsp.h
"
23
#include "
libavcodec/mathops.h
"
24
25
#define randomize_buffers() \
26
do { \
27
int i; \
28
for (i = 0; i < PREV_SAMPLES_BUF_SIZE; i++) { \
29
src0[i] = src1[i] = sign_extend(rnd(), 16); \
30
} \
31
} while (0)
32
33
static
void
check_qmf
(
void
) {
34
int16_t
src0
[
PREV_SAMPLES_BUF_SIZE
];
35
int16_t
src1
[
PREV_SAMPLES_BUF_SIZE
];
36
const
int16_t *tmp0 =
src0
;
37
const
int16_t *tmp1 =
src1
;
38
int
dst0[2], dst1[2];
39
int
i;
40
41
declare_func
(
void
,
const
int16_t *prev_samples,
int
xout[2]);
42
43
randomize_buffers
();
44
for
(i = 0; i <
PREV_SAMPLES_BUF_SIZE
- 24; i++) {
45
call_ref
(tmp0++, dst0);
46
call_new
(tmp1++, dst1);
47
if
(memcmp(dst0, dst1,
sizeof
(dst0)))
48
fail
();
49
}
50
bench_new
(src1, dst1);
51
}
52
53
void
checkasm_check_g722dsp
(
void
)
54
{
55
G722DSPContext
h
;
56
57
ff_g722dsp_init
(&h);
58
59
if
(
check_func
(h.
apply_qmf
,
"g722_apply_qmf"
))
60
check_qmf
();
61
62
report
(
"apply_qmf"
);
63
}
G722DSPContext
Definition:
g722dsp.h:26
h
h
Definition:
vp9dsp_template.c:2038
G722DSPContext::apply_qmf
void(* apply_qmf)(const int16_t *prev_samples, int xout[2])
Definition:
g722dsp.h:27
g722.h
report
#define report
Definition:
checkasm.h:119
PREV_SAMPLES_BUF_SIZE
#define PREV_SAMPLES_BUF_SIZE
Definition:
g722.h:32
checkasm.h
declare_func
#define declare_func(ret,...)
Definition:
checkasm.h:111
fail
#define fail()
Definition:
checkasm.h:116
mathops.h
g722dsp.h
checkasm_check_g722dsp
void checkasm_check_g722dsp(void)
Definition:
g722dsp.c:53
call_ref
#define call_ref(...)
Definition:
checkasm.h:122
src1
#define src1
Definition:
h264pred.c:139
check_func
#define check_func(func,...)
Definition:
checkasm.h:107
check_qmf
static void check_qmf(void)
Definition:
g722dsp.c:33
src0
#define src0
Definition:
h264pred.c:138
randomize_buffers
#define randomize_buffers()
Definition:
g722dsp.c:25
bench_new
#define bench_new(...)
Definition:
checkasm.h:249
ff_g722dsp_init
av_cold void ff_g722dsp_init(G722DSPContext *c)
Definition:
g722dsp.c:68
call_new
#define call_new(...)
Definition:
checkasm.h:189
Generated on Sun May 13 2018 02:03:46 for FFmpeg by
1.8.6