$search

EthercatHardware Class Reference

#include <ethercat_hardware.h>

List of all members.

Public Member Functions

void collectDiagnostics ()
 Collects diagnotics from all devices.
 EthercatHardware (const std::string &name)
 Constructor.
void init (char *interface, bool allow_unprogrammed)
 Initialize the EtherCAT Master Library.
void printCounters (std::ostream &os=std::cout)
bool publishTrace (int position, const string &reason, unsigned level, unsigned delay)
 Ask one or all EtherCAT devices to publish (motor) traces.
bool txandrx_PD (unsigned buffer_size, unsigned char *buffer, unsigned tries)
 Send process data.
void update (bool reset, bool halt)
 Send most recent motor commands and retrieve updates. This command must be run at a sufficient rate or else the motors will be disabled.
 ~EthercatHardware ()
 Destructor.

Public Attributes

pr2_hardware_interface::HardwareInterfacehw_

Private Member Functions

EthercatDeviceconfigNonEthercatDevice (const std::string &product_id, const std::string &data)
EthercatDeviceconfigSlave (EtherCAT_SlaveHandler *sh)
void loadNonEthercatDevices ()
void publishDiagnostics ()
 Collects raw diagnostics data and passes it to diagnostics_publisher.

Static Private Member Functions

static void changeState (EtherCAT_SlaveHandler *sh, EC_State new_state)
static void updateAccMax (double &max, const accumulator_set< double, stats< tag::max, tag::mean > > &acc)

Private Attributes

EtherCAT_AL * al_
unsigned int buffer_size_
unsigned char * buffers_
pluginlib::ClassLoader
< EthercatDevice
device_loader_
EthercatHardwareDiagnostics diagnostics_
EthercatHardwareDiagnosticsPublisher diagnostics_publisher_
EtherCAT_Master * em_
bool halt_motors_
string interface_
ros::Time last_published_
ros::Time last_reset_
unsigned max_pd_retries_
 Max number of times to retry sending process data before halting motors.
ros::Time motor_last_published_
realtime_tools::RealtimePublisher
< std_msgs::Bool > 
motor_publisher_
struct netif * ni_
ros::NodeHandle node_
unsigned int num_ethercat_devices_
EthercatOobComoob_com_
unsigned char * prev_buffer_
unsigned int reset_state_
std::vector< EthercatDevice * > slaves_
unsigned char * this_buffer_
unsigned timeout_
 Timeout (in microseconds) to used for sending/recieving packets once in realtime mode.

Detailed Description

Definition at line 202 of file ethercat_hardware.h.


Constructor & Destructor Documentation

EthercatHardware::EthercatHardware ( const std::string &  name  ) 

Constructor.

Definition at line 67 of file ethercat_hardware.cpp.

EthercatHardware::~EthercatHardware (  ) 

Destructor.

Definition at line 78 of file ethercat_hardware.cpp.


Member Function Documentation

void EthercatHardware::changeState ( EtherCAT_SlaveHandler *  sh,
EC_State  new_state 
) [static, private]

Definition at line 99 of file ethercat_hardware.cpp.

void EthercatHardware::collectDiagnostics (  ) 

Collects diagnotics from all devices.

Definition at line 892 of file ethercat_hardware.cpp.

EthercatDevice * EthercatHardware::configNonEthercatDevice ( const std::string &  product_id,
const std::string &  data 
) [private]

Definition at line 796 of file ethercat_hardware.cpp.

EthercatDevice * EthercatHardware::configSlave ( EtherCAT_SlaveHandler *  sh  )  [private]

Definition at line 702 of file ethercat_hardware.cpp.

void EthercatHardware::init ( char *  interface,
bool  allow_unprogrammed 
)

Initialize the EtherCAT Master Library.

Parameters:
interface The socket interface that is connected to the EtherCAT devices (e.g., eth0)
allow_unprogrammed A boolean indicating if the driver should treat the discovery of unprogrammed boards as a fatal error. Set to 'true' during board configuration, and set to 'false' otherwise.

Definition at line 116 of file ethercat_hardware.cpp.

void EthercatHardware::loadNonEthercatDevices (  )  [private]

Definition at line 825 of file ethercat_hardware.cpp.

void EthercatHardware::printCounters ( std::ostream &  os = std::cout  ) 

Definition at line 927 of file ethercat_hardware.cpp.

void EthercatHardware::publishDiagnostics (  )  [private]

Collects raw diagnostics data and passes it to diagnostics_publisher.

Definition at line 675 of file ethercat_hardware.cpp.

bool EthercatHardware::publishTrace ( int  position,
const string &  reason,
unsigned  level,
unsigned  delay 
)

Ask one or all EtherCAT devices to publish (motor) traces.

Parameters:
position device ring position to publish trace for. Use -1 to trigger all devices.
reason Message to put in trace as reason.
level Level to put in trace (aka ERROR=2, WARN=1, OK=0)
delay Publish trace after delay cyles. For 1kHz realtime loop 1cycle = 1ms.
Returns:
Return true if device supports publishing trace. False, if not. If all devices are triggered, returns true if any device publishes trace.

Definition at line 969 of file ethercat_hardware.cpp.

bool EthercatHardware::txandrx_PD ( unsigned  buffer_size,
unsigned char *  buffer,
unsigned  tries 
)

Send process data.

Definition at line 952 of file ethercat_hardware.cpp.

void EthercatHardware::update ( bool  reset,
bool  halt 
)

Send most recent motor commands and retrieve updates. This command must be run at a sufficient rate or else the motors will be disabled.

Parameters:
reset A boolean indicating if the motor controller boards should be reset
halt A boolean indicating if the motors should be halted

Definition at line 544 of file ethercat_hardware.cpp.

void EthercatHardware::updateAccMax ( double &  max,
const accumulator_set< double, stats< tag::max, tag::mean > > &  acc 
) [static, private]

Definition at line 670 of file ethercat_hardware.cpp.


Member Data Documentation

EtherCAT_AL* EthercatHardware::al_ [private]

Definition at line 265 of file ethercat_hardware.h.

unsigned int EthercatHardware::buffer_size_ [private]

Definition at line 275 of file ethercat_hardware.h.

unsigned char* EthercatHardware::buffers_ [private]

Definition at line 274 of file ethercat_hardware.h.

Definition at line 295 of file ethercat_hardware.h.

Definition at line 285 of file ethercat_hardware.h.

Definition at line 286 of file ethercat_hardware.h.

EtherCAT_Master* EthercatHardware::em_ [private]

Definition at line 266 of file ethercat_hardware.h.

Definition at line 277 of file ethercat_hardware.h.

Definition at line 252 of file ethercat_hardware.h.

string EthercatHardware::interface_ [private]

Definition at line 263 of file ethercat_hardware.h.

Definition at line 287 of file ethercat_hardware.h.

Definition at line 288 of file ethercat_hardware.h.

Max number of times to retry sending process data before halting motors.

Definition at line 281 of file ethercat_hardware.h.

Definition at line 291 of file ethercat_hardware.h.

Definition at line 290 of file ethercat_hardware.h.

struct netif* EthercatHardware::ni_ [private]

Definition at line 262 of file ethercat_hardware.h.

Definition at line 260 of file ethercat_hardware.h.

Definition at line 270 of file ethercat_hardware.h.

Definition at line 293 of file ethercat_hardware.h.

unsigned char* EthercatHardware::prev_buffer_ [private]

Definition at line 273 of file ethercat_hardware.h.

unsigned int EthercatHardware::reset_state_ [private]

Definition at line 278 of file ethercat_hardware.h.

std::vector<EthercatDevice*> EthercatHardware::slaves_ [private]

Definition at line 269 of file ethercat_hardware.h.

unsigned char* EthercatHardware::this_buffer_ [private]

Definition at line 272 of file ethercat_hardware.h.

unsigned EthercatHardware::timeout_ [private]

Timeout (in microseconds) to used for sending/recieving packets once in realtime mode.

Definition at line 280 of file ethercat_hardware.h.


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines


ethercat_hardware
Author(s): Rob Wheeler (email: wheeler@willowgarage.com), Maintained by Derek King (email: dking@willowgarage.com)
autogenerated on Fri Mar 1 16:52:17 2013