gpio_controllers
This is a collection of controllers for hardware interfaces of type GPIO (<gpio> tag in the URDF).
gpio_command_controller
gpio_command_controller let the user expose command interfaces of given GPIO interfaces and publishes state interfaces of the configured command interfaces.
Description of controller’s interfaces
- /<controller_name>/gpio_states[- control_msgs/msg/DynamicJointState]: Publishes all state interfaces of the given GPIO interfaces.
- /<controller_name>/commands[- control_msgs/msg/DynamicJointState]: A subscriber for configured command interfaces.
Parameters
This controller uses the generate_parameter_library to handle its parameters. The parameter definition file located in the src folder contains descriptions for all the parameters used by the controller.
The controller expects at least one GPIO interface and the corresponding command interface names or state interface. However, these Command and State interfaces are optional. The controller behaves as a broadcaster when no Command Interface is present, thereby publishing the configured GPIO state interfaces if set, else the one present in the URDF.
Note
When no state interface is provided in the param file, the controller will try to use state_interfaces from ros2_control’s config placed in the URDF for configured gpio interfaces. However, command interfaces will not be configured based on the available URDF setup.
gpio_command_controller:
  ros__parameters:
    type: gpio_controllers/GpioCommandController
    gpios:
      - Gpio1
      - Gpio2
    command_interfaces:
      Gpio1:
        - interfaces:
          - dig.1
          - dig.2
          - dig.3
      Gpio2:
        - interfaces:
          - ana.1
          - ana.2
    state_interfaces:
      Gpio2:
        - interfaces:
          - ana.1
          - ana.2
With the above-defined controller configuration, the controller will accept commands for all gpios’ interfaces and will only publish the state of Gpio2.