mirror of
https://github.com/vdr-projects/vdr.git
synced 2025-03-01 10:50:46 +00:00
- Fixed detecting transponder lock in cDvbTuner (based on a patch from Stefan Meyknecht). - What was previously marked with WAIT_FOR_LOCK_AFTER_TUNING is now permanently active and uses a cCondVar to signal when a transponder is locked. - Added some missing 'const' to cChannel. - Added a sample setup for 'DisiCon-4 Single Cable Network' to 'diseqc.conf' (thanks to Oliver Endriss). - Fixed attaching a cPlayer to a cDevice, so that 'Operation not permitted' errors don't occur any more (thanks to Marco Schlüßler). - Fixed a case where the resultBuffer in cRemux ran full before getting a sync. - Removed the usleep() call from cDvbPlayer::Action() to make VDR run on NPTL systems (thanks to Alfred Zastrow). The NPTL check at startup has also been removed. - Taking the complete size of available data into account when deciding whether to clear the transfer buffer to avoid overflows (thanks to Reinhard Nissl). - Updated Romanian language texts and the iso8859-2 fonts (thanks to Lucian Muresan). - Now actually using the iso8859-15 fonts (thanks to Lucian Muresan). - Some minor code cleanups (thanks to Prakash K. Cheemplavam). - Fixed missing cleanup at program exit in case there is a problem with a plugin (thanks to Mattias Grönlund for pointing this out). - Increased the required free buffer space in the resultBuffer of cRemux to 2 * IPACKS to avoid a buffer overflow in case a cTS2PES writes one complete packet and then (within processing the same TS packet) wants to write another small packet. - Removed the signal handler and WakeUp() call from cThread (it is no longer needed). - Added some checks when canceling a thread and removed the usleep() in cThread::Start() (suggested by Ludwig Nussel). Also removed 'running' from cThread and using only childTid to indicate whether a thread is actually running. - Added cCondWait::Sleep() and using it to replace all usleep() calls (based on a suggestion by Werner Fink). - Only assigning events to timers if the related schedule has actually been modified. - When searching for the present event, the running status is now only taken into account if the event has been "seen" within the past 30 seconds. This avoids shortly seeing the wrong events in the channel display when switching to a channel that hasn't been tuned to in a while.
163 lines
5.7 KiB
C++
163 lines
5.7 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 1.5 2004/10/23 14:22:40 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, unsigned 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 unsigned 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, unsigned int &offset) const { p=(T*)getData(offset); offset+=sizeof(T); }
|
|
unsigned char operator[](const unsigned int index) const { return data_->data ? data_->data[off+index] : 0; }
|
|
int getLength() const { return data_->size; }
|
|
u_int16_t TwoBytes(const unsigned int index) const { return data_->data ? data_->TwoBytes(off+index) : 0; }
|
|
u_int32_t FourBytes(const unsigned int index) const { return data_->data ? data_->FourBytes(off+index) : 0; }
|
|
|
|
bool isValid() const { return data_->valid; }
|
|
bool checkSize(unsigned int offset) { return (data_->valid && (data_->valid=(off+offset < data_->size))); }
|
|
|
|
void addOffset(unsigned int offset) { off+=offset; }
|
|
private:
|
|
class Data {
|
|
public:
|
|
Data();
|
|
virtual ~Data();
|
|
|
|
virtual void assign(const unsigned char*data, unsigned int size) = 0;
|
|
virtual void Delete() = 0;
|
|
|
|
u_int16_t TwoBytes(const unsigned int index) const
|
|
{ return (data[index] << 8) | data[index+1]; }
|
|
u_int32_t FourBytes(const unsigned 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(unsigned int size);
|
|
*/
|
|
|
|
const unsigned char*data;
|
|
unsigned 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, unsigned int size);
|
|
virtual void Delete();
|
|
};
|
|
class DataForeignData : public Data {
|
|
public:
|
|
DataForeignData() {}
|
|
virtual ~DataForeignData();
|
|
virtual void assign(const unsigned char*data, unsigned int size);
|
|
virtual void Delete();
|
|
};
|
|
Data* data_;
|
|
unsigned 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; }
|
|
protected:
|
|
static u_int32_t crc_table[256];
|
|
static u_int32_t crc32 (const char *d, int len, u_int32_t CRCvalue);
|
|
|
|
const char *data;
|
|
int length;
|
|
u_int32_t value;
|
|
};
|
|
|
|
} //end of namespace
|
|
|
|
#endif
|