vdr-plugin-softhddevice-drm-gles 1.5.9-20e15de
cSoftHdDevice Class Reference

#include <softhddevice.h>

Public Member Functions

 cSoftHdDevice (cSoftHdConfig *)
 cSoftHdDevice constructor
 
virtual ~cSoftHdDevice (void)
 cSoftHdDevice destructor
 
virtual cString DeviceName (void) const
 
virtual bool HasDecoder (void) const
 Tells whether this device has an MPEG decoder.
 
virtual cSpuDecoder * GetSpuDecoder (void)
 Get the device SPU decoder.
 
virtual bool CanReplay (void) const
 Returns true if this device can currently start a replay session.
 
virtual bool SetPlayMode (ePlayMode)
 Sets the device into the given play mode.
 
virtual int PlayVideo (const uchar *, int)
 Play a video packet of the main videostream.
 
virtual int PlayAudio (const uchar *, int, uchar)
 Play an audio packet.
 
virtual int64_t GetSTC (void)
 Gets the current System Time Counter, which can be used to synchronize audio, video and subtitles.
 
virtual cRect CanScaleVideo (const cRect &, int taCenter)
 Ask the output, if it can scale video.
 
virtual void ScaleVideo (const cRect &=cRect::Null)
 Scale the currently shown video.
 
virtual void TrickSpeed (int, bool)
 Sets the device into a mode where replay is done slower.
 
virtual void Clear (void)
 Clears all video and audio data from the device.
 
virtual void Play (void)
 Sets the device into play mode (after a previous trick mode, or pause)
 
virtual void Freeze (void)
 Puts the device into "freeze frame" mode.
 
virtual void StillPicture (const uchar *, int)
 Display the given I-frame as a still picture.
 
virtual bool Poll (cPoller &, int=0)
 Returns true if the device itself or any of the file handles in Poller is ready for further action.
 
virtual bool Flush (int=0)
 Flush the device output buffers.
 
virtual uchar * GrabImage (int &, bool, int, int, int)
 Grabs the currently visible screen image.
 
virtual void SetVideoDisplayFormat (eVideoDisplayFormat)
 Sets the video display format.
 
virtual void SetVideoFormat (bool)
 Set the video format.
 
virtual void GetVideoSize (int &, int &, double &)
 Get the video size.
 
virtual void GetOsdSize (int &, int &, double &)
 Returns the width, height and aspect ratio the OSD.
 
virtual void SetAudioTrackDevice (eTrackType)
 
virtual int GetAudioChannelDevice (void)
 
virtual void SetAudioChannelDevice (int)
 
virtual void SetVolumeDevice (int)
 Sets the audio volume on this device (Volume = 0...255).
 
virtual void SetDigitalAudioDevice (bool)
 
const char * CommandLineHelp (void)
 Return command line help string.
 
int ProcessArgs (int, char *[])
 Process the command line arguments.
 
int Start (void)
 Called by VDR when the plugin is started.
 
void Stop (void)
 Called by VDR when the plugin is stopped.
 
cSoftHdConfigConfig (void)
 
cVideoStreamVideoStream (void)
 
cVideoRenderRender (void)
 
cSoftHdAudioAudio (void)
 
void SetDisableDeint (void)
 Disables deinterlacer (called from setup menu or conf)
 
void SetDecoderNeedsIFrame (void)
 Forces the h264 decoder to wait for an I-Frame to start.
 
void SetParseH264Dimensions (void)
 Parse the h264 stream width and height before starting the decoder.
 
void SetDecoderFallbackToSw (bool enable)
 Force the decoder to fallback to software if the hardware decoder fails after the configured amount of packets were sent and no frame was received.
 
void OsdClose (void)
 Close the OSD.
 
void OsdDrawARGB (int, int, int, int, int, const uint8_t *, int, int)
 Draw an OSD pixmap.
 
void SetScreenSize (int, int, double)
 Set the screen size.
 
int GetVideoAudioDelayMs (void)
 
void SetPassthrough (int)
 Set the passthrough mask (called from setup menu or conf)
 
void ResetChannelId (void)
 Reset the channel ID (restarts audio)
 
void GetStats (int *, int *, int *)
 Get statistics from the renderer.
 
void SetAudioCodec (enum AVCodecID, AVCodecParameters *, AVRational)
 Open an audio codec.
 
void SetVideoCodec (enum AVCodecID, AVCodecParameters *, AVRational)
 Open a video codec.
 
int PlayAudioPkts (AVPacket *)
 Play an audio packet.
 
int PlayVideoPkts (AVPacket *)
 Play a video packet.
 
void Detach (void)
 Detach the device.
 
void Attach (void)
 Attach the device again.
 
bool IsDetached (void) const
 Returns true, if the device is detached.
 
void ResetOsdProvider (void)
 
bool IsOsdProviderSet (void) const
 
bool IsBufferingThresholdReached (void)
 Check if the buffering threshold has been reached.
 
bool PipIsEnabled (void)
 Returns true, if pip is currently enabled.
 
void PipEnable (void)
 
void PipDisable (void)
 
void PipToggle (void)
 
void PipChannelChange (int)
 
void PipChannelSwap (bool)
 
void PipSwapPosition (void)
 
void PipSetSize (void)
 
void SetRenderPipSize (void)
 Wrapper functions for cVideoRender and cPipHandler.
 
void SetRenderPipActive (bool)
 
int PlayPipVideo (const uchar *, int)
 Play a video packet of the pip videostream.
 
void SetDrmCanDisplayPip (bool canDisplay)
 
bool UsePip (void)
 
void ResetPipStream (void)
 Resets pip stream and render pipeline.
 
void ToggleRenderPipPosition (void)
 

Protected Member Functions

virtual void MakePrimaryDevice (bool)
 Informs a device that it will be the primary device.
 

Private Member Functions

int PlayVideoInternal (cVideoStream *, cReassemblyBufferVideo *, const uchar *, int, bool)
 Play a video packet.
 
void ClearAudio (void)
 Clear all audio data from the decoder and ringbuffer.
 
void OnEventReceived (const Event &)
 Event handler for playback state transitions.
 
void HandleStillPicture (const uchar *data, int size)
 The still picture data received from VDR can contain multiple PES packets.
 
int64_t GetFirstAudioPtsMsToPlay ()
 Calculate the first audio PTS that should be played during synchronized playback.
 
int64_t GetFirstVideoPtsMsToPlay ()
 
int GetBufferFillLevelThresholdMs ()
 Returns the buffer fill level threshold in milliseconds.
 
void SetState (State)
 Sets the device into the given state.
 
void OnEnteringState (State)
 Actions to be performed when entering a state.
 
void OnLeavingState (State)
 Actions to be performed when leaving a state.
 

Private Attributes

std::atomic< Statem_state = DETACHED
 current plugin state, normal plugin start sets detached state
 
std::mutex m_eventMutex
 mutex to protect event queue
 
bool m_needsMakePrimary = false
 
cDvbSpuDecoder * m_pSpuDecoder
 pointer to spu decoder
 
cSoftHdConfigm_pConfig
 pointer to cSoftHdConfig object
 
cVideoRenderm_pRender
 pointer to cVideoRender object
 
cVideoStreamm_pVideoStream
 pointer to main video stream
 
cSoftHdAudiom_pAudio
 pointer to cSoftHdAudio object
 
cAudioDecoderm_pAudioDecoder = nullptr
 pointer to cAudioDecoder object
 
cSoftOsdProviderm_pOsdProvider = nullptr
 pointer to cSoftOsdProvider object
 
cReassemblyBufferVideo m_videoReassemblyBuffer
 video pes reassembly buffer
 
cReassemblyBufferAudio m_audioReassemblyBuffer
 audio pes reassembly buffer
 
cJitterTracker m_audioJitterTracker {"audio"}
 audio jitter tracker
 
cJitterTracker m_videoJitterTracker {"video"}
 video jitter tracker
 
std::atomic< PlaybackModem_playbackMode = NONE
 current playback mode
 
int m_audioChannelID = -1
 current audio channel ID
 
cSoftHdGrabm_pGrab
 pointer to grabber object
 
cVideoStreamm_pPipStream
 pointer to pip video stream
 
cReassemblyBufferVideo m_pipReassemblyBuffer
 pip pes reassembly buffer
 
cPipHandlerm_pPipHandler = nullptr
 pointer to pip handler
 
std::mutex m_mutex
 mutex to lock the state machine
 
std::mutex m_sizeMutex
 mutex to lock screen size (which is accessed by different threads)
 
std::atomic< bool > m_receivedAudio = false
 flag if audio packets have been received
 
std::atomic< bool > m_receivedVideo = false
 flag if video packets have been received
 
bool m_pipUseAlt
 use alternative pip position
 
bool m_drmCanDisplayPip = true
 true, if the drm device is able to display a pip video
 
bool m_disablePip = false
 true, if pip was disabled by the user
 
int m_screenWidth
 
int m_screenHeight
 
double m_screenRefreshRateHz
 
bool m_forceDetached = false
 start the plugin in detached state
 

Static Private Attributes

static constexpr int MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS = 450
 min buffering threshold in ms
 

Detailed Description

Definition at line 109 of file softhddevice.h.

Constructor & Destructor Documentation

◆ cSoftHdDevice()

cSoftHdDevice::cSoftHdDevice ( cSoftHdConfig config)

cSoftHdDevice constructor

Initializes some member variables

Parameters
configpointer to cSoftHdConfig class

Definition at line 62 of file softhddevice.cpp.

◆ ~cSoftHdDevice()

cSoftHdDevice::~cSoftHdDevice ( void  )
virtual

cSoftHdDevice destructor

only deletes spu decoder, which was created in constructor

Definition at line 75 of file softhddevice.cpp.

References LOGDEBUG, and m_pSpuDecoder.

Member Function Documentation

◆ Attach()

void cSoftHdDevice::Attach ( void  )

Attach the device again.

Kind of a plugin restart. Inits and starts all necessary resources. Only valid after a detach.

Definition at line 1659 of file softhddevice.cpp.

References m_forceDetached, m_needsMakePrimary, MakePrimaryDevice(), and OnEventReceived().

Referenced by cSoftHdMenu::HandleHotKey(), and cPluginSoftHdDevice::SVDRPCommand().

◆ Audio()

cSoftHdAudio * cSoftHdDevice::Audio ( void  )
inline

Definition at line 176 of file softhddevice.h.

References m_pAudio.

◆ CanReplay()

bool cSoftHdDevice::CanReplay ( void  ) const
virtual

Returns true if this device can currently start a replay session.

Definition at line 157 of file softhddevice.cpp.

References IsDetached(), and LOGDEBUG.

◆ CanScaleVideo()

cRect cSoftHdDevice::CanScaleVideo ( const cRect &  ,
int  taCenter 
)
virtual

Ask the output, if it can scale video.

Parameters
rectrequested video window rectangle
Returns
the real rectangle or cRect::NULL if invalid

Definition at line 1303 of file softhddevice.cpp.

◆ Clear()

◆ ClearAudio()

void cSoftHdDevice::ClearAudio ( void  )
private

Clear all audio data from the decoder and ringbuffer.

Definition at line 104 of file softhddevice.cpp.

References cSoftHdAudio::FlushBuffers(), cAudioDecoder::FlushBuffers(), LOGDEBUG, m_audioReassemblyBuffer, m_pAudio, m_pAudioDecoder, and cReassemblyBuffer::Reset().

Referenced by Clear(), and OnEnteringState().

◆ CommandLineHelp()

const char * cSoftHdDevice::CommandLineHelp ( void  )

Return command line help string.

Definition at line 1331 of file softhddevice.cpp.

Referenced by cPluginSoftHdDevice::CommandLineHelp().

◆ Config()

cSoftHdConfig * cSoftHdDevice::Config ( void  )
inline

Definition at line 173 of file softhddevice.h.

References m_pConfig.

◆ Detach()

void cSoftHdDevice::Detach ( void  )

Detach the device.

Clears audio and video, stops all threads and releases drm/alsa. A detached state can only be exited (restarted) with an AttachEvent.

Definition at line 1638 of file softhddevice.cpp.

References LOGDEBUG, m_needsMakePrimary, MakePrimaryDevice(), and OnEventReceived().

Referenced by cSoftHdMenu::HandleHotKey(), cSoftHdMenu::ProcessKey(), and cPluginSoftHdDevice::SVDRPCommand().

◆ DeviceName()

virtual cString cSoftHdDevice::DeviceName ( void  ) const
inlinevirtual

Definition at line 122 of file softhddevice.h.

◆ Flush()

bool cSoftHdDevice::Flush ( int  timeout = 0)
virtual

Flush the device output buffers.

Parameters
timeout_mstimeout in ms to become ready

Definition at line 834 of file softhddevice.cpp.

References cVideoStream::GetAvPacketsFilled(), IsDetached(), LOGDEBUG, and m_pVideoStream.

◆ Freeze()

void cSoftHdDevice::Freeze ( void  )
virtual

Puts the device into "freeze frame" mode.

Definition at line 743 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cSoftHdControl::ProcessKey().

◆ GetAudioChannelDevice()

int cSoftHdDevice::GetAudioChannelDevice ( void  )
virtual

Definition at line 1058 of file softhddevice.cpp.

◆ GetBufferFillLevelThresholdMs()

int cSoftHdDevice::GetBufferFillLevelThresholdMs ( )
private

Returns the buffer fill level threshold in milliseconds.

Combines the minimum threshold with the user-configured additional buffer length.

Definition at line 1684 of file softhddevice.cpp.

References cSoftHdConfig::ConfigAdditionalBufferLengthMs, m_pConfig, and MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS.

Referenced by IsBufferingThresholdReached().

◆ GetFirstAudioPtsMsToPlay()

int64_t cSoftHdDevice::GetFirstAudioPtsMsToPlay ( )
private

Calculate the first audio PTS that should be played during synchronized playback.

This method determines the starting audio presentation timestamp when transitioning from BUFFERING to PLAY state. It synchronizes audio with video by taking the maximum of both output PTSes, then adjusts for user-configured audio/video delay.

Returns
The first audio PTS in milliseconds that should be played
Note
Positive ConfigVideoAudioDelayMs means audio is intentionally delayed (video ahead)
Negative ConfigVideoAudioDelayMs means video is intentionally delayed (audio ahead)

Definition at line 1239 of file softhddevice.cpp.

References cSoftHdConfig::ConfigVideoAudioDelayMs, cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), m_pAudio, m_pConfig, and m_pRender.

Referenced by IsBufferingThresholdReached(), and OnEventReceived().

◆ GetFirstVideoPtsMsToPlay()

◆ GetOsdSize()

void cSoftHdDevice::GetOsdSize ( int &  width,
int &  height,
double &  aspectRatio 
)
virtual

Returns the width, height and aspect ratio the OSD.

FIXME: Called every second, for nothing (no OSD displayed)?

Definition at line 908 of file softhddevice.cpp.

References IsDetached(), m_screenHeight, m_screenWidth, and m_sizeMutex.

Referenced by cOglOsd::cOglOsd(), cSoftOsd::Flush(), and GrabImage().

◆ GetSpuDecoder()

cSpuDecoder * cSoftHdDevice::GetSpuDecoder ( void  )
virtual

Get the device SPU decoder.

Returns
a pointer to the device's SPU decoder (or NULL, if thisdevice doesn't have an SPU decoder)

Definition at line 133 of file softhddevice.cpp.

References LOGDEBUG, and m_pSpuDecoder.

◆ GetStats()

void cSoftHdDevice::GetStats ( int *  duped,
int *  dropped,
int *  counter 
)

Get statistics from the renderer.

Parameters
[out]dupedduped frames
[out]droppeddropped frames
[out]countnumber of total rendered frames

Definition at line 1553 of file softhddevice.cpp.

References cVideoRender::GetStats(), and m_pRender.

Referenced by cMenuSetupSoft::Create().

◆ GetSTC()

int64_t cSoftHdDevice::GetSTC ( void  )
virtual

Gets the current System Time Counter, which can be used to synchronize audio, video and subtitles.

Definition at line 591 of file softhddevice.cpp.

References AUDIO_AND_VIDEO, AUDIO_ONLY, AV_NOPTS_VALUE, cSoftHdAudio::GetHardwareOutputPtsTimebaseUnits(), cVideoRender::GetVideoClock(), IsDetached(), m_pAudio, m_playbackMode, m_pRender, NONE, and VIDEO_ONLY.

◆ GetVideoAudioDelayMs()

int cSoftHdDevice::GetVideoAudioDelayMs ( void  )
inline

◆ GetVideoSize()

void cSoftHdDevice::GetVideoSize ( int &  width,
int &  height,
double &  aspectRatio 
)
virtual

Get the video size.

Returns the width, height and aspect ratio of the currently displayed video material

Note
the video_aspect is used to scale the subtitle.

Definition at line 889 of file softhddevice.cpp.

References cVideoStream::GetVideoSize(), IsDetached(), and m_pVideoStream.

◆ GrabImage()

uchar * cSoftHdDevice::GrabImage ( int &  size,
bool  jpeg,
int  quality,
int  width,
int  height 
)
virtual

Grabs the currently visible screen image.

Parameters
sizesize of the returned data
jpegflag true, create JPEG data
qualityJPEG quality
widthnumber of horizontal pixels in the frame
heightnumber of vertical pixels in the frame

Definition at line 1271 of file softhddevice.cpp.

References cSoftHdGrab::Active(), GetOsdSize(), cSoftHdGrab::Image(), IsDetached(), L_GRAB, LOGDEBUG2, LOGWARNING, m_pGrab, cSoftHdGrab::Size(), and cSoftHdGrab::Start().

◆ HandleStillPicture()

void cSoftHdDevice::HandleStillPicture ( const uchar *  data,
int  size 
)
private

The still picture data received from VDR can contain multiple PES packets.

This sends each PES packet's raw data separately to PlayVideo(), and does a flush to display the frame immediately.

Parameters
datapes data of one or more frames
sizelength of data area

Definition at line 776 of file softhddevice.cpp.

References cVideoStream::Flush(), cPes::GetPacketLength(), cPes::IsValid(), LOGWARNING, m_pRender, m_pVideoStream, m_videoReassemblyBuffer, PlayVideoInternal(), cReassemblyBufferVideo::PopAvPacket(), cVideoStream::PushAvPacket(), cVideoStream::ResetInputPts(), cVideoStream::SetDeinterlacerDeactivated(), cVideoRender::SetPlaybackPaused(), and cVideoRender::SetStillpicture().

Referenced by OnEventReceived().

◆ HasDecoder()

bool cSoftHdDevice::HasDecoder ( void  ) const
virtual

Tells whether this device has an MPEG decoder.

Definition at line 145 of file softhddevice.cpp.

References IsDetached().

◆ IsBufferingThresholdReached()

bool cSoftHdDevice::IsBufferingThresholdReached ( void  )

Check if the buffering threshold has been reached.

During the BUFFERING state, this method determines when sufficient audio/video data has been buffered to start playback.

Returns
true if buffering threshold is reached and playback can start, false otherwise

Definition at line 1188 of file softhddevice.cpp.

References AV_NOPTS_VALUE, BUFFERING, GetBufferFillLevelThresholdMs(), GetFirstAudioPtsMsToPlay(), GetFirstVideoPtsMsToPlay(), cSoftHdAudio::GetInputPtsMs(), cVideoStream::GetInputPtsMs(), cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), cVideoStream::HasInputPts(), cSoftHdAudio::HasPts(), cVideoRender::IsOutputBufferFull(), L_AV_SYNC, LOGDEBUG, LOGDEBUG2, m_pAudio, m_pRender, m_pVideoStream, m_receivedAudio, m_receivedVideo, m_state, and Timestamp2String().

Referenced by cVideoRender::DisplayFrame(), and PlayAudio().

◆ IsDetached()

bool cSoftHdDevice::IsDetached ( void  ) const

◆ IsOsdProviderSet()

bool cSoftHdDevice::IsOsdProviderSet ( void  ) const
inline

Definition at line 213 of file softhddevice.h.

References m_pOsdProvider.

Referenced by cSoftOsdProvider::~cSoftOsdProvider().

◆ MakePrimaryDevice()

void cSoftHdDevice::MakePrimaryDevice ( bool  on)
protectedvirtual

Informs a device that it will be the primary device.

Parameters
onflag if becoming or loosing primary

Definition at line 117 of file softhddevice.cpp.

References LOGDEBUG, and m_pOsdProvider.

Referenced by Attach(), and Detach().

◆ OnEnteringState()

◆ OnEventReceived()

void cSoftHdDevice::OnEventReceived ( const Event event)
privatevirtual

Event handler for playback state transitions.

Processes events (Play, Pause, Stop, TrickSpeed, StillPicture) and performs the appropriate state transitions based on the current state. The method halts both display and decoding threads before processing the event and resumes them afterwards to ensure thread-safe state transitions.

Parameters
eventThe event to process (variant type containing specific event data)

Implements IEventReceiver.

Definition at line 176 of file softhddevice.cpp.

References AUDIO_AND_VIDEO, AUDIO_ONLY, BUFFERING, cSoftHdConfig::ConfigVideoAudioDelayMs, cVideoStream::DecodingThreadHalt(), cVideoStream::DecodingThreadResume(), DETACHED, cVideoRender::DisplayThreadHalt(), cVideoRender::DisplayThreadResume(), cSoftHdAudio::DropSamplesOlderThanPtsMs(), EventToString(), GetFirstAudioPtsMsToPlay(), GetFirstVideoPtsMsToPlay(), cSoftHdAudio::GetOutputPtsMs(), cVideoRender::GetOutputPtsMs(), cPipHandler::HandleEvent(), HandleStillPicture(), cVideoStream::HasInputPts(), cSoftHdAudio::HasPts(), cSoftHdAudio::LazyInit(), LOGDEBUG, LOGFATAL, LOGWARNING, m_forceDetached, m_mutex, m_pAudio, m_pConfig, m_playbackMode, m_pPipHandler, m_pRender, m_pVideoStream, m_state, NONE, PIPSTOP, PLAY, cVideoStream::ResetFilterThreadNeededCheck(), cVideoRender::ResetFrameCounter(), cVideoRender::SchedulePlaybackStartAtPtsMs(), cVideoRender::ScheduleResyncAtPtsMs(), cSoftHdAudio::SetPaused(), cVideoRender::SetPlaybackPaused(), cVideoRender::SetScheduleAudioResume(), SetState(), cVideoRender::SetStillpicture(), cVideoRender::SetTrickSpeed(), StateToString(), STOP, TRICK_SPEED, and VIDEO_ONLY.

Referenced by Attach(), Detach(), Freeze(), Play(), PlayAudio(), SetPlayMode(), Start(), StillPicture(), Stop(), and TrickSpeed().

◆ OnLeavingState()

◆ OsdClose()

void cSoftHdDevice::OsdClose ( void  )

◆ OsdDrawARGB()

void cSoftHdDevice::OsdDrawARGB ( int  xi,
int  yi,
int  height,
int  width,
int  pitch,
const uint8_t *  argb,
int  x,
int  y 
)

Draw an OSD pixmap.

Parameters
xix-coordinate in argb image
yiy-coordinate in argb image
heightheight in pixel in argb image
widthwidth in pixel in argb image
pitchpitch of argb image
argb32bit ARGB image data
xx-coordinate on screen of argb image
yy-coordinate on screen of argb image

Definition at line 1437 of file softhddevice.cpp.

References IsDetached(), m_pRender, and cVideoRender::OsdDrawARGB().

Referenced by cOglCmdCopyBufferToOutputFb::Execute(), and cSoftOsd::Flush().

◆ PipChannelChange()

void cSoftHdDevice::PipChannelChange ( int  dir)

◆ PipChannelSwap()

void cSoftHdDevice::PipChannelSwap ( bool  closePip)

◆ PipDisable()

void cSoftHdDevice::PipDisable ( void  )

Definition at line 1721 of file softhddevice.cpp.

References cPipHandler::Disable(), and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipEnable()

void cSoftHdDevice::PipEnable ( void  )

Definition at line 1720 of file softhddevice.cpp.

References cPipHandler::Enable(), and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipIsEnabled()

bool cSoftHdDevice::PipIsEnabled ( void  )

Returns true, if pip is currently enabled.

Definition at line 1709 of file softhddevice.cpp.

References cPipHandler::IsEnabled(), m_mutex, and m_pPipHandler.

Referenced by cPluginSoftHdDevice::SVDRPCommand().

◆ PipSetSize()

void cSoftHdDevice::PipSetSize ( void  )

Definition at line 1726 of file softhddevice.cpp.

References m_pPipHandler, and cPipHandler::SetSize().

Referenced by cMenuSetupSoft::Store().

◆ PipSwapPosition()

void cSoftHdDevice::PipSwapPosition ( void  )

◆ PipToggle()

void cSoftHdDevice::PipToggle ( void  )

Definition at line 1722 of file softhddevice.cpp.

References m_pPipHandler, and cPipHandler::Toggle().

Referenced by cSoftHdMenu::HandleHotKey(), and cSoftHdMenu::ProcessKey().

◆ Play()

void cSoftHdDevice::Play ( void  )
virtual

Sets the device into play mode (after a previous trick mode, or pause)

This is called by VDR via DevicePlay() in the Play() and Goto() call

Definition at line 733 of file softhddevice.cpp.

References OnEventReceived().

Referenced by cSoftHdControl::ProcessKey().

◆ PlayAudio()

int cSoftHdDevice::PlayAudio ( const uchar *  data,
int  size,
uchar  id 
)
virtual

◆ PlayAudioPkts()

int cSoftHdDevice::PlayAudioPkts ( AVPacket *  pkt)

Play an audio packet.

Parameters
pktAVPacket to play
Return values
0packet could not be player, free audio buffer too small
1packet was sent to be decoded

Definition at line 1599 of file softhddevice.cpp.

References cAudioDecoder::Decode(), cSoftHdAudio::IsBufferFull(), cSoftHdAudio::LazyInit(), m_pAudio, and m_pAudioDecoder.

Referenced by cSoftHdPlayer::Play().

◆ PlayPipVideo()

int cSoftHdDevice::PlayPipVideo ( const uchar *  data,
int  size 
)

Play a video packet of the pip videostream.

Parameters
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header

The caller must ensure, that PlayPipVideo() is not called in detached state. (CanReplay() and HasDecoder() return false in this state and we are not the primary device.)

Definition at line 1111 of file softhddevice.cpp.

References cVideoStream::IsInputBufferFull(), m_pipReassemblyBuffer, m_pPipStream, and PlayVideoInternal().

Referenced by cPipReceiver::PlayTs().

◆ PlayVideo()

int cSoftHdDevice::PlayVideo ( const uchar *  data,
int  size 
)
virtual

Play a video packet of the main videostream.

Parameters
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header

This is called directly from VDR

The caller must ensure, that PlayVideo() is not called in detached state. (CanReplay() and HasDecoder() return false in this state and we are not the primary device.)

Definition at line 1090 of file softhddevice.cpp.

References IsDetached(), m_pVideoStream, m_receivedVideo, m_videoReassemblyBuffer, and PlayVideoInternal().

◆ PlayVideoInternal()

int cSoftHdDevice::PlayVideoInternal ( cVideoStream stream,
cReassemblyBufferVideo buffer,
const uchar *  data,
int  size,
bool  trackJitter 
)
private

Play a video packet.

Parameters
streamvideo stream to play to
bufferreassembly buffer for this stream
dataA complete PES packet with optionally fragmented payload
sizethe length of the PES packet including header
trackJitterwhether to track jitter for this packet

Definition at line 1134 of file softhddevice.cpp.

References cReassemblyBuffer::GetCodec(), cVideoStream::GetCodecId(), cPes::GetPayload(), cPes::GetPayloadSize(), cPes::GetPts(), cReassemblyBufferVideo::HasLeadingZero(), cPes::HasPts(), cReassemblyBuffer::IsEmpty(), cVideoStream::IsInputBufferFull(), cPes::IsValid(), m_videoJitterTracker, cVideoStream::Open(), cJitterTracker::PacketReceived(), cReassemblyBufferVideo::ParseCodecHeader(), cReassemblyBufferVideo::PopAvPacket(), PrintStreamData(), cReassemblyBuffer::Push(), cVideoStream::PushAvPacket(), and cReassemblyBuffer::Reset().

Referenced by HandleStillPicture(), PlayPipVideo(), and PlayVideo().

◆ PlayVideoPkts()

int cSoftHdDevice::PlayVideoPkts ( AVPacket *  pkt)

Play a video packet.

Parameters
pktAVPacket to play
Return values
0packet could not be player, free audio buffer too small
1packet was sent to be decoded

Definition at line 1619 of file softhddevice.cpp.

References cVideoStream::GetAvPacketsFilled(), cSoftHdAudio::LazyInit(), m_pAudio, m_pVideoStream, cVideoStream::PushAvPacket(), and VIDEO_PACKET_MAX.

Referenced by cSoftHdPlayer::Play().

◆ Poll()

bool cSoftHdDevice::Poll ( cPoller &  ,
int  = 0 
)
virtual

Returns true if the device itself or any of the file handles in Poller is ready for further action.

If TimeoutMs is not zero, the device will wait up to the given number of milliseconds before returning in case it can't accept any data.

Parameters
pollerfile handles (unused)
timeoutMstimeout in ms to become ready
Return values
trueif ready
falseif busy

Definition at line 815 of file softhddevice.cpp.

References cSoftHdAudio::IsBufferFull(), IsDetached(), cVideoStream::IsInputBufferFull(), m_pAudio, and m_pVideoStream.

◆ ProcessArgs()

int cSoftHdDevice::ProcessArgs ( int  argc,
char *  argv[] 
)

Process the command line arguments.

Parameters
argcnumber of arguments
argvarguments vector

Definition at line 1352 of file softhddevice.cpp.

References cSoftHdConfig::ConfigAudioMixerChannel, cSoftHdConfig::ConfigAudioPassthroughDevice, cSoftHdConfig::ConfigAudioPCMDevice, cSoftHdConfig::ConfigDisplayResolution, m_disablePip, m_forceDetached, and m_pConfig.

Referenced by cPluginSoftHdDevice::ProcessArgs().

◆ Render()

cVideoRender * cSoftHdDevice::Render ( void  )
inline

Definition at line 175 of file softhddevice.h.

References m_pRender.

◆ ResetChannelId()

void cSoftHdDevice::ResetChannelId ( void  )

Reset the channel ID (restarts audio)

Definition at line 1540 of file softhddevice.cpp.

References LOGDEBUG, and m_audioChannelID.

Referenced by cMenuSetupSoft::Store().

◆ ResetOsdProvider()

void cSoftHdDevice::ResetOsdProvider ( void  )
inline

Definition at line 212 of file softhddevice.h.

References m_pOsdProvider.

Referenced by cSoftOsdProvider::~cSoftOsdProvider().

◆ ResetPipStream()

◆ ScaleVideo()

void cSoftHdDevice::ScaleVideo ( const cRect &  rect = cRect::Null)
virtual

Scale the currently shown video.

Parameters
xvideo window x coordinate OSD relative
yvideo window x coordinate OSD relative
widthvideo window width OSD relative
heightvideo window height OSD relative

Definition at line 1316 of file softhddevice.cpp.

References IsDetached(), L_OSD, LOGDEBUG2, m_pRender, and cVideoRender::SetVideoOutputPosition().

◆ SetAudioChannelDevice()

void cSoftHdDevice::SetAudioChannelDevice ( int  )
virtual

Definition at line 1052 of file softhddevice.cpp.

◆ SetAudioCodec()

void cSoftHdDevice::SetAudioCodec ( enum AVCodecID  codecId,
AVCodecParameters *  par,
AVRational  timebase 
)

Open an audio codec.

Parameters
codecIdaudio codec id
paraudio codec parameters
timebasetimebase

Definition at line 1574 of file softhddevice.cpp.

References m_pAudioDecoder, and cAudioDecoder::Open().

Referenced by cSoftHdPlayer::Play().

◆ SetAudioTrackDevice()

void cSoftHdDevice::SetAudioTrackDevice ( eTrackType  )
virtual

Definition at line 1042 of file softhddevice.cpp.

◆ SetDecoderFallbackToSw()

void cSoftHdDevice::SetDecoderFallbackToSw ( bool  enable)

Force the decoder to fallback to software if the hardware decoder fails after the configured amount of packets were sent and no frame was received.

Definition at line 1516 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDecoderFallbackToSwNumPkts, m_pConfig, m_pVideoStream, and cVideoStream::SetDecoderFallbackToSwNumPkts().

Referenced by cMenuSetupSoft::Store().

◆ SetDecoderNeedsIFrame()

void cSoftHdDevice::SetDecoderNeedsIFrame ( void  )

Forces the h264 decoder to wait for an I-Frame to start.

Definition at line 1497 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDecoderNeedsIFrame, m_pConfig, m_pVideoStream, and cVideoStream::SetStartDecodingWithIFrame().

Referenced by cMenuSetupSoft::Store().

◆ SetDigitalAudioDevice()

void cSoftHdDevice::SetDigitalAudioDevice ( bool  )
virtual

Definition at line 1047 of file softhddevice.cpp.

◆ SetDisableDeint()

void cSoftHdDevice::SetDisableDeint ( void  )

Disables deinterlacer (called from setup menu or conf)

Definition at line 1488 of file softhddevice.cpp.

References cSoftHdConfig::ConfigDisableDeint, cVideoStream::DisableDeint(), m_pConfig, and m_pVideoStream.

Referenced by cMenuSetupSoft::Store().

◆ SetDrmCanDisplayPip()

void cSoftHdDevice::SetDrmCanDisplayPip ( bool  canDisplay)
inline

Definition at line 231 of file softhddevice.h.

References m_drmCanDisplayPip.

Referenced by cVideoRender::Init().

◆ SetParseH264Dimensions()

void cSoftHdDevice::SetParseH264Dimensions ( void  )

Parse the h264 stream width and height before starting the decoder.

Definition at line 1506 of file softhddevice.cpp.

References cSoftHdConfig::ConfigParseH264Dimensions, m_pConfig, m_pVideoStream, and cVideoStream::SetParseH264Dimensions().

Referenced by cMenuSetupSoft::Store().

◆ SetPassthrough()

void cSoftHdDevice::SetPassthrough ( int  mask)

Set the passthrough mask (called from setup menu or conf)

Definition at line 1530 of file softhddevice.cpp.

References m_pAudio, m_pAudioDecoder, cSoftHdAudio::SetPassthrough(), and cAudioDecoder::SetPassthrough().

Referenced by cMenuSetupSoft::Store().

◆ SetPlayMode()

bool cSoftHdDevice::SetPlayMode ( ePlayMode  play_mode)
virtual

Sets the device into the given play mode.

Parameters
play_modenew play mode (Audio/Video/External...)

Definition at line 564 of file softhddevice.cpp.

References LOGDEBUG, LOGERROR, and OnEventReceived().

◆ SetRenderPipActive()

void cSoftHdDevice::SetRenderPipActive ( bool  active)

Definition at line 1719 of file softhddevice.cpp.

References m_pRender, and cVideoRender::SetPipActive().

Referenced by cPipHandler::HandleEnable().

◆ SetRenderPipSize()

void cSoftHdDevice::SetRenderPipSize ( void  )

Wrapper functions for cVideoRender and cPipHandler.

Definition at line 1718 of file softhddevice.cpp.

References m_pipUseAlt, m_pRender, and cVideoRender::SetPipSize().

Referenced by cPipHandler::HandleEvent().

◆ SetScreenSize()

void cSoftHdDevice::SetScreenSize ( int  width,
int  height,
double  refreshRateHz 
)

Set the screen size.

Parameters
widthscreen width
heightscreen height
refreshRateHzscreen refresh rate in Hz

Definition at line 930 of file softhddevice.cpp.

References m_screenHeight, m_screenRefreshRateHz, m_screenWidth, and m_sizeMutex.

Referenced by cVideoRender::SetScreenSize().

◆ SetState()

void cSoftHdDevice::SetState ( State  newState)
private

Sets the device into the given state.

Parameters
newStatenew state

Definition at line 547 of file softhddevice.cpp.

References LOGDEBUG, m_state, OnEnteringState(), OnLeavingState(), and StateToString().

Referenced by Clear(), and OnEventReceived().

◆ SetVideoCodec()

void cSoftHdDevice::SetVideoCodec ( enum AVCodecID  codecId,
AVCodecParameters *  par,
AVRational  timebase 
)

Open a video codec.

Parameters
codecIdvideo codec id
parvideo codec parameters
timebasetimebase

Definition at line 1586 of file softhddevice.cpp.

References m_pVideoStream, and cVideoStream::Open().

Referenced by cSoftHdPlayer::Play().

◆ SetVideoDisplayFormat()

void cSoftHdDevice::SetVideoDisplayFormat ( eVideoDisplayFormat  videoDisplayFormat)
virtual

Sets the video display format.

Parameters
videoDisplayFormatvideo display format Set it to the given one (only useful if this device has an MPEG decoder).

Definition at line 856 of file softhddevice.cpp.

References LOGDEBUG.

Referenced by SetVideoFormat().

◆ SetVideoFormat()

void cSoftHdDevice::SetVideoFormat ( bool  videoFormat16_9)
virtual

Set the video format.

Sets the output video format to either 16:9 or 4:3 (only useful if this device has an MPEG decoder).

Should call SetVideoDisplayFormat

Parameters
videoFormat16_9flag true 16:9.

Definition at line 873 of file softhddevice.cpp.

References LOGDEBUG, and SetVideoDisplayFormat().

◆ SetVolumeDevice()

void cSoftHdDevice::SetVolumeDevice ( int  volume)
virtual

Sets the audio volume on this device (Volume = 0...255).

Parameters
volumedevice volume

Definition at line 1069 of file softhddevice.cpp.

References IsDetached(), LOGDEBUG, m_pAudio, and cSoftHdAudio::SetVolume().

◆ Start()

int cSoftHdDevice::Start ( void  )

Called by VDR when the plugin is started.

Definition at line 84 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cPluginSoftHdDevice::Start().

◆ StillPicture()

void cSoftHdDevice::StillPicture ( const uchar *  data,
int  size 
)
virtual

Display the given I-frame as a still picture.

Parameters
datapes or ts data of a frame
lengthlength of data area

Definition at line 757 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

◆ Stop()

void cSoftHdDevice::Stop ( void  )

Called by VDR when the plugin is stopped.

Definition at line 95 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

Referenced by cPluginSoftHdDevice::Stop().

◆ ToggleRenderPipPosition()

void cSoftHdDevice::ToggleRenderPipPosition ( void  )
inline

Definition at line 234 of file softhddevice.h.

References m_pipUseAlt.

Referenced by cPipHandler::HandleEvent().

◆ TrickSpeed()

void cSoftHdDevice::TrickSpeed ( int  speed,
bool  forward 
)
virtual

Sets the device into a mode where replay is done slower.

Every single frame shall then be displayed the given number of times. Forward is true if replay is done in the normal (forward) direction, false if it is done reverse. The cDvbPlayer uses the following values for the various speeds: 1x 2x 3x Fast Forward 6 3 1 Fast Reverse 6 3 1 Slow Forward 8 4 2 Slow Reverse 63 48 24

Definition at line 621 of file softhddevice.cpp.

References LOGDEBUG, and OnEventReceived().

◆ UsePip()

◆ VideoStream()

cVideoStream * cSoftHdDevice::VideoStream ( void  )
inline

Definition at line 174 of file softhddevice.h.

References m_pVideoStream.

Referenced by cVideoRender::DisplayFrame(), and cVideoRender::LogDroppedDuped().

Member Data Documentation

◆ m_audioChannelID

int cSoftHdDevice::m_audioChannelID = -1
private

current audio channel ID

Definition at line 255 of file softhddevice.h.

Referenced by PlayAudio(), and ResetChannelId().

◆ m_audioJitterTracker

cJitterTracker cSoftHdDevice::m_audioJitterTracker {"audio"}
private

audio jitter tracker

Definition at line 251 of file softhddevice.h.

Referenced by OnEnteringState(), and PlayAudio().

◆ m_audioReassemblyBuffer

cReassemblyBufferAudio cSoftHdDevice::m_audioReassemblyBuffer
private

audio pes reassembly buffer

Definition at line 250 of file softhddevice.h.

Referenced by ClearAudio(), and PlayAudio().

◆ m_disablePip

bool cSoftHdDevice::m_disablePip = false
private

true, if pip was disabled by the user

Definition at line 267 of file softhddevice.h.

Referenced by ProcessArgs(), and UsePip().

◆ m_drmCanDisplayPip

bool cSoftHdDevice::m_drmCanDisplayPip = true
private

true, if the drm device is able to display a pip video

Definition at line 266 of file softhddevice.h.

Referenced by SetDrmCanDisplayPip(), and UsePip().

◆ m_eventMutex

std::mutex cSoftHdDevice::m_eventMutex
private

mutex to protect event queue

Definition at line 240 of file softhddevice.h.

◆ m_forceDetached

bool cSoftHdDevice::m_forceDetached = false
private

start the plugin in detached state

Definition at line 273 of file softhddevice.h.

Referenced by Attach(), OnEventReceived(), and ProcessArgs().

◆ m_mutex

std::mutex cSoftHdDevice::m_mutex
mutableprivate

mutex to lock the state machine

Definition at line 261 of file softhddevice.h.

Referenced by IsDetached(), OnEventReceived(), and PipIsEnabled().

◆ m_needsMakePrimary

bool cSoftHdDevice::m_needsMakePrimary = false
private

Definition at line 241 of file softhddevice.h.

Referenced by Attach(), and Detach().

◆ m_pAudio

◆ m_pAudioDecoder

cAudioDecoder* cSoftHdDevice::m_pAudioDecoder = nullptr
private

◆ m_pConfig

◆ m_pGrab

cSoftHdGrab* cSoftHdDevice::m_pGrab
private

pointer to grabber object

Definition at line 256 of file softhddevice.h.

Referenced by GrabImage(), OnEnteringState(), and OnLeavingState().

◆ m_pipReassemblyBuffer

cReassemblyBufferVideo cSoftHdDevice::m_pipReassemblyBuffer
private

pip pes reassembly buffer

Definition at line 259 of file softhddevice.h.

Referenced by PlayPipVideo(), and ResetPipStream().

◆ m_pipUseAlt

bool cSoftHdDevice::m_pipUseAlt
private

use alternative pip position

Definition at line 265 of file softhddevice.h.

Referenced by SetRenderPipSize(), and ToggleRenderPipPosition().

◆ m_playbackMode

std::atomic<PlaybackMode> cSoftHdDevice::m_playbackMode = NONE
private

current playback mode

Definition at line 254 of file softhddevice.h.

Referenced by Clear(), GetSTC(), OnEnteringState(), and OnEventReceived().

◆ m_pOsdProvider

cSoftOsdProvider* cSoftHdDevice::m_pOsdProvider = nullptr
private

pointer to cSoftOsdProvider object

Definition at line 248 of file softhddevice.h.

Referenced by IsOsdProviderSet(), MakePrimaryDevice(), OnEnteringState(), and ResetOsdProvider().

◆ m_pPipHandler

cPipHandler* cSoftHdDevice::m_pPipHandler = nullptr
private

◆ m_pPipStream

cVideoStream* cSoftHdDevice::m_pPipStream
private

pointer to pip video stream

Definition at line 258 of file softhddevice.h.

Referenced by OnEnteringState(), OnLeavingState(), PlayPipVideo(), and ResetPipStream().

◆ m_pRender

◆ m_pSpuDecoder

cDvbSpuDecoder* cSoftHdDevice::m_pSpuDecoder
private

pointer to spu decoder

Definition at line 242 of file softhddevice.h.

Referenced by GetSpuDecoder(), and ~cSoftHdDevice().

◆ m_pVideoStream

◆ m_receivedAudio

std::atomic<bool> cSoftHdDevice::m_receivedAudio = false
private

flag if audio packets have been received

Definition at line 263 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), OnLeavingState(), and PlayAudio().

◆ m_receivedVideo

std::atomic<bool> cSoftHdDevice::m_receivedVideo = false
private

flag if video packets have been received

Definition at line 264 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), OnLeavingState(), and PlayVideo().

◆ m_screenHeight

int cSoftHdDevice::m_screenHeight
private

Definition at line 270 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_screenRefreshRateHz

double cSoftHdDevice::m_screenRefreshRateHz
private

Definition at line 271 of file softhddevice.h.

Referenced by SetScreenSize().

◆ m_screenWidth

int cSoftHdDevice::m_screenWidth
private

Definition at line 269 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_sizeMutex

std::mutex cSoftHdDevice::m_sizeMutex
private

mutex to lock screen size (which is accessed by different threads)

Definition at line 262 of file softhddevice.h.

Referenced by GetOsdSize(), and SetScreenSize().

◆ m_state

std::atomic<State> cSoftHdDevice::m_state = DETACHED
private

current plugin state, normal plugin start sets detached state

Definition at line 239 of file softhddevice.h.

Referenced by IsBufferingThresholdReached(), IsDetached(), OnEventReceived(), and SetState().

◆ m_videoJitterTracker

cJitterTracker cSoftHdDevice::m_videoJitterTracker {"video"}
private

video jitter tracker

Definition at line 252 of file softhddevice.h.

Referenced by OnEnteringState(), and PlayVideoInternal().

◆ m_videoReassemblyBuffer

cReassemblyBufferVideo cSoftHdDevice::m_videoReassemblyBuffer
private

video pes reassembly buffer

Definition at line 249 of file softhddevice.h.

Referenced by Clear(), HandleStillPicture(), OnEnteringState(), and PlayVideo().

◆ MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS

constexpr int cSoftHdDevice::MIN_BUFFER_FILL_LEVEL_THRESHOLD_MS = 450
staticconstexprprivate

min buffering threshold in ms

Definition at line 237 of file softhddevice.h.

Referenced by GetBufferFillLevelThresholdMs().


The documentation for this class was generated from the following files: