Commit 8de9f501 authored by rbultje's avatar rbultje

Use get_buffer() and url_fskip() for some loops of get_byte()s. See discussion in ML thread

"[PATCH] rmdec.c: use get_buffer and skip_bytes instead of loops of get_byte".



git-svn-id: file:///var/local/repositories/ffmpeg/trunk@16139 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 4f33e85e
...@@ -74,15 +74,12 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -74,15 +74,12 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
RMDemuxContext *rm = s->priv_data; RMDemuxContext *rm = s->priv_data;
char buf[256]; char buf[256];
uint32_t version; uint32_t version;
int i;
/* ra type header */ /* ra type header */
version = get_be32(pb); /* version */ version = get_be32(pb); /* version */
if (((version >> 16) & 0xff) == 3) { if (((version >> 16) & 0xff) == 3) {
int64_t startpos = url_ftell(pb); int64_t startpos = url_ftell(pb);
/* very old version */ url_fskip(pb, 14);
for(i = 0; i < 14; i++)
get_byte(pb);
get_str8(pb, s->title, sizeof(s->title)); get_str8(pb, s->title, sizeof(s->title));
get_str8(pb, s->author, sizeof(s->author)); get_str8(pb, s->author, sizeof(s->author));
get_str8(pb, s->copyright, sizeof(s->copyright)); get_str8(pb, s->copyright, sizeof(s->copyright));
...@@ -123,10 +120,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -123,10 +120,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
st->codec->channels = get_be16(pb); st->codec->channels = get_be16(pb);
if (((version >> 16) & 0xff) == 5) { if (((version >> 16) & 0xff) == 5) {
get_be32(pb); get_be32(pb);
buf[0] = get_byte(pb); get_buffer(pb, buf, 4);
buf[1] = get_byte(pb);
buf[2] = get_byte(pb);
buf[3] = get_byte(pb);
buf[4] = 0; buf[4] = 0;
} else { } else {
get_str8(pb, buf, sizeof(buf)); /* desc */ get_str8(pb, buf, sizeof(buf)); /* desc */
...@@ -149,7 +143,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -149,7 +143,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
rm->audiobuf = av_malloc(rm->audio_framesize * sub_packet_h); rm->audiobuf = av_malloc(rm->audio_framesize * sub_packet_h);
} else if ((!strcmp(buf, "cook")) || (!strcmp(buf, "atrc")) || (!strcmp(buf, "sipr"))) { } else if ((!strcmp(buf, "cook")) || (!strcmp(buf, "atrc")) || (!strcmp(buf, "sipr"))) {
int codecdata_length, i; int codecdata_length;
get_be16(pb); get_byte(pb); get_be16(pb); get_byte(pb);
if (((version >> 16) & 0xff) == 5) if (((version >> 16) & 0xff) == 5)
get_byte(pb); get_byte(pb);
...@@ -169,8 +163,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -169,8 +163,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
else st->codec->codec_id = CODEC_ID_ATRAC3; else st->codec->codec_id = CODEC_ID_ATRAC3;
st->codec->extradata_size= codecdata_length; st->codec->extradata_size= codecdata_length;
st->codec->extradata= av_mallocz(st->codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); st->codec->extradata= av_mallocz(st->codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
for(i = 0; i < codecdata_length; i++) get_buffer(pb, st->codec->extradata, st->codec->extradata_size);
((uint8_t*)st->codec->extradata)[i] = get_byte(pb);
rm->audio_framesize = st->codec->block_align; rm->audio_framesize = st->codec->block_align;
st->codec->block_align = rm->sub_packet_size; st->codec->block_align = rm->sub_packet_size;
...@@ -181,7 +174,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -181,7 +174,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
rm->audiobuf = av_malloc(rm->audio_framesize * sub_packet_h); rm->audiobuf = av_malloc(rm->audio_framesize * sub_packet_h);
} else if (!strcmp(buf, "raac") || !strcmp(buf, "racp")) { } else if (!strcmp(buf, "raac") || !strcmp(buf, "racp")) {
int codecdata_length, i; int codecdata_length;
get_be16(pb); get_byte(pb); get_be16(pb); get_byte(pb);
if (((version >> 16) & 0xff) == 5) if (((version >> 16) & 0xff) == 5)
get_byte(pb); get_byte(pb);
...@@ -195,8 +188,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb, ...@@ -195,8 +188,7 @@ static int rm_read_audio_stream_info(AVFormatContext *s, ByteIOContext *pb,
st->codec->extradata_size = codecdata_length - 1; st->codec->extradata_size = codecdata_length - 1;
st->codec->extradata = av_mallocz(st->codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE); st->codec->extradata = av_mallocz(st->codec->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
get_byte(pb); get_byte(pb);
for(i = 0; i < st->codec->extradata_size; i++) get_buffer(pb, st->codec->extradata, st->codec->extradata_size);
((uint8_t*)st->codec->extradata)[i] = get_byte(pb);
} }
} else { } else {
st->codec->codec_id = CODEC_ID_NONE; st->codec->codec_id = CODEC_ID_NONE;
......
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