Using elf file: 3.2.014.ovms3.elf
0x4008e627 is in invoke_abort (/home/openvehicles/build/esp-idf/components/esp32/panic.c:156).
151 #endif
152 while (1) {
153 if (esp_cpu_in_ocd_debug_mode()) {
154 __asm__ ("break 0,0");
155 }
156 *((int *) 0) = 0;
157 }
158 }
159
160 void abort()
0x4008e8c1 is in abort (/home/openvehicles/build/esp-idf/components/esp32/panic.c:171).
166 * don't overwrite that.
167 */
168 if (esp_reset_reason_get_hint() == ESP_RST_UNKNOWN) {
169 esp_reset_reason_set_hint(ESP_RST_PANIC);
170 }
171 invoke_abort();
172 }
173
174
175 static const char *edesc[] = {
0x400f2be4 is in CheckQueueOverflow(char const*, char*) (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/main/ovms_events.cpp:339).
334 // We've dropped a potentially important event, system is instable now.
335 // As the event queue is full, a normal reboot is no option, so…
336 ESP_LOGE(TAG, "%s: lost important event => aborting", from);
337 MyCommandApp.CloseLogfile();
338 vTaskDelay(pdMS_TO_TICKS(100));
339 abort();
340 }
341 }
342
343 static void SignalScheduledEvent(TimerHandle_t timer)
0x400f3145 is in OvmsEvents::SignalEvent(std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char> >, void*, void (*)(char const*, void*), unsigned int) (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/main/ovms_events.cpp:417).
412
413 if (delay_ms == 0)
414 {
415 if (xQueueSend(m_taskqueue, &msg, 0) != pdTRUE)
416 {
417 CheckQueueOverflow("SignalEvent", msg.body.signal.event);
418 FreeQueueSignalEvent(&msg);
419 }
420 }
421 else
0x4014a7d1 is in OvmsWebServer::DestroyWebSocketHandler(WebSocketHandler*) (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/ovms_webserver/src/ovms_websockethandler.cpp:502).
497
498 // clear unqueued notifications if any:
499 MyNotify.ClearReader(m_client_slots[i].reader);
500
501 ESP_LOGD(TAG, "WebSocket[%p] handler %p closed; %d clients active", nc, handler, m_client_cnt);
502 MyEvents.SignalEvent("server.web.socket.closed", (void*)m_client_cnt);
503
504 break;
505 }
506 }
0x401538b0 is in OvmsWebServer::EventHandler(mg_connection*, int, void*) (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/ovms_webserver/src/ovms_webserver.cpp:534).
529
530 case MG_EV_CLOSE: // connection has been closed
531 {
532 if (handler) {
533 if (nc->flags & MG_F_IS_WEBSOCKET)
534 MyWebServer.DestroyWebSocketHandler((WebSocketHandler*)handler);
535 else
536 delete handler;
537 }
538 }
0x401082be is in mg_call (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:2368).
2363 }
2364 #endif
2365 if (ev_handler != NULL) {
2366 unsigned long flags_before = nc->flags;
2367 size_t recv_mbuf_before = nc->recv_mbuf.len, recved;
2368 ev_handler(nc, ev, ev_data MG_UD_ARG(user_data));
2369 recved = (recv_mbuf_before - nc->recv_mbuf.len);
2370 /* Prevent user handler from fiddling with system flags. */
2371 if (ev_handler == nc->handler && nc->flags != flags_before) {
2372 nc->flags = (flags_before & ~_MG_CALLBACK_MODIFIABLE_FLAGS_MASK) |
0x401092ed is in mg_ws_handler (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:9950).
9945 }
9946 }
9947
9948 MG_INTERNAL void mg_ws_handler(struct mg_connection *nc, int ev,
9949 void *ev_data MG_UD_ARG(void *user_data)) {
9950 mg_call(nc, nc->handler, nc->user_data, ev, ev_data);
9951
9952 switch (ev) {
9953 case MG_EV_RECV:
9954 do {
0x401082be is in mg_call (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:2368).
2363 }
2364 #endif
2365 if (ev_handler != NULL) {
2366 unsigned long flags_before = nc->flags;
2367 size_t recv_mbuf_before = nc->recv_mbuf.len, recved;
2368 ev_handler(nc, ev, ev_data MG_UD_ARG(user_data));
2369 recved = (recv_mbuf_before - nc->recv_mbuf.len);
2370 /* Prevent user handler from fiddling with system flags. */
2371 if (ev_handler == nc->handler && nc->flags != flags_before) {
2372 nc->flags = (flags_before & ~_MG_CALLBACK_MODIFIABLE_FLAGS_MASK) |
0x40108430 is in mg_close_conn (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:2435).
2430 mg_ssl_if_conn_close_notify(conn);
2431 }
2432 #endif
2433 mg_remove_conn(conn);
2434 conn->iface->vtable->destroy_conn(conn);
2435 mg_call(conn, NULL, conn->user_data, MG_EV_CLOSE, NULL);
2436 mg_destroy_conn(conn, 0 /* destroy_if */);
2437 }
2438
2439 void mg_mgr_init(struct mg_mgr *m, void *user_data) {
0x4010a3bb is in mg_socket_if_poll (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:4049).
4044
4045 for (nc = mgr->active_connections; nc != NULL; nc = tmp) {
4046 tmp = nc->next;
4047 if ((nc->flags & MG_F_CLOSE_IMMEDIATELY) ||
4048 (nc->send_mbuf.len == 0 && (nc->flags & MG_F_SEND_AND_CLOSE))) {
4049 mg_close_conn(nc);
4050 }
4051 }
4052
4053 return (time_t) now;
0x4010647a is in mg_mgr_poll (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/components/mongoose/mongoose/mongoose.c:2538).
2533 LOG(LL_ERROR, ("cannot poll: no interfaces"));
2534 return 0;
2535 }
2536
2537 for (i = 0; i < m->num_ifaces; i++) {
2538 now = m->ifaces[i]->vtable->poll(m->ifaces[i], timeout_ms);
2539 }
2540 return now;
2541 }
2542
0x400fb63f is in OvmsNetManager::MongooseTask() (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/main/ovms_netmanager.cpp:733).
728
729 // Main event loop
730 while (m_mongoose_running)
731 {
732 // poll interfaces:
733 if (mg_mgr_poll(&m_mongoose_mgr, 250) == 0)
734 {
735 ESP_LOGD(TAG, "MongooseTask: no interfaces available => exit");
736 break;
737 }
0x400fb6ed is in MongooseRawTask(void*) (/home/openvehicles/build/Open-Vehicle-Monitoring-System-3.1/vehicle/OVMS.V3/main/ovms_netmanager.cpp:715).
710 #ifdef CONFIG_OVMS_SC_GPL_MONGOOSE
711
712 static void MongooseRawTask(void *pvParameters)
713 {
714 OvmsNetManager* me = (OvmsNetManager*)pvParameters;
715 me->MongooseTask();
716 }
717
718 void OvmsNetManager::MongooseTask()
719 {