# HG changeset patch # User ivo # Date 1199748777 0 # Node ID e5dfe3c96f3b77fad2fe13b67f503a339418aaf9 # Parent 616fb87724b52087d7023fa1a766eadbeb9f3966 Move parsing of MPEG-PES timestamp to mpeg.h (as an inline function) so it can easily be reused by other demuxers for formats that encapsulate MPEG-PES. diff -r 616fb87724b5 -r e5dfe3c96f3b mpeg.c --- a/mpeg.c Mon Jan 07 00:03:19 2008 +0000 +++ b/mpeg.c Mon Jan 07 23:32:57 2008 +0000 @@ -120,17 +120,12 @@ static int64_t get_pts(ByteIOContext *pb, int c) { - int64_t pts; - int val; + uint8_t buf[5]; - if (c < 0) - c = get_byte(pb); - pts = (int64_t)(c & 0x0e) << 29; - val = get_be16(pb); - pts |= (int64_t)(val >> 1) << 15; - val = get_be16(pb); - pts |= (int64_t)(val >> 1); - return pts; + buf[0] = c<0 ? get_byte(pb) : c; + get_buffer(pb, buf+1, 4); + + return ff_parse_pes_pts(buf); } static int find_next_start_code(ByteIOContext *pb, int *size_ptr, diff -r 616fb87724b5 -r e5dfe3c96f3b mpeg.h --- a/mpeg.h Mon Jan 07 00:03:19 2008 +0000 +++ b/mpeg.h Mon Jan 07 23:32:57 2008 +0000 @@ -57,4 +57,13 @@ static const int lpcm_freq_tab[4] = { 48000, 96000, 44100, 32000 }; +/** + * Parse MPEG-PES five-byte timestamp + */ +static inline int64_t ff_parse_pes_pts(uint8_t *buf) { + return (int64_t)(*buf & 0x0e) << 29 | + (AV_RB16(buf+1) >> 1) << 15 | + AV_RB16(buf+3) >> 1; +} + #endif /* FFMPEG_MPEG_H */