Public Member Functions | Static Public Member Functions | Private Member Functions | Static Private Attributes | List of all members
dynamixel::Protocol1PacketHandler Class Reference

The class for control Dynamixel by using Protocol1.0. More...

#include <protocol1_packet_handler.h>

Inheritance diagram for dynamixel::Protocol1PacketHandler:
Inheritance graph
[legend]

Public Member Functions

int action (PortHandler *port, uint8_t id)
 The function that makes Dynamixels run as written in the Dynamixel register @description The function makes an instruction packet with INST_ACTION, @description transmits the packet with Protocol1PacketHandler::txRxPacket(). @description To use this function, Dynamixel register should be set by Protocol1PacketHandler::regWriteTxOnly() or Protocol1PacketHandler::regWriteTxRx() More...
 
int broadcastPing (PortHandler *port, std::vector< uint8_t > &id_list)
 (Available only in Protocol 2.0) The function that pings all connected Dynamixel More...
 
int bulkReadTx (PortHandler *port, uint8_t *param, uint16_t param_length)
 (Available only on Dynamixel MX / X series) The function that transmits Bulk Read instruction packet @description The function makes an instruction packet with INST_BULK_READ, @description transmits the packet with Protocol1PacketHandler::txPacket(). More...
 
int bulkWriteTxOnly (PortHandler *port, uint8_t *param, uint16_t param_length)
 (Available only in Protocol 2.0) The function that transmits Bulk Write instruction packet More...
 
int clearMultiTurn (PortHandler *port, uint8_t id, uint8_t *error=0)
 (Available only in Protocol 2.0) The function that reset multi-turn revolution information of Dynamixel More...
 
int factoryReset (PortHandler *port, uint8_t id, uint8_t option, uint8_t *error=0)
 The function that makes Dynamixel reset as it was produced in the factory @description The function makes an instruction packet with INST_FACTORY_RESET, @description transmits the packet with Protocol1PacketHandler::txRxPacket(). @description Be careful of the use. More...
 
float getProtocolVersion ()
 The function that returns Protocol version used in Protocol1PacketHandler (1.0) More...
 
const char * getRxPacketError (uint8_t error)
 The function that gets description of hardware error. More...
 
const char * getTxRxResult (int result)
 The function that gets description of communication result. More...
 
int ping (PortHandler *port, uint8_t id, uint16_t *model_number, uint8_t *error=0)
 The function that pings Dynamixel and takes its model number @description The function makes an instruction packet with INST_PING, @description transmits the packet with Protocol1PacketHandler::txRxPacket(), @description and call Protocol1PacketHandler::readTxRx to read model_number in the rx buffer. @description It breaks out @description when it tries to transmit to BROADCAST_ID. More...
 
int ping (PortHandler *port, uint8_t id, uint8_t *error=0)
 The function that pings Dynamixel but doesn't take its model number @description The function calls Protocol1PacketHandler::ping() which gets Dynamixel model number, @description but doesn't carry the model number. More...
 
int read1ByteRx (PortHandler *port, uint8_t id, uint8_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readRx() function and reads 1 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 1 byte data from the packet. More...
 
int read1ByteTx (PortHandler *port, uint8_t id, uint16_t address)
 The function that calls Protocol1PacketHandler::readTx() function for reading 1 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 1 byte data. More...
 
int read1ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint8_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readTxRx() function for reading 1 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 1 byte data from the packet. More...
 
int read2ByteRx (PortHandler *port, uint8_t id, uint16_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readRx() function and reads 2 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 2 byte data from the packet. More...
 
int read2ByteTx (PortHandler *port, uint8_t id, uint16_t address)
 The function that calls Protocol1PacketHandler::readTx() function for reading 2 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 2 byte data. More...
 
int read2ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint16_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readTxRx() function for reading 2 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 2 byte data from the packet. More...
 
int read4ByteRx (PortHandler *port, uint8_t id, uint32_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readRx() function and reads 4 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 4 byte data from the packet. More...
 
int read4ByteTx (PortHandler *port, uint8_t id, uint16_t address)
 The function that calls Protocol1PacketHandler::readTx() function for reading 4 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 4 byte data. More...
 
int read4ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint32_t *data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::readTxRx() function for reading 4 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 4 byte data from the packet. More...
 
int readRx (PortHandler *port, uint8_t id, uint16_t length, uint8_t *data, uint8_t *error=0)
 The function that receives the packet and reads the data in the packet @description The function receives the packet which might be come by previous INST_READ instruction packet transmission, @description gets the data from the packet. More...
 
int readTx (PortHandler *port, uint8_t id, uint16_t address, uint16_t length)
 The function that transmits INST_READ instruction packet @description The function makes an instruction packet with INST_READ, @description transmits the packet with Protocol1PacketHandler::txPacket(). @description It breaks out @description when it tries to transmit to BROADCAST_ID. More...
 
int readTxRx (PortHandler *port, uint8_t id, uint16_t address, uint16_t length, uint8_t *data, uint8_t *error=0)
 The function that transmits INST_READ instruction packet, and read data from received packet @description The function makes an instruction packet with INST_READ, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the data from the packet. @description It breaks out @description when it tries to transmit to BROADCAST_ID. More...
 
int reboot (PortHandler *port, uint8_t id, uint8_t *error=0)
 (Available only in Protocol 2.0) The function that makes Dynamixel reboot More...
 
int regWriteTxOnly (PortHandler *port, uint8_t id, uint16_t address, uint16_t length, uint8_t *data)
 The function that transmits INST_REG_WRITE instruction packet with the data for writing on the Dynamixel register @description The function makes an instruction packet with INST_REG_WRITE and the data for writing on the Dynamixel register, @description transmits the packet with Protocol1PacketHandler::txPacket(). @description The data written in the register will act when INST_ACTION instruction packet is transmitted to the Dynamixel. More...
 
int regWriteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint16_t length, uint8_t *data, uint8_t *error=0)
 The function that transmits INST_REG_WRITE instruction packet with the data for writing on the Dynamixel register, and receives the packet @description The function makes an instruction packet with INST_REG_WRITE and the data for writing on the Dynamixel register, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the error from the packet. @description The data written in the register will act when INST_ACTION instruction packet is transmitted to the Dynamixel. More...
 
int rxPacket (PortHandler *port, uint8_t *rxpacket)
 The function that receives packet (rxpacket) during designated time via PortHandler port @description The function repeatedly tries to receive rxpacket by PortHandler::readPort() function. @description It breaks out @description when PortHandler::isPacketTimeout() shows the timeout, @description when rxpacket seemed as corrupted, or @description when nothing received. More...
 
int syncReadTx (PortHandler *port, uint16_t start_address, uint16_t data_length, uint8_t *param, uint16_t param_length)
 (Available only in Protocol 2.0) The function that transmits Sync Read instruction packet More...
 
int syncWriteTxOnly (PortHandler *port, uint16_t start_address, uint16_t data_length, uint8_t *param, uint16_t param_length)
 The function that transmits Sync Write instruction packet @description The function makes an instruction packet with INST_SYNC_WRITE, @description transmits the packet with Protocol1PacketHandler::txRxPacket(). More...
 
int txPacket (PortHandler *port, uint8_t *txpacket)
 The function that transmits the instruction packet txpacket via PortHandler port. @description The function clears the port buffer by PortHandler::clearPort() function, @description then transmits txpacket by PortHandler::writePort() function. @description The function activates only when the port is not busy and when the packet is already written on the port buffer. More...
 
int txRxPacket (PortHandler *port, uint8_t *txpacket, uint8_t *rxpacket, uint8_t *error=0)
 The function that transmits packet (txpacket) and receives packet (rxpacket) during designated time via PortHandler port @description The function calls Protocol1PacketHandler::txPacket(), @description and calls Protocol1PacketHandler::rxPacket() if it succeeds Protocol1PacketHandler::txPacket(). @description It breaks out @description when it fails Protocol1PacketHandler::txPacket(), @description when txpacket is called by Protocol1PacketHandler::broadcastPing() / Protocol1PacketHandler::syncWriteTxOnly() / Protocol1PacketHandler::regWriteTxOnly / Protocol1PacketHandler::action. More...
 
int write1ByteTxOnly (PortHandler *port, uint8_t id, uint16_t address, uint8_t data)
 The function that calls Protocol1PacketHandler::writeTxOnly() for writing 1 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 1 byte data. More...
 
int write1ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint8_t data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::writeTxRx() for writing 1 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 1 byte data and receves the packet, @description gets the error from the packet. More...
 
int write2ByteTxOnly (PortHandler *port, uint8_t id, uint16_t address, uint16_t data)
 The function that calls Protocol1PacketHandler::writeTxOnly() for writing 2 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 2 byte data. More...
 
int write2ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint16_t data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::writeTxRx() for writing 2 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 2 byte data and receves the packet, @description gets the error from the packet. More...
 
int write4ByteTxOnly (PortHandler *port, uint8_t id, uint16_t address, uint32_t data)
 The function that calls Protocol1PacketHandler::writeTxOnly() for writing 4 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 4 byte data. More...
 
int write4ByteTxRx (PortHandler *port, uint8_t id, uint16_t address, uint32_t data, uint8_t *error=0)
 The function that calls Protocol1PacketHandler::writeTxRx() for writing 4 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 4 byte data and receves the packet, @description gets the error from the packet. More...
 
int writeTxOnly (PortHandler *port, uint8_t id, uint16_t address, uint16_t length, uint8_t *data)
 The function that transmits INST_WRITE instruction packet with the data for write @description The function makes an instruction packet with INST_WRITE and the data for write, @description transmits the packet with Protocol1PacketHandler::txPacket(). More...
 
int writeTxRx (PortHandler *port, uint8_t id, uint16_t address, uint16_t length, uint8_t *data, uint8_t *error=0)
 The function that transmits INST_WRITE instruction packet with the data for write, and receives the packet @description The function makes an instruction packet with INST_WRITE and the data for write, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the error from the packet. More...
 
virtual ~Protocol1PacketHandler ()
 
- Public Member Functions inherited from dynamixel::PacketHandler
virtual ~PacketHandler ()
 

Static Public Member Functions

static Protocol1PacketHandlergetInstance ()
 The function that returns Protocol1PacketHandler instance. More...
 
- Static Public Member Functions inherited from dynamixel::PacketHandler
static PacketHandlergetPacketHandler (float protocol_version=2.0)
 The function that returns PacketHandler instance. More...
 

Private Member Functions

 Protocol1PacketHandler ()
 

Static Private Attributes

static Protocol1PacketHandlerunique_instance_ = new Protocol1PacketHandler()
 

Additional Inherited Members

- Protected Member Functions inherited from dynamixel::PacketHandler
 PacketHandler ()
 

Detailed Description

The class for control Dynamixel by using Protocol1.0.

Definition at line 34 of file protocol1_packet_handler.h.

Constructor & Destructor Documentation

◆ Protocol1PacketHandler()

Protocol1PacketHandler::Protocol1PacketHandler ( )
private

Definition at line 58 of file protocol1_packet_handler.cpp.

◆ ~Protocol1PacketHandler()

virtual dynamixel::Protocol1PacketHandler::~Protocol1PacketHandler ( )
inlinevirtual

Definition at line 48 of file protocol1_packet_handler.h.

Member Function Documentation

◆ action()

int Protocol1PacketHandler::action ( PortHandler port,
uint8_t  id 
)
virtual

The function that makes Dynamixels run as written in the Dynamixel register @description The function makes an instruction packet with INST_ACTION, @description transmits the packet with Protocol1PacketHandler::txRxPacket(). @description To use this function, Dynamixel register should be set by Protocol1PacketHandler::regWriteTxOnly() or Protocol1PacketHandler::regWriteTxRx()

Parameters
portPortHandler instance
idDynamixel ID
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 352 of file protocol1_packet_handler.cpp.

◆ broadcastPing()

int Protocol1PacketHandler::broadcastPing ( PortHandler port,
std::vector< uint8_t > &  id_list 
)
virtual

(Available only in Protocol 2.0) The function that pings all connected Dynamixel

Parameters
portPortHandler instance
id_listID list of Dynamixels which are found by broadcast ping
Returns
COMM_NOT_AVAILABLE

Implements dynamixel::PacketHandler.

Definition at line 347 of file protocol1_packet_handler.cpp.

◆ bulkReadTx()

int Protocol1PacketHandler::bulkReadTx ( PortHandler port,
uint8_t *  param,
uint16_t  param_length 
)
virtual

(Available only on Dynamixel MX / X series) The function that transmits Bulk Read instruction packet @description The function makes an instruction packet with INST_BULK_READ, @description transmits the packet with Protocol1PacketHandler::txPacket().

Parameters
portPortHandler instance
paramParameter for Bulk Read {LEN1, ID1, ADDR1, LEN2, ID2, ADDR2, ...}
param_lengthLength of the data for Bulk Read
Returns
communication results which come from Protocol1PacketHandler::txPacket()

Implements dynamixel::PacketHandler.

Definition at line 718 of file protocol1_packet_handler.cpp.

◆ bulkWriteTxOnly()

int Protocol1PacketHandler::bulkWriteTxOnly ( PortHandler port,
uint8_t *  param,
uint16_t  param_length 
)
virtual

(Available only in Protocol 2.0) The function that transmits Bulk Write instruction packet

Parameters
portPortHandler instance
paramParameter for Bulk Write
param_lengthLength of the data for Bulk Write
Returns
COMM_NOT_AVAILABLE

Implements dynamixel::PacketHandler.

Definition at line 752 of file protocol1_packet_handler.cpp.

◆ clearMultiTurn()

int Protocol1PacketHandler::clearMultiTurn ( PortHandler port,
uint8_t  id,
uint8_t *  error = 0 
)
virtual

(Available only in Protocol 2.0) The function that reset multi-turn revolution information of Dynamixel

Parameters
portPortHandler instance
idDynamixel ID
errorDynamixel hardware error
Returns
COMM_NOT_AVAILABLE

Implements dynamixel::PacketHandler.

Definition at line 368 of file protocol1_packet_handler.cpp.

◆ factoryReset()

int Protocol1PacketHandler::factoryReset ( PortHandler port,
uint8_t  id,
uint8_t  option,
uint8_t *  error = 0 
)
virtual

The function that makes Dynamixel reset as it was produced in the factory @description The function makes an instruction packet with INST_FACTORY_RESET, @description transmits the packet with Protocol1PacketHandler::txRxPacket(). @description Be careful of the use.

Parameters
portPortHandler instance
idDynamixel ID
option(Not available in Protocol 1.0) Reset option
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 373 of file protocol1_packet_handler.cpp.

◆ getInstance()

static Protocol1PacketHandler* dynamixel::Protocol1PacketHandler::getInstance ( )
inlinestatic

The function that returns Protocol1PacketHandler instance.

Returns
Protocol1PacketHandler instance

Definition at line 46 of file protocol1_packet_handler.h.

◆ getProtocolVersion()

float dynamixel::Protocol1PacketHandler::getProtocolVersion ( )
inlinevirtual

The function that returns Protocol version used in Protocol1PacketHandler (1.0)

Returns
1.0

Implements dynamixel::PacketHandler.

Definition at line 54 of file protocol1_packet_handler.h.

◆ getRxPacketError()

const char * Protocol1PacketHandler::getRxPacketError ( uint8_t  error)
virtual

The function that gets description of hardware error.

Parameters
errorDynamixel hardware error which might be gotten by the tx rx functions
Returns
description of hardware error in const char* (string)

Implements dynamixel::PacketHandler.

Definition at line 96 of file protocol1_packet_handler.cpp.

◆ getTxRxResult()

const char * Protocol1PacketHandler::getTxRxResult ( int  result)
virtual

The function that gets description of communication result.

Parameters
resultCommunication result which might be gotten by the tx rx functions
Returns
description of communication result in const char* (string)

Implements dynamixel::PacketHandler.

Definition at line 60 of file protocol1_packet_handler.cpp.

◆ ping() [1/2]

int Protocol1PacketHandler::ping ( PortHandler port,
uint8_t  id,
uint16_t *  model_number,
uint8_t *  error = 0 
)
virtual

The function that pings Dynamixel and takes its model number @description The function makes an instruction packet with INST_PING, @description transmits the packet with Protocol1PacketHandler::txRxPacket(), @description and call Protocol1PacketHandler::readTxRx to read model_number in the rx buffer. @description It breaks out @description when it tries to transmit to BROADCAST_ID.

Parameters
portPortHandler instance
idDynamixel ID
errorDynamixel hardware error
Returns
COMM_NOT_AVAILABLE
when it tries to transmit to BROADCAST_ID
COMM_SUCCESS
when it succeeds to ping Dynamixel and get model_number from it
or the other communication results which come from Protocol1PacketHandler::txRxPacket() and Protocol1PacketHandler::readTxRx()

Implements dynamixel::PacketHandler.

Definition at line 322 of file protocol1_packet_handler.cpp.

◆ ping() [2/2]

int Protocol1PacketHandler::ping ( PortHandler port,
uint8_t  id,
uint8_t *  error = 0 
)
virtual

The function that pings Dynamixel but doesn't take its model number @description The function calls Protocol1PacketHandler::ping() which gets Dynamixel model number, @description but doesn't carry the model number.

Parameters
portPortHandler instance
idDynamixel ID
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::ping()

Implements dynamixel::PacketHandler.

Definition at line 317 of file protocol1_packet_handler.cpp.

◆ read1ByteRx()

int Protocol1PacketHandler::read1ByteRx ( PortHandler port,
uint8_t  id,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readRx() function and reads 1 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 1 byte data from the packet.

Parameters
portPortHandler instance
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::readRx()

Implements dynamixel::PacketHandler.

Definition at line 485 of file protocol1_packet_handler.cpp.

◆ read1ByteTx()

int Protocol1PacketHandler::read1ByteTx ( PortHandler port,
uint8_t  id,
uint16_t  address 
)
virtual

The function that calls Protocol1PacketHandler::readTx() function for reading 1 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 1 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
Returns
communication results which come from Protocol1PacketHandler::readTx()

Implements dynamixel::PacketHandler.

Definition at line 481 of file protocol1_packet_handler.cpp.

◆ read1ByteTxRx()

int Protocol1PacketHandler::read1ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readTxRx() function for reading 1 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 1 byte data from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
lengthLength of the data for read
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 493 of file protocol1_packet_handler.cpp.

◆ read2ByteRx()

int Protocol1PacketHandler::read2ByteRx ( PortHandler port,
uint8_t  id,
uint16_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readRx() function and reads 2 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 2 byte data from the packet.

Parameters
portPortHandler instance
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::readRx()

Implements dynamixel::PacketHandler.

Definition at line 506 of file protocol1_packet_handler.cpp.

◆ read2ByteTx()

int Protocol1PacketHandler::read2ByteTx ( PortHandler port,
uint8_t  id,
uint16_t  address 
)
virtual

The function that calls Protocol1PacketHandler::readTx() function for reading 2 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 2 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
Returns
communication results which come from Protocol1PacketHandler::readTx()

Implements dynamixel::PacketHandler.

Definition at line 502 of file protocol1_packet_handler.cpp.

◆ read2ByteTxRx()

int Protocol1PacketHandler::read2ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readTxRx() function for reading 2 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 2 byte data from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
lengthLength of the data for read
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 514 of file protocol1_packet_handler.cpp.

◆ read4ByteRx()

int Protocol1PacketHandler::read4ByteRx ( PortHandler port,
uint8_t  id,
uint32_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readRx() function and reads 4 byte data on the packet @description The function calls Protocol1PacketHandler::readRx() function, @description gets 4 byte data from the packet.

Parameters
portPortHandler instance
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::readRx()

Implements dynamixel::PacketHandler.

Definition at line 527 of file protocol1_packet_handler.cpp.

◆ read4ByteTx()

int Protocol1PacketHandler::read4ByteTx ( PortHandler port,
uint8_t  id,
uint16_t  address 
)
virtual

The function that calls Protocol1PacketHandler::readTx() function for reading 4 byte data @description The function calls Protocol1PacketHandler::readTx() function for reading 4 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
Returns
communication results which come from Protocol1PacketHandler::readTx()

Implements dynamixel::PacketHandler.

Definition at line 523 of file protocol1_packet_handler.cpp.

◆ read4ByteTxRx()

int Protocol1PacketHandler::read4ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint32_t *  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::readTxRx() function for reading 4 byte data @description The function calls Protocol1PacketHandler::readTxRx(), @description gets 4 byte data from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
lengthLength of the data for read
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 535 of file protocol1_packet_handler.cpp.

◆ readRx()

int Protocol1PacketHandler::readRx ( PortHandler port,
uint8_t  id,
uint16_t  length,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that receives the packet and reads the data in the packet @description The function receives the packet which might be come by previous INST_READ instruction packet transmission, @description gets the data from the packet.

Parameters
portPortHandler instance
lengthLength of the data for read
dataData extracted from the packet
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::rxPacket()

Implements dynamixel::PacketHandler.

Definition at line 409 of file protocol1_packet_handler.cpp.

◆ readTx()

int Protocol1PacketHandler::readTx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length 
)
virtual

The function that transmits INST_READ instruction packet @description The function makes an instruction packet with INST_READ, @description transmits the packet with Protocol1PacketHandler::txPacket(). @description It breaks out @description when it tries to transmit to BROADCAST_ID.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
lengthLength of the data for read
Returns
COMM_NOT_AVAILABLE
when it tries to transmit to BROADCAST_ID
or the other communication results which come from Protocol1PacketHandler::txPacket()

Implements dynamixel::PacketHandler.

Definition at line 385 of file protocol1_packet_handler.cpp.

◆ readTxRx()

int Protocol1PacketHandler::readTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that transmits INST_READ instruction packet, and read data from received packet @description The function makes an instruction packet with INST_READ, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the data from the packet. @description It breaks out @description when it tries to transmit to BROADCAST_ID.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for read
lengthLength of the data for read
dataData extracted from the packet
errorDynamixel hardware error
Returns
COMM_NOT_AVAILABLE
when it tries to transmit to BROADCAST_ID
or the other communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 440 of file protocol1_packet_handler.cpp.

◆ reboot()

int Protocol1PacketHandler::reboot ( PortHandler port,
uint8_t  id,
uint8_t *  error = 0 
)
virtual

(Available only in Protocol 2.0) The function that makes Dynamixel reboot

Parameters
portPortHandler instance
idDynamixel ID
errorDynamixel hardware error
Returns
COMM_NOT_AVAILABLE

Implements dynamixel::PacketHandler.

Definition at line 363 of file protocol1_packet_handler.cpp.

◆ regWriteTxOnly()

int Protocol1PacketHandler::regWriteTxOnly ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length,
uint8_t *  data 
)
virtual

The function that transmits INST_REG_WRITE instruction packet with the data for writing on the Dynamixel register @description The function makes an instruction packet with INST_REG_WRITE and the data for writing on the Dynamixel register, @description transmits the packet with Protocol1PacketHandler::txPacket(). @description The data written in the register will act when INST_ACTION instruction packet is transmitted to the Dynamixel.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
lengthLength of the data for write
dataData for write
Returns
communication results which come from Protocol1PacketHandler::txPacket()

Implements dynamixel::PacketHandler.

Definition at line 631 of file protocol1_packet_handler.cpp.

◆ regWriteTxRx()

int Protocol1PacketHandler::regWriteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that transmits INST_REG_WRITE instruction packet with the data for writing on the Dynamixel register, and receives the packet @description The function makes an instruction packet with INST_REG_WRITE and the data for writing on the Dynamixel register, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the error from the packet. @description The data written in the register will act when INST_ACTION instruction packet is transmitted to the Dynamixel.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
lengthLength of the data for write
dataData for write
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 658 of file protocol1_packet_handler.cpp.

◆ rxPacket()

int Protocol1PacketHandler::rxPacket ( PortHandler port,
uint8_t *  rxpacket 
)
virtual

The function that receives packet (rxpacket) during designated time via PortHandler port @description The function repeatedly tries to receive rxpacket by PortHandler::readPort() function. @description It breaks out @description when PortHandler::isPacketTimeout() shows the timeout, @description when rxpacket seemed as corrupted, or @description when nothing received.

Parameters
portPortHandler instance
rxpacketreceived packet
Returns
COMM_RX_CORRUPT
when it received the packet but it couldn't find header in the packet
when it found header in the packet but the id, length or error value is out of range
when it received the packet but it is shorted than expected
COMM_RX_TIMEOUT
when there is no rxpacket received until PortHandler::isPacketTimeout() shows the timeout
COMM_SUCCESS
when rxpacket passes checksum test
or COMM_RX_FAIL

Implements dynamixel::PacketHandler.

Definition at line 160 of file protocol1_packet_handler.cpp.

◆ syncReadTx()

int Protocol1PacketHandler::syncReadTx ( PortHandler port,
uint16_t  start_address,
uint16_t  data_length,
uint8_t *  param,
uint16_t  param_length 
)
virtual

(Available only in Protocol 2.0) The function that transmits Sync Read instruction packet

Parameters
portPortHandler instance
start_addressAddress of the data for Sync Read
data_lengthLength of the data for Sync Read
paramParameter for Sync Read
param_lengthLength of the data for Sync Read
Returns
COMM_NOT_AVAILABLE

Implements dynamixel::PacketHandler.

Definition at line 685 of file protocol1_packet_handler.cpp.

◆ syncWriteTxOnly()

int Protocol1PacketHandler::syncWriteTxOnly ( PortHandler port,
uint16_t  start_address,
uint16_t  data_length,
uint8_t *  param,
uint16_t  param_length 
)
virtual

The function that transmits Sync Write instruction packet @description The function makes an instruction packet with INST_SYNC_WRITE, @description transmits the packet with Protocol1PacketHandler::txRxPacket().

Parameters
portPortHandler instance
start_addressAddress of the data for Sync Write
data_lengthLength of the data for Sync Write
paramParameter for Sync Write {ID1, DATA0, DATA1, ..., DATAn, ID2, DATA0, DATA1, ..., DATAn, ID3, DATA0, DATA1, ..., DATAn}
param_lengthLength of the data for Sync Write
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 690 of file protocol1_packet_handler.cpp.

◆ txPacket()

int Protocol1PacketHandler::txPacket ( PortHandler port,
uint8_t *  txpacket 
)
virtual

The function that transmits the instruction packet txpacket via PortHandler port. @description The function clears the port buffer by PortHandler::clearPort() function, @description then transmits txpacket by PortHandler::writePort() function. @description The function activates only when the port is not busy and when the packet is already written on the port buffer.

Parameters
portPortHandler instance
txpacketpacket for transmission
Returns
COMM_PORT_BUSY
when the port is already in use
COMM_TX_ERROR
when txpacket is out of range described by TXPACKET_MAX_LEN
COMM_TX_FAIL
when written packet is shorter than expected
or COMM_SUCCESS

Implements dynamixel::PacketHandler.

Definition at line 122 of file protocol1_packet_handler.cpp.

◆ txRxPacket()

int Protocol1PacketHandler::txRxPacket ( PortHandler port,
uint8_t *  txpacket,
uint8_t *  rxpacket,
uint8_t *  error = 0 
)
virtual

The function that transmits packet (txpacket) and receives packet (rxpacket) during designated time via PortHandler port @description The function calls Protocol1PacketHandler::txPacket(), @description and calls Protocol1PacketHandler::rxPacket() if it succeeds Protocol1PacketHandler::txPacket(). @description It breaks out @description when it fails Protocol1PacketHandler::txPacket(), @description when txpacket is called by Protocol1PacketHandler::broadcastPing() / Protocol1PacketHandler::syncWriteTxOnly() / Protocol1PacketHandler::regWriteTxOnly / Protocol1PacketHandler::action.

Parameters
portPortHandler instance
txpacketpacket for transmission
rxpacketreceived packet
Returns
COMM_SUCCESS
when it succeeds Protocol1PacketHandler::txPacket() and Protocol1PacketHandler::rxPacket()
or the other communication results which come from Protocol1PacketHandler::txPacket() and Protocol1PacketHandler::rxPacket()

Implements dynamixel::PacketHandler.

Definition at line 272 of file protocol1_packet_handler.cpp.

◆ write1ByteTxOnly()

int Protocol1PacketHandler::write1ByteTxOnly ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint8_t  data 
)
virtual

The function that calls Protocol1PacketHandler::writeTxOnly() for writing 1 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 1 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
Returns
communication results which come from Protocol1PacketHandler::writeTxOnly()

Implements dynamixel::PacketHandler.

Definition at line 598 of file protocol1_packet_handler.cpp.

◆ write1ByteTxRx()

int Protocol1PacketHandler::write1ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint8_t  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::writeTxRx() for writing 1 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 1 byte data and receves the packet, @description gets the error from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::writeTxRx()

Implements dynamixel::PacketHandler.

Definition at line 603 of file protocol1_packet_handler.cpp.

◆ write2ByteTxOnly()

int Protocol1PacketHandler::write2ByteTxOnly ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  data 
)
virtual

The function that calls Protocol1PacketHandler::writeTxOnly() for writing 2 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 2 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
Returns
communication results which come from Protocol1PacketHandler::writeTxOnly()

Implements dynamixel::PacketHandler.

Definition at line 609 of file protocol1_packet_handler.cpp.

◆ write2ByteTxRx()

int Protocol1PacketHandler::write2ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::writeTxRx() for writing 2 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 2 byte data and receves the packet, @description gets the error from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::writeTxRx()

Implements dynamixel::PacketHandler.

Definition at line 614 of file protocol1_packet_handler.cpp.

◆ write4ByteTxOnly()

int Protocol1PacketHandler::write4ByteTxOnly ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint32_t  data 
)
virtual

The function that calls Protocol1PacketHandler::writeTxOnly() for writing 4 byte data @description The function calls Protocol1PacketHandler::writeTxOnly() for writing 4 byte data.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
Returns
communication results which come from Protocol1PacketHandler::writeTxOnly()

Implements dynamixel::PacketHandler.

Definition at line 620 of file protocol1_packet_handler.cpp.

◆ write4ByteTxRx()

int Protocol1PacketHandler::write4ByteTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint32_t  data,
uint8_t *  error = 0 
)
virtual

The function that calls Protocol1PacketHandler::writeTxRx() for writing 4 byte data and receives the packet @description The function calls Protocol1PacketHandler::writeTxRx() for writing 4 byte data and receves the packet, @description gets the error from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
dataData for write
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::writeTxRx()

Implements dynamixel::PacketHandler.

Definition at line 625 of file protocol1_packet_handler.cpp.

◆ writeTxOnly()

int Protocol1PacketHandler::writeTxOnly ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length,
uint8_t *  data 
)
virtual

The function that transmits INST_WRITE instruction packet with the data for write @description The function makes an instruction packet with INST_WRITE and the data for write, @description transmits the packet with Protocol1PacketHandler::txPacket().

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
lengthLength of the data for write
dataData for write
Returns
communication results which come from Protocol1PacketHandler::txPacket()

Implements dynamixel::PacketHandler.

Definition at line 544 of file protocol1_packet_handler.cpp.

◆ writeTxRx()

int Protocol1PacketHandler::writeTxRx ( PortHandler port,
uint8_t  id,
uint16_t  address,
uint16_t  length,
uint8_t *  data,
uint8_t *  error = 0 
)
virtual

The function that transmits INST_WRITE instruction packet with the data for write, and receives the packet @description The function makes an instruction packet with INST_WRITE and the data for write, @description transmits and receives the packet with Protocol1PacketHandler::txRxPacket(), @description gets the error from the packet.

Parameters
portPortHandler instance
idDynamixel ID
addressAddress of the data for write
lengthLength of the data for write
dataData for write
errorDynamixel hardware error
Returns
communication results which come from Protocol1PacketHandler::txRxPacket()

Implements dynamixel::PacketHandler.

Definition at line 571 of file protocol1_packet_handler.cpp.

Member Data Documentation

◆ unique_instance_

Protocol1PacketHandler * Protocol1PacketHandler::unique_instance_ = new Protocol1PacketHandler()
staticprivate

Definition at line 37 of file protocol1_packet_handler.h.


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


dynamixel_sdk
Author(s): Gilbert , Zerom , Darby Lim , Leon
autogenerated on Wed Mar 2 2022 00:13:50