summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBradley Sepos <[email protected]>2016-11-25 09:39:51 -0500
committerJohn Stebbins <[email protected]>2016-12-17 07:28:51 -0800
commit66af0167b40262f2aaf55bfe368f4125b7535020 (patch)
treecc05be17da180a88dd9930b598b8e42cf9038888
parentbece9c2677e20649e5ebf9d91cb7b55c8a7759db (diff)
contrib: Add libav colr patch to support new color signaling in mov.
Needed for BT.2020, etc.
-rw-r--r--contrib/ffmpeg/A02-mov-colr.patch57
1 files changed, 57 insertions, 0 deletions
diff --git a/contrib/ffmpeg/A02-mov-colr.patch b/contrib/ffmpeg/A02-mov-colr.patch
new file mode 100644
index 000000000..b65b465e6
--- /dev/null
+++ b/contrib/ffmpeg/A02-mov-colr.patch
@@ -0,0 +1,57 @@
+diff --git a/libavformat/mov.c b/libavformat/mov.c
+index 36e75d5..fee9f36 100644
+--- a/libavformat/mov.c
++++ b/libavformat/mov.c
+@@ -36,6 +36,7 @@
+ #include "libavutil/avstring.h"
+ #include "libavutil/dict.h"
+ #include "libavutil/opt.h"
++#include "libavutil/pixdesc.h"
+ #include "libavcodec/ac3tab.h"
+ #include "avformat.h"
+ #include "internal.h"
+@@ -1083,16 +1084,14 @@ static int mov_read_colr(MOVContext *c, AVIOContext *pb, MOVAtom atom)
+ st->codecpar->color_range = AVCOL_RANGE_JPEG;
+ else
+ st->codecpar->color_range = AVCOL_RANGE_MPEG;
+- /* 14496-12 references JPEG XR specs (rather than the more complete
+- * 23001-8) so some adjusting is required */
+- if (color_primaries >= AVCOL_PRI_FILM)
++
++ if (!av_color_primaries_name(color_primaries))
+ color_primaries = AVCOL_PRI_UNSPECIFIED;
+- if ((color_trc >= AVCOL_TRC_LINEAR &&
+- color_trc <= AVCOL_TRC_LOG_SQRT) ||
+- color_trc >= AVCOL_TRC_BT2020_10)
++ if (!av_color_transfer_name(color_trc))
+ color_trc = AVCOL_TRC_UNSPECIFIED;
+- if (color_matrix >= AVCOL_SPC_BT2020_NCL)
++ if (!av_color_space_name(color_matrix))
+ color_matrix = AVCOL_SPC_UNSPECIFIED;
++
+ st->codecpar->color_primaries = color_primaries;
+ st->codecpar->color_trc = color_trc;
+ st->codecpar->color_space = color_matrix;
+@@ -1102,17 +1101,22 @@ static int mov_read_colr(MOVContext *c, AVIOContext *pb, MOVAtom atom)
+ case 1: st->codecpar->color_primaries = AVCOL_PRI_BT709; break;
+ case 5: st->codecpar->color_primaries = AVCOL_PRI_SMPTE170M; break;
+ case 6: st->codecpar->color_primaries = AVCOL_PRI_SMPTE240M; break;
++ case 9: st->codecpar->color_primaries = AVCOL_PRI_BT2020; break;
++ case 10: st->codecpar->color_primaries = AVCOL_PRI_SMPTE431; break;
++ case 11: st->codecpar->color_primaries = AVCOL_PRI_SMPTE432; break;
+ }
+ /* color transfer, Table 4-5 */
+ switch (color_trc) {
+ case 1: st->codecpar->color_trc = AVCOL_TRC_BT709; break;
+ case 7: st->codecpar->color_trc = AVCOL_TRC_SMPTE240M; break;
++ case 17: st->codecpar->color_trc = AVCOL_TRC_SMPTE428; break;
+ }
+ /* color matrix, Table 4-6 */
+ switch (color_matrix) {
+ case 1: st->codecpar->color_space = AVCOL_SPC_BT709; break;
+ case 6: st->codecpar->color_space = AVCOL_SPC_BT470BG; break;
+ case 7: st->codecpar->color_space = AVCOL_SPC_SMPTE240M; break;
++ case 9: st->codecpar->color_space = AVCOL_SPC_BT2020_NCL; break;
+ }
+ }
+ av_log(c->fc, AV_LOG_TRACE, "\n");