Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

3.1.0 with ESP32 C6 - SimpleTime.ino produces mutex not ready errors #10754

Closed
1 task done
Daedelos opened this issue Dec 18, 2024 · 24 comments
Closed
1 task done

3.1.0 with ESP32 C6 - SimpleTime.ino produces mutex not ready errors #10754

Daedelos opened this issue Dec 18, 2024 · 24 comments
Assignees
Labels
Priority: High 🗻 Issues with high priority which needs to be solved first. Status: In Progress Issue is in progress Status: Needs investigation We need to do some research before taking next steps on this issue
Milestone

Comments

@Daedelos
Copy link

Board

M5Stack M5NanoC6

Device Description

None

Hardware Configuration

Nothing

Version

latest master (checkout manually)

IDE Name

Arduino IDE 2.3.4

Operating System

Windows 11

Flash frequency

80MHz

PSRAM enabled

no

Upload speed

115200

Description

3.1.0 with ESP32 C6 - SimpleTime produces mutex not ready errors

Running SimpleTime.ino example under 3.1.0 with a M5NanoC6 (ESP32 C6) produces repeated:

E (50100) OPENTHREAD: esp_openthread_task_switching_lock_acquire(38): Failed to acquire the lock because the mutex is not ready
E (50100) OPENTHREAD: esp_openthread_task_switching_lock_release(46): Failed to release the lock because the mutex is not ready
E (50111) OT_DNS64: Cannot find NAT64 prefix
No time available (yet)

Sketch

Example SimpleTime.ino code

Debug Message

E (50100) OPENTHREAD: esp_openthread_task_switching_lock_acquire(38): Failed to acquire the lock because the mutex is not ready
E (50100) OPENTHREAD: esp_openthread_task_switching_lock_release(46): Failed to release the lock because the mutex is not ready
E (50111) OT_DNS64: Cannot find NAT64 prefix

Other Steps to Reproduce

SimpleTime.ino on M5NanoC6 with 3.0.7 works correctly.
ESP32 & ESP32 S2 work correctly on 3.1.0.

I have checked existing issues, online documentation and the Troubleshooting Guide

  • I confirm I have checked existing issues, online documentation and Troubleshooting guide.
@Daedelos Daedelos added the Status: Awaiting triage Issue is waiting for triage label Dec 18, 2024
@SuGlider
Copy link
Collaborator

@me-no-dev - I confirm the issue.
The error message points to some issue with SDK Config settings related to IPv6 and OpenThread.

@desiFish
Copy link

desiFish commented Dec 20, 2024

I am getting the same error. Is there any fix to it? I am unable to make HTTP GET calls. Even the Async Server is broken now. Everything seems broken with XIAO ESP32C6 moving from XIAO ESP32C3.
This is my code on ESP32C6:

static WiFiClient client;
  HTTPClient http;

  // Your Domain name with URL path or IP address with path
  http.begin(client, serverName);

  // Send HTTP POST request
  httpResponseCode = http.GET();

  String payload = "{}";

  if (httpResponseCode > 0) {
    Serial.print("HTTP Response code: ");
    Serial.println(httpResponseCode);
    payload = http.getString();
  } else {
    Serial.print("Error code: ");
    Serial.println(httpResponseCode);
  }
  // Free resources
  http.end();

  return payload;

Gives error:

E (3862) OPENTHREAD: esp_openthread_task_switching_lock_acquire(38): Failed to acquire the lock because the mutex is not ready
E (3863) OPENTHREAD: esp_openthread_task_switching_lock_release(46): Failed to release the lock because the mutex is not ready
E (3874) OT_DNS64: Cannot find NAT64 prefix
Error code: -1

@SuGlider SuGlider added Status: Needs investigation We need to do some research before taking next steps on this issue and removed Status: Awaiting triage Issue is waiting for triage labels Dec 20, 2024
@SuGlider SuGlider self-assigned this Dec 20, 2024
@desiFish
Copy link

Another Example. While running this program, the same error on XIAO ESP32C6.
Program:

#include <NTPClient.h>
// change next line to use with another board/shield
//#include <ESP8266WiFi.h>
#include <WiFi.h> // for WiFi shield
//#include <WiFi101.h> // for WiFi 101 shield or MKR1000
#include <WiFiUdp.h>

const char *ssid     = "SSID";
const char *password = "PASS";

WiFiUDP ntpUDP;
NTPClient timeClient(ntpUDP);

void setup(){
  Serial.begin(115200);

  WiFi.begin(ssid, password);

  while ( WiFi.status() != WL_CONNECTED ) {
    delay ( 500 );
    Serial.print ( "." );
  }

  timeClient.begin();
}

void loop() {
  timeClient.update();

  Serial.println(timeClient.getFormattedTime());

  delay(1000);
}

Error:

E (36035) OPENTHREAD: esp_openthread_task_switching_lock_acquire(38): Failed to acquire the lock because the mutex is not ready
E (36035) OPENTHREAD: esp_openthread_task_switching_lock_release(46): Failed to release the lock because the mutex is not ready
E (36046) OT_DNS64: Cannot find NAT64 prefix

@desiFish
Copy link

desiFish commented Dec 20, 2024

I can confirm that any kind of network activity, mostly requests are leading to this issue.

@SuGlider
Copy link
Collaborator

The issue has been found, but the fix will require a new Arduino release because it is embedded into OpenThread static precompiled library.

We are working to solve it. I'll post the progress in this issue thread.
Fell free to ask about it.

@SuGlider
Copy link
Collaborator

Lib Builder PR espressif/esp32-arduino-lib-builder#257 fixes this issue.
A new ESP32 Arduino Release will address and solve the problem.
Thanks for the report!

@desiFish
Copy link

@SuGlider Wow, you people are like heroes without the cape of the open-source world. Thank You very much.

@desiFish
Copy link

Lib Builder PR espressif/esp32-arduino-lib-builder#257 fixes this issue. A new ESP32 Arduino Release will address and solve the problem. Thanks for the report!

@SuGlider I am new to these things, I explored few things, so a new ESP32 Arduino Release will happen when these milestones are completed right? These: Milestones

@motamman
Copy link

I have reproduced this error on all the C6 boards I have laying around. Basically, anytime I use a domain name for anything, it blows up. If I shift to IP addresses, the problem disappears. It makes it a little cumbersome switching back and forth between chips.

@SuGlider
Copy link
Collaborator

The issue is directly related to DNS resolution.

ESP32 Arduino will solve it by releasing a new package version that fixes it by removing the OpenThread protocol DNS64 client feature.

This shall be done soon in the beginning of 2025.

At the same time OpenThread IDF Team is investigating the issue in order to fix DNS64 client. When this is solved, we shall reactivate it in the ESP32 Arduino Configuration.

That shall be done by releasing again a new version package.

@SuGlider
Copy link
Collaborator

FYI: An IDF fix has been tested and I confirmed that it solves this issue.

Therefore, it will be merged soon to IDF and we will be able to enable back OpenThread DNS64 Client support with no problems related to WiFi DNS Client resolution as here reported.

@SuGlider
Copy link
Collaborator

Lib Builder PR espressif/esp32-arduino-lib-builder#257 fixes this issue. A new ESP32 Arduino Release will address and solve the problem. Thanks for the report!

@SuGlider I am new to these things, I explored few things, so a new ESP32 Arduino Release will happen when these milestones are completed right? These: Milestones

I think that a fix release will be released first.
I'll confirm that on the Jan 6th when the team will back from vacation.

@bjax
Copy link

bjax commented Jan 5, 2025

Is there a workaround for this bug? I tried using an IP address vs. hostname as a string (e.g. "162.159.200.123" instead of "pool.ntp.org") as the third argument to configTime but got the same error.

@SuGlider
Copy link
Collaborator

SuGlider commented Jan 5, 2025

Is there a workaround for this bug? I tried using an IP address vs. hostname as a string (e.g. "162.159.200.123" instead of "pool.ntp.org") as the third argument to configTime but got the same error.

The solution is ready. We will release as soon as possible a new ESP32 Arduino version that solves it.

@pohlt
Copy link

pohlt commented Jan 6, 2025 via email

@dirkvranckaert
Copy link

Facing the same issue here. Seems like 3.1.0 fixes some other issue I'm facing but introducing this mutex stuff...

Hoping for a quick new release... 🤞 Any updat on that matter @SuGlider?

@SuGlider
Copy link
Collaborator

SuGlider commented Jan 7, 2025

Facing the same issue here. Seems like 3.1.0 fixes some other issue I'm facing but introducing this mutex stuff...

Hoping for a quick new release... 🤞 Any updat on that matter @SuGlider?

We will release a new version, Arduino Core 3.1.1, up to the of this week with a fix to this issue.

@desiFish
Copy link

desiFish commented Jan 8, 2025

Another Example. While running this program, the same error on XIAO ESP32C6. Program:

#include <NTPClient.h>
// change next line to use with another board/shield
//#include <ESP8266WiFi.h>
#include <WiFi.h> // for WiFi shield
//#include <WiFi101.h> // for WiFi 101 shield or MKR1000
#include <WiFiUdp.h>

const char *ssid     = "SSID";
const char *password = "PASS";

WiFiUDP ntpUDP;
NTPClient timeClient(ntpUDP);

void setup(){
  Serial.begin(115200);

  WiFi.begin(ssid, password);

  while ( WiFi.status() != WL_CONNECTED ) {
    delay ( 500 );
    Serial.print ( "." );
  }

  timeClient.begin();
}

void loop() {
  timeClient.update();

  Serial.println(timeClient.getFormattedTime());

  delay(1000);
}

Error:

E (36035) OPENTHREAD: esp_openthread_task_switching_lock_acquire(38): Failed to acquire the lock because the mutex is not ready
E (36035) OPENTHREAD: esp_openthread_task_switching_lock_release(46): Failed to release the lock because the mutex is not ready
E (36046) OT_DNS64: Cannot find NAT64 prefix

I can confirm that this code now works normally in ESP32 C6 in 3.1.1, I will confirm other codes as well soon.

@bjax
Copy link

bjax commented Jan 8, 2025

Yep, 3.1.1 fixed my problem as well. Thanks, folks!

@REMcD
Copy link

REMcD commented Jan 9, 2025

Uploading to thingspeak again - phew! Thanks to all involved

@desiFish
Copy link

desiFish commented Jan 10, 2025 via email

@SuGlider
Copy link
Collaborator

IDF Team has fixed the issue with OpenThread DNS Hook.
Therefore we shall enable OpenThread DNS64 again for the next releases (3.1.2, 3.2.0 and so on).

I'll test the new IDF library for Arduino before we release next versions.
In case the issue here presented doesn't happen again, we will move forward with the reactivation of OpenThread DNS64.

@SuGlider
Copy link
Collaborator

IDF Team has fixed the issue with OpenThread DNS Hook. Therefore we shall enable OpenThread DNS64 again for the next releases (3.1.2, 3.2.0 and so on).

I'll test the new IDF library for Arduino before we release next versions. In case the issue here presented doesn't happen again, we will move forward with the reactivation of OpenThread DNS64.

FYI: A decision was made that ESP32 Arduino won't enable Open Thread DNS64 Client feature due to issues with Zigbee and WiFi coexistant applications. It seems that enabling DNS64 Client in the sdkconfig leads to linking twice some functions that prevent building Zigbee + WiFi Arduino sketches.

Therefore, no changes will be done, based on the present scenario. No DNS issues shall happen as well.

@desiFish
Copy link

IDF Team has fixed the issue with OpenThread DNS Hook. Therefore we shall enable OpenThread DNS64 again for the next releases (3.1.2, 3.2.0 and so on).
I'll test the new IDF library for Arduino before we release next versions. In case the issue here presented doesn't happen again, we will move forward with the reactivation of OpenThread DNS64.

FYI: A decision was made that ESP32 Arduino won't enable Open Thread DNS64 Client feature due to issues with Zigbee and WiFi coexistant applications. It seems that enabling DNS64 Client in the sdkconfig leads to linking twice some functions that prevent building Zigbee + WiFi Arduino sketches.

Therefore, no changes will be done, based on the present scenario. No DNS issues shall happen as well.

I am not using Thread for any project right now, but what will I do to use it in the future? Just curious. Because while purchasing these microcontrollers they list these in features.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Priority: High 🗻 Issues with high priority which needs to be solved first. Status: In Progress Issue is in progress Status: Needs investigation We need to do some research before taking next steps on this issue
Projects
Development

No branches or pull requests

8 participants