event_send.c 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. // Copyright 2018 Espressif Systems (Shanghai) PTE LTD
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. #include <string.h>
  15. #include "esp_log.h"
  16. #include "esp_event.h"
  17. #include "esp_event_legacy.h"
  18. #define TAG "event_send"
  19. esp_err_t esp_event_send_noop(system_event_t *event);
  20. extern esp_err_t esp_event_send_legacy(system_event_t *event) __attribute__((weak, alias("esp_event_send_noop")));
  21. extern esp_err_t esp_event_send_to_default_loop(system_event_t *event) __attribute((weak, alias("esp_event_send_noop")));
  22. esp_err_t esp_event_send_noop(system_event_t *event)
  23. {
  24. return ESP_OK;
  25. }
  26. static system_event_id_t esp_event_legacy_wifi_event_id(int32_t event_id)
  27. {
  28. switch (event_id) {
  29. case WIFI_EVENT_WIFI_READY:
  30. return SYSTEM_EVENT_WIFI_READY;
  31. case WIFI_EVENT_SCAN_DONE:
  32. return SYSTEM_EVENT_SCAN_DONE;
  33. case WIFI_EVENT_STA_START:
  34. return SYSTEM_EVENT_STA_START;
  35. case WIFI_EVENT_STA_STOP:
  36. return SYSTEM_EVENT_STA_STOP;
  37. case WIFI_EVENT_STA_CONNECTED:
  38. return SYSTEM_EVENT_STA_CONNECTED;
  39. case WIFI_EVENT_STA_DISCONNECTED:
  40. return SYSTEM_EVENT_STA_DISCONNECTED;
  41. case WIFI_EVENT_STA_AUTHMODE_CHANGE:
  42. return SYSTEM_EVENT_STA_AUTHMODE_CHANGE;
  43. case WIFI_EVENT_STA_BSS_RSSI_LOW:
  44. return SYSTEM_EVENT_STA_BSS_RSSI_LOW;
  45. case WIFI_EVENT_STA_WPS_ER_SUCCESS:
  46. return SYSTEM_EVENT_STA_WPS_ER_SUCCESS;
  47. case WIFI_EVENT_STA_WPS_ER_FAILED:
  48. return SYSTEM_EVENT_STA_WPS_ER_FAILED;
  49. case WIFI_EVENT_STA_WPS_ER_TIMEOUT:
  50. return SYSTEM_EVENT_STA_WPS_ER_TIMEOUT;
  51. case WIFI_EVENT_STA_WPS_ER_PIN:
  52. return SYSTEM_EVENT_STA_WPS_ER_PIN;
  53. case WIFI_EVENT_STA_WPS_ER_PBC_OVERLAP:
  54. return SYSTEM_EVENT_STA_WPS_ER_PBC_OVERLAP;
  55. case WIFI_EVENT_AP_START:
  56. return SYSTEM_EVENT_AP_START;
  57. case WIFI_EVENT_AP_STOP:
  58. return SYSTEM_EVENT_AP_STOP;
  59. case WIFI_EVENT_AP_STACONNECTED:
  60. return SYSTEM_EVENT_AP_STACONNECTED;
  61. case WIFI_EVENT_AP_STADISCONNECTED:
  62. return SYSTEM_EVENT_AP_STADISCONNECTED;
  63. case WIFI_EVENT_AP_PROBEREQRECVED:
  64. return SYSTEM_EVENT_AP_PROBEREQRECVED;
  65. case WIFI_EVENT_ACTION_TX_STATUS:
  66. return SYSTEM_EVENT_ACTION_TX_STATUS;
  67. case WIFI_EVENT_ROC_DONE:
  68. return SYSTEM_EVENT_ROC_DONE;
  69. case WIFI_EVENT_FTM_REPORT:
  70. return SYSTEM_EVENT_FTM_REPORT;
  71. default:
  72. ESP_LOGE(TAG, "invalid wifi event id %d", event_id);
  73. return SYSTEM_EVENT_MAX;
  74. }
  75. }
  76. static system_event_id_t esp_event_legacy_ip_event_id(int32_t event_id)
  77. {
  78. switch (event_id) {
  79. case IP_EVENT_STA_GOT_IP:
  80. return SYSTEM_EVENT_STA_GOT_IP;
  81. case IP_EVENT_STA_LOST_IP:
  82. return SYSTEM_EVENT_STA_LOST_IP;
  83. case IP_EVENT_AP_STAIPASSIGNED:
  84. return SYSTEM_EVENT_AP_STAIPASSIGNED;
  85. case IP_EVENT_GOT_IP6:
  86. return SYSTEM_EVENT_GOT_IP6;
  87. case IP_EVENT_ETH_GOT_IP:
  88. return SYSTEM_EVENT_ETH_GOT_IP;
  89. default:
  90. ESP_LOGE(TAG, "invalid ip event id %d", event_id);
  91. return SYSTEM_EVENT_MAX;
  92. }
  93. }
  94. static system_event_id_t esp_event_legacy_event_id(esp_event_base_t event_base, int32_t event_id)
  95. {
  96. if (event_base == WIFI_EVENT) {
  97. return esp_event_legacy_wifi_event_id(event_id);
  98. } else if (event_base == IP_EVENT) {
  99. return esp_event_legacy_ip_event_id(event_id);
  100. } else {
  101. ESP_LOGE(TAG, "invalid event base %s", event_base);
  102. return SYSTEM_EVENT_MAX;
  103. }
  104. }
  105. esp_err_t esp_event_send(system_event_t *event)
  106. {
  107. // send the event to the new style event loop
  108. esp_err_t err = esp_event_send_to_default_loop(event);
  109. if (err != ESP_OK) {
  110. return err;
  111. }
  112. // send the event to the legacy event loop
  113. err = esp_event_send_legacy(event);
  114. if (err != ESP_OK) {
  115. return err;
  116. }
  117. return ESP_OK;
  118. }
  119. esp_err_t esp_event_send_internal(esp_event_base_t event_base,
  120. int32_t event_id,
  121. void* event_data,
  122. size_t event_data_size,
  123. TickType_t ticks_to_wait)
  124. {
  125. system_event_t event;
  126. // send the event to the new style event loop
  127. esp_err_t err = esp_event_post(event_base, event_id, event_data, event_data_size, ticks_to_wait);
  128. if (err != ESP_OK) {
  129. return err;
  130. }
  131. event.event_id = esp_event_legacy_event_id(event_base, event_id);
  132. if (event_data) {
  133. memcpy(&event.event_info, event_data, event_data_size);
  134. }
  135. return esp_event_send_legacy(&event);
  136. }