2015-09-18 23:00:31 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* 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 sys_arduino_api Arduino API
|
|
|
|
* @ingroup sys_arduino
|
|
|
|
* @brief Implementation of the Arduino API in RIOT
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Main interface definition of the Arduino API
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2019-09-05 17:39:32 +02:00
|
|
|
#ifndef ARDUINO_HPP
|
|
|
|
#define ARDUINO_HPP
|
2015-09-18 23:00:31 +02:00
|
|
|
|
|
|
|
extern "C" {
|
2019-09-09 01:51:09 +02:00
|
|
|
#include <stdint.h>
|
2015-09-18 23:00:31 +02:00
|
|
|
#include "periph/gpio.h"
|
|
|
|
#include "arduino_board.h"
|
|
|
|
}
|
|
|
|
|
|
|
|
#include "serialport.hpp"
|
|
|
|
|
2019-09-09 01:51:09 +02:00
|
|
|
/**
|
2019-09-09 01:59:01 +02:00
|
|
|
* @brief Arduino boolean data type definion
|
2019-09-09 01:51:09 +02:00
|
|
|
*/
|
|
|
|
typedef bool boolean;
|
|
|
|
|
|
|
|
/**
|
2019-09-09 01:59:01 +02:00
|
|
|
* @brief Arduino byte data type definion
|
2019-09-09 01:51:09 +02:00
|
|
|
*/
|
|
|
|
typedef uint8_t byte;
|
|
|
|
|
2015-09-18 23:00:31 +02:00
|
|
|
/**
|
|
|
|
* @brief Possible pin configurations
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
INPUT, /**< configure pin as input */
|
|
|
|
OUTPUT, /**< configure pin as output */
|
2015-11-28 12:46:09 +01:00
|
|
|
INPUT_PULLUP /**< configure pin as input with pull-up resistor */
|
2015-09-18 23:00:31 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Possible pin states
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
LOW = 0, /**< pin is cleared */
|
2015-11-28 12:46:09 +01:00
|
|
|
HIGH = 1 /**< pin is set */
|
2015-09-18 23:00:31 +02:00
|
|
|
};
|
|
|
|
|
2018-10-11 21:33:50 +02:00
|
|
|
#ifndef ARDUINO_UART_DEV
|
2015-09-18 23:00:31 +02:00
|
|
|
/**
|
2018-10-11 21:33:50 +02:00
|
|
|
* @brief UART device to use for Arduino serial
|
2015-09-18 23:00:31 +02:00
|
|
|
*/
|
2018-10-11 21:33:50 +02:00
|
|
|
#define ARDUINO_UART_DEV UART_DEV(0)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Primary serial port (mapped to ARDUINO_UART_DEV)
|
|
|
|
*/
|
|
|
|
static SerialPort Serial(ARDUINO_UART_DEV);
|
2015-09-18 23:00:31 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Configure a pin as either input or output
|
|
|
|
*
|
|
|
|
* @param[in] pin pin to configure
|
|
|
|
* @param[in] mode mode to set the pin to
|
|
|
|
*/
|
|
|
|
void pinMode(int pin, int mode);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the value for the given pin
|
|
|
|
*
|
|
|
|
* @param[in] pin pin to set
|
|
|
|
* @param[in] state HIGH or LOW
|
|
|
|
*/
|
|
|
|
void digitalWrite(int pin, int state);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Read the current state of the given pin
|
|
|
|
*
|
|
|
|
* @param[in] pin pin to read
|
|
|
|
*
|
|
|
|
* @return state of the given pin, HIGH or LOW
|
|
|
|
*/
|
|
|
|
int digitalRead(int pin);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Sleep for a given amount of time [milliseconds]
|
|
|
|
*
|
|
|
|
* @param[in] msec number of milliseconds to sleep
|
|
|
|
*/
|
2016-10-24 11:01:48 +02:00
|
|
|
void delay(unsigned long msec);
|
2015-09-18 23:00:31 +02:00
|
|
|
|
2018-10-11 14:42:46 +02:00
|
|
|
/**
|
|
|
|
* @brief Sleep for a given amount of time [microseconds]
|
|
|
|
*
|
|
|
|
* @param[in] usec number of microseconds to sleep
|
|
|
|
*/
|
|
|
|
void delayMicroseconds(unsigned long usec);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the number of microseconds since start
|
|
|
|
*
|
|
|
|
* @return value of microseconds since start
|
|
|
|
*/
|
|
|
|
unsigned long micros();
|
|
|
|
|
2019-05-29 12:53:17 +02:00
|
|
|
/**
|
|
|
|
* @brief Returns the number of milliseconds since start
|
|
|
|
*
|
|
|
|
* @return value of milliseconds since start
|
|
|
|
*/
|
|
|
|
unsigned long millis();
|
|
|
|
|
2019-10-08 10:26:23 +02:00
|
|
|
#if MODULE_PERIPH_ADC || DOXYGEN
|
2017-02-15 21:28:10 +01:00
|
|
|
/**
|
|
|
|
* @brief Read the current value of the given analog pin
|
|
|
|
*
|
|
|
|
* @param[in] pin pin to read
|
|
|
|
*
|
|
|
|
* @return a value between 0 to 1023 that is proportionnal
|
|
|
|
* to the voltage applied to the pin
|
|
|
|
*/
|
|
|
|
int analogRead(int pin);
|
2019-10-08 10:26:23 +02:00
|
|
|
#endif
|
2017-02-15 21:28:10 +01:00
|
|
|
|
2019-10-20 17:28:29 +02:00
|
|
|
#if MODULE_PERIPH_PWM || DOXYGEN
|
|
|
|
/**
|
|
|
|
* @brief PWM default frequency
|
|
|
|
*
|
|
|
|
* Can be overridden at board level in arduino_board.h.
|
|
|
|
*
|
|
|
|
* See table from https://www.arduino.cc/reference/en/language/functions/analog-io/analogwrite/
|
|
|
|
* for reference values.
|
|
|
|
*/
|
|
|
|
#ifndef ARDUINO_PWM_FREQU
|
|
|
|
#define ARDUINO_PWM_FREQU (1000U)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWM mode
|
|
|
|
*/
|
|
|
|
#define ARDUINO_PWM_MODE PWM_LEFT
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief PWM steps
|
|
|
|
*/
|
|
|
|
#define ARDUINO_PWM_STEPS (256U)
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Write an analog value to a pin
|
|
|
|
*
|
|
|
|
* @param[in] pin pin to write
|
|
|
|
* @param[in] value duty cycle value, between 0 and 255
|
|
|
|
*/
|
|
|
|
void analogWrite(int pin, int value);
|
|
|
|
#endif
|
|
|
|
|
2019-09-05 17:39:32 +02:00
|
|
|
#endif /* ARDUINO_HPP */
|
2015-09-18 23:00:31 +02:00
|
|
|
/** @} */
|