Fork of the espurna firmware for `mhsw` switches
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

746 lines
24 KiB

7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
7 years ago
  1. // =============================================================================
  2. // SENSORS - General data
  3. // =============================================================================
  4. #define SENSOR_DEBUG 0 // Debug sensors
  5. #define SENSOR_READ_INTERVAL 6 // Read data from sensors every 6 seconds
  6. #define SENSOR_READ_MIN_INTERVAL 6 // Minimum read interval
  7. #define SENSOR_READ_MAX_INTERVAL 3600 // Maximum read interval
  8. #define SENSOR_INIT_INTERVAL 10000 // Try to re-init non-ready sensors every 10s
  9. #define SENSOR_REPORT_EVERY 10 // Report every this many readings
  10. #define SENSOR_REPORT_MIN_EVERY 1 // Minimum every value
  11. #define SENSOR_REPORT_MAX_EVERY 12 // Maximum
  12. #define SENSOR_USE_INDEX 0 // Use the index in topic (i.e. temperature/0)
  13. // even if just one sensor (0 for backwards compatibility)
  14. #ifndef SENSOR_POWER_CHECK_STATUS
  15. #define SENSOR_POWER_CHECK_STATUS 1 // If set to 1 the reported power/current/energy will be 0 if the relay[0] is OFF
  16. #endif
  17. #ifndef SENSOR_TEMPERATURE_CORRECTION
  18. #define SENSOR_TEMPERATURE_CORRECTION 0.0 // Offset correction
  19. #endif
  20. #ifndef TEMPERATURE_MIN_CHANGE
  21. #define TEMPERATURE_MIN_CHANGE 0.0 // Minimum temperature change to report
  22. #endif
  23. #ifndef SENSOR_HUMIDITY_CORRECTION
  24. #define SENSOR_HUMIDITY_CORRECTION 0.0 // Offset correction
  25. #endif
  26. #ifndef HUMIDITY_MIN_CHANGE
  27. #define HUMIDITY_MIN_CHANGE 0 // Minimum humidity change to report
  28. #endif
  29. #define SENSOR_PUBLISH_ADDRESSES 0 // Publish sensor addresses
  30. #define SENSOR_ADDRESS_TOPIC "address" // Topic to publish sensor addresses
  31. #ifndef SENSOR_TEMPERATURE_UNITS
  32. #define SENSOR_TEMPERATURE_UNITS TMP_CELSIUS // Temperature units (TMP_CELSIUS | TMP_FAHRENHEIT)
  33. #endif
  34. #ifndef SENSOR_ENERGY_UNITS
  35. #define SENSOR_ENERGY_UNITS ENERGY_JOULES // Energy units (ENERGY_JOULES | ENERGY_KWH)
  36. #endif
  37. #ifndef SENSOR_POWER_UNITS
  38. #define SENSOR_POWER_UNITS POWER_WATTS // Power units (POWER_WATTS | POWER_KILOWATTS)
  39. #endif
  40. // =============================================================================
  41. // Specific data for each sensor
  42. // =============================================================================
  43. //------------------------------------------------------------------------------
  44. // AM2320 Humidity & Temperature sensor over I2C
  45. // Enable support by passing AM2320_SUPPORT=1 build flag
  46. //------------------------------------------------------------------------------
  47. #ifndef AM2320_SUPPORT
  48. #define AM2320_SUPPORT 0
  49. #endif
  50. #ifndef AM2320_ADDRESS
  51. #define AM2320_ADDRESS 0x00 // 0x00 means auto
  52. #endif
  53. //------------------------------------------------------------------------------
  54. // Analog sensor
  55. // Enable support by passing ANALOG_SUPPORT=1 build flag
  56. //--------------------------------------------------------------------------------
  57. #ifndef ANALOG_SUPPORT
  58. #define ANALOG_SUPPORT 0
  59. #endif
  60. //------------------------------------------------------------------------------
  61. // BH1750
  62. // Enable support by passing BH1750_SUPPORT=1 build flag
  63. // http://www.elechouse.com/elechouse/images/product/Digital%20light%20Sensor/bh1750fvi-e.pdf
  64. //------------------------------------------------------------------------------
  65. #ifndef BH1750_SUPPORT
  66. #define BH1750_SUPPORT 0
  67. #endif
  68. #ifndef BH1750_ADDRESS
  69. #define BH1750_ADDRESS 0x00 // 0x00 means auto
  70. #endif
  71. #define BH1750_MODE BH1750_CONTINUOUS_HIGH_RES_MODE
  72. //------------------------------------------------------------------------------
  73. // BME280/BMP280
  74. // Enable support by passing BMX280_SUPPORT=1 build flag
  75. //------------------------------------------------------------------------------
  76. #ifndef BMX280_SUPPORT
  77. #define BMX280_SUPPORT 0
  78. #endif
  79. #ifndef BMX280_ADDRESS
  80. #define BMX280_ADDRESS 0x00 // 0x00 means auto
  81. #endif
  82. #define BMX280_MODE 1 // 0 for sleep mode, 1 or 2 for forced mode, 3 for normal mode
  83. #define BMX280_STANDBY 0 // 0 for 0.5ms, 1 for 62.5ms, 2 for 125ms
  84. // 3 for 250ms, 4 for 500ms, 5 for 1000ms
  85. // 6 for 10ms, 7 for 20ms
  86. #define BMX280_FILTER 0 // 0 for OFF, 1 for 2 values, 2 for 4 values, 3 for 8 values and 4 for 16 values
  87. #define BMX280_TEMPERATURE 1 // Oversampling for temperature (set to 0 to disable magnitude)
  88. #define BMX280_HUMIDITY 1 // Oversampling for humidity (set to 0 to disable magnitude, only for BME280)
  89. #define BMX280_PRESSURE 1 // Oversampling for pressure (set to 0 to disable magnitude)
  90. //------------------------------------------------------------------------------
  91. // Dallas OneWire temperature sensors
  92. // Enable support by passing DALLAS_SUPPORT=1 build flag
  93. //------------------------------------------------------------------------------
  94. #ifndef DALLAS_SUPPORT
  95. #define DALLAS_SUPPORT 0
  96. #endif
  97. #ifndef DALLAS_PIN
  98. #define DALLAS_PIN 14
  99. #endif
  100. #define DALLAS_RESOLUTION 9 // Not used atm
  101. #define DALLAS_READ_INTERVAL 2000 // Force sensor read & cache every 2 seconds
  102. //------------------------------------------------------------------------------
  103. // DHTXX temperature/humidity sensor
  104. // Enable support by passing DHT_SUPPORT=1 build flag
  105. //------------------------------------------------------------------------------
  106. #ifndef DHT_SUPPORT
  107. #define DHT_SUPPORT 0
  108. #endif
  109. #ifndef DHT_PIN
  110. #define DHT_PIN 14
  111. #endif
  112. #ifndef DHT_TYPE
  113. #define DHT_TYPE DHT_CHIP_DHT22
  114. #endif
  115. //------------------------------------------------------------------------------
  116. // CSE7766 based power sensor
  117. // Enable support by passing CSE7766_SUPPORT=1 build flag
  118. //------------------------------------------------------------------------------
  119. #ifndef CSE7766_SUPPORT
  120. #define CSE7766_SUPPORT 0
  121. #endif
  122. #ifndef CSE7766_PIN
  123. #define CSE7766_PIN 1 // TX pin from the CSE7766
  124. #endif
  125. #ifndef CSE7766_PIN_INVERSE
  126. #define CSE7766_PIN_INVERSE 0 // Signal is inverted
  127. #endif
  128. #define CSE7766_SYNC_INTERVAL 300 // Safe time between transmissions (ms)
  129. #define CSE7766_BAUDRATE 4800 // UART baudrate
  130. #define CSE7766_V1R 1.0 // 1mR current resistor
  131. #define CSE7766_V2R 1.0 // 1M voltage resistor
  132. //------------------------------------------------------------------------------
  133. // Digital sensor
  134. // Enable support by passing DIGITAL_SUPPORT=1 build flag
  135. //------------------------------------------------------------------------------
  136. #ifndef DIGITAL_SUPPORT
  137. #define DIGITAL_SUPPORT 0
  138. #endif
  139. #ifndef DIGITAL_PIN
  140. #define DIGITAL_PIN 2
  141. #endif
  142. #ifndef DIGITAL_PIN_MODE
  143. #define DIGITAL_PIN_MODE INPUT_PULLUP
  144. #endif
  145. #ifndef DIGITAL_DEFAULT_STATE
  146. #define DIGITAL_DEFAULT_STATE 1
  147. #endif
  148. //------------------------------------------------------------------------------
  149. // ECH1560 based power sensor
  150. // Enable support by passing ECH1560_SUPPORT=1 build flag
  151. //------------------------------------------------------------------------------
  152. #ifndef ECH1560_SUPPORT
  153. #define ECH1560_SUPPORT 0
  154. #endif
  155. #ifndef ECH1560_CLK_PIN
  156. #define ECH1560_CLK_PIN 4 // CLK pin for the ECH1560
  157. #endif
  158. #ifndef ECH1560_MISO_PIN
  159. #define ECH1560_MISO_PIN 5 // MISO pin for the ECH1560
  160. #endif
  161. #ifndef ECH1560_INVERTED
  162. #define ECH1560_INVERTED 0 // Signal is inverted
  163. #endif
  164. //------------------------------------------------------------------------------
  165. // Energy Monitor general settings
  166. //------------------------------------------------------------------------------
  167. #define EMON_MAX_SAMPLES 1000 // Max number of samples to get
  168. #define EMON_MAX_TIME 250 // Max time in ms to sample
  169. #define EMON_FILTER_SPEED 512 // Mobile average filter speed
  170. #define EMON_MAINS_VOLTAGE 230 // Mains voltage
  171. #define EMON_REFERENCE_VOLTAGE 3.3 // Reference voltage of the ADC
  172. #define EMON_CURRENT_RATIO 30 // Current ratio in the clamp (30V/1A)
  173. #define EMON_REPORT_CURRENT 0 // Report current
  174. #define EMON_REPORT_POWER 1 // Report power
  175. #define EMON_REPORT_ENERGY 1 // Report energy
  176. //------------------------------------------------------------------------------
  177. // Energy Monitor based on ADC121
  178. // Enable support by passing EMON_ADC121_SUPPORT=1 build flag
  179. //------------------------------------------------------------------------------
  180. #ifndef EMON_ADC121_SUPPORT
  181. #define EMON_ADC121_SUPPORT 0 // Do not build support by default
  182. #endif
  183. #define EMON_ADC121_I2C_ADDRESS 0x00 // 0x00 means auto
  184. //------------------------------------------------------------------------------
  185. // Energy Monitor based on ADS1X15
  186. // Enable support by passing EMON_ADS1X15_SUPPORT=1 build flag
  187. //------------------------------------------------------------------------------
  188. #ifndef EMON_ADS1X15_SUPPORT
  189. #define EMON_ADS1X15_SUPPORT 0 // Do not build support by default
  190. #endif
  191. #define EMON_ADS1X15_I2C_ADDRESS 0x00 // 0x00 means auto
  192. #define EMON_ADS1X15_TYPE ADS1X15_CHIP_ADS1115
  193. #define EMON_ADS1X15_GAIN ADS1X15_REG_CONFIG_PGA_4_096V
  194. #define EMON_ADS1X15_MASK 0x0F // A0=1 A1=2 A2=4 A3=8
  195. //------------------------------------------------------------------------------
  196. // Energy Monitor based on interval analog GPIO
  197. // Enable support by passing EMON_ANALOG_SUPPORT=1 build flag
  198. //------------------------------------------------------------------------------
  199. #ifndef EMON_ANALOG_SUPPORT
  200. #define EMON_ANALOG_SUPPORT 0 // Do not build support by default
  201. #endif
  202. //------------------------------------------------------------------------------
  203. // Counter sensor
  204. // Enable support by passing EVENTS_SUPPORT=1 build flag
  205. //------------------------------------------------------------------------------
  206. #ifndef EVENTS_SUPPORT
  207. #define EVENTS_SUPPORT 0 // Do not build with counter support by default
  208. #endif
  209. #ifndef EVENTS_PIN
  210. #define EVENTS_PIN 2 // GPIO to monitor
  211. #endif
  212. #ifndef EVENTS_PIN_MODE
  213. #define EVENTS_PIN_MODE INPUT // INPUT, INPUT_PULLUP
  214. #endif
  215. #ifndef EVENTS_INTERRUPT_MODE
  216. #define EVENTS_INTERRUPT_MODE RISING // RISING, FALLING, BOTH
  217. #endif
  218. #define EVENTS_DEBOUNCE 50 // Do not register events within less than 50 millis
  219. //------------------------------------------------------------------------------
  220. // Geiger sensor
  221. // Enable support by passing GEIGER_SUPPORT=1 build flag
  222. //------------------------------------------------------------------------------
  223. #ifndef GEIGER_SUPPORT
  224. #define GEIGER_SUPPORT 0 // Do not build with geiger support by default
  225. #endif
  226. #ifndef GEIGER_PIN
  227. #define GEIGER_PIN D1 // GPIO to monitor "D1" => "GPIO5"
  228. #endif
  229. #ifndef GEIGER_PIN_MODE
  230. #define GEIGER_PIN_MODE INPUT // INPUT, INPUT_PULLUP
  231. #endif
  232. #ifndef GEIGER_INTERRUPT_MODE
  233. #define GEIGER_INTERRUPT_MODE RISING // RISING, FALLING, BOTH
  234. #endif
  235. #define GEIGER_DEBOUNCE 25 // Do not register events within less than 25 millis.
  236. // Value derived here: Debounce time 25ms, because https://github.com/Trickx/espurna/wiki/Geiger-counter
  237. #define GEIGER_CPM2SIEVERT 240 // CPM to µSievert per hour conversion factor
  238. // Typically the literature uses the invers, but I find an integer type more convienient.
  239. #define GEIGER_REPORT_SIEVERTS 1 // Enabler for local dose rate reports in µSv/h
  240. #define GEIGER_REPORT_CPM 1 // Enabler for local dose rate reports in counts per minute
  241. //------------------------------------------------------------------------------
  242. // GUVAS12SD UV Sensor (analog)
  243. // Enable support by passing GUVAS12SD_SUPPORT=1 build flag
  244. //------------------------------------------------------------------------------
  245. #ifndef GUVAS12SD_SUPPORT
  246. #define GUVAS12SD_SUPPORT 0
  247. #endif
  248. #ifndef GUVAS12SD_PIN
  249. #define GUVAS12SD_PIN 14
  250. #endif
  251. //------------------------------------------------------------------------------
  252. // HC-SR04
  253. // Enable support by passing HCSR04_SUPPORT=1 build flag
  254. //------------------------------------------------------------------------------
  255. #ifndef HCSR04_SUPPORT
  256. #define HCSR04_SUPPORT 0
  257. #endif
  258. #ifndef HCSR04_TRIGGER
  259. #define HCSR04_TRIGGER 12 // GPIO for the trigger pin (output)
  260. #endif
  261. #ifndef HCSR04_ECHO
  262. #define HCSR04_ECHO 14 // GPIO for the echo pin (input)
  263. #endif
  264. //------------------------------------------------------------------------------
  265. // HLW8012 Energy monitor IC
  266. // Enable support by passing HLW8012_SUPPORT=1 build flag
  267. //------------------------------------------------------------------------------
  268. #ifndef HLW8012_SUPPORT
  269. #define HLW8012_SUPPORT 0
  270. #endif
  271. #ifndef HLW8012_SEL_PIN
  272. #define HLW8012_SEL_PIN 5
  273. #endif
  274. #ifndef HLW8012_CF1_PIN
  275. #define HLW8012_CF1_PIN 13
  276. #endif
  277. #ifndef HLW8012_CF_PIN
  278. #define HLW8012_CF_PIN 14
  279. #endif
  280. #ifndef HLW8012_SEL_CURRENT
  281. #define HLW8012_SEL_CURRENT HIGH // SEL pin to HIGH to measure current
  282. #endif
  283. #ifndef HLW8012_CURRENT_R
  284. #define HLW8012_CURRENT_R 0.001 // Current resistor
  285. #endif
  286. #ifndef HLW8012_VOLTAGE_R_UP
  287. #define HLW8012_VOLTAGE_R_UP ( 5 * 470000 ) // Upstream voltage resistor
  288. #endif
  289. #ifndef HLW8012_VOLTAGE_R_DOWN
  290. #define HLW8012_VOLTAGE_R_DOWN ( 1000 ) // Downstream voltage resistor
  291. #endif
  292. #ifndef HLW8012_CURRENT_RATIO
  293. #define HLW8012_CURRENT_RATIO 0 // Set to 0 to use factory defaults
  294. #endif
  295. #ifndef HLW8012_VOLTAGE_RATIO
  296. #define HLW8012_VOLTAGE_RATIO 0 // Set to 0 to use factory defaults
  297. #endif
  298. #ifndef HLW8012_POWER_RATIO
  299. #define HLW8012_POWER_RATIO 0 // Set to 0 to use factory defaults
  300. #endif
  301. #ifndef HLW8012_USE_INTERRUPTS
  302. #define HLW8012_USE_INTERRUPTS 1 // Use interrupts to trap HLW8012 signals
  303. #endif
  304. #ifndef HLW8012_INTERRUPT_ON
  305. #define HLW8012_INTERRUPT_ON CHANGE // When to trigger the interrupt
  306. // Use CHANGE for HLW8012
  307. // Use FALLING for BL0937 / HJL0
  308. #endif
  309. //------------------------------------------------------------------------------
  310. // MHZ19 CO2 sensor
  311. // Enable support by passing MHZ19_SUPPORT=1 build flag
  312. //------------------------------------------------------------------------------
  313. #ifndef MHZ19_SUPPORT
  314. #define MHZ19_SUPPORT 0
  315. #endif
  316. #ifndef MHZ19_RX_PIN
  317. #define MHZ19_RX_PIN 13
  318. #endif
  319. #ifndef MHZ19_TX_PIN
  320. #define MHZ19_TX_PIN 15
  321. #endif
  322. //------------------------------------------------------------------------------
  323. // SenseAir CO2 sensor
  324. // Enable support by passing SENSEAIR_SUPPORT=1 build flag
  325. //------------------------------------------------------------------------------
  326. #ifndef SENSEAIR_SUPPORT
  327. #define SENSEAIR_SUPPORT 0
  328. #endif
  329. #ifndef SENSEAIR_RX_PIN
  330. #define SENSEAIR_RX_PIN 0
  331. #endif
  332. #ifndef SENSEAIR_TX_PIN
  333. #define SENSEAIR_TX_PIN 2
  334. #endif
  335. //------------------------------------------------------------------------------
  336. // Particle Monitor based on Plantower PMS
  337. // Enable support by passing PMSX003_SUPPORT=1 build flag
  338. //------------------------------------------------------------------------------
  339. #ifndef PMSX003_SUPPORT
  340. #define PMSX003_SUPPORT 0
  341. #endif
  342. #ifndef PMS_TYPE
  343. #define PMS_TYPE PMS_TYPE_X003
  344. #endif
  345. // You can enable smart sleep (read 6-times then sleep on 24-reading-cycles) to extend PMS sensor's life.
  346. // Otherwise the default lifetime of PMS sensor is about 8000-hours/1-years.
  347. // The PMS's fan will stop working on sleeping cycle, and will wake up on reading cycle.
  348. #ifndef PMS_SMART_SLEEP
  349. #define PMS_SMART_SLEEP 0
  350. #endif
  351. #ifndef PMS_RX_PIN
  352. #define PMS_RX_PIN 13
  353. #endif
  354. #ifndef PMS_TX_PIN
  355. #define PMS_TX_PIN 15
  356. #endif
  357. //------------------------------------------------------------------------------
  358. // PZEM004T based power monitor
  359. // Enable support by passing PZEM004T_SUPPORT=1 build flag
  360. //------------------------------------------------------------------------------
  361. #ifndef PZEM004T_SUPPORT
  362. #define PZEM004T_SUPPORT 0
  363. #endif
  364. #ifndef PZEM004T_USE_SOFT
  365. #define PZEM004T_USE_SOFT 0 // Software serial is not working atm, use hardware serial
  366. #endif
  367. #ifndef PZEM004T_RX_PIN
  368. #define PZEM004T_RX_PIN 13 // Software serial RX GPIO (if PZEM004T_USE_SOFT == 1)
  369. #endif
  370. #ifndef PZEM004T_TX_PIN
  371. #define PZEM004T_TX_PIN 15 // Software serial TX GPIO (if PZEM004T_USE_SOFT == 1)
  372. #endif
  373. #ifndef PZEM004T_HW_PORT
  374. #define PZEM004T_HW_PORT Serial // Hardware serial port (if PZEM004T_USE_SOFT == 0)
  375. #endif
  376. //------------------------------------------------------------------------------
  377. // SHT3X I2C (Wemos) temperature & humidity sensor
  378. // Enable support by passing SHT3X_SUPPORT=1 build flag
  379. //------------------------------------------------------------------------------
  380. #ifndef SHT3X_I2C_SUPPORT
  381. #define SHT3X_I2C_SUPPORT 0
  382. #endif
  383. #ifndef SHT3X_I2C_ADDRESS
  384. #define SHT3X_I2C_ADDRESS 0x00 // 0x00 means auto
  385. #endif
  386. //------------------------------------------------------------------------------
  387. // SI7021 temperature & humidity sensor
  388. // Enable support by passing SI7021_SUPPORT=1 build flag
  389. //------------------------------------------------------------------------------
  390. #ifndef SI7021_SUPPORT
  391. #define SI7021_SUPPORT 0
  392. #endif
  393. #ifndef SI7021_ADDRESS
  394. #define SI7021_ADDRESS 0x00 // 0x00 means auto
  395. #endif
  396. //------------------------------------------------------------------------------
  397. // TMP3X analog temperature sensor
  398. // Enable support by passing TMP3X_SUPPORT=1 build flag
  399. //------------------------------------------------------------------------------
  400. #ifndef TMP3X_SUPPORT
  401. #define TMP3X_SUPPORT 0
  402. #endif
  403. #ifndef TMP3X_TYPE
  404. #define TMP3X_TYPE TMP3X_TMP35
  405. #endif
  406. //------------------------------------------------------------------------------
  407. // V9261F based power sensor
  408. // Enable support by passing SI7021_SUPPORT=1 build flag
  409. //------------------------------------------------------------------------------
  410. #ifndef V9261F_SUPPORT
  411. #define V9261F_SUPPORT 0
  412. #endif
  413. #ifndef V9261F_PIN
  414. #define V9261F_PIN 2 // TX pin from the V9261F
  415. #endif
  416. #ifndef V9261F_PIN_INVERSE
  417. #define V9261F_PIN_INVERSE 1 // Signal is inverted
  418. #endif
  419. #define V9261F_SYNC_INTERVAL 600 // Sync signal length (ms)
  420. #define V9261F_BAUDRATE 4800 // UART baudrate
  421. // Default ratios
  422. #define V9261F_CURRENT_FACTOR 79371434.0
  423. #define V9261F_VOLTAGE_FACTOR 4160651.0
  424. #define V9261F_POWER_FACTOR 153699.0
  425. #define V9261F_RPOWER_FACTOR V9261F_CURRENT_FACTOR
  426. // =============================================================================
  427. // Sensor helpers configuration - can't move to dependencies.h
  428. // =============================================================================
  429. #ifndef SENSOR_SUPPORT
  430. #define SENSOR_SUPPORT ( \
  431. AM2320_SUPPORT || \
  432. ANALOG_SUPPORT || \
  433. BH1750_SUPPORT || \
  434. BMX280_SUPPORT || \
  435. CSE7766_SUPPORT || \
  436. DALLAS_SUPPORT || \
  437. DHT_SUPPORT || \
  438. DIGITAL_SUPPORT || \
  439. ECH1560_SUPPORT || \
  440. EMON_ADC121_SUPPORT || \
  441. EMON_ADS1X15_SUPPORT || \
  442. EMON_ANALOG_SUPPORT || \
  443. EVENTS_SUPPORT || \
  444. GEIGER_SUPPORT || \
  445. GUVAS12SD_SUPPORT || \
  446. HCSR04_SUPPORT || \
  447. HLW8012_SUPPORT || \
  448. MHZ19_SUPPORT || \
  449. SENSEAIR_SUPPORT || \
  450. PMSX003_SUPPORT || \
  451. PZEM004T_SUPPORT || \
  452. SHT3X_I2C_SUPPORT || \
  453. SI7021_SUPPORT || \
  454. TMP3X_SUPPORT || \
  455. V9261F_SUPPORT \
  456. )
  457. #endif
  458. // -----------------------------------------------------------------------------
  459. // ADC
  460. // -----------------------------------------------------------------------------
  461. // Default ADC mode is to monitor internal power supply
  462. #ifndef ADC_MODE_VALUE
  463. #define ADC_MODE_VALUE ADC_VCC
  464. #endif
  465. // -----------------------------------------------------------------------------
  466. // I2C
  467. // -----------------------------------------------------------------------------
  468. #ifndef I2C_SUPPORT
  469. #define I2C_SUPPORT 0 // I2C enabled (1.98Kb)
  470. #endif
  471. #define I2C_USE_BRZO 0 // Use brzo_i2c library or standard Wire
  472. #ifndef I2C_SDA_PIN
  473. #define I2C_SDA_PIN SDA // SDA GPIO (Sonoff => 4)
  474. #endif
  475. #ifndef I2C_SCL_PIN
  476. #define I2C_SCL_PIN SCL // SCL GPIO (Sonoff => 14)
  477. #endif
  478. #define I2C_CLOCK_STRETCH_TIME 200 // BRZO clock stretch time
  479. #define I2C_SCL_FREQUENCY 1000 // BRZO SCL frequency
  480. #define I2C_CLEAR_BUS 0 // Clear I2C bus on boot
  481. #define I2C_PERFORM_SCAN 1 // Perform a bus scan on boot
  482. //--------------------------------------------------------------------------------
  483. // Class loading
  484. //--------------------------------------------------------------------------------
  485. #if SENSOR_SUPPORT
  486. #if SENSOR_DEBUG
  487. #include "../config/debug.h"
  488. #endif
  489. #include "../sensors/BaseSensor.h"
  490. #if AM2320_SUPPORT
  491. #include "../sensors/AM2320Sensor.h"
  492. #endif
  493. #if ANALOG_SUPPORT
  494. #include "../sensors/AnalogSensor.h"
  495. #endif
  496. #if BH1750_SUPPORT
  497. #include "../sensors/BH1750Sensor.h"
  498. #endif
  499. #if BMX280_SUPPORT
  500. #include "../sensors/BMX280Sensor.h"
  501. #endif
  502. #if CSE7766_SUPPORT
  503. #include <SoftwareSerial.h>
  504. #include "../sensors/CSE7766Sensor.h"
  505. #endif
  506. #if DALLAS_SUPPORT
  507. #include <OneWire.h>
  508. #include "../sensors/DallasSensor.h"
  509. #endif
  510. #if DHT_SUPPORT
  511. #include "../sensors/DHTSensor.h"
  512. #endif
  513. #if DIGITAL_SUPPORT
  514. #include "../sensors/DigitalSensor.h"
  515. #endif
  516. #if ECH1560_SUPPORT
  517. #include "../sensors/ECH1560Sensor.h"
  518. #endif
  519. #if EMON_ADC121_SUPPORT
  520. #include "../sensors/EmonADC121Sensor.h"
  521. #endif
  522. #if EMON_ADS1X15_SUPPORT
  523. #include "../sensors/EmonADS1X15Sensor.h"
  524. #endif
  525. #if EMON_ANALOG_SUPPORT
  526. #include "../sensors/EmonAnalogSensor.h"
  527. #endif
  528. #if EVENTS_SUPPORT
  529. #include "../sensors/EventSensor.h"
  530. #endif
  531. #if GEIGER_SUPPORT
  532. #include "../sensors/GeigerSensor.h" // The main file for geiger counting module
  533. #endif
  534. #if GUVAS12SD_SUPPORT
  535. #include "../sensors/GUVAS12SDSensor.h"
  536. #endif
  537. #if HCSR04_SUPPORT
  538. #include "../sensors/HCSR04Sensor.h"
  539. #endif
  540. #if HLW8012_SUPPORT
  541. #include <HLW8012.h>
  542. #include "../sensors/HLW8012Sensor.h"
  543. #endif
  544. #if MHZ19_SUPPORT
  545. #include <SoftwareSerial.h>
  546. #include "../sensors/MHZ19Sensor.h"
  547. #endif
  548. #if SENSEAIR_SUPPORT
  549. #include <SoftwareSerial.h>
  550. #include "../sensors/SenseAirSensor.h"
  551. #endif
  552. #if PMSX003_SUPPORT
  553. #include <SoftwareSerial.h>
  554. #include "../sensors/PMSX003Sensor.h"
  555. #endif
  556. #if PZEM004T_SUPPORT
  557. #include <SoftwareSerial.h>
  558. #include "../sensors/PZEM004TSensor.h"
  559. #endif
  560. #if SI7021_SUPPORT
  561. #include "../sensors/SI7021Sensor.h"
  562. #endif
  563. #if SHT3X_I2C_SUPPORT
  564. #include "../sensors/SHT3XI2CSensor.h"
  565. #endif
  566. #if TMP3X_SUPPORT
  567. #include "../sensors/TMP3XSensor.h"
  568. #endif
  569. #if V9261F_SUPPORT
  570. #include <SoftwareSerial.h>
  571. #include "../sensors/V9261FSensor.h"
  572. #endif
  573. #endif // SENSOR_SUPPORT