Commit 44448fec authored by michael's avatar michael

make StreamContext.time_base a pointer


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@10010 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent c48308c3
...@@ -72,7 +72,7 @@ typedef struct { ...@@ -72,7 +72,7 @@ typedef struct {
int skip_until_key_frame; int skip_until_key_frame;
int64_t last_pts; int64_t last_pts;
int time_base_id; int time_base_id;
AVRational time_base; AVRational *time_base;
int msb_pts_shift; int msb_pts_shift;
int max_pts_distance; int max_pts_distance;
int decode_delay; //FIXME duplicate of has_b_frames int decode_delay; //FIXME duplicate of has_b_frames
......
...@@ -288,7 +288,7 @@ static int decode_stream_header(NUTContext *nut){ ...@@ -288,7 +288,7 @@ static int decode_stream_header(NUTContext *nut){
end= get_packetheader(nut, bc, 1); end= get_packetheader(nut, bc, 1);
end += url_ftell(bc); end += url_ftell(bc);
GET_V(stream_id, tmp < s->nb_streams && !nut->stream[tmp].time_base.num); GET_V(stream_id, tmp < s->nb_streams && !nut->stream[tmp].time_base);
stc= &nut->stream[stream_id]; stc= &nut->stream[stream_id];
st = s->streams[stream_id]; st = s->streams[stream_id];
...@@ -358,8 +358,8 @@ static int decode_stream_header(NUTContext *nut){ ...@@ -358,8 +358,8 @@ static int decode_stream_header(NUTContext *nut){
av_log(s, AV_LOG_ERROR, "Stream header %d checksum mismatch\n", stream_id); av_log(s, AV_LOG_ERROR, "Stream header %d checksum mismatch\n", stream_id);
return -1; return -1;
} }
stc->time_base= nut->time_base[stc->time_base_id]; stc->time_base= &nut->time_base[stc->time_base_id];
av_set_pts_info(s->streams[stream_id], 63, stc->time_base.num, stc->time_base.den); av_set_pts_info(s->streams[stream_id], 63, stc->time_base->num, stc->time_base->den);
return 0; return 0;
} }
...@@ -461,8 +461,8 @@ static int decode_syncpoint(NUTContext *nut, int64_t *ts, int64_t *back_ptr){ ...@@ -461,8 +461,8 @@ static int decode_syncpoint(NUTContext *nut, int64_t *ts, int64_t *back_ptr){
for(i=0; i<s->nb_streams; i++){ for(i=0; i<s->nb_streams; i++){
nut->stream[i].last_pts= av_rescale_rnd( nut->stream[i].last_pts= av_rescale_rnd(
tmp / nut->time_base_count, tmp / nut->time_base_count,
time_base.num * (int64_t)nut->stream[i].time_base.den, time_base.num * (int64_t)nut->stream[i].time_base->den,
time_base.den * (int64_t)nut->stream[i].time_base.num, time_base.den * (int64_t)nut->stream[i].time_base->num,
AV_ROUND_DOWN); AV_ROUND_DOWN);
//last_key_frame ? //last_key_frame ?
} }
......
...@@ -236,29 +236,28 @@ static int write_header(AVFormatContext *s){ ...@@ -236,29 +236,28 @@ static int write_header(AVFormatContext *s){
for(i=0; i<s->nb_streams; i++){ for(i=0; i<s->nb_streams; i++){
AVStream *st= s->streams[i]; AVStream *st= s->streams[i];
int num, denom, ssize; int ssize;
ff_parse_specific_params(st->codec, &num, &ssize, &denom); AVRational time_base;
ff_parse_specific_params(st->codec, &time_base.den, &ssize, &time_base.num);
nut->stream[i].time_base= (AVRational){denom, num}; av_set_pts_info(st, 64, time_base.num, time_base.den);
av_set_pts_info(st, 64, denom, num);
for(j=0; j<nut->time_base_count; j++){ for(j=0; j<nut->time_base_count; j++){
if(!memcmp(&nut->stream[i].time_base, &nut->time_base[j], sizeof(AVRational))){ if(!memcmp(&time_base, &nut->time_base[j], sizeof(AVRational))){
break; break;
} }
} }
nut->time_base[j]= nut->stream[i].time_base; nut->time_base[j]= time_base;
nut->stream[i].time_base= &nut->time_base[j];
if(j==nut->time_base_count) if(j==nut->time_base_count)
nut->time_base_count++; nut->time_base_count++;
if(av_q2d(nut->stream[i].time_base) >= 0.001) if(av_q2d(time_base) >= 0.001)
nut->stream[i].msb_pts_shift = 7; nut->stream[i].msb_pts_shift = 7;
else else
nut->stream[i].msb_pts_shift = 14; nut->stream[i].msb_pts_shift = 14;
nut->stream[i].max_pts_distance= FFMAX(1/av_q2d(nut->stream[i].time_base), 1); nut->stream[i].max_pts_distance= FFMAX(1/av_q2d(time_base), 1);
} }
//FIXME make nut->stream[i].time_base pointers into nut->time_base
put_buffer(bc, ID_STRING, strlen(ID_STRING)); put_buffer(bc, ID_STRING, strlen(ID_STRING));
put_byte(bc, 0); put_byte(bc, 0);
......
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