/usr/include/ltcsmpte/ltcsmpte.h is in libltcsmpte-dev 0.4.4-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 | /**
@brief libltcsmpte - en+decode linear SMPTE timecode
@file ltcsmpte.h
@author Robin Gareus <robin@gareus.org>
Copyright (C) 2006 Robin Gareus <robin@gareus.org>
Copyright (C) 2008-2009 Jan <jan@geheimwerk.de>
inspired by SMPTE Decoder - Maarten de Boer <mdeboer@iua.upf.es>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser Public License as published by
the Free Software Foundation; either version 3, or (at your option)
any later version.
This program 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 Lesser Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef LTCSMPTE_H
#define LTCSMPTE_H 1
#ifdef __cplusplus
extern "C" {
#endif
#ifndef DOXYGEN_IGNORE
// libltcsmpte version
#define LIBLTCSMPTE_VERSION "0.4.4"
#define LIBLTCSMPTE_VERSION_MAJOR 0
#define LIBLTCSMPTE_VERSION_MINOR 4
#define LIBLTCSMPTE_VERSION_MICRO 4
//interface revision number
//http://www.gnu.org/software/libtool/manual/html_node/Updating-version-info.html
#define LIBLTCSMPTE_CUR 1
#define LIBLTCSMPTE_REV 1
#define LIBLTCSMPTE_AGE 0
#endif
#include <sys/types.h>
#include <ltcsmpte/framerate.h>
typedef double timeu;
#define FPRNT_TIME "%lf"
#define TIME_DELIM "\t"
#ifdef DIAGNOSTICS_OUTPUT
#define WRITE_DECODER_BIPHASE_DIAGNOSTICS(A, B, C, D, E) SMPTEDecoderPrintDiagnosticsForAudacity(A, B, C, D, E, 0)
#define WRITE_DECODER_BITS_DIAGNOSTICS(A, B, C, D, E) SMPTEDecoderPrintDiagnosticsForAudacity(A, B, C, D, E, 1)
#else
#define WRITE_DECODER_BIPHASE_DIAGNOSTICS(A, B, C, D, E)
#define WRITE_DECODER_BITS_DIAGNOSTICS(A, B, C, D, E)
#endif
#ifdef USE_FLOAT
typedef float sample_t;
typedef float curve_sample_t;
//#define SAMPLE_AND_CURVE_ARE_DIFFERENT_TYPE
#define SAMPLE_CENTER 0
#define CURVE_MIN -0.9765625
#define CURVE_MAX 0.9765625
//#define SAMPLE_IS_UNSIGNED
//#define SAMPLE_IS_INTEGER
typedef float diagnostics_t;
#else
#ifdef USE16BIT
typedef short sample_t;
typedef short curve_sample_t;
//#define SAMPLE_AND_CURVE_ARE_DIFFERENT_TYPE
#define SAMPLE_CENTER 0
#define CURVE_MIN -32000
#define CURVE_MAX 32000
//#define SAMPLE_IS_UNSIGNED
#define SAMPLE_IS_INTEGER
typedef int diagnostics_t;
#else
#define USE8BIT
typedef unsigned char sample_t;
typedef short curve_sample_t;
#define SAMPLE_AND_CURVE_ARE_DIFFERENT_TYPE
#define SAMPLE_CENTER 128 // unsigned 8 bit.
#define CURVE_MIN -127
#define CURVE_MAX 127
#define SAMPLE_IS_UNSIGNED
#define SAMPLE_IS_INTEGER
typedef int diagnostics_t;
#endif
#endif
#define LTC_FRAME_BIT_COUNT 80
/**
* Raw 80 bit SMPTE frame
*/
#ifdef __BIG_ENDIAN__
// Big Endian version, bytes are "upside down"
typedef struct SMPTEFrame {
unsigned int user1:4;
unsigned int frameUnits:4;
unsigned int user2:4;
unsigned int colFrm:1;
unsigned int dfbit:1;
unsigned int frameTens:2;
unsigned int user3:4;
unsigned int secsUnits:4;
unsigned int user4:4;
unsigned int biphaseMarkPhaseCorrection:1;
unsigned int secsTens:3;
unsigned int user5:4;
unsigned int minsUnits:4;
unsigned int user6:4;
unsigned int binaryGroupFlagBit1:1;
unsigned int minsTens:3;
unsigned int user7:4;
unsigned int hoursUnits:4;
unsigned int user8:4;
unsigned int binaryGroupFlagBit2:1;
unsigned int reserved:1;
unsigned int hoursTens:2;
unsigned int syncWord:16;
} SMPTEFrame;
#else
// Little Endian version (default)
typedef struct SMPTEFrame {
unsigned int frameUnits:4;
unsigned int user1:4;
unsigned int frameTens:2;
unsigned int dfbit:1;
unsigned int colFrm:1;
unsigned int user2:4;
unsigned int secsUnits:4;
unsigned int user3:4;
unsigned int secsTens:3;
unsigned int biphaseMarkPhaseCorrection:1;
unsigned int user4:4;
unsigned int minsUnits:4;
unsigned int user5:4;
unsigned int minsTens:3;
unsigned int binaryGroupFlagBit1:1;
unsigned int user6:4;
unsigned int hoursUnits:4;
unsigned int user7:4;
unsigned int hoursTens:2;
unsigned int reserved:1;
unsigned int binaryGroupFlagBit2:1;
unsigned int user8:4;
unsigned int syncWord:16;
} SMPTEFrame;
#endif
/**
* Human readable time representation
*/
typedef struct SMPTETime {
// these are only set when compiled with ENABLE_DATE
char timezone[6];
unsigned char years;
unsigned char months;
unsigned char days;
//
unsigned char hours;
unsigned char mins;
unsigned char secs;
unsigned char frame;
} SMPTETime;
/**
* Extended SMPTE frame
* The maximum error for startpos is 1/80 of a frame. Usually it is 0;
*/
typedef struct SMPTEFrameExt {
SMPTEFrame base; ///< the SMPTE decoded from the audio
int delayed; ///< detected jitter in LTC-framerate/80 unit(s) - bit count in LTC frame.
long int startpos; ///< the approximate sample in the stream corresponding to the start of the LTC SMPTE frame.
long int endpos; ///< the sample in the stream corresponding to the end of the LTC SMPTE frame.
} SMPTEFrameExt;
/**
* opaque structure.
* see: SMPTEDecoderCreate, SMPTEFreeDecoder
*/
typedef struct SMPTEDecoder SMPTEDecoder;
/**
* opaque structure
* see: SMPTEEncoderCreate, SMPTEFreeEncoder
*/
typedef struct SMPTEEncoder SMPTEEncoder;
/**
* convert binary SMPTEFrame into SMPTETime struct
*/
int SMPTEFrameToTime(SMPTEFrame* frame, SMPTETime* stime);
/**
* convert SMPTETime struct into it's binary SMPTE representation.
*/
int SMPTETimeToFrame(SMPTETime* stime, SMPTEFrame* frame);
/**
* set all values of a SMPTE FRAME to zero except for the sync-word (0x3FFD) at the end.
* This will also clear the dfbit.
*/
int SMPTEFrameReset(SMPTEFrame* frame);
/**
* increments the SMPTE by one SMPTE-Frame (1/framerate seconds)
*/
int SMPTEFrameIncrease(SMPTEFrame *frame, int framesPerSec);
/**
* Create a new decoder. Pass sample rate, number of smpte frames per
* seconds, and the size of the internal queue where decoded frames are
* stored. Set correctJitter flag, to correct jitter resulting from
* audio fragment size when decoding from a realtime audiostream. This
* works only correctly when buffers of exactly fragment size are passed
* to SMPTEDecoderWrite. (as discussed on LAD [msgID])
*/
SMPTEDecoder * SMPTEDecoderCreate(int sampleRate, FrameRate *fps, int queueSize, int correctJitter);
/**
* release memory of Decoder structure.
*/
int SMPTEFreeDecoder(SMPTEDecoder *d);
/**
* Reset the decoder error tracking internals
*/
int SMPTEDecoderErrorReset(SMPTEDecoder *decoder);
/**
* Feed the SMPTE decoder with new samples.
*
* parse raw audio for LTC timestamps. If found, store them in the
* Decoder queue (see SMPTEDecoderRead)
* always returns 1 ;-)
* d: the decoder
* buf: pointer to sample_t (defaults to unsigned 8 bit) mono audio data
* size: number of bytes to parse
* posinfo: (optional) byte offset in stream to set LTC location offset
*/
int SMPTEDecoderWrite(SMPTEDecoder *decoder, sample_t *buf, int size, long int posinfo);
/**
* All decoded SMPTE frames are placed in a queue. This function gets
* a frame from the queue, and stores it in SMPTEFrameExt* frame.
* Returns 1 on success, 0 when no frames where on the queue, and
* and errorcode otherwise.
*/
int SMPTEDecoderRead(SMPTEDecoder *decoder, SMPTEFrameExt *frame);
/**
* flush unread LTCs in queue and return the last timestamp.
* (note that the last timestamp may not be the latest if the queue has
* overflown!)
*/
int SMPTEDecoderReadLast(SMPTEDecoder* decoder, SMPTEFrameExt* frame);
/**
* Convert the frame to time in milliseconds. This uses the
* position of the end of the frame related to the sample-time
* to compensate for jitter.
*/
int SMPTEDecoderFrameToMillisecs(SMPTEDecoder* decoder, SMPTEFrameExt* frame, int *timems);
/**
* Convert the index or position of a sample to
* its position in time (seconds) relative to the first sample.
*/
timeu SMPTEDecoderSamplesToSeconds(SMPTEDecoder* d, long int sampleCount);
/**
* get accumulated error count since last reset.
*/
int SMPTEDecoderErrors(SMPTEDecoder *decoder, int *errors);
/**
* Allocate and initialize LTC encoder
* sampleRate: audio sample rate (eg. 48000)
* fps: framerate
*/
SMPTEEncoder * SMPTEEncoderCreate(int sampleRate, FrameRate *fps);
/**
* release encoder data structure
*/
int SMPTEFreeEncoder(SMPTEEncoder *e);
/**
* set internal Audio-sample counter.
* SMPTEEncode() increments this counter when it encodes samples.
*/
int SMPTESetNsamples(SMPTEEncoder *e, int val);
/**
* returns the current values of the Audio-sample counter.
* ie. the number of encoded samples.
*/
int SMPTEGetNsamples(SMPTEEncoder *e);
/**
* moves the SMPTE to the next frame.
* it uses SMPTEFrameIncrease().
*/
int SMPTEEncIncrease(SMPTEEncoder *e);
/**
* sets the current encoder SMPTE frame to SMPTETime.
*/
int SMPTESetTime(SMPTEEncoder *e, SMPTETime *t);
/**
* set t from current Encoder timecode
*/
int SMPTEGetTime(SMPTEEncoder *e, SMPTETime *t);
/**
* returns the current value of the encoder's SMPTE frame converted to video-frames
*/
long int SMPTEGetVideoFrameNumber(SMPTEEncoder *e);
/**
* returns the current value of the encoder's SMPTE frame converted to ms
*/
int SMPTEGetTimeInMillisecs(SMPTEEncoder *e);
/**
* returns and flushes the accumulated Encoded Audio.
* returns the number of bytes written to the memory area
* pointed to by buf.
*
* no overflow check is perfomed! use DTMFGetBuffersize().
*/
int SMPTEGetBuffer(SMPTEEncoder *e, sample_t *buf);
/**
* returns the size of the accumulated encoded Audio in bytes.
*/
size_t SMPTEGetBuffersize(SMPTEEncoder *e);
/**
* Generate LTC audio for byte "byteCnt" of the current frame into the buffer of Encoder e.
* LTC has 10 bytes per frame: 0 <= bytecnt < 10
* use SMPTESetTime(..) to set the current frame before Encoding.
* see tests/encoder.c for an example.
*/
int SMPTEEncode(SMPTEEncoder *e, int byteCnt);
#ifdef __cplusplus
}
#endif
#endif
|