You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
2.2 KiB
105 lines
2.2 KiB
4 years ago
|
/*
|
||
|
* ioaux.c
|
||
|
*
|
||
|
* Copyright (C) Thomas Oestreich - June 2001
|
||
|
*
|
||
|
* This file is part of transcode, a video stream processing tool
|
||
|
*
|
||
|
* transcode is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License as published by
|
||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||
|
* any later version.
|
||
|
*
|
||
|
* transcode is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License
|
||
|
* along with GNU Make; see the file COPYING. If not, write to
|
||
|
* the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
|
||
|
#include "ioaux.h"
|
||
|
#include "libtc/libtc.h"
|
||
|
#include "libtc/xio.h"
|
||
|
|
||
|
|
||
|
unsigned int stream_read_int16(const unsigned char *s)
|
||
|
{
|
||
|
unsigned int a, b, result;
|
||
|
|
||
|
a = s[0];
|
||
|
b = s[1];
|
||
|
|
||
|
result = (a << 8) | b;
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
|
||
|
unsigned int stream_read_int32(const unsigned char *s)
|
||
|
{
|
||
|
unsigned int a, b, c, d, result;
|
||
|
|
||
|
a = s[0];
|
||
|
b = s[1];
|
||
|
c = s[2];
|
||
|
d = s[3];
|
||
|
|
||
|
result = (a << 24) | (b << 16) | (c << 8) | d;
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
|
||
|
double read_time_stamp(const unsigned char *s)
|
||
|
{
|
||
|
|
||
|
unsigned long i, j;
|
||
|
unsigned long clock_ref=0, clock_ref_ext=0;
|
||
|
|
||
|
if(s[0] & 0x40) {
|
||
|
|
||
|
i = stream_read_int32(s);
|
||
|
j = stream_read_int16(s+4);
|
||
|
|
||
|
if(i & 0x40000000 || (i >> 28) == 2)
|
||
|
{
|
||
|
clock_ref = ((i & 0x31000000) << 3);
|
||
|
clock_ref |= ((i & 0x03fff800) << 4);
|
||
|
clock_ref |= ((i & 0x000003ff) << 5);
|
||
|
clock_ref |= ((j & 0xf800) >> 11);
|
||
|
clock_ref_ext = (j >> 1) & 0x1ff;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return (double)(clock_ref + clock_ref_ext / 300) / 90000;
|
||
|
}
|
||
|
|
||
|
|
||
|
long read_time_stamp_long(const unsigned char *s)
|
||
|
{
|
||
|
|
||
|
unsigned long i, j;
|
||
|
unsigned long clock_ref=0, clock_ref_ext=0;
|
||
|
|
||
|
if(s[0] & 0x40) {
|
||
|
|
||
|
i = stream_read_int32(s);
|
||
|
j = stream_read_int16(s+4);
|
||
|
|
||
|
if(i & 0x40000000 || (i >> 28) == 2)
|
||
|
{
|
||
|
clock_ref = ((i & 0x31000000) << 3);
|
||
|
clock_ref |= ((i & 0x03fff800) << 4);
|
||
|
clock_ref |= ((i & 0x000003ff) << 5);
|
||
|
clock_ref |= ((j & 0xf800) >> 11);
|
||
|
clock_ref_ext = (j >> 1) & 0x1ff;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return (clock_ref);
|
||
|
}
|
||
|
|