mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
- Adapted the tuning code to the new DVBFE_SET_DELSYS API (thanks to Reinhard Nissl). VDR now uses the driver from http://jusst.de/hg/multiproto_plus. - Updated the Italian OSD texts (thanks to Diego Pierotto). - Removed obsolete $(NCURSESLIB) from the Makefile. - Implemented handling the standard component descriptor for AC3 (stream=4), as it will soon be used by the German ARD channels (thanks to Michael Pennewiß for advance information about this change). The previously used "Premiere pseudo standard" (stream=2, type=5) still works, but has apparently been wrongfully used by broadcasters from the beginning. - Added missing description of the 'S' channel parameter to vdr.5 (reported by Reinhard Nissl). - The SVDRP signon message now indicates the character encoding in use, as in "220 video SVDRP VideoDiskRecorder 1.7.1; Fri May 2 16:17:10 2008; ISO-8859-1". This may be useful for instance for external tools that provide EPG data, so that they can correctly encode the strings. - No longer calling FcFini() to avoid problems with older (broken) versions of fontconfig (suggested by Edgar Toernig). - Removed the compile time option VFAT to allow users of precompiled binary distributions to have full control over whether or not to use the --vfat option at runtime (suggested by Michael Nork). - First step towards switching to TS (Transport Stream) as recording format: + The new function cDevice::PlayTs() is used to play TS packets. + The new functions cDevice::PlayTsVideo() and cDevice::PlayTsAudio() are used to play video and audio TS packets, respectively. + The new function cAudio::PlayTs() is used to play audio TS packets. + The new class cPatPmtGenerator is used to generate a PAT/PMT pair that precedes the TS data in Transfer Mode. + The new class cPatPmtParser is used by cDevice to parse the PAT/PMT data in a TS in order to find out which streams it contains. + The new class cTsToPes is used to convert TS packets to a PES packet. + cTransfer no longer uses cRemux, and doesn't run a separate thread any more. It just generates a PAT/PMT and sends all received TS packets to the primary device's PlayTs(). + Live subtitle display no longer uses a ring buffer and separate thread. + cPesAssembler has been removed. Old VDR recordings only contain complete PES packets. + Since a TS needs to have a PAT/PMT, which requires the video stream type to be explicitly given, the format of the VPID field in the channels.conf file and the SVDRP commands NEWC/MODC/LSTC has been extended. The video stream type now follows the VPID and optional PPID, separated by an '=' sign. - Updated the sources.conf file (thanks to Oleg Roitburd). - Fixed a possible integer overflow in GetAbsTime() (thanks to Alexander Rieger). - Fixed a problem with calling isyslog() from within the SignalHandler() (thanks to Udo Richter). - Replaced the Finnish language code "smi" with "suo" (thanks to Rolf Ahrenberg). - Fixed wrong value for TableIdBAT in libsi/si.h (thanks to Winfried Köhler). - Errors in config files no longer keep VDR from starting. - Removed unneeded include files <linux/dvb/dmx.h> und <time.h> from remux.h (reported by Tobias Grimm).
163 lines
5.6 KiB
C++
163 lines
5.6 KiB
C++
/***************************************************************************
|
|
* Copyright (c) 2003 by Marcel Wiesweg *
|
|
* *
|
|
* This program 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 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
* $Id: util.h 2.1 2008/05/22 10:49:08 kls Exp $
|
|
* *
|
|
***************************************************************************/
|
|
|
|
#ifndef LIBSI_UTIL_H
|
|
#define LIBSI_UTIL_H
|
|
|
|
#include <stdint.h>
|
|
#include <sys/types.h>
|
|
#include <pthread.h>
|
|
#include <time.h>
|
|
|
|
#define HILO(x) (x##_hi << 8 | x##_lo)
|
|
#define BCD_TIME_TO_SECONDS(x) ((3600 * ((10*((x##_h & 0xF0)>>4)) + (x##_h & 0xF))) + \
|
|
(60 * ((10*((x##_m & 0xF0)>>4)) + (x##_m & 0xF))) + \
|
|
((10*((x##_s & 0xF0)>>4)) + (x##_s & 0xF)))
|
|
|
|
namespace SI {
|
|
|
|
//Holds an array of unsigned char which is deleted
|
|
//when the last object pointing to it is deleted.
|
|
//Optimized for use in libsi.
|
|
class CharArray {
|
|
public:
|
|
CharArray();
|
|
|
|
CharArray(const CharArray &source);
|
|
CharArray& operator=(const CharArray &source);
|
|
~CharArray();
|
|
|
|
//can be called exactly once
|
|
void assign(const unsigned char*data, int size, bool doCopy=true);
|
|
//compares to a null-terminated string
|
|
bool operator==(const char *string) const;
|
|
//compares to another CharArray (data not necessarily null-terminated)
|
|
bool operator==(const CharArray &other) const;
|
|
|
|
//returns another CharArray with its offset incremented by offset
|
|
CharArray operator+(const int offset) const;
|
|
|
|
//access and convenience methods
|
|
const unsigned char* getData() const { return data_->data+off; }
|
|
const unsigned char* getData(int offset) const { return data_->data+offset+off; }
|
|
template <typename T> const T* getData() const { return (T*)(data_->data+off); }
|
|
template <typename T> const T* getData(int offset) const { return (T*)(data_->data+offset+off); }
|
|
//sets p to point to data+offset, increments offset
|
|
template <typename T> void setPointerAndOffset(const T* &p, int &offset) const { p=(T*)getData(offset); offset+=sizeof(T); }
|
|
unsigned char operator[](const int index) const { return data_->data ? data_->data[off+index] : 0; }
|
|
int getLength() const { return data_->size; }
|
|
u_int16_t TwoBytes(const int index) const { return data_->data ? data_->TwoBytes(off+index) : 0; }
|
|
u_int32_t FourBytes(const int index) const { return data_->data ? data_->FourBytes(off+index) : 0; }
|
|
|
|
bool isValid() const { return data_->valid; }
|
|
bool checkSize(int offset) { return (data_->valid && (data_->valid=(offset>=0 && off+offset < data_->size))); }
|
|
|
|
void addOffset(int offset) { off+=offset; }
|
|
private:
|
|
class Data {
|
|
public:
|
|
Data();
|
|
virtual ~Data();
|
|
|
|
virtual void assign(const unsigned char*data, int size) = 0;
|
|
virtual void Delete() = 0;
|
|
|
|
u_int16_t TwoBytes(const int index) const
|
|
{ return (data[index] << 8) | data[index+1]; }
|
|
u_int32_t FourBytes(const int index) const
|
|
{ return (data[index] << 24) | (data[index+1] << 16) | (data[index+2] << 8) | data[index+3]; }
|
|
/*#ifdef CHARARRAY_THREADSAFE
|
|
void Lock();
|
|
void Unlock();
|
|
#else
|
|
void Lock() {}
|
|
void Unlock() {}
|
|
#endif
|
|
Data(const Data& d);
|
|
void assign(int size);
|
|
*/
|
|
|
|
const unsigned char*data;
|
|
int size;
|
|
|
|
// count_ is the number of CharArray objects that point at this
|
|
// count_ must be initialized to 1 by all constructors
|
|
// (it starts as 1 since it is pointed to by the CharArray object that created it)
|
|
unsigned count_;
|
|
|
|
bool valid;
|
|
|
|
/*
|
|
pthread_mutex_t mutex;
|
|
pid_t lockingPid;
|
|
pthread_t locked;
|
|
*/
|
|
};
|
|
class DataOwnData : public Data {
|
|
public:
|
|
DataOwnData() {}
|
|
virtual ~DataOwnData();
|
|
virtual void assign(const unsigned char*data, int size);
|
|
virtual void Delete();
|
|
};
|
|
class DataForeignData : public Data {
|
|
public:
|
|
DataForeignData() {}
|
|
virtual ~DataForeignData();
|
|
virtual void assign(const unsigned char*data, int size);
|
|
virtual void Delete();
|
|
};
|
|
Data* data_;
|
|
int off;
|
|
};
|
|
|
|
|
|
|
|
//abstract base class
|
|
class Parsable {
|
|
public:
|
|
void CheckParse();
|
|
protected:
|
|
Parsable();
|
|
virtual ~Parsable() {}
|
|
//actually parses given data.
|
|
virtual void Parse() = 0;
|
|
private:
|
|
bool parsed;
|
|
};
|
|
|
|
//taken and adapted from libdtv, (c) Rolf Hakenes and VDR, (c) Klaus Schmidinger
|
|
namespace DVBTime {
|
|
time_t getTime(unsigned char date_hi, unsigned char date_lo, unsigned char timehr, unsigned char timemi, unsigned char timese);
|
|
time_t getDuration(unsigned char timehr, unsigned char timemi, unsigned char timese);
|
|
inline unsigned char bcdToDec(unsigned char b) { return ((b >> 4) & 0x0F) * 10 + (b & 0x0F); }
|
|
}
|
|
|
|
//taken and adapted from libdtv, (c) Rolf Hakenes
|
|
class CRC32 {
|
|
public:
|
|
CRC32(const char *d, int len, u_int32_t CRCvalue=0xFFFFFFFF);
|
|
bool isValid() { return crc32(data, length, value) == 0; }
|
|
static bool isValid(const char *d, int len, u_int32_t CRCvalue=0xFFFFFFFF) { return crc32(d, len, CRCvalue) == 0; }
|
|
static u_int32_t crc32(const char *d, int len, u_int32_t CRCvalue);
|
|
protected:
|
|
static u_int32_t crc_table[256];
|
|
|
|
const char *data;
|
|
int length;
|
|
u_int32_t value;
|
|
};
|
|
|
|
} //end of namespace
|
|
|
|
#endif
|