2017-03-31 11:35:27 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2017 Inria
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup drivers_dynamixel Dynamixel driver
|
|
|
|
* @ingroup drivers_actuators
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Drivers for any device using dynamixel's servomotors communication bus
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* The bus is mainly used for servomotors, but a device can be anything : sensors, other actuators.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for Dynamixel devices driver
|
|
|
|
*
|
|
|
|
* @author Loïc Dauphin <loic.dauphin@inria.fr>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DYNAMIXEL_H
|
|
|
|
#define DYNAMIXEL_H
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
#include "dynamixel_protocol.h"
|
|
|
|
#include "uart_half_duplex.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
typedef uint8_t dynamixel_id_t; /**< device id type */
|
2017-03-31 11:35:27 +02:00
|
|
|
typedef uint16_t dynamixel_addr_t; /**< register address type */
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Descriptor struct for a dynamixel device
|
2017-03-31 11:35:27 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uart_half_duplex_t *stream; /**< the stream used */
|
|
|
|
dynamixel_id_t id; /**< the device address */
|
|
|
|
} dynamixel_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Possible dynamixel return values
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
DYNAMIXEL_OK, /**< Success */
|
|
|
|
DYNAMIXEL_TIMEOUT, /**< No response from the device */
|
|
|
|
DYNAMIXEL_BUFFER_TOO_SMALL, /**< Buffer is too small for the message */
|
|
|
|
DYNAMIXEL_INVALID_MESSAGE, /**< Invalid message received */
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Send a PING message to a device
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] stream the stream
|
|
|
|
* @param[in] id the device address
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK if a device answered
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
|
|
|
int dynamixel_ping(uart_half_duplex_t *stream, dynamixel_id_t id);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Initialize a Dynamixel device
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[out] device the Dynamixel device
|
|
|
|
* @param[in] stream the stream
|
|
|
|
* @param[in] id the device address
|
|
|
|
*/
|
|
|
|
void dynamixel_init(dynamixel_t *device, uart_half_duplex_t *stream, dynamixel_id_t id);
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Write to a device 8bits register
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the register to write
|
|
|
|
* @param[in] value the value to write
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_write8(const dynamixel_t *device, dynamixel_addr_t reg, uint8_t value);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Write to a device 16bits register
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the register to write
|
|
|
|
* @param[in] value the value to write
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_write16(const dynamixel_t *device, dynamixel_addr_t reg, uint16_t value);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Write to a device address
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the address to start write
|
|
|
|
* @param[in] data the data to write
|
|
|
|
* @param[in] length the data length
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_write(const dynamixel_t *device, dynamixel_addr_t reg, const uint8_t *data, size_t length);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Read from a device 8bits register
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the register to read
|
|
|
|
* @param[out] value the value to read
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_read8(const dynamixel_t *device, dynamixel_addr_t reg, uint8_t *value);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Read from a device 16bits register
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the register to read
|
|
|
|
* @param[out] value the value to read
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_read16(const dynamixel_t *device, dynamixel_addr_t reg, uint16_t *value);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Read from a device address
|
2017-03-31 11:35:27 +02:00
|
|
|
*
|
|
|
|
* @param[in] device the Dynamixel device
|
|
|
|
* @param[in] reg the address to start read
|
|
|
|
* @param[out] data the data buffer to fill
|
|
|
|
* @param[in] length the data length
|
|
|
|
*
|
|
|
|
* @return DYNAMIXEL_OK on success
|
|
|
|
* @return DYNAMIXEL_TIMEOUT if the device did not answer
|
|
|
|
* @return DYNAMIXEL_BUFFER_TOO_SMALL if buffer is too small for the message
|
|
|
|
* @return DYNAMIXEL_INVALID_MESSAGE if an invalid message was received
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int dynamixel_read(const dynamixel_t *device, dynamixel_addr_t reg, uint8_t *data, size_t length);
|
2017-03-31 11:35:27 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* DYNAMIXEL_H */
|
2017-03-31 11:35:27 +02:00
|
|
|
/** @} */
|