* commit '0c03cc68386443f1e96ab6fb358220faf67cd5ff': mp3: exit on parsing error in mp_decode_frame rtmppkt: Avoid unescaped backslash in Doxygen comment fate-lavfi: replace sed/grep/cut combos with awk build: Plan 9 support Conflicts: configure tests/lavfi-regression.sh Merged-by: Michael Niedermayer <michaelni@gmx.at>tags/n1.1
| @@ -0,0 +1,10 @@ | |||||
| #!/bin/sh | |||||
| n=10 | |||||
| case "$1" in | |||||
| -n) n=$2; shift 2 ;; | |||||
| -n*) n=${1#-n}; shift ;; | |||||
| esac | |||||
| exec sed ${n}q "$@" | |||||
| @@ -0,0 +1,34 @@ | |||||
| /* | |||||
| * This file is part of FFmpeg. | |||||
| * | |||||
| * FFmpeg 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. | |||||
| * | |||||
| * FFmpeg 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 FFmpeg; if not, write to the Free Software | |||||
| * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | |||||
| */ | |||||
| int plan9_main(int argc, char **argv); | |||||
| #undef main | |||||
| int main(int argc, char **argv) | |||||
| { | |||||
| /* The setfcr() function in lib9 is broken, must use asm. */ | |||||
| #ifdef __i386 | |||||
| short fcr; | |||||
| __asm__ volatile ("fstcw %0 \n" | |||||
| "or $63, %0 \n" | |||||
| "fldcw %0 \n" | |||||
| : "=m"(fcr)); | |||||
| #endif | |||||
| return plan9_main(argc, argv); | |||||
| } | |||||
| @@ -0,0 +1,2 @@ | |||||
| #!/bin/sh | |||||
| exec awk "BEGIN { for (i = 2; i < ARGC; i++) printf \"$1\", ARGV[i] }" "$@" | |||||
| @@ -1071,7 +1071,7 @@ apply(){ | |||||
| cp_if_changed(){ | cp_if_changed(){ | ||||
| cmp -s "$1" "$2" && echo "$2 is unchanged" && return | cmp -s "$1" "$2" && echo "$2 is unchanged" && return | ||||
| mkdir -p "$(dirname $2)" | mkdir -p "$(dirname $2)" | ||||
| cp -f "$1" "$2" | |||||
| $cp_f "$1" "$2" | |||||
| } | } | ||||
| # CONFIG_LIST contains configurable options, while HAVE_LIST is for | # CONFIG_LIST contains configurable options, while HAVE_LIST is for | ||||
| @@ -2010,6 +2010,7 @@ ar_default="ar" | |||||
| cc_default="gcc" | cc_default="gcc" | ||||
| cxx_default="g++" | cxx_default="g++" | ||||
| host_cc_default="gcc" | host_cc_default="gcc" | ||||
| cp_f="cp -f" | |||||
| install="install" | install="install" | ||||
| ln_s="ln -sf" | ln_s="ln -sf" | ||||
| nm_default="nm -g" | nm_default="nm -g" | ||||
| @@ -3202,6 +3203,19 @@ case $target_os in | |||||
| ;; | ;; | ||||
| minix) | minix) | ||||
| ;; | ;; | ||||
| plan9) | |||||
| add_cppflags -D_C99_SNPRINTF_EXTENSION \ | |||||
| -D_REENTRANT_SOURCE \ | |||||
| -D_RESEARCH_SOURCE \ | |||||
| -DFD_SETSIZE=96 \ | |||||
| -DHAVE_SOCK_OPTS | |||||
| add_compat strtod.o strtod=avpriv_strtod | |||||
| network_extralibs='-lbsd' | |||||
| exeobjs=compat/plan9/main.o | |||||
| disable ffserver | |||||
| ln_s='ln -s -f' | |||||
| cp_f='cp' | |||||
| ;; | |||||
| none) | none) | ||||
| ;; | ;; | ||||
| *) | *) | ||||
| @@ -3955,6 +3969,12 @@ elif enabled msvc; then | |||||
| enabled x86_32 && disable aligned_stack | enabled x86_32 && disable aligned_stack | ||||
| fi | fi | ||||
| case $target_os in | |||||
| plan9) | |||||
| add_cppflags -Dmain=plan9_main | |||||
| ;; | |||||
| esac | |||||
| enabled_any $THREADS_LIST && enable threads | enabled_any $THREADS_LIST && enable threads | ||||
| enabled asm || { arch=c; disable $ARCH_LIST $ARCH_EXT_LIST; } | enabled asm || { arch=c; disable $ARCH_LIST $ARCH_EXT_LIST; } | ||||
| @@ -304,4 +304,67 @@ and for a build with shared libraries | |||||
| ./configure --target-os=mingw32 --enable-shared --disable-static --extra-cflags=-mno-cygwin --extra-libs=-mno-cygwin | ./configure --target-os=mingw32 --enable-shared --disable-static --extra-cflags=-mno-cygwin --extra-libs=-mno-cygwin | ||||
| @end example | @end example | ||||
| @chapter Plan 9 | |||||
| The native @uref{http://plan9.bell-labs.com/plan9/, Plan 9} compiler | |||||
| does not implement all the C99 features needed by FFmpeg so the gcc | |||||
| port must be used. Furthermore, a few items missing from the C | |||||
| library and shell environment need to be fixed. | |||||
| @itemize | |||||
| @item GNU awk, grep, make, and sed | |||||
| Working packages of these tools can be found at | |||||
| @uref{http://code.google.com/p/ports2plan9/downloads/list, ports2plan9}. | |||||
| They can be installed with @uref{http://9front.org/, 9front's} @code{pkg} | |||||
| utility by setting @code{pkgpath} to | |||||
| @code{http://ports2plan9.googlecode.com/files/}. | |||||
| @item Missing/broken @code{head} and @code{printf} commands | |||||
| Replacements adequate for building FFmpeg can be found in the | |||||
| @code{compat/plan9} directory. Place these somewhere they will be | |||||
| found by the shell. These are not full implementations of the | |||||
| commands and are @emph{not} suitable for general use. | |||||
| @item Missing C99 @code{stdint.h} and @code{inttypes.h} | |||||
| Replacement headers are available from | |||||
| @url{http://code.google.com/p/plan9front/issues/detail?id=152}. | |||||
| @item Missing or non-standard library functions | |||||
| Some functions in the C library are missing or incomplete. The | |||||
| @code{@uref{http://ports2plan9.googlecode.com/files/gcc-apelibs-1207.tbz, | |||||
| gcc-apelibs-1207}} package from | |||||
| @uref{http://code.google.com/p/ports2plan9/downloads/list, ports2plan9} | |||||
| includes an updated C library, but installing the full package gives | |||||
| unusable executables. Instead, keep the files from @code{gccbin.tgz} | |||||
| under @code{/386/lib/gnu}. From the @code{libc.a} archive in the | |||||
| @code{gcc-apelibs-1207} package, extract the following object files and | |||||
| turn them into a library: | |||||
| @itemize | |||||
| @item @code{strerror.o} | |||||
| @item @code{strtoll.o} | |||||
| @item @code{snprintf.o} | |||||
| @item @code{vsnprintf.o} | |||||
| @item @code{vfprintf.o} | |||||
| @item @code{_IO_getc.o} | |||||
| @item @code{_IO_putc.o} | |||||
| @end itemize | |||||
| Use the @code{--extra-libs} option of @code{configure} to inform the | |||||
| build system of this library. | |||||
| @item FPU exceptions enabled by default | |||||
| Unlike most other systems, Plan 9 enables FPU exceptions by default. | |||||
| These must be disabled before calling any FFmpeg functions. While the | |||||
| included tools will do this automatically, other users of the | |||||
| libraries must do it themselves. | |||||
| @end itemize | |||||
| @bye | @bye | ||||
| @@ -67,7 +67,7 @@ static inline int is_dos_path(const char *path) | |||||
| return 0; | return 0; | ||||
| } | } | ||||
| #if defined(__OS2__) | |||||
| #if defined(__OS2__) || defined(__Plan9__) | |||||
| #define SHUT_RD 0 | #define SHUT_RD 0 | ||||
| #define SHUT_WR 1 | #define SHUT_WR 1 | ||||
| #define SHUT_RDWR 2 | #define SHUT_RDWR 2 | ||||
| @@ -253,7 +253,7 @@ int ff_amf_read_number(GetByteContext *gbc, double *val); | |||||
| /** | /** | ||||
| * Read AMF string value. | * Read AMF string value. | ||||
| * | * | ||||
| * Appends a trailing \0 to output string in order to | |||||
| * Appends a trailing null byte to output string in order to | |||||
| * ease later parsing. | * ease later parsing. | ||||
| * | * | ||||
| *@param[in,out] gbc GetByteContext initialized with AMF-formatted data | *@param[in,out] gbc GetByteContext initialized with AMF-formatted data | ||||