Commit f27425b9 authored by michael's avatar michael

move lsb2full to common file


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@10025 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 891ca761
...@@ -35,3 +35,10 @@ void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val){ ...@@ -35,3 +35,10 @@ void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val){
AV_ROUND_DOWN); AV_ROUND_DOWN);
} }
} }
int64_t ff_lsb2full(StreamContext *stream, int64_t lsb){
int64_t mask = (1<<stream->msb_pts_shift)-1;
int64_t delta= stream->last_pts - mask/2;
return ((lsb - delta)&mask) + delta;
}
...@@ -94,5 +94,6 @@ typedef struct { ...@@ -94,5 +94,6 @@ typedef struct {
unsigned long av_crc04C11DB7_update(unsigned long checksum, const uint8_t *buf, unsigned int len); unsigned long av_crc04C11DB7_update(unsigned long checksum, const uint8_t *buf, unsigned int len);
void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val); void ff_nut_reset_ts(NUTContext *nut, AVRational time_base, int64_t val);
int64_t ff_lsb2full(StreamContext *stream, int64_t lsb);
#endif /* AVFORMAT_NUT_H */ #endif /* AVFORMAT_NUT_H */
...@@ -155,12 +155,6 @@ static int64_t find_startcode(ByteIOContext *bc, uint64_t code, int64_t pos){ ...@@ -155,12 +155,6 @@ static int64_t find_startcode(ByteIOContext *bc, uint64_t code, int64_t pos){
} }
} }
static int64_t lsb2full(StreamContext *stream, int64_t lsb){
int64_t mask = (1<<stream->msb_pts_shift)-1;
int64_t delta= stream->last_pts - mask/2;
return ((lsb - delta)&mask) + delta;
}
static int nut_probe(AVProbeData *p){ static int nut_probe(AVProbeData *p){
int i; int i;
uint64_t code= 0; uint64_t code= 0;
...@@ -655,7 +649,7 @@ static int decode_frame_header(NUTContext *nut, int64_t *pts, int *stream_id, in ...@@ -655,7 +649,7 @@ static int decode_frame_header(NUTContext *nut, int64_t *pts, int *stream_id, in
int coded_pts= get_v(bc); int coded_pts= get_v(bc);
//FIXME check last_pts validity? //FIXME check last_pts validity?
if(coded_pts < (1<<stc->msb_pts_shift)){ if(coded_pts < (1<<stc->msb_pts_shift)){
*pts=lsb2full(stc, coded_pts); *pts=ff_lsb2full(stc, coded_pts);
}else }else
*pts=coded_pts - (1<<stc->msb_pts_shift); *pts=coded_pts - (1<<stc->msb_pts_shift);
}else }else
......
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