mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
Merge remote-tracking branch 'newdev/master'
* newdev/master: matroskadec: set default duration for simple block When building for MinGW32 disable strict ANSI compliancy. ARM: fix ff_apply_window_int16_neon() prototype configure: check for --as-needed support early ARM: NEON optimised apply_window_int16() ac3enc: NEON optimised shift functions ac3enc: NEON optimised ac3_max_msb_abs_int16 and ac3_exponent_min mpeg12.c: fix slice threading for mpeg2 field picture mode. ffmetadec.c: fix compiler warnings. configure: Don't explicitly disable ffplay or in/outdevices on dos configure: Remove the explicit disabling of ffserver configure: Add fork as a dependency to ffserver Merged-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
commit
797ef671dd
9
configure
vendored
9
configure
vendored
@ -1488,7 +1488,7 @@ ffmpeg_select="buffer_filter"
|
|||||||
ffplay_deps="avcodec avformat swscale sdl"
|
ffplay_deps="avcodec avformat swscale sdl"
|
||||||
ffplay_select="rdft"
|
ffplay_select="rdft"
|
||||||
ffprobe_deps="avcodec avformat"
|
ffprobe_deps="avcodec avformat"
|
||||||
ffserver_deps="avformat ffm_muxer rtp_protocol rtsp_demuxer"
|
ffserver_deps="avformat ffm_muxer fork rtp_protocol rtsp_demuxer"
|
||||||
ffserver_extralibs='$ldl'
|
ffserver_extralibs='$ldl'
|
||||||
|
|
||||||
doc_deps="texi2html"
|
doc_deps="texi2html"
|
||||||
@ -2427,7 +2427,6 @@ case $target_os in
|
|||||||
LIBTARGET=arm-wince
|
LIBTARGET=arm-wince
|
||||||
fi
|
fi
|
||||||
shlibdir_default="$bindir_default"
|
shlibdir_default="$bindir_default"
|
||||||
disable ffserver
|
|
||||||
SLIBPREF=""
|
SLIBPREF=""
|
||||||
SLIBSUF=".dll"
|
SLIBSUF=".dll"
|
||||||
SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)'
|
SLIBNAME_WITH_VERSION='$(SLIBPREF)$(FULLNAME)-$(LIBVERSION)$(SLIBSUF)'
|
||||||
@ -2446,6 +2445,7 @@ case $target_os in
|
|||||||
check_cpp_condition _mingw.h "defined (__MINGW64_VERSION_MAJOR) || (__MINGW32_MAJOR_VERSION > 3) \
|
check_cpp_condition _mingw.h "defined (__MINGW64_VERSION_MAJOR) || (__MINGW32_MAJOR_VERSION > 3) \
|
||||||
|| (__MINGW32_MAJOR_VERSION == 3 && __MINGW32_MINOR_VERSION >= 15)" ||
|
|| (__MINGW32_MAJOR_VERSION == 3 && __MINGW32_MINOR_VERSION >= 15)" ||
|
||||||
die "ERROR: MinGW runtime version must be >= 3.15."
|
die "ERROR: MinGW runtime version must be >= 3.15."
|
||||||
|
add_cppflags -U__STRICT_ANSI__
|
||||||
;;
|
;;
|
||||||
cygwin*)
|
cygwin*)
|
||||||
target_os=cygwin
|
target_os=cygwin
|
||||||
@ -2460,8 +2460,6 @@ case $target_os in
|
|||||||
check_cflags -fno-common
|
check_cflags -fno-common
|
||||||
;;
|
;;
|
||||||
*-dos|freedos|opendos)
|
*-dos|freedos|opendos)
|
||||||
disable ffplay ffserver
|
|
||||||
disable $INDEV_LIST $OUTDEV_LIST
|
|
||||||
network_extralibs="-lsocket"
|
network_extralibs="-lsocket"
|
||||||
objformat="coff"
|
objformat="coff"
|
||||||
enable dos_paths
|
enable dos_paths
|
||||||
@ -2742,6 +2740,8 @@ if enabled asm; then
|
|||||||
$nogas "GNU assembler not found, install gas-preprocessor"
|
$nogas "GNU assembler not found, install gas-preprocessor"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
check_ldflags -Wl,--as-needed
|
||||||
|
|
||||||
if check_func dlopen; then
|
if check_func dlopen; then
|
||||||
ldl=
|
ldl=
|
||||||
elif check_func dlopen -ldl; then
|
elif check_func dlopen -ldl; then
|
||||||
@ -2976,7 +2976,6 @@ enabled extra_warnings && check_cflags -Winline
|
|||||||
|
|
||||||
# add some linker flags
|
# add some linker flags
|
||||||
check_ldflags -Wl,--warn-common
|
check_ldflags -Wl,--warn-common
|
||||||
check_ldflags -Wl,--as-needed
|
|
||||||
check_ldflags '-Wl,-rpath-link,\$(BUILD_ROOT)/libpostproc -Wl,-rpath-link,\$(BUILD_ROOT)/libswscale -Wl,-rpath-link,\$(BUILD_ROOT)/libavfilter -Wl,-rpath-link,\$(BUILD_ROOT)/libavdevice -Wl,-rpath-link,\$(BUILD_ROOT)/libavformat -Wl,-rpath-link,\$(BUILD_ROOT)/libavcodec -Wl,-rpath-link,\$(BUILD_ROOT)/libavutil'
|
check_ldflags '-Wl,-rpath-link,\$(BUILD_ROOT)/libpostproc -Wl,-rpath-link,\$(BUILD_ROOT)/libswscale -Wl,-rpath-link,\$(BUILD_ROOT)/libavfilter -Wl,-rpath-link,\$(BUILD_ROOT)/libavdevice -Wl,-rpath-link,\$(BUILD_ROOT)/libavformat -Wl,-rpath-link,\$(BUILD_ROOT)/libavcodec -Wl,-rpath-link,\$(BUILD_ROOT)/libavutil'
|
||||||
test_ldflags -Wl,-Bsymbolic && append SHFLAGS -Wl,-Bsymbolic
|
test_ldflags -Wl,-Bsymbolic && append SHFLAGS -Wl,-Bsymbolic
|
||||||
|
|
||||||
|
@ -109,6 +109,8 @@ av_cold void ff_ac3dsp_init(AC3DSPContext *c, int bit_exact)
|
|||||||
c->ac3_rshift_int32 = ac3_rshift_int32_c;
|
c->ac3_rshift_int32 = ac3_rshift_int32_c;
|
||||||
c->float_to_fixed24 = float_to_fixed24_c;
|
c->float_to_fixed24 = float_to_fixed24_c;
|
||||||
|
|
||||||
|
if (ARCH_ARM)
|
||||||
|
ff_ac3dsp_init_arm(c, bit_exact);
|
||||||
if (HAVE_MMX)
|
if (HAVE_MMX)
|
||||||
ff_ac3dsp_init_x86(c, bit_exact);
|
ff_ac3dsp_init_x86(c, bit_exact);
|
||||||
}
|
}
|
||||||
|
@ -84,6 +84,7 @@ typedef struct AC3DSPContext {
|
|||||||
} AC3DSPContext;
|
} AC3DSPContext;
|
||||||
|
|
||||||
void ff_ac3dsp_init (AC3DSPContext *c, int bit_exact);
|
void ff_ac3dsp_init (AC3DSPContext *c, int bit_exact);
|
||||||
|
void ff_ac3dsp_init_arm(AC3DSPContext *c, int bit_exact);
|
||||||
void ff_ac3dsp_init_x86(AC3DSPContext *c, int bit_exact);
|
void ff_ac3dsp_init_x86(AC3DSPContext *c, int bit_exact);
|
||||||
|
|
||||||
#endif /* AVCODEC_AC3DSP_H */
|
#endif /* AVCODEC_AC3DSP_H */
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
OBJS-$(CONFIG_AC3DSP) += arm/ac3dsp_init_arm.o
|
||||||
OBJS-$(CONFIG_DCA_DECODER) += arm/dcadsp_init_arm.o \
|
OBJS-$(CONFIG_DCA_DECODER) += arm/dcadsp_init_arm.o \
|
||||||
|
|
||||||
OBJS-$(CONFIG_VP5_DECODER) += arm/vp56dsp_init_arm.o
|
OBJS-$(CONFIG_VP5_DECODER) += arm/vp56dsp_init_arm.o
|
||||||
@ -46,6 +47,8 @@ NEON-OBJS-$(CONFIG_H264DSP) += arm/h264dsp_neon.o \
|
|||||||
|
|
||||||
NEON-OBJS-$(CONFIG_H264PRED) += arm/h264pred_neon.o \
|
NEON-OBJS-$(CONFIG_H264PRED) += arm/h264pred_neon.o \
|
||||||
|
|
||||||
|
NEON-OBJS-$(CONFIG_AC3DSP) += arm/ac3dsp_neon.o
|
||||||
|
|
||||||
NEON-OBJS-$(CONFIG_DCA_DECODER) += arm/dcadsp_neon.o \
|
NEON-OBJS-$(CONFIG_DCA_DECODER) += arm/dcadsp_neon.o \
|
||||||
arm/synth_filter_neon.o \
|
arm/synth_filter_neon.o \
|
||||||
|
|
||||||
|
39
libavcodec/arm/ac3dsp_init_arm.c
Normal file
39
libavcodec/arm/ac3dsp_init_arm.c
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011 Mans Rullgard <mans@mansr.com>
|
||||||
|
*
|
||||||
|
* 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 <stdint.h>
|
||||||
|
#include "libavutil/attributes.h"
|
||||||
|
#include "libavcodec/ac3dsp.h"
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
void ff_ac3_exponent_min_neon(uint8_t *exp, int num_reuse_blocks, int nb_coefs);
|
||||||
|
int ff_ac3_max_msb_abs_int16_neon(const int16_t *src, int len);
|
||||||
|
void ff_ac3_lshift_int16_neon(int16_t *src, unsigned len, unsigned shift);
|
||||||
|
void ff_ac3_rshift_int32_neon(int32_t *src, unsigned len, unsigned shift);
|
||||||
|
|
||||||
|
av_cold void ff_ac3dsp_init_arm(AC3DSPContext *c, int bit_exact)
|
||||||
|
{
|
||||||
|
if (HAVE_NEON) {
|
||||||
|
c->ac3_exponent_min = ff_ac3_exponent_min_neon;
|
||||||
|
c->ac3_max_msb_abs_int16 = ff_ac3_max_msb_abs_int16_neon;
|
||||||
|
c->ac3_lshift_int16 = ff_ac3_lshift_int16_neon;
|
||||||
|
c->ac3_rshift_int32 = ff_ac3_rshift_int32_neon;
|
||||||
|
}
|
||||||
|
}
|
80
libavcodec/arm/ac3dsp_neon.S
Normal file
80
libavcodec/arm/ac3dsp_neon.S
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011 Mans Rullgard <mans@mansr.com>
|
||||||
|
*
|
||||||
|
* 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 "asm.S"
|
||||||
|
|
||||||
|
function ff_ac3_max_msb_abs_int16_neon, export=1
|
||||||
|
vmov.i16 q0, #0
|
||||||
|
vmov.i16 q2, #0
|
||||||
|
1: vld1.16 {q1}, [r0,:128]!
|
||||||
|
vabs.s16 q1, q1
|
||||||
|
vld1.16 {q3}, [r0,:128]!
|
||||||
|
vabs.s16 q3, q3
|
||||||
|
vorr q0, q0, q1
|
||||||
|
vorr q2, q2, q3
|
||||||
|
subs r1, r1, #16
|
||||||
|
bgt 1b
|
||||||
|
vorr q0, q0, q2
|
||||||
|
vorr d0, d0, d1
|
||||||
|
vpmax.u16 d0, d0, d0
|
||||||
|
vpmax.u16 d0, d0, d0
|
||||||
|
vmov.u16 r0, d0[0]
|
||||||
|
bx lr
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
function ff_ac3_exponent_min_neon, export=1
|
||||||
|
cmp r1, #0
|
||||||
|
bxeq lr
|
||||||
|
push {lr}
|
||||||
|
mov r12, #256
|
||||||
|
1:
|
||||||
|
vld1.8 {q0}, [r0,:128]
|
||||||
|
mov lr, r1
|
||||||
|
add r3, r0, #256
|
||||||
|
2: vld1.8 {q1}, [r3,:128], r12
|
||||||
|
subs lr, lr, #1
|
||||||
|
vmin.u8 q0, q0, q1
|
||||||
|
bgt 2b
|
||||||
|
subs r2, r2, #16
|
||||||
|
vst1.8 {q0}, [r0,:128]!
|
||||||
|
bgt 1b
|
||||||
|
pop {pc}
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
function ff_ac3_lshift_int16_neon, export=1
|
||||||
|
vdup.16 q0, r2
|
||||||
|
1: vld1.16 {q1}, [r0,:128]
|
||||||
|
vshl.s16 q1, q1, q0
|
||||||
|
vst1.16 {q1}, [r0,:128]!
|
||||||
|
subs r1, r1, #8
|
||||||
|
bgt 1b
|
||||||
|
bx lr
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
function ff_ac3_rshift_int32_neon, export=1
|
||||||
|
rsb r2, r2, #0
|
||||||
|
vdup.32 q0, r2
|
||||||
|
1: vld1.32 {q1}, [r0,:128]
|
||||||
|
vshl.s32 q1, q1, q0
|
||||||
|
vst1.32 {q1}, [r0,:128]!
|
||||||
|
subs r1, r1, #4
|
||||||
|
bgt 1b
|
||||||
|
bx lr
|
||||||
|
endfunc
|
@ -168,6 +168,9 @@ int32_t ff_scalarproduct_int16_neon(const int16_t *v1, const int16_t *v2, int le
|
|||||||
int32_t ff_scalarproduct_and_madd_int16_neon(int16_t *v1, const int16_t *v2,
|
int32_t ff_scalarproduct_and_madd_int16_neon(int16_t *v1, const int16_t *v2,
|
||||||
const int16_t *v3, int len, int mul);
|
const int16_t *v3, int len, int mul);
|
||||||
|
|
||||||
|
void ff_apply_window_int16_neon(int16_t *dst, const int16_t *src,
|
||||||
|
const int16_t *window, unsigned n);
|
||||||
|
|
||||||
void ff_dsputil_init_neon(DSPContext *c, AVCodecContext *avctx)
|
void ff_dsputil_init_neon(DSPContext *c, AVCodecContext *avctx)
|
||||||
{
|
{
|
||||||
if (!avctx->lowres) {
|
if (!avctx->lowres) {
|
||||||
@ -319,4 +322,6 @@ void ff_dsputil_init_neon(DSPContext *c, AVCodecContext *avctx)
|
|||||||
|
|
||||||
c->scalarproduct_int16 = ff_scalarproduct_int16_neon;
|
c->scalarproduct_int16 = ff_scalarproduct_int16_neon;
|
||||||
c->scalarproduct_and_madd_int16 = ff_scalarproduct_and_madd_int16_neon;
|
c->scalarproduct_and_madd_int16 = ff_scalarproduct_and_madd_int16_neon;
|
||||||
|
|
||||||
|
c->apply_window_int16 = ff_apply_window_int16_neon;
|
||||||
}
|
}
|
||||||
|
@ -789,3 +789,26 @@ NOVFP ldr r2, [sp]
|
|||||||
vst1.f32 {q9},[r0,:128]!
|
vst1.f32 {q9},[r0,:128]!
|
||||||
bx lr
|
bx lr
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
function ff_apply_window_int16_neon, export=1
|
||||||
|
push {r4,lr}
|
||||||
|
add r4, r1, r3, lsl #1
|
||||||
|
add lr, r0, r3, lsl #1
|
||||||
|
sub r4, r4, #16
|
||||||
|
sub lr, lr, #16
|
||||||
|
mov r12, #-16
|
||||||
|
1:
|
||||||
|
vld1.16 {q0}, [r1,:128]!
|
||||||
|
vld1.16 {q2}, [r2,:128]!
|
||||||
|
vld1.16 {q1}, [r4,:128], r12
|
||||||
|
vrev64.16 q3, q2
|
||||||
|
vqrdmulh.s16 q0, q0, q2
|
||||||
|
vqrdmulh.s16 d2, d2, d7
|
||||||
|
vqrdmulh.s16 d3, d3, d6
|
||||||
|
vst1.16 {q0}, [r0,:128]!
|
||||||
|
vst1.16 {q1}, [lr,:128], r12
|
||||||
|
subs r3, r3, #16
|
||||||
|
bgt 1b
|
||||||
|
|
||||||
|
pop {r4,pc}
|
||||||
|
endfunc
|
||||||
|
@ -1924,7 +1924,9 @@ static int slice_decode_thread(AVCodecContext *c, void *arg){
|
|||||||
|
|
||||||
start_code= -1;
|
start_code= -1;
|
||||||
buf = ff_find_start_code(buf, s->gb.buffer_end, &start_code);
|
buf = ff_find_start_code(buf, s->gb.buffer_end, &start_code);
|
||||||
mb_y= start_code - SLICE_MIN_START_CODE;
|
mb_y= (start_code - SLICE_MIN_START_CODE) << field_pic;
|
||||||
|
if (s->picture_structure == PICT_BOTTOM_FIELD)
|
||||||
|
mb_y++;
|
||||||
if(mb_y < 0 || mb_y >= s->end_mb_y)
|
if(mb_y < 0 || mb_y >= s->end_mb_y)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -2342,6 +2344,16 @@ static int decode_chunks(AVCodecContext *avctx,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case PICTURE_START_CODE:
|
case PICTURE_START_CODE:
|
||||||
|
if (avctx->thread_count > 1 && s->slice_count) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
avctx->execute(avctx, slice_decode_thread,
|
||||||
|
s2->thread_context, NULL,
|
||||||
|
s->slice_count, sizeof(void*));
|
||||||
|
for (i = 0; i < s->slice_count; i++)
|
||||||
|
s2->error_count += s2->thread_context[i]->error_count;
|
||||||
|
s->slice_count = 0;
|
||||||
|
}
|
||||||
if(last_code == 0 || last_code == SLICE_MIN_START_CODE){
|
if(last_code == 0 || last_code == SLICE_MIN_START_CODE){
|
||||||
if(mpeg_decode_postinit(avctx) < 0){
|
if(mpeg_decode_postinit(avctx) < 0){
|
||||||
av_log(avctx, AV_LOG_ERROR, "mpeg_decode_postinit() failure\n");
|
av_log(avctx, AV_LOG_ERROR, "mpeg_decode_postinit() failure\n");
|
||||||
|
@ -61,14 +61,14 @@ static AVChapter *read_chapter(AVFormatContext *s)
|
|||||||
|
|
||||||
if (sscanf(line, "TIMEBASE=%d/%d", &tb.num, &tb.den))
|
if (sscanf(line, "TIMEBASE=%d/%d", &tb.num, &tb.den))
|
||||||
get_line(s->pb, line, sizeof(line));
|
get_line(s->pb, line, sizeof(line));
|
||||||
if (!sscanf(line, "START=%lld", &start)) {
|
if (!sscanf(line, "START=%"SCNd64, &start)) {
|
||||||
av_log(s, AV_LOG_ERROR, "Expected chapter start timestamp, found %s.\n", line);
|
av_log(s, AV_LOG_ERROR, "Expected chapter start timestamp, found %s.\n", line);
|
||||||
start = (s->nb_chapters && s->chapters[s->nb_chapters - 1]->end != AV_NOPTS_VALUE) ?
|
start = (s->nb_chapters && s->chapters[s->nb_chapters - 1]->end != AV_NOPTS_VALUE) ?
|
||||||
s->chapters[s->nb_chapters - 1]->end : 0;
|
s->chapters[s->nb_chapters - 1]->end : 0;
|
||||||
} else
|
} else
|
||||||
get_line(s->pb, line, sizeof(line));
|
get_line(s->pb, line, sizeof(line));
|
||||||
|
|
||||||
if (!sscanf(line, "END=%lld", &end)) {
|
if (!sscanf(line, "END=%"SCNd64, &end)) {
|
||||||
av_log(s, AV_LOG_ERROR, "Expected chapter end timestamp, found %s.\n", line);
|
av_log(s, AV_LOG_ERROR, "Expected chapter end timestamp, found %s.\n", line);
|
||||||
end = AV_NOPTS_VALUE;
|
end = AV_NOPTS_VALUE;
|
||||||
}
|
}
|
||||||
|
@ -1859,6 +1859,8 @@ static int matroska_parse_cluster(MatroskaDemuxContext *matroska)
|
|||||||
for (i=0; i<blocks_list->nb_elem; i++)
|
for (i=0; i<blocks_list->nb_elem; i++)
|
||||||
if (blocks[i].bin.size > 0 && blocks[i].bin.data) {
|
if (blocks[i].bin.size > 0 && blocks[i].bin.data) {
|
||||||
int is_keyframe = blocks[i].non_simple ? !blocks[i].reference : -1;
|
int is_keyframe = blocks[i].non_simple ? !blocks[i].reference : -1;
|
||||||
|
if (!blocks[i].non_simple)
|
||||||
|
blocks[i].duration = AV_NOPTS_VALUE;
|
||||||
res=matroska_parse_block(matroska,
|
res=matroska_parse_block(matroska,
|
||||||
blocks[i].bin.data, blocks[i].bin.size,
|
blocks[i].bin.data, blocks[i].bin.size,
|
||||||
blocks[i].bin.pos, cluster.timecode,
|
blocks[i].bin.pos, cluster.timecode,
|
||||||
|
Loading…
Reference in New Issue
Block a user