1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-16 00:33:16 +01:00
RIOT/sys/arduino/base.cpp

162 lines
3.4 KiB
C++
Raw Normal View History

/*
* 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.
*/
/**
* @ingroup sys_arduino
* @{
*
* @file
* @brief Implementation of Arduino core functionality
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*
* @}
*/
extern "C" {
#include "xtimer.h"
#include "periph/gpio.h"
2017-02-15 21:28:10 +01:00
#include "periph/adc.h"
#include "periph/pwm.h"
}
#include "arduino.hpp"
2019-07-18 15:16:43 +02:00
#define ANALOG_PIN_NUMOF (ARRAY_SIZE(arduino_analog_map))
2017-02-15 21:28:10 +01:00
2016-02-20 17:22:39 +01:00
void pinMode(int pin, int mode)
{
2016-02-20 17:22:39 +01:00
gpio_mode_t m = GPIO_OUT;
2016-02-20 17:22:39 +01:00
if (mode == INPUT) {
m = GPIO_IN;
}
else if (mode == INPUT_PULLUP) {
m = GPIO_IN_PU;
}
2016-02-20 17:22:39 +01:00
gpio_init(arduino_pinmap[pin], m);
}
void digitalWrite(int pin, int state)
{
gpio_write(arduino_pinmap[pin], state);
}
int digitalRead(int pin)
{
if (gpio_read(arduino_pinmap[pin])) {
return HIGH;
}
else {
return LOW;
}
}
void delay(unsigned long msec)
{
xtimer_usleep(msec * US_PER_MS);
}
2017-02-15 21:28:10 +01:00
void delayMicroseconds(unsigned long usec)
{
xtimer_usleep(usec);
}
unsigned long micros()
{
return xtimer_now_usec();
}
unsigned long millis()
{
return xtimer_now_usec64() / US_PER_MS;
}
2019-10-08 10:26:23 +02:00
#if MODULE_PERIPH_ADC
2017-02-15 21:28:10 +01:00
int analogRead(int arduino_pin)
{
/*
* Bitfield for the state of the ADC-channels.
* 0: Not initialized
* 1: Successfully initialized
*/
static uint16_t adc_line_state;
2017-02-15 21:28:10 +01:00
int adc_value;
/* Check if the ADC line is valid */
assert((arduino_pin >= 0) && (arduino_pin < (int)ANALOG_PIN_NUMOF));
/* Initialization of given ADC channel */
if (!(adc_line_state & (1 << arduino_pin))) {
if (adc_init(arduino_analog_map[arduino_pin]) != 0) {
return -1;
}
/* The ADC channel is initialized */
adc_line_state |= (1 << arduino_pin);
2017-02-15 21:28:10 +01:00
}
/* Read the ADC channel */
adc_value = adc_sample(arduino_analog_map[arduino_pin], ADC_RES_10BIT);
return adc_value;
}
2019-10-08 10:26:23 +02:00
#endif
#if MODULE_PERIPH_PWM
static int _get_pwm_pin_idx(int pin)
{
for (uint8_t i = 0; i < ARRAY_SIZE(arduino_pwm_list); ++i) {
if (arduino_pwm_list[i].pin == pin) {
return i;
}
}
return -1;
}
void analogWrite(int pin, int value)
{
/*
* Bitfield for the state of the PWM devices.
* 0: Not initialized
* 1: Successfully initialized
*/
static uint8_t pwm_dev_state;
/* Clamp given value within bounds */
if (value < 0) {
value = 0;
}
if ((unsigned)value >= ARDUINO_PWM_STEPS) {
value = ARDUINO_PWM_STEPS - 1;
}
/* Check if the PWM pin is valid */
int pin_idx = _get_pwm_pin_idx(pin);
if (pin_idx == -1) {
/* Set to digital write if not a PWM pin */
pinMode(pin, OUTPUT);
return;
}
/* Initialization of given PWM pin */
if (!(pwm_dev_state & (1 << arduino_pwm_list[pin_idx].dev))) {
if (pwm_init(arduino_pwm_list[pin_idx].dev,
ARDUINO_PWM_MODE, ARDUINO_PWM_FREQU, ARDUINO_PWM_STEPS) == 0) {
return;
}
/* The PWM channel is initialized */
pwm_dev_state |= (1 << arduino_pwm_list[pin_idx].dev);
}
/* Write analog value */
pwm_set(arduino_pwm_list[pin_idx].dev, arduino_pwm_list[pin_idx].chan, value);
}
#endif /* MODULE_PERIPH_PWM */