/* * moisture.cpp * * ESP8266 / ESP32 Environmental Sensor * * ---------------------------------------------------------------------------- * "THE BEER-WARE LICENSE" (Revision 42): * wrote this file. As long as you retain this notice * you can do whatever you want with this stuff. If we meet some day, and you * think this stuff is worth it, you can buy me a beer in return. Thomas Buck * ---------------------------------------------------------------------------- */ #include #include "moisture.h" #if defined(ARDUINO_ARCH_ESP8266) int moisture_count(void) { return 0; } int moisture_read(int sensor) { return 0; } int moisture_max(void) { return 0; } void moisture_init(void) { } #elif defined(ARDUINO_ARCH_ESP32) #include #define ADC_OVERSAMPLE 20 #define ADC_BITWIDTH 12 #define ADC_BITS ADC_WIDTH_BIT_12 #define ADC_ATTENUATION ADC_ATTEN_DB_11 #define SENSOR_COUNT 6 adc1_channel_t sensor_pin[SENSOR_COUNT] = { ADC1_CHANNEL_0, ADC1_CHANNEL_3, ADC1_CHANNEL_6, ADC1_CHANNEL_7, ADC1_CHANNEL_4, ADC1_CHANNEL_5 }; static int adc_read_oversampled(adc1_channel_t pin) { uint32_t sample_sum = 0; for (int i = 0; i < ADC_OVERSAMPLE; i++) { sample_sum += adc1_get_raw(pin); } return sample_sum / ADC_OVERSAMPLE; } int moisture_count(void) { return SENSOR_COUNT; } int moisture_read(int sensor) { if ((sensor < 0) || (sensor > SENSOR_COUNT)) { return -1; } return adc_read_oversampled(sensor_pin[sensor]); } int moisture_max(void) { return (1 << ADC_BITWIDTH) - 1; } void moisture_init(void) { adc1_config_width(ADC_BITS); for (int i = 0; i < SENSOR_COUNT; i++) { adc1_config_channel_atten(sensor_pin[i], ADC_ATTENUATION); } } #elif defined(ARDUINO_ARCH_AVR) #define SENSOR_COUNT 6 uint8_t sensor_pins[SENSOR_COUNT] = { A0, A1, A2, A3, A4, A5 }; int moisture_count(void) { return 6; } int moisture_read(int sensor) { return (analogRead(sensor_pins[sensor]) << 2) | 3; } int moisture_max(void) { return 4095; } void moisture_init(void) { } #endif