Closed PaulZC closed 4 months ago
Have ran into the same issue, seems like the setting has changed from https://github.com/espressif/arduino-esp32/blob/a6df1f5e7cca9a81095937d58599a29d791ef878/tools/sdk/esp32/sdkconfig#L777 to https://github.com/espressif/esp32-arduino-libs/blob/a6dac936bfcfa4c11468e003f550b41c76efeae6/esp32/sdkconfig#L1086
We could not keep the crystal to AUTO, because other things stopped working. I can not recall what was exactly breaking, but it was critical.
That might explain it! ;-) Many thanks Ivan. Best wishes.
Many thanks @me-no-dev,
I don't want this to soak up much of your time - especially as the ESP32-D0WDQ6-V3 is NRND, and I think this is the only SparkFun board with a 26MHz crystal, and the work-around works...
Maybe it could be possible to specify / override the XTAL frequency through boards.txt?
Best wishes, Paul
Maybe it could be possible to specify / override the XTAL frequency through boards.txt?
Unfortunately this would require rework that is just not worth for a single type of board (I also do not know of another board with 26MHz crystal) which was manufactured in the very early ESP32 days. I have a few myself and would rather replace their crystals. Would have been great if we could keep the crystal to AUTO also. I tried to find out what was happening, but the change came in a PR with many, many changes and message was not so clear.
I also do not know of another board with 26MHz crystal
In my case it was with Heltec Lora boards, they used to come with 26 MHz XTALs. Unfortunately replacing an XTAL is not an option for me, but I went back to v2.0.x for the time being.
I went back to v2.0.x for the time being.
You could try the workaround above
Created PR with support for SparkFun ESP32 Thing: https://github.com/espressif/arduino-esp32/pull/9844
@igrr similar thing can be done for your board too (or even through menu that adds -DF_XTAL_MHZ=26
)
Excellent - thank you @me-no-dev
I am the developer who originally reported the "ESP32 Thing" board CPU frequency issue to Sparkfun. I've retested with the 3.0.2 version of the ESP32 library and everything is behaving correctly. Thanks for your efforts.
Is this supposed to be working now? I'm using the latest nightly and esp32 3.0.5 and running into this issue.
Initial findings:
So there was a patch, but a) it didn't patch esp32thing_plus, just esp32thing, ie esp32thing_plus is missing
#define F_XTAL_MHZ 26 //SparkFun ESP32 Thing has 26MHz Crystal
in variants/esp32thing_plus/pins_arduino.h
Secondly it still doesn't work, even though I've closed and opened and cleared /tmp/arduino etc many times for some reason and compiled and upload many times.
According to the datasheet (ESP32-WROOM-32D), this device should have 40MHz crystal, yet it definitely outputs at 74880 when Serial.begin(115200) is set.
Even stranger: after upload the device outputs at 74880, but then on plug out and back in or pressing reset button results in the device outputting on 115200 :D
Even even stranger, the device also initially outputs on the correct frequency but then switches to the wrong one after
The only code on the device is Arduino RMT.
I've attempted to change the erase all flash option both on and off for multiple times in a row.
Update on the changing of output: it doesn't change the output on plug out/in, but it does on pressing the reset button.
Could there be an issue with esp32 init code? On fresh boot wrong crystal speed is set, but on reset where there is continuous power we get the correct speed?
For some, very interesting, reason, the issue might have something to do with UART initialisation.
I have managed to narrow the issue down to:
#define PIN 16
void setup()
{
rmt_data_t rawData[]={{.duration0=1, .level0=0, .duration1=1, .level1=1}};
pinMode(PIN, OUTPUT);
rmtInit(PIN, RMT_TX_MODE, RMT_MEM_NUM_BLOCKS_1, 1000000);
rmtWriteLooping(PIN, rawData, RMT_SYMBOLS_OF(rawData));
}
void loop(){}
When connected to USB, the issue exists. When connected to just a power socket, everything is fine.
Issue opened at https://github.com/espressif/arduino-esp32/issues/10388
Board
SparkFun ESP32 Thing
Device Description
The SparkFun ESP32 Thing is a 3rd Party Board based on the ESP32-D0WDQ6-V3 chip with a 26MHz XTAL
https://www.sparkfun.com/products/13907
Hardware Configuration
Only USB
Version
v3.0.0
IDE Name
Arduino IDE
Operating System
Windows
Flash frequency
80MHz
PSRAM enabled
no
Upload speed
921600
Description
A full write-up, diagnosis and fix available at: https://github.com/sparkfun/ESP32_Thing_Plus/issues/7
In cores below 3.0.0, the XTAL frequency was detected correctly. millis and UART baud rates were correct.
From 3.0.0, the XTAL frequency is detected as or defaults to 40MHz. millis and UART baud rates are off by a factor of 1.54.
Using the Serial_All_CPU_Freqs example:
We have a work-around:
But it would be really nice if the core could be corrected / updated... Thanks!
Sketch
Debug Message
Other Steps to Reproduce
N/A
I have checked existing issues, online documentation and the Troubleshooting Guide