2014-10-15 11:29:41 +02:00
|
|
|
/*
|
2015-04-13 13:07:56 +02:00
|
|
|
* Copyright (C) 2013 Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
2015-09-04 18:45:32 +02:00
|
|
|
* 2015 Freie Universität Berlin
|
2014-10-15 11:29:41 +02:00
|
|
|
*
|
|
|
|
* 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_srf02 SRF02 ultrasonic range sensor
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_sensors
|
2014-10-15 11:29:41 +02:00
|
|
|
* @brief Driver for the SRF02 ultrasonic range sensor
|
|
|
|
* @{
|
|
|
|
*
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2014-10-15 11:29:41 +02:00
|
|
|
* @brief Driver definitions for the SRF02 ultrasonic ranger.
|
|
|
|
*
|
|
|
|
* @author Zakaria Kasmi <zkasmi@inf.fu-berlin.de>
|
|
|
|
* @author Peter Kietzmann <peter.kietzmann@haw-hamburg.de>
|
2015-09-04 18:45:32 +02:00
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2014-10-15 11:29:41 +02:00
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef SRF02_H
|
|
|
|
#define SRF02_H
|
2014-10-15 11:29:41 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-09-04 18:45:32 +02:00
|
|
|
/**
|
|
|
|
* @brief Default I2C address of SRF02 sensors
|
|
|
|
*/
|
2016-02-12 17:23:06 +01:00
|
|
|
#define SRF02_DEFAULT_ADDR (0xe0) /* 224 decimal */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief The datasheet tells us, that ranging takes 70ms
|
|
|
|
*/
|
|
|
|
#define SRF02_RANGE_DELAY (70000U)
|
2014-12-08 12:00:51 +01:00
|
|
|
|
2014-10-15 11:29:41 +02:00
|
|
|
/**
|
2015-09-04 18:45:32 +02:00
|
|
|
* @brief Device descriptor for SRF02 sensors
|
2014-10-15 11:29:41 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2014-12-08 12:00:51 +01:00
|
|
|
i2c_t i2c; /**< I2C device the sensor is connected to */
|
|
|
|
uint8_t addr; /**< I2C bus address of the sensor */
|
2014-10-15 11:29:41 +02:00
|
|
|
} srf02_t;
|
|
|
|
|
|
|
|
/**
|
2015-09-04 18:45:32 +02:00
|
|
|
* @brief Possible measurement modes of the SRF02 sensor
|
2014-10-15 11:29:41 +02:00
|
|
|
*/
|
|
|
|
typedef enum {
|
2015-09-04 18:45:32 +02:00
|
|
|
SRF02_MODE_REAL_INCH = 0x50, /**< result in inches */
|
|
|
|
SRF02_MODE_REAL_CM = 0x51, /**< result in centimeters */
|
|
|
|
SRF02_MODE_REAL_MS = 0x52, /**< result in microseconds */
|
|
|
|
SRF02_MODE_FAKE_INCH = 0x56, /**< result in inches (no pulse send) */
|
|
|
|
SRF02_MODE_FAKE_CM = 0x57, /**< result in cm (no pulse send) */
|
|
|
|
SRF02_MODE_FAKE_MS = 0x58 /**< result in ms (no pulse send) */
|
|
|
|
} srf02_mode_t;
|
2014-10-15 11:29:41 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-04 18:45:32 +02:00
|
|
|
* @brief Initialize the SRF02 ultrasonic sensor
|
2014-10-15 11:29:41 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of an SRF02 sensor
|
|
|
|
* @param[in] i2c I2C device the sensor is connected to
|
|
|
|
* @param[in] addr I2C address of the sensor
|
|
|
|
*
|
|
|
|
* @return 0 on successful initialization
|
2015-09-04 18:45:32 +02:00
|
|
|
* @return -1 on error
|
2014-10-15 11:29:41 +02:00
|
|
|
*/
|
2015-09-04 18:45:32 +02:00
|
|
|
int srf02_init(srf02_t *dev, i2c_t i2c, uint8_t addr);
|
2014-10-15 11:29:41 +02:00
|
|
|
|
|
|
|
/**
|
2016-02-12 17:23:06 +01:00
|
|
|
* @brief Trigger a new measurement
|
|
|
|
*
|
|
|
|
* This function triggers a new ranging operation. After triggering this
|
|
|
|
* operation, you have to wait at least 70ms for the result to be ready.
|
2015-09-04 18:45:32 +02:00
|
|
|
*
|
|
|
|
* The result of the ranging operation is returned in inches, centimeters or
|
|
|
|
* microseconds - depending on the given @p mode parameter.
|
|
|
|
*
|
2016-02-12 17:23:06 +01:00
|
|
|
* @param[in] dev device to trigger
|
|
|
|
* @param[in] 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
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
void srf02_trigger(const srf02_t *dev, srf02_mode_t mode);
|
2016-02-12 17:23:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read the results of the last ranging operation
|
|
|
|
*
|
|
|
|
* @param[in] dev device to read from
|
|
|
|
*
|
|
|
|
* @return result of the last ranging operation, meaning depends on the mode
|
|
|
|
* parameter given to the srf02_trigger function
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
uint16_t srf02_read(const srf02_t *dev);
|
2016-02-12 17:23:06 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the distance measured from the SRF02 ultrasonic sensor
|
|
|
|
*
|
|
|
|
* This function combines the srf02_trigger and the srf02_read functions for
|
|
|
|
* simplified usage in simple (single sensor) setups.
|
|
|
|
*
|
2014-10-15 11:29:41 +02:00
|
|
|
* @param[in] dev device descriptor of an SRF02 sensor
|
|
|
|
* @param[in] 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
|
|
|
|
*
|
2015-09-04 18:45:32 +02:00
|
|
|
* @return the ranging result in inches, centimeters or microseconds
|
2014-10-15 11:29:41 +02:00
|
|
|
*
|
|
|
|
*/
|
2017-06-20 17:32:45 +02:00
|
|
|
uint16_t srf02_get_distance(const srf02_t *dev, srf02_mode_t mode);
|
2014-10-15 11:29:41 +02:00
|
|
|
|
2016-02-10 18:26:02 +01:00
|
|
|
/**
|
|
|
|
* @brief Program the given device with a new bus address
|
|
|
|
*
|
|
|
|
* @param[in] dev device to program
|
|
|
|
* @param[in] new_addr new address to program the given device to
|
|
|
|
*/
|
|
|
|
void srf02_set_addr(srf02_t *dev, uint8_t new_addr);
|
|
|
|
|
2014-10-15 11:29:41 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* SRF02_H */
|
2015-09-04 18:45:32 +02:00
|
|
|
/** @} */
|