Commit 42f27d1b authored by James Almer's avatar James Almer

Merge commit '0539d84d'

* commit '0539d84d':
  asfdec: Account for different Format Data sizes

See 76853a3eMerged-by: 's avatarJames Almer <jamrial@gmail.com>
parents e2a5fa11 0539d84d
...@@ -691,20 +691,22 @@ static int asf_read_properties(AVFormatContext *s, const GUIDParseTable *g) ...@@ -691,20 +691,22 @@ static int asf_read_properties(AVFormatContext *s, const GUIDParseTable *g)
static int parse_video_info(AVIOContext *pb, AVStream *st) static int parse_video_info(AVIOContext *pb, AVStream *st)
{ {
uint16_t size; uint16_t size_asf; // ASF-specific Format Data size
uint32_t size_bmp; // BMP_HEADER-specific Format Data size
unsigned int tag; unsigned int tag;
st->codecpar->width = avio_rl32(pb); st->codecpar->width = avio_rl32(pb);
st->codecpar->height = avio_rl32(pb); st->codecpar->height = avio_rl32(pb);
avio_skip(pb, 1); // skip reserved flags avio_skip(pb, 1); // skip reserved flags
size = avio_rl16(pb); // size of the Format Data size_asf = avio_rl16(pb);
tag = ff_get_bmp_header(pb, st, NULL); tag = ff_get_bmp_header(pb, st, &size_bmp);
st->codecpar->codec_tag = tag; st->codecpar->codec_tag = tag;
st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag); st->codecpar->codec_id = ff_codec_get_id(ff_codec_bmp_tags, tag);
size_bmp = FFMAX(size_asf, size_bmp);
if (size > BMP_HEADER_SIZE) { if (size_bmp > BMP_HEADER_SIZE) {
int ret; int ret;
st->codecpar->extradata_size = size - BMP_HEADER_SIZE; st->codecpar->extradata_size = size_bmp - BMP_HEADER_SIZE;
if (!(st->codecpar->extradata = av_malloc(st->codecpar->extradata_size + if (!(st->codecpar->extradata = av_malloc(st->codecpar->extradata_size +
AV_INPUT_BUFFER_PADDING_SIZE))) { AV_INPUT_BUFFER_PADDING_SIZE))) {
st->codecpar->extradata_size = 0; st->codecpar->extradata_size = 0;
......
...@@ -41,9 +41,10 @@ void ff_end_tag(AVIOContext *pb, int64_t start); ...@@ -41,9 +41,10 @@ void ff_end_tag(AVIOContext *pb, int64_t start);
/** /**
* Read BITMAPINFOHEADER structure and set AVStream codec width, height and * Read BITMAPINFOHEADER structure and set AVStream codec width, height and
* bits_per_encoded_sample fields. Does not read extradata. * bits_per_encoded_sample fields. Does not read extradata.
* Writes the size of the BMP file to *size.
* @return codec tag * @return codec tag
*/ */
int ff_get_bmp_header(AVIOContext *pb, AVStream *st, unsigned *esize); int ff_get_bmp_header(AVIOContext *pb, AVStream *st, uint32_t *size);
void ff_put_bmp_header(AVIOContext *pb, AVCodecParameters *par, int for_asf, int ignore_extradata); void ff_put_bmp_header(AVIOContext *pb, AVCodecParameters *par, int for_asf, int ignore_extradata);
......
...@@ -208,11 +208,12 @@ enum AVCodecID ff_wav_codec_get_id(unsigned int tag, int bps) ...@@ -208,11 +208,12 @@ enum AVCodecID ff_wav_codec_get_id(unsigned int tag, int bps)
return id; return id;
} }
int ff_get_bmp_header(AVIOContext *pb, AVStream *st, unsigned *esize) int ff_get_bmp_header(AVIOContext *pb, AVStream *st, uint32_t *size)
{ {
int tag1; int tag1;
if(esize) *esize = avio_rl32(pb); uint32_t size_ = avio_rl32(pb);
else avio_rl32(pb); if (size)
*size = size_;
st->codecpar->width = avio_rl32(pb); st->codecpar->width = avio_rl32(pb);
st->codecpar->height = (int32_t)avio_rl32(pb); st->codecpar->height = (int32_t)avio_rl32(pb);
avio_rl16(pb); /* planes */ avio_rl16(pb); /* planes */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment