main.c 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. #include "freertos/FreeRTOS.h"
  2. #include "freertos/task.h"
  3. #include "esp_log.h"
  4. #include "config.h"
  5. #include "wifi.h"
  6. #include "mqtt.h"
  7. #include "kWhCounter.h"
  8. #include "http_client.h"
  9. #include "readTemps.h"
  10. // Chip info:
  11. // This is esp32 chip with 2 CPU cores, WiFi/BT/BLE, silicon revision 1, 4MB external flash
  12. void app_main(void)
  13. {
  14. char txt[50];
  15. ESP_LOGI("MAIN", "HomeEnergyMeter ESP32. Core:%d",xPortGetCoreID());
  16. gpio_reset_pin(VVB_RELAY_OUTPUT_IO);
  17. gpio_set_direction(VVB_RELAY_OUTPUT_IO, GPIO_MODE_OUTPUT);
  18. #ifdef ENABLE_KWH_COUNTER
  19. kWhCounter_init();
  20. #endif
  21. #ifdef WIFI_ENABLED
  22. initWifi(); // Init WIFI
  23. #endif
  24. #ifdef MQTT_ENABLED
  25. mqtt_init();
  26. #endif
  27. const TickType_t xFreq = 5000 / portTICK_PERIOD_MS;
  28. TickType_t vLastWakeTime = xTaskGetTickCount();
  29. // ---------------- MAIN WHILE -------------------
  30. while(1) {
  31. vTaskDelayUntil( &vLastWakeTime, 2000/portTICK_PERIOD_MS );
  32. readTemps();
  33. vTaskDelayUntil( &vLastWakeTime, xFreq );
  34. #ifdef HTTP_ENABLED
  35. http_rest_with_url();
  36. #endif
  37. vTaskDelayUntil( &vLastWakeTime, xFreq );
  38. sprintf(txt,"%u",kWh_cnt);
  39. #ifdef MQTT_ENABLED
  40. sendMQTTMessage("basement/boiler/onTime", txt);
  41. #endif
  42. #ifdef ENABLE_DS18B20
  43. readTemps();
  44. #endif
  45. }
  46. vTaskDelete(NULL);
  47. }