CARMA C++
carma::clock::ClockMaster Class Reference

Carma Master Clock CAN Master class. More...

#include <carma/clock/ClockMaster.h>

Inheritance diagram for carma::clock::ClockMaster:
carma::canbus::Master carma::canbus::CanDio carma::canbus::CanIo carma::canbus::CanOutput

Public Member Functions

carma::clock::ClockControl_ptr Clock ()
 
 ClockMaster (bool enableAutowriter, double autoWriteDelayInS)
 Default constructor for emulation. More...
 
 ClockMaster (int modulBusNo, int slotNo, double autoWriteDelayInS)
 Clock Master constructor. More...
 
 ClockMaster (int modulBusNo, double autoWriteDelayInS)
 Clock Master constructor. More...
 
carma::clock::ClockControl_ptr GlobalClock ()
 
bool isDone ()
 Query to see if the System::quit() method has been invoked. More...
 
void quit ()
 
void reset ()
 
void softReset ()
 
virtual ~ClockMaster ()
 Destructor. More...
 
- Public Member Functions inherited from carma::canbus::Master
 Master (bool simOfflineNodes=true)
 Default constructor for emulation. More...
 
 Master (int boardId, bool simOfflineNodes=false, bool reset=false, bool terminate=true)
 Master constructor. More...
 
 Master (int boardId, int modulbusId, bool simOfflineNodes=false, bool reset=false, bool terminate=true)
 Master constructor. More...
 
 Master (const ::std::vector< DevTermPair > &devTermPairs, bool simOfflineNodes=false, bool reset=false)
 Constructor for arbitrary number of CanDio ports. More...
 
void run ()
 Run the Master. More...
 
void stop ()
 Stop running internal Master threads. More...
 
virtual ~Master ()
 Master destructor. More...
 
- Public Member Functions inherited from carma::canbus::CanDio
 CanDio ()
 Default constructor. More...
 
 CanDio (int boardId, bool reset=true, bool terminate=true)
 Constructor to control both CAN busses on a single board. More...
 
 CanDio (int boardId, int slotId, bool reset=true, bool terminate=true)
 Constructor to control a single CAN bus. More...
 
 CanDio (const std::vector< DevTermPair > &devTermPairs, bool reset=true)
 Constructor to control arbitrary number of CAN busses. More...
 
void echoAll (bool enable)
 Enable or disable echoing sent messages back through the read interface. More...
 
std::map< busIdType,
carma::canbus::busStatusType
getBusStatus ()
 
carma::canbus::Message getMessage ()
 Retrieve a CAN message. More...
 
bool isTerminated ()
 Return termination state. More...
 
void postMessage (const carma::canbus::Message &msg, carma::canbus::txPriorityType prio=carma::canbus::NORMAL)
 Post a CAN message. More...
 
void reset ()
 Reset. More...
 
- Public Member Functions inherited from carma::canbus::CanIo
virtual BusStatusMap getBusStatus () const
 Retrieve bus statistics. More...
 
virtual ~CanIo ()
 Virtual destructor. More...
 

Protected Member Functions

void updateStatus ()
 Update the status of the Clock CAN Master. More...
 
- Protected Member Functions inherited from carma::canbus::Master
void addDevice (Device *device)
 Add a device to the master. More...
 
virtual std::map< msgType,
std::string > 
getControls () const
 Get controls. More...
 
DevicegetDevice (apiType api, nodeType node)
 Get pointer to a device. More...
 
int getDonglelessPacketCount () const
 Get 'Dongleless node' packet count This routine returns the number of Dongleless node packets detected by Master. More...
 
unsigned int getLatePacketCount ()
 Get combined late packet count from all devices. More...
 
int getOfflineNodeCount () const
 Get number of offline nodes. More...
 
int getOnlineNodeCount () const
 Get number of online nodes. More...
 
int getUnknownPacketCount () const
 Get number of unknown packets This method returns the number of CAN packets that canbus::Master does not recognize. More...
 
 Master (const Master &)
 
Masteroperator= (const Master &)
 
void removeDevice (apiType api, nodeType node)
 Remove a device. More...
 
virtual void runReadThread ()
 Thread to read and process incoming CAN messages. More...
 
void runTimerThread ()
 Timer thread. More...
 
virtual void setTime ()
 Send a time sync message. More...
 
void softwareReset ()
 Send a software reset command to all modules. More...
 
void updateDevicesStates ()
 Update the devices states. More...
 
- Protected Member Functions inherited from carma::canbus::CanDio
void clearReadQueue ()
 Clear any underlying read buffers. More...
 
void queueMessage (const Message &msg)
 Queue CAN message to be read for simulation purposes. More...
 
void setTimestampEchoLatency (int tsLatency, busIdType busId)
 Set timestamp echo latency. More...
 

Additional Inherited Members

- Public Types inherited from carma::canbus::CanDio
typedef ::std::pair< int, int > BoardSlotPair
 Pair containing boardId (first) and slotId (second). More...
 
typedef ::std::pair
< BoardSlotPair, bool > 
DevTermPair
 Pair for board & slot (first) and termination setting (second). More...
 
- Static Protected Member Functions inherited from carma::canbus::Master
static void * readThreadEntry (void *arg)
 Entry point for main thread. More...
 
static void * timerThreadEntry (void *arg)
 Entry point for timer thread. More...
 
- Protected Attributes inherited from carma::canbus::Master
pthread_mutex_t deviceMutex_
 
std::map< keyType, Device * > devices_
 
int nDonglelessPackets_
 
int nOfflineNodes_
 
int nOnlineNodes_
 
int nUnknownPackets_
 
pthread_t readThreadId_
 
bool running_
 
carma::util::PthreadMutex runningMutex_
 
const int simOfflineNodes_
 
pthread_t timerThreadId_
 
- Protected Attributes inherited from carma::canbus::CanDio
std::auto_ptr
< carma::canbus::CanIo
cio_
 
std::auto_ptr< carma::canbus::Diodio_
 
const long pulseWidth_
 Reset pulsewidth. More...
 
const bool terminate_
 

Detailed Description

Carma Master Clock CAN Master class.

This class realizes the carma::canbus::Master class for the Carma Master Clock CANbus system.

Definition at line 31 of file ClockMaster.h.

Constructor & Destructor Documentation

carma::clock::ClockMaster::ClockMaster ( bool  enableAutowriter,
double  autoWriteDelayInS 
)

Default constructor for emulation.

This constructor is for emulation only when it is not desired or not possible to communicate with the underlying Janz hardware (i.e. the Janz hardware doesn't exist on the system). In this mode all DOs are still published, and remote method invocations are still possible. However, CANbus writes will go to /dev/null rather than the CANbus.

Parameters
autoWriteDelayInSMonitor system autowrite delay in seconds.
See Also
carma::canbus::Master::Master()
carma::clock::ClockMaster::ClockMaster ( int  modulBusNo,
int  slotNo,
double  autoWriteDelayInS 
)

Clock Master constructor.

Constructor for use with a single CANbus. This constructor should only be used during initial integration and testing when there are not yet enough CAN modules to utilize two busses.

Parameters
modulBusNoJanz modulBus board designator (0 - 15).
slotNoJanz modulBus slot # of CAN card to use (0 or 1).
autoWriteDelayInSMonitor system autowrite delay in seconds.
carma::clock::ClockMaster::ClockMaster ( int  modulBusNo,
double  autoWriteDelayInS 
)

Clock Master constructor.

Constructor for use with two CANbusses. It controls both CANbusses on the Carma specialized Janz Can/Dio board.

Parameters
modulBusNoJanz modulBus board designator (0 - 15).
autoWriteDelayInSMonitor system autowrite delay in seconds.
virtual carma::clock::ClockMaster::~ClockMaster ( )
virtual

Destructor.

Member Function Documentation

bool carma::clock::ClockMaster::isDone ( )

Query to see if the System::quit() method has been invoked.

This routine is for DEBUG USE ONLY to explicitly determine if a user has invoked the carma::clock::System::quit() method

void carma::clock::ClockMaster::updateStatus ( )
protectedvirtual

Update the status of the Clock CAN Master.

This routine is responsible for retrieving values specific to the state of the CanMaster object and the CANbus(ses) themselves such as number of online nodes, CANbus errors, etc. It retrieves these values and places them into the monitor stream. The method is called internally my the canbus::Master base class every half second as described in carma::canbus::Master.

Implements carma::canbus::Master.


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