A controller that manages a Robotis/Dynamixel servo bus.
This controller wraps the Robotis GenServer and provides a shared ETS table
for actuators to write commands to. The controller runs a fixed-rate control
loop that batches all pending commands into writes and reads positions via
bulk reads (fast_sync_read).
On each loop tick, the controller:
- Reads all pending commands from the ETS table
- Writes them to the serial bus
- Clears the command fields
- Reads all servo positions via
fast_sync_read - Updates the ETS table with current positions
- Publishes
JointStatemessages for positions that exceed deadband
Configuration
The controller is typically defined in the robot DSL:
controller :dynamixel, {BB.Servo.Robotis.Controller,
port: "/dev/ttyUSB0",
baud_rate: 1_000_000,
control_table: Robotis.ControlTable.XM430,
loop_interval_ms: 10
}Options
:port- (required) The serial port path, e.g.,"/dev/ttyUSB0":baud_rate- Baud rate in bps (default: 1_000_000):control_table- The servo control table to use (default:Robotis.ControlTable.XM430):loop_interval_ms- Control loop interval in ms (default: 10, i.e. 100Hz):status_poll_interval_ms- Status polling interval in ms (default: 1000, set to 0 to disable):disarm_action- Action to take when robot is disarmed (default::disable_torque):disable_torque- Disable torque on all servos (safe default):hold- Keep torque enabled (servos hold position)
ETS Table Structure
Each registered servo has a row in the ETS table:
{servo_id, joint_name, center_angle, reverse?, position_deadband,
last_position_raw, present_position,
present_temperature, present_voltage, present_current, hardware_error,
goal_position}Actuators write goal_position (raw units) via :ets.update_element/3.
The controller reads and clears them each tick.
Safety
This controller implements the BB.Safety behaviour. When the robot is disarmed
or crashes, torque is disabled on all known servo IDs using sync_write for speed.
Summary
Functions
Handle disarm based on the configured disarm_action.
Functions
Handle disarm based on the configured disarm_action.
Called by BB.Safety.Controller when the robot is disarmed or crashes.
By default, disables torque on all registered servo IDs.