2014-12-11 16:13:49 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @defgroup drivers_srf08 SRF08 ultrasonic range sensor
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_sensors
|
2014-12-11 16:13:49 +01:00
|
|
|
* @brief Driver for the SRF08 ultrasonic range sensor
|
|
|
|
*
|
|
|
|
* The connection between the MCU and the SRF08 is based on the i2c-interface.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2014-12-11 16:13:49 +01:00
|
|
|
* @brief Driver definitions for the SRF02 ultrasonic ranger.
|
|
|
|
*
|
|
|
|
* The connection between the SRF08 and the MCU is based on the i2c interface.
|
|
|
|
*
|
|
|
|
* @author Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
|
2018-06-27 08:25:51 +02:00
|
|
|
* @author Kevin Weiss <kevin.weiss@haw-hamburg.de>
|
2014-12-11 16:13:49 +01:00
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef SRF08_H
|
|
|
|
#define SRF08_H
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief The sensors default I2C address */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_DEFAULT_ADDR 112
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief The sensors command register (write) */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_COMMAND_REG 0x0
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Max. gain register (write) */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_GAIN_REG 0x1
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief The sensors range register (write) */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_RANGE_REG 0x2
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief The upper measurement byte (read) */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_RANGE_HIGH_BYTE 0x2
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief The lower measurement byte (read)*/
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_RANGE_LOW_BYTE 0x3
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Number of highest register */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_MAX_REGISTER_NUMBER 35
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Maximum number of echos from more distant objects */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_MAX_ECHO_NUMBER 17
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Maximum range the sensor can measure (6m) */
|
2014-12-11 16:13:49 +01:00
|
|
|
#define SRF08_MAX_RANGE_6M 0x8C
|
|
|
|
|
2017-08-29 18:00:46 +02:00
|
|
|
/** @brief Maximum gain of the sensor (1025)*/
|
2017-11-07 23:31:40 +01:00
|
|
|
#define SRF08_MAX_GAIN 0x1F
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Device descriptor for SRF08 sensors
|
2014-12-11 16:13:49 +01:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
i2c_t i2c; /**< I2C device the sensor is connected to */
|
|
|
|
uint8_t addr; /**< I2C bus address of the sensor */
|
|
|
|
} srf08_t;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Possible measurement modes for the SRF08 sensor
|
2014-12-11 16:13:49 +01:00
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
SRF08_MODE_INCH = 0x50, /**< result in inches */
|
|
|
|
SRF08_MODE_CM = 0x51, /**< result in centimeters */
|
|
|
|
SRF08_MODE_MICRO_SEC = 0x52, /**< result in centimeters */
|
2018-06-27 08:25:51 +02:00
|
|
|
SRF08_ANN_MODE_INCH = 0x53, /**< synchronous measurement in inch */
|
|
|
|
SRF08_ANN_MODE_CM = 0x54, /**< synchronous measurement in cm */
|
|
|
|
SRF08_ANN_MODE_MICRO_SEC = 0x55 /**< synchronous measurement in us */
|
2014-12-11 16:13:49 +01:00
|
|
|
}srf08_mode_t;
|
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Initialize the SRF08 ultrasonic sensor
|
2014-12-11 16:13:49 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an SRF08 sensor
|
|
|
|
* @param[in] i2c I2C device the sensor is connected to
|
|
|
|
* @param[in] addr I2C address of the sensor
|
|
|
|
* @param[in] speed I2C speed mode
|
|
|
|
*
|
|
|
|
* @return 0 on successful initialization
|
|
|
|
* @return -1 on undefined device given
|
|
|
|
* @return -2 on unsupported speed value
|
|
|
|
* @return -3 on max. range error
|
|
|
|
* @return -4 on max. gain error
|
|
|
|
*
|
|
|
|
*/
|
2018-06-27 08:25:51 +02:00
|
|
|
int srf08_init(srf08_t *dev, i2c_t i2c, uint8_t addr);
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set the maximum range of the SRF08.
|
2014-12-11 16:13:49 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an SRF08 sensor
|
|
|
|
* @param[in] max_range the adjusted maximal range is:
|
|
|
|
* max_range = (max_range x 43mm) + 43mm.
|
|
|
|
* The hardware limit is 6m.
|
|
|
|
*
|
|
|
|
* @return 1 on success
|
|
|
|
* @return -1 on undefined device given
|
|
|
|
*
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int srf08_set_max_range(const srf08_t *dev, uint8_t max_range);
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Set the maximum of the analog stages.
|
2014-12-11 16:13:49 +01:00
|
|
|
*
|
|
|
|
* @ note
|
2018-06-27 08:25:51 +02:00
|
|
|
* This value is just a limitation of the maximum amplification and not the
|
|
|
|
* actual. While measuring, this value starts at its minimum and increases
|
|
|
|
* approx. each 75 us until the maximum value is reached.
|
2014-12-11 16:13:49 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an SRF08 sensor
|
|
|
|
* @param[in] max_gain the maximal gain value.
|
|
|
|
*
|
|
|
|
* @return 1 on success
|
|
|
|
* @return -1 on undefined device given
|
|
|
|
*
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int srf08_set_max_gain(const srf08_t *dev, uint8_t max_gain);
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Get all distances measured from the SRF08 ultrasonic sensor.
|
|
|
|
* The results of a ranging can be returned in inches, centimeters
|
|
|
|
* or microseconds. The SRF08 can detect up to 17 targets.
|
2014-12-11 16:13:49 +01:00
|
|
|
*
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an SRF08 sensor
|
|
|
|
* @param[in] range_array a pointer to a buffer holding the ranging results.
|
|
|
|
* @param[in] num_echos number of stored measurements (echos)
|
|
|
|
* @param[in] ranging_mode there are three real ranging modes, which return
|
|
|
|
* the result in inches, centimeters or microseconds.
|
|
|
|
* Another set of three fake ranging modes do the same
|
|
|
|
* but without transmitting the burst.
|
|
|
|
*
|
|
|
|
* @return number of measured echos on success
|
|
|
|
* @return -1 on ranging mode errors
|
|
|
|
* @return -2 if num_echos exceeds the max. number of
|
|
|
|
possible measurements
|
|
|
|
* @return -3 if i2c read high byte failed
|
|
|
|
* @return -4 if i2c read low byte failed
|
|
|
|
*
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
int srf08_get_distances(const srf08_t *dev,
|
|
|
|
uint16_t *range_array,
|
|
|
|
int num_echos,
|
|
|
|
srf08_mode_t ranging_mode);
|
2014-12-11 16:13:49 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @} */
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* SRF08_H */
|