mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-26 04:33:47 +00:00 
			
		
		
		
	[esp32_ble] Use RAMAllocator to avoid panic abort from `new` (#7936)
				
					
				
			This commit is contained in:
		| @@ -27,6 +27,9 @@ namespace esp32_ble { | |||||||
|  |  | ||||||
| static const char *const TAG = "esp32_ble"; | static const char *const TAG = "esp32_ble"; | ||||||
|  |  | ||||||
|  | static RAMAllocator<BLEEvent> EVENT_ALLOCATOR(  // NOLINT(cppcoreguidelines-avoid-non-const-global-variables) | ||||||
|  |     RAMAllocator<BLEEvent>::ALLOW_FAILURE | RAMAllocator<BLEEvent>::ALLOC_INTERNAL); | ||||||
|  |  | ||||||
| void ESP32BLE::setup() { | void ESP32BLE::setup() { | ||||||
|   global_ble = this; |   global_ble = this; | ||||||
|   ESP_LOGCONFIG(TAG, "Setting up BLE..."); |   ESP_LOGCONFIG(TAG, "Setting up BLE..."); | ||||||
| @@ -322,7 +325,8 @@ void ESP32BLE::loop() { | |||||||
|       default: |       default: | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|     delete ble_event;  // NOLINT(cppcoreguidelines-owning-memory) |     ble_event->~BLEEvent(); | ||||||
|  |     EVENT_ALLOCATOR.deallocate(ble_event, 1); | ||||||
|     ble_event = this->ble_events_.pop(); |     ble_event = this->ble_events_.pop(); | ||||||
|   } |   } | ||||||
|   if (this->advertising_ != nullptr) { |   if (this->advertising_ != nullptr) { | ||||||
| @@ -331,9 +335,14 @@ void ESP32BLE::loop() { | |||||||
| } | } | ||||||
|  |  | ||||||
| void ESP32BLE::gap_event_handler(esp_gap_ble_cb_event_t event, esp_ble_gap_cb_param_t *param) { | void ESP32BLE::gap_event_handler(esp_gap_ble_cb_event_t event, esp_ble_gap_cb_param_t *param) { | ||||||
|   BLEEvent *new_event = new BLEEvent(event, param);  // NOLINT(cppcoreguidelines-owning-memory) |   BLEEvent *new_event = EVENT_ALLOCATOR.allocate(1); | ||||||
|  |   if (new_event == nullptr) { | ||||||
|  |     // Memory too fragmented to allocate new event. Can only drop it until memory comes back | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   new (new_event) BLEEvent(event, param); | ||||||
|   global_ble->ble_events_.push(new_event); |   global_ble->ble_events_.push(new_event); | ||||||
| }  // NOLINT(clang-analyzer-cplusplus.NewDeleteLeaks) | }  // NOLINT(clang-analyzer-unix.Malloc) | ||||||
|  |  | ||||||
| void ESP32BLE::real_gap_event_handler_(esp_gap_ble_cb_event_t event, esp_ble_gap_cb_param_t *param) { | void ESP32BLE::real_gap_event_handler_(esp_gap_ble_cb_event_t event, esp_ble_gap_cb_param_t *param) { | ||||||
|   ESP_LOGV(TAG, "(BLE) gap_event_handler - %d", event); |   ESP_LOGV(TAG, "(BLE) gap_event_handler - %d", event); | ||||||
| @@ -344,9 +353,14 @@ void ESP32BLE::real_gap_event_handler_(esp_gap_ble_cb_event_t event, esp_ble_gap | |||||||
|  |  | ||||||
| void ESP32BLE::gatts_event_handler(esp_gatts_cb_event_t event, esp_gatt_if_t gatts_if, | void ESP32BLE::gatts_event_handler(esp_gatts_cb_event_t event, esp_gatt_if_t gatts_if, | ||||||
|                                    esp_ble_gatts_cb_param_t *param) { |                                    esp_ble_gatts_cb_param_t *param) { | ||||||
|   BLEEvent *new_event = new BLEEvent(event, gatts_if, param);  // NOLINT(cppcoreguidelines-owning-memory) |   BLEEvent *new_event = EVENT_ALLOCATOR.allocate(1); | ||||||
|  |   if (new_event == nullptr) { | ||||||
|  |     // Memory too fragmented to allocate new event. Can only drop it until memory comes back | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   new (new_event) BLEEvent(event, gatts_if, param); | ||||||
|   global_ble->ble_events_.push(new_event); |   global_ble->ble_events_.push(new_event); | ||||||
| }  // NOLINT(clang-analyzer-cplusplus.NewDeleteLeaks) | }  // NOLINT(clang-analyzer-unix.Malloc) | ||||||
|  |  | ||||||
| void ESP32BLE::real_gatts_event_handler_(esp_gatts_cb_event_t event, esp_gatt_if_t gatts_if, | void ESP32BLE::real_gatts_event_handler_(esp_gatts_cb_event_t event, esp_gatt_if_t gatts_if, | ||||||
|                                          esp_ble_gatts_cb_param_t *param) { |                                          esp_ble_gatts_cb_param_t *param) { | ||||||
| @@ -358,9 +372,14 @@ void ESP32BLE::real_gatts_event_handler_(esp_gatts_cb_event_t event, esp_gatt_if | |||||||
|  |  | ||||||
| void ESP32BLE::gattc_event_handler(esp_gattc_cb_event_t event, esp_gatt_if_t gattc_if, | void ESP32BLE::gattc_event_handler(esp_gattc_cb_event_t event, esp_gatt_if_t gattc_if, | ||||||
|                                    esp_ble_gattc_cb_param_t *param) { |                                    esp_ble_gattc_cb_param_t *param) { | ||||||
|   BLEEvent *new_event = new BLEEvent(event, gattc_if, param);  // NOLINT(cppcoreguidelines-owning-memory) |   BLEEvent *new_event = EVENT_ALLOCATOR.allocate(1); | ||||||
|  |   if (new_event == nullptr) { | ||||||
|  |     // Memory too fragmented to allocate new event. Can only drop it until memory comes back | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |   new (new_event) BLEEvent(event, gattc_if, param); | ||||||
|   global_ble->ble_events_.push(new_event); |   global_ble->ble_events_.push(new_event); | ||||||
| }  // NOLINT(clang-analyzer-cplusplus.NewDeleteLeaks) | }  // NOLINT(clang-analyzer-unix.Malloc) | ||||||
|  |  | ||||||
| void ESP32BLE::real_gattc_event_handler_(esp_gattc_cb_event_t event, esp_gatt_if_t gattc_if, | void ESP32BLE::real_gattc_event_handler_(esp_gattc_cb_event_t event, esp_gatt_if_t gattc_if, | ||||||
|                                          esp_ble_gattc_cb_param_t *param) { |                                          esp_ble_gattc_cb_param_t *param) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user