[FFmpeg-cvslog] Merge commit '47e547b321338c73c21fa623789f1efbd80a297a'

Clément Bœsch git at videolan.org
Mon Apr 17 15:06:55 EEST 2017


ffmpeg | branch: master | Clément Bœsch <u at pkh.me> | Mon Apr 17 14:01:31 2017 +0200| [e22d495538c1de6a13cf8f51e7448d3312365747] | committer: Clément Bœsch

Merge commit '47e547b321338c73c21fa623789f1efbd80a297a'

* commit '47e547b321338c73c21fa623789f1efbd80a297a':
  lavc: add a null bitstream filter

Merged-by: Clément Bœsch <u at pkh.me>

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=e22d495538c1de6a13cf8f51e7448d3312365747
---

 doc/bitstream_filters.texi     |  3 +++
 libavcodec/Makefile            |  1 +
 libavcodec/bitstream_filters.c |  1 +
 libavcodec/null_bsf.c          | 43 ++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 48 insertions(+)

diff --git a/doc/bitstream_filters.texi b/doc/bitstream_filters.texi
index 947c31dae8..6f4846f55f 100644
--- a/doc/bitstream_filters.texi
+++ b/doc/bitstream_filters.texi
@@ -234,6 +234,9 @@ ffmpeg -i INPUT -c copy -bsf noise[=1] output.mkv
 @end example
 applies the modification to every byte.
 
+ at section null
+This bitstream filter passes the packets through unchanged.
+
 @section remove_extra
 
 Remove extradata from packets.
diff --git a/libavcodec/Makefile b/libavcodec/Makefile
index c7454543bb..62f9db5c86 100644
--- a/libavcodec/Makefile
+++ b/libavcodec/Makefile
@@ -993,6 +993,7 @@ OBJS-$(CONFIG_MOV2TEXTSUB_BSF)            += movsub_bsf.o
 OBJS-$(CONFIG_MP3_HEADER_DECOMPRESS_BSF)  += mp3_header_decompress_bsf.o \
                                              mpegaudiodata.o
 OBJS-$(CONFIG_NOISE_BSF)                  += noise_bsf.o
+OBJS-$(CONFIG_NULL_BSF)                   += null_bsf.o
 OBJS-$(CONFIG_REMOVE_EXTRADATA_BSF)       += remove_extradata_bsf.o
 OBJS-$(CONFIG_TEXT2MOVSUB_BSF)            += movsub_bsf.o
 OBJS-$(CONFIG_VP9_SUPERFRAME_BSF)         += vp9_superframe_bsf.o
diff --git a/libavcodec/bitstream_filters.c b/libavcodec/bitstream_filters.c
index 2045e18b94..6893a4b6e4 100644
--- a/libavcodec/bitstream_filters.c
+++ b/libavcodec/bitstream_filters.c
@@ -38,6 +38,7 @@ extern const AVBitStreamFilter ff_mp3_header_decompress_bsf;
 extern const AVBitStreamFilter ff_mpeg4_unpack_bframes_bsf;
 extern const AVBitStreamFilter ff_mov2textsub_bsf;
 extern const AVBitStreamFilter ff_noise_bsf;
+extern const AVBitStreamFilter ff_null_bsf;
 extern const AVBitStreamFilter ff_remove_extradata_bsf;
 extern const AVBitStreamFilter ff_text2movsub_bsf;
 extern const AVBitStreamFilter ff_vp9_superframe_bsf;
diff --git a/libavcodec/null_bsf.c b/libavcodec/null_bsf.c
new file mode 100644
index 0000000000..feb71248a9
--- /dev/null
+++ b/libavcodec/null_bsf.c
@@ -0,0 +1,43 @@
+/*
+ * 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
+ */
+
+/**
+ * @file
+ * Null bitstream filter -- pass the input through unchanged.
+ */
+
+#include "avcodec.h"
+#include "bsf.h"
+
+static int null_filter(AVBSFContext *ctx, AVPacket *out)
+{
+    AVPacket *in;
+    int ret;
+
+    ret = ff_bsf_get_packet(ctx, &in);
+    if (ret < 0)
+        return ret;
+    av_packet_move_ref(out, in);
+    av_packet_free(&in);
+    return 0;
+}
+
+const AVBitStreamFilter ff_null_bsf = {
+    .name           = "null",
+    .filter         = null_filter,
+};


======================================================================

diff --cc doc/bitstream_filters.texi
index 947c31dae8,2e13cbe180..6f4846f55f
--- a/doc/bitstream_filters.texi
+++ b/doc/bitstream_filters.texi
@@@ -220,54 -90,9 +220,57 @@@ ffmpeg -i INPUT.avi -codec copy -bsf:v 
  
  @section noise
  
 +Damages the contents of packets without damaging the container. Can be
 +used for fuzzing or testing error resilience/concealment.
 +
 +Parameters:
 +A numeral string, whose value is related to how often output bytes will
 +be modified. Therefore, values below or equal to 0 are forbidden, and
 +the lower the more frequent bytes will be modified, with 1 meaning
 +every byte is modified.
 +
 + at example
 +ffmpeg -i INPUT -c copy -bsf noise[=1] output.mkv
 + at end example
 +applies the modification to every byte.
 +
+ @section null
+ This bitstream filter passes the packets through unchanged.
+ 
 - at section remove_extradata
 + at section remove_extra
 +
 +Remove extradata from packets.
 +
 +It accepts the following parameter:
 + at table @option
 + at item freq
 +Set which frame types to remove extradata from.
 +
 + at table @samp
 + at item k
 +Remove extradata from non-keyframes only.
 +
 + at item keyframe
 +Remove extradata from keyframes only.
 +
 + at item e, all
 +Remove extradata from all frames.
 +
 + at end table
 + at end table
 +
 + at anchor{text2movsub}
 + at section text2movsub
 +
 +Convert text subtitles to MOV subtitles (as used by the @code{mov_text}
 +codec) with metadata headers.
 +
 +See also the @ref{mov2textsub} filter.
 +
 + at section vp9_superframe
 +
 +Merge VP9 invisible (alt-ref) frames back into VP9 superframes. This
 +fixes merging of split/segmented VP9 streams where the alt-ref frame
 +was split from its visible counterpart.
  
  @c man end BITSTREAM FILTERS
diff --cc libavcodec/Makefile
index c7454543bb,d571d8def3..62f9db5c86
--- a/libavcodec/Makefile
+++ b/libavcodec/Makefile
@@@ -988,14 -762,11 +988,15 @@@ OBJS-$(CONFIG_HEVC_MP4TOANNEXB_BSF
  OBJS-$(CONFIG_IMX_DUMP_HEADER_BSF)        += imx_dump_header_bsf.o
  OBJS-$(CONFIG_MJPEG2JPEG_BSF)             += mjpeg2jpeg_bsf.o
  OBJS-$(CONFIG_MJPEGA_DUMP_HEADER_BSF)     += mjpega_dump_header_bsf.o
 +OBJS-$(CONFIG_MPEG4_UNPACK_BFRAMES_BSF)   += mpeg4_unpack_bframes_bsf.o
  OBJS-$(CONFIG_MOV2TEXTSUB_BSF)            += movsub_bsf.o
 +OBJS-$(CONFIG_MP3_HEADER_DECOMPRESS_BSF)  += mp3_header_decompress_bsf.o \
 +                                             mpegaudiodata.o
  OBJS-$(CONFIG_NOISE_BSF)                  += noise_bsf.o
+ OBJS-$(CONFIG_NULL_BSF)                   += null_bsf.o
  OBJS-$(CONFIG_REMOVE_EXTRADATA_BSF)       += remove_extradata_bsf.o
  OBJS-$(CONFIG_TEXT2MOVSUB_BSF)            += movsub_bsf.o
 +OBJS-$(CONFIG_VP9_SUPERFRAME_BSF)         += vp9_superframe_bsf.o
  
  # thread libraries
  OBJS-$(HAVE_LIBC_MSVCRT)               += file_open.o
diff --cc libavcodec/bitstream_filters.c
index 2045e18b94,ee9e4bade5..6893a4b6e4
--- a/libavcodec/bitstream_filters.c
+++ b/libavcodec/bitstream_filters.c
@@@ -34,13 -33,11 +34,14 @@@ extern const AVBitStreamFilter ff_hevc_
  extern const AVBitStreamFilter ff_imx_dump_header_bsf;
  extern const AVBitStreamFilter ff_mjpeg2jpeg_bsf;
  extern const AVBitStreamFilter ff_mjpega_dump_header_bsf;
 +extern const AVBitStreamFilter ff_mp3_header_decompress_bsf;
 +extern const AVBitStreamFilter ff_mpeg4_unpack_bframes_bsf;
  extern const AVBitStreamFilter ff_mov2textsub_bsf;
 -extern const AVBitStreamFilter ff_null_bsf;
 -extern const AVBitStreamFilter ff_text2movsub_bsf;
  extern const AVBitStreamFilter ff_noise_bsf;
++extern const AVBitStreamFilter ff_null_bsf;
  extern const AVBitStreamFilter ff_remove_extradata_bsf;
 +extern const AVBitStreamFilter ff_text2movsub_bsf;
 +extern const AVBitStreamFilter ff_vp9_superframe_bsf;
  
  #include "libavcodec/bsf_list.c"
  
diff --cc libavcodec/null_bsf.c
index 0000000000,0fe4f3529f..feb71248a9
mode 000000,100644..100644
--- a/libavcodec/null_bsf.c
+++ b/libavcodec/null_bsf.c
@@@ -1,0 -1,43 +1,43 @@@
+ /*
 - * This file is part of Libav.
++ * This file is part of FFmpeg.
+  *
 - * Libav is free software; you can redistribute it and/or
++ * 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.
+  *
 - * Libav is distributed in the hope that it will be useful,
++ * 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 Libav; if not, write to the Free Software
++ * License along with FFmpeg; if not, write to the Free Software
+  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+  */
+ 
+ /**
+  * @file
+  * Null bitstream filter -- pass the input through unchanged.
+  */
+ 
+ #include "avcodec.h"
+ #include "bsf.h"
+ 
+ static int null_filter(AVBSFContext *ctx, AVPacket *out)
+ {
+     AVPacket *in;
+     int ret;
+ 
+     ret = ff_bsf_get_packet(ctx, &in);
+     if (ret < 0)
+         return ret;
+     av_packet_move_ref(out, in);
+     av_packet_free(&in);
+     return 0;
+ }
+ 
+ const AVBitStreamFilter ff_null_bsf = {
+     .name           = "null",
+     .filter         = null_filter,
+ };



More information about the ffmpeg-cvslog mailing list