-
Notifications
You must be signed in to change notification settings - Fork 7.6k
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
v3.0 couldn't keep the correct serial port with Arduino Nano ESP32 once RST button is pressed #10025
Comments
cc @pillo79 |
@riywo thanks for the detailed report! We will try to investigate and let you know. |
@pillo79 Please let me know if any more data you need from my board for your further investigation. This issue is pretty annoying to me as I can't run my sketch on Arduino Nano ESP32 without USB serial connection (USB battery won't work). I really want to workaround this issue. BTW, the reason why I want to use v3.0 is the new I2S library. It's cool! |
Another finding if it helps: I tried to use 5V VIN today.
So, by this way, I could use this board without USB serial somehow (Power on 5V VIN, plug USB serial then unplug). Hope this helps the investigation... |
Thanks for these updates! I see you are referring to multiple ways of powering the board - does this issue happen also in the simplest case, with a Blink sketch and no electronics attached except for the USB-C cable powering the board? I tried to do so in Linux using IDE I am not very skilled in Windows issues. I have escalated this internally so someone can try and replicate on a Windows machine. We haven't yet completed these tests for 3.0, so for the time being we still advise Nano ESP32 users to hold on 2.0.x (2.0.17 will soon be released!) for stability. But thanks for being on the bleeding edge and providing feedback! |
@pillo79 Thank you for your investigation! Yes, it happens with the simplest case:
I have Raspberry Pi 5, so let me try Linux later! |
and if you then do a normal upload from IDE? |
@JAndrassy Thank you for the suggestion. It can't upload through COM11 because "USB DFU" isn't working properly? (I can't see something like "2-5 USB DFU" with COM11 while there is with COM12):
|
Arduino IDE 2 doesn't support ARM, so I couldn't try Linux on Raspberry Pi. Thus, I tried macOS Apple Silicon instead. In summary, it worked well, so the problem looks like happening only on (my) Windows.
|
and on Windows you can do a normal upload to COM12 after you uploaded Blink with esptool? |
Sure as long as COM12 is active. The problem is that whenever I press RST or reconnect USB-C cable, it goes back to COM11 and I need to enable Bootloader-mode (press RST twice) that activates COM12 then I need to re-upload the same sketch again. |
after the reset/reconnect normal upload to COM11 doesn't work? |
No, never. COM11 can only work with ROM Boot Mode but normal upload won't work. |
I see the same problem on my Win11 computer using the Arduino IDE 2.3.2 and both a Nano ESP32 and a Waveshare clone of the Nano ESP32 (a Waveshare ESP32-S3-Nano) and version 3.0.3 of the Espressif esp32 board manager. If I configure the board to use the Arduino ESP32 Boards version 2.0.13 board manager then I do not see this problem. I used the standard 'Blink' sketch with an added Serial.println statement:
I am using a 'bare' Arduino Nano ESP32 with no additional circuitry. I am using the Arduino IDE 2.3.2 on a Windows 11 computer. Arduino ESP32 Boards by Arduino: Compile and (normal) upload with the board set to 'Arduino Nano ESP32' using the 'Arduino ESP32 Boards' version 2.0.13
All as expected. esp32 boards by Espressif: Compile and upload with the board set to 'Arduino Nano ESP32' using the 'esp 32 boards' version 3.0.3
|
Just saying that I got the same problem. Arduino uses the DFU mode for upload, if you download to the Nano ESP32 a program compiled with the Espresif package, after you unplug and replug the board, there is a "USB JTAG debug unit" instead of the DFU device and the COM port does not work. If you change the USB Mode to Debug Mode (Hardware CDC) the COM port works (but you do not have the DFU device, so normal download cannot be used). |
Just tried under Linux Mint 22, IDE 2.3.3. ESP32 core 3.0.5. board "Arduino Nano ESP32" and reproduced the problem: "No DFU" when trying to upload the Blink sketch (after successfully uploading using the "upload with programmer"). Using the "Arduino ESP32 boards" package it worked fine (but I had to set up a udev rule, as stated on https://forum.arduino.cc/t/upload-on-linux-fails-no-dfu-capable-usb-device-available/1252666/3). I noticed that the VID/PID is different (2341/0070 for Aduino, 303a/1001 for Espressif) and tried a udev rule using the Espressif vid/pid but it made no difference. |
@dquadros thanks for the feedback. Did the "Upload using programmer" use |
The "Upload using programmer" uses There are two packages that support the Arduino Nano ESP32 board:
Hope this helps to identify the issue! |
With 3.0.5 I had this issue so now and then but now with core 3.0.7 I can upload, see COM13 in my case and see serial communication but the RGB LED on the Nano ESP32 board does not blink as it should in my sketch every second. |
Same problem here: Arch Linux With arduino-esp32 V2.0.17 all works fine. |
Closing since a 3rd party hardware board. Please open an issue at the manufacturer repo. |
How can you simply close this issue when it has been reported against several boards and used to work in earlier versions of Espressif's board manager? |
@DonWT The board is not manufactured from espressif. 3rd party boards issues needs to be fixed from the manufacturer of the board. |
@pillo79 Are you going to fix the issue with your board? |
@Jason2866 Closing an issue as "completed" looks weird to me as well honestly, this is clearly not solved for the affected users, and GH issues are a super helpful way to get user feedback. On topic, I am sorry but... still not able to reproduce this. |
@pillo79 Imho This issue should have been not accepted here in general. Arduino code developers don't know this board (and are not responsible for). |
Luca: Sorry for the delay in responding. I am testing using my lightly modified Blink sketch that I posted earlier: #10025 (comment) Test 1 The same code using the Arduino ESP32 Boards version 2.0.18-arduino.5 Using this version of the Arduino version of the ESP32 board I get the problem of the serial port being changed after pressing reset or unplugging and re-plugging the USB port. Test 2 The same code using an old version of the Arduino ESP32 board, this time version 2.0.13 Now everything works as expected, pressing reset or disconnecting the USB port does not change the serial port. Test 3 The same code using the Espressif board manager version 3.1.1 This fails in the same way as Test 1. After a couple of tries I managed to burn a new boot loader and upload the blink sketch using the Programmer. I seem to have everything working now once I did the following:
I can now recompile and normal upload and that now works OK. |
That was a good thought; using 2.0.13 |
@DonWT thanks for this news, that appears to be a fantastic result! 😁 |
Luca
BTW. The bootloader update page is missing the step about using Tools->Burn
Bootloader.
I also raised this issue on the Arduino forum:
https://forum.arduino.cc/t/midi-usb-on-the-nano-esp32/1162846/33?u=dtone1
After I have done a bit more experimenting then I will post the solution
there. (Are you ptillisch <https://forum.arduino.cc/u/ptillisch>?)
A question: Do you know if there was an update to the bootloader firmware
at any time? I bought my Nano ESP32 fairly soon after they first came
out. Or is there some way that the bootloader firmware could have been
changed?
Don.
…On Fri, 14 Mar 2025 at 04:25, Luca Burelli ***@***.***> wrote:
@DonWT <https://github.com/DonWT> thanks for this news, that appears to
be a fantastic result! 😁
I do not know the specifics, but if *"Burn bootloader"* solved the issue,
then something that was written in the Flash was confusing the Arduino boot
stage, and manually erasing the Flash restored the correct behavior. 🥳
Will make sure to add a mention to this in the Nano ESP32 Cheat sheet
<https://docs.arduino.cc/tutorials/nano-esp32/cheat-sheet/> and/or Bootloader
update
<https://support.arduino.cc/hc/en-us/articles/9810414060188-Reset-the-Arduino-bootloader-on-the-Nano-ESP32>
pages on the web site!
—
Reply to this email directly, view it on GitHub
<#10025 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/BAIB5KSVBCGM4AVXJDUBUUL2UKG7TAVCNFSM6AAAAABK27ZNPCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDOMRTHE3TINBRG4>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
[image: pillo79]*pillo79* left a comment (espressif/arduino-esp32#10025)
<#10025 (comment)>
@DonWT <https://github.com/DonWT> thanks for this news, that appears to
be a fantastic result! 😁
I do not know the specifics, but if *"Burn bootloader"* solved the issue,
then something that was written in the Flash was confusing the Arduino boot
stage, and manually erasing the Flash restored the correct behavior. 🥳
Will make sure to add a mention to this in the Nano ESP32 Cheat sheet
<https://docs.arduino.cc/tutorials/nano-esp32/cheat-sheet/> and/or Bootloader
update
<https://support.arduino.cc/hc/en-us/articles/9810414060188-Reset-the-Arduino-bootloader-on-the-Nano-ESP32>
pages on the web site!
—
Reply to this email directly, view it on GitHub
<#10025 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/BAIB5KSVBCGM4AVXJDUBUUL2UKG7TAVCNFSM6AAAAABK27ZNPCVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDOMRTHE3TINBRG4>
.
You are receiving this because you were mentioned.Message ID:
***@***.***>
|
Let me start by explaining that I want to use the Espressif ESP32 package with the Arduino Nano ESP 32 board because it is based on a more recent IDF version and it is updated more frequently. The Arduino Nano ESP32 (and many other third-party boards) is explicitly supported by the Espressif package. I made some new tests with version 3.1.1, starting with using the Burn Bootloader. Long story short, it works as long as Programmer is esptopl (it is the only option but sometimes it is not selected), I short B1 to ground and use Upload Using Programmer. Normal upload will not work (also upload using programmer if the board is not placed in boot mode by B1). I may be wrong (this happens a lot), but I believe using this procedure will bypass the normal Arduino Bootloader. Things got worse when I updated to version 3.1.3, I got compiler errors in the standard Blink example. The same thing happened with other examples. Changing to another board (XIAO ESP32-S3), compilation was ok, so it look likes something specific to the Nano ESP32. |
Board
Arduino Nano ESP32
Device Description
Vanilla Arduino Nano ESP32
Hardware Configuration
No GPIO
Version
v3.0.2
IDE Name
Arduino IDE
Operating System
Windows 11
Flash frequency
?
PSRAM enabled
no
Upload speed
115200
Description
I tried to use v3.0.2 of esp32 board manager with Arduino Nano ESP32 but it couldn't keep the correct serial port. Let me describe the repro steps (I'm using Arduino IDE):
The only way to work with v3.0.2 is entering Bootloader-mode, then COM12 (Arduino Nano ESP32, Arduino Nano ESP32) is showed up. Once I upload the same sketch without Programmer, serial output works. However, when I press RST button, COM12 is gone and COM11 is back. In other words, the workaround is that using Bootloader-mode whenever I reset the board, that is insane.
This behavior only happens with v3.0 of esp32, though. I checked v2.0.17 of esp32, then RST button correctly keeps COM12 and the serial port is working. Same as the Arduino's Arduino ESP32 Boards, RST keeps COM12.
Sketch
Debug Message
Other Steps to Reproduce
Note: When I use Blink sketch, LED properly blinks after RST even though the serial port is wrong (COM11).
Note: When the correct port is showed up (i.e. after uploading with Bootloader-mode), physically reconnecting USB cable still remains the correct port (COM12). However, once I press RST button, it never goes back to COM12 even after reconnecting USB cable again. Bootloader-mode is the only way to recover. => Update: The first half isn't true. It sometimes changes to the wrong port by just reconnecting USB cable.
Note: Also, re-uploading a new sketch when the correct port is showed up doesn't change the serial port. Only pressing RST button triggers this problematic behavior.
I have checked existing issues, online documentation and the Troubleshooting Guide
The text was updated successfully, but these errors were encountered: