ADTF
IReferenceClockabstract

The IReferenceClock interface provides the reference time source for the filter graph. More...

Inheritance diagram for IReferenceClock:
[legend]

Public Types

enum class  tTimeBase : uint8_t { UNSPECIFIED , POSIX_UTC , POSIX_TAI }
 The time bases of a timestamp. More...
 
- Public Types inherited from IReferenceClock
enum  tReferenceClockEventId { EVENT_TimeResetBegin = 0x0000 , EVENT_TimeResetEnd = 0x0001 , EVENT_TimeUpdate = 0x0004 }
 Event Id enumeration for the tReferenceClockEvent::nEventId. More...
 

Public Member Functions

 ADTF_IID (IReferenceClock, "reference_clock.riddler.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual tResult GetSync2RefChannel (tTimeBase eTimeBase, adtf::ucom::ant::iobject_ptr< IReferenceClock::ISync2RefChannel > &pSync2RefChannel, const char *strName=nullptr) const =0
 Returns a new instance of a Sync2Ref Channel implementation. More...
 
- Public Member Functions inherited from IReferenceClock
 ADTF_IID (IReferenceClock, "reference_clock.penguin.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual tResult GetTimeGuard (const char *strName, ucom::ant::iobject_ptr< ITimeGuard > &pGuard)=0
 Get a new time guard object from the current ADTF Stream Time clock. More...
 
- Public Member Functions inherited from IReferenceClock
 ADTF_IID (IReferenceClock, "reference_clock.osborn.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual tResult ConvertStreamTime (adtf::base::flash::tNanoSeconds tmStreamTime, adtf::base::ant::IString &&strStringRepresentation) const =0
 Converts an absolute timestamp into a textual representation based on the settings of the clock service. More...
 
virtual tResult ConvertStreamTime (const char *strStringRepresentation, adtf::base::flash::tNanoSeconds &tmStreamTime) const =0
 Converts a textual timestamp into an absolute numeric timestamp based on the settings of the clock service. More...
 
virtual tResult ConvertTimeOffset (adtf::base::flash::tNanoSeconds tmOffset, adtf::base::ant::IString &&strStringRepresentation) const =0
 Converts a relative timestamp into a textual representation based on the settings of the clock service. More...
 
virtual tResult ConvertTimeOffset (const char *strStringRepresentation, adtf::base::flash::tNanoSeconds &tmOffset) const =0
 Converts a textual timestamp into a relative numeric timestamp based on the settings of the clock service. More...
 
virtual tResult GetSync2RefChannel (bool bSystemClockTimestamps, adtf::ucom::ant::iobject_ptr< giant::IReferenceClock::ISync2RefChannel > &pSync2RefChannel, const char *strName=nullptr) const =0
 Returns a new instance of a Sync2Ref Channel implementation. More...
 
- Public Member Functions inherited from IReferenceClock
 ADTF_IID (IReferenceClock, "reference_clock.giant.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual tResult GetSync2RefChannel (adtf::ucom::ant::iobject_ptr< ISync2RefChannel > &pSync2RefChannel, const char *strName=nullptr, const char *strMethod=nullptr) const =0
 
- Public Member Functions inherited from IReferenceClock
 ADTF_IID (IReferenceClock, "reference_clock.flash.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual base::flash::tNanoSeconds GetTimeNs () const =0
 
virtual base::flash::tNanoSeconds GetStreamTimeNs () const =0
 
virtual tResult GetSync2RefChannel (adtf::ucom::ant::iobject_ptr< ISync2RefChannel > &pSync2RefChannel, const char *strName=nullptr, const char *strMethod=nullptr) const =0
 
- Public Member Functions inherited from IReferenceClock
 ADTF_IID (IReferenceClock, "reference_clock.ant.streaming.adtf.iid")
 Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast. More...
 
virtual tTimeStamp GetTime () const =0
 Retrieves the current reference time. More...
 
virtual tTimeStamp GetStreamTime () const =0
 Retrieves the stream time which is reset at the start of the stream. More...
 
virtual tResult RegisterClock (const adtf::ucom::ant::iobject_ptr< IClock > &pClock)=0
 Registers a new clock. More...
 
virtual tResult UnregisterClock (const adtf::ucom::ant::iobject_ptr< IClock > &pClock)=0
 Unregisters a clock. More...
 
virtual tResult GetClocks (IClockListCallback &oCallback) const =0
 Lists all available clocks. More...
 
virtual tResult GetClock (const char *strName, adtf::ucom::ant::iobject_ptr< IClock > &pClock) const =0
 Find a clock. More...
 
virtual tResult SetMainClock (const char *strName)=0
 This will change the main clock to the given clock. More...
 
virtual tResult GetMainClock (adtf::base::ant::IString &&strName) const =0
 Retrieves the name of the current main clock. More...
 
virtual tResult SetStreamClock (const char *strName)=0
 Sets the clock of which the time is returned by adtf::services::ant::IReferenceClock::GetStreamTime. More...
 
virtual tResult GetStreamClock (adtf::base::ant::IString &&strName) const =0
 Retrieves the name of the current stream clock. More...
 
virtual tResult RegisterSync2RefFactory (const adtf::ucom::ant::iobject_ptr< ISync2RefChannelFactory > &oSync2RefFactory)=0
 Registers a new Sync2Ref channel factory. More...
 
virtual tResult UnregisterSync2RefFactory (const adtf::ucom::ant::iobject_ptr< ISync2RefChannelFactory > &oSync2RefFactory)=0
 Unregisters a Sync2Ref channel factory. More...
 
virtual tResult ListSync2RefMethods (ISync2RefListCallback &oCallback)=0
 Lists all available Sync2Ref methods. More...
 
virtual tResult GetSync2RefChannel (adtf::ucom::ant::iobject_ptr< ISync2RefChannel > &pSync2RefChannel, const char *strName=nullptr, const char *strMethod=nullptr) const =0
 Returns a new instance of a Sync2Ref Channel implementation. More...
 
- Public Member Functions inherited from IObject
 ADTF_IID (IObject, "object.ant.ucom.adtf.iid")
 Marks the IObject to be castable with the ucom_cast() More...
 

Protected Member Functions

 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IReferenceClock
 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IReferenceClock
 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IReferenceClock
 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IReferenceClock
 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IReferenceClock
 ~IReferenceClock ()=default
 not destructable
 
- Protected Member Functions inherited from IObject
 ~IObject ()=default
 Protected destructor --> Use implemented Destroy() instead of delete!
 

Additional Inherited Members

- Static Public Attributes inherited from IReferenceClock
static const int ADTF_MAX_CLOCK_NAME_LENGTH = 256
 The maximum length of clock names, due to length restrictions when storing names in the clock extension of DAT files.
 

Detailed Description

The IReferenceClock interface provides the reference time source for the filter graph.

See also Clock Concept for further information on timings within ADTF. Default implementation of provide service is reached by CID_ADTF_REFERENCE_CLOCK.

Definition at line 704 of file reference_clock_intf.h.

Member Enumeration Documentation

◆ tTimeBase

enum tTimeBase : uint8_t
strong

The time bases of a timestamp.

Enumerator
UNSPECIFIED 

no timebase specified

POSIX_UTC 

Posix UTC timebase.

POSIX_TAI 

Posix TAI timebase.

Definition at line 720 of file reference_clock_intf.h.

Member Function Documentation

◆ ADTF_IID()

ADTF_IID ( IReferenceClock  ,
"reference_clock.riddler.streaming.adtf.iid"   
)

Marks the IReferenceClock to be castable with the adtf::ucom::ant::ucom_cast.

See also
ADTF_IID(_interface, _striid)

◆ GetSync2RefChannel()

virtual tResult GetSync2RefChannel ( tTimeBase  eTimeBase,
adtf::ucom::ant::iobject_ptr< IReferenceClock::ISync2RefChannel > &  pSync2RefChannel,
const char *  strName = nullptr 
) const
pure virtual

Returns a new instance of a Sync2Ref Channel implementation.

If the given timestamps are TAI based then the returned timestamps are incremented by the corresponding leap seconds

Parameters
[in]eTimeBaseDescribes the timeBase (UTC/TAI) of the timestamps you want to synchronize.
[out]pSync2RefChannelThe pointer to the new instance.
[in]strNameAn optional name of the channel (for logging purposes, need not be unique)
Returns
Standard result.