[SCM] libav/experimental: the PSP rejects video with too high bitrates so lets claim they arent too high ...
siretart at users.alioth.debian.org
siretart at users.alioth.debian.org
Sun Jun 30 15:47:22 UTC 2013
The following commit has been merged in the experimental branch:
commit 9e282ba38279d961ee6970ae89cd5bb25aa4caf8
Author: Michael Niedermayer <michaelni at gmx.at>
Date: Tue Apr 4 12:58:56 2006 +0000
the PSP rejects video with too high bitrates so lets claim they arent too high ...
Originally committed as revision 5267 to svn://svn.ffmpeg.org/ffmpeg/trunk
diff --git a/libavformat/movenc.c b/libavformat/movenc.c
index 2fbfdbd..41e4d6d 100644
--- a/libavformat/movenc.c
+++ b/libavformat/movenc.c
@@ -1510,6 +1510,8 @@ static void mov_write_uuidprof_tag(ByteIOContext *pb, AVFormatContext *s)
AVCodecContext *AudioCodec = s->streams[1]->codec;
int AudioRate = AudioCodec->sample_rate;
int FrameRate = ((VideoCodec->time_base.den) * (0x10000))/ (VideoCodec->time_base.num);
+ int audio_kbitrate= AudioCodec->bit_rate / 1000;
+ int video_kbitrate= FFMIN(VideoCodec->bit_rate / 1000, 800 - audio_kbitrate);
put_be32(pb, 0x94 ); /* size */
put_tag(pb, "uuid");
@@ -1535,8 +1537,8 @@ static void mov_write_uuidprof_tag(ByteIOContext *pb, AVFormatContext *s)
put_tag(pb, "mp4a");
put_be32(pb, 0x20f );
put_be32(pb, 0x0 );
- put_be32(pb, AudioCodec->bit_rate / 1000);
- put_be32(pb, AudioCodec->bit_rate / 1000);
+ put_be32(pb, audio_kbitrate);
+ put_be32(pb, audio_kbitrate);
put_be32(pb, AudioRate );
put_be32(pb, AudioCodec->channels );
@@ -1547,8 +1549,8 @@ static void mov_write_uuidprof_tag(ByteIOContext *pb, AVFormatContext *s)
put_tag(pb, "mp4v");
put_be32(pb, 0x103 );
put_be32(pb, 0x0 );
- put_be32(pb, VideoCodec->bit_rate / 1000);
- put_be32(pb, VideoCodec->bit_rate / 1000);
+ put_be32(pb, video_kbitrate);
+ put_be32(pb, video_kbitrate);
put_be32(pb, FrameRate);
put_be32(pb, FrameRate);
put_be16(pb, VideoCodec->width);
--
Libav/FFmpeg packaging
More information about the pkg-multimedia-commits
mailing list