Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

desyner
Posts: 3
Joined: Sun Sep 27, 2020 8:16 pm

Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby desyner » Mon Sep 28, 2020 2:37 am

I've built a custom PCB designed to use the ESP32 WROOM. During the assembly and validation of the board I've been using example arduino programs to make sure the esp32 is running correctly.

Currently, I'm having a problem with running wifi examples on my board. When I flash the WiFiScan example, I get the following console output. Sometimes it will reboot and display the same messages a few times before it permanently hangs. Occasionally it will cause a kernel panic and crash my mac.

Code: Select all

rst:0x1 (POWERON_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:2
load:0x3fff0018,len:4
load:0x3fff001c,len:1216
ho 0 tail 12 room 4
load:0x40078000,len:10864
load:0x40080400,len:6404
entry 0x400806b8
[W][esp32-hal-psram.c:30] psramInit(): PSRAM init failed!
[D][WiFiGeneric.cpp:332] _eventCallback(): Event: 0 - WIFI_READY
[D][WiFiGeneric.cpp:332] _eventCallback(): Event: 2 - STA_START
Here is my schematic. U1 is the ESP32-WROOM, U4 is a CH340C, and IC1 is a HT7833 LDO.
esp32_WROOM_BASIC_SCHEMATIC.jpg
esp32_WROOM_BASIC_SCHEMATIC.jpg (128.56 KiB) Viewed 5791 times

I am able to successfully run basic serial programs such as echoing serial console input, etc...

In searching the web before posting here, it was suggested to measure the logic levels of the bootstrapping pins...
GPIO 0: High
GPIO 2: Low
GPIO 4: High
GPIO 5: High
GPIO 12: Low
GPIO 15: High

At this point I’m really stumped. I would appreciate some help. Thank you.

ESP_Sprite
Posts: 9025
Joined: Thu Nov 26, 2015 4:08 am

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby ESP_Sprite » Mon Sep 28, 2020 8:03 am

What is IC1? Are you sure your setup can deliver at least 500mA on the 3.3V line?

desyner
Posts: 3
Joined: Sun Sep 27, 2020 8:16 pm

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby desyner » Mon Sep 28, 2020 5:33 pm

IC1 is an HT7833 low drop-out regulator. The datasheet guarantees an output of 500mA: https://www.holtek.com.tw/documents/101 ... 99f2d0f6d7

wevets
Posts: 112
Joined: Sat Mar 09, 2019 2:56 am

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby wevets » Mon Sep 28, 2020 9:22 pm

It looks like desyner listed the answer to your question right above the schematic. It's an HT7833 LDO. It's spec'ed to handle 500mA.

ESP_Sprite
Posts: 9025
Joined: Thu Nov 26, 2015 4:08 am

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby ESP_Sprite » Tue Sep 29, 2020 1:32 pm

And are you sure the LDO can get 500mA to the device at all times? For instance, if you feed the device using USB, are you sure the USB cable is nice and thick? Can you try feeding the 5V via a lab power supply instead and see if it still crashes?

becorey
Posts: 92
Joined: Sat Mar 28, 2020 4:18 pm

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby becorey » Mon Nov 09, 2020 6:46 am

You might need .1uF and 1uF closer to the ESP32 VDD supply. Can you share your PCB layout?
Wifi pulls a lot of current, it can cause brownout and the ESP32 will crash or reboot.
Try more output capacitance on your LDO, put a 22uF or 47uF.
You could also try a higher rated 3.3V supply for 600mA~1A

desyner
Posts: 3
Joined: Sun Sep 27, 2020 8:16 pm

Re: Custom PCB + Wroom 32 crashes using Arduino-ESP32 Wifi Library

Postby desyner » Sun Nov 22, 2020 5:29 am

Thanks for all the suggestions. I found adding a 100uF electrolytic capacitor allows the system to work. I have some 600mA LDO's on order, which I am hopeful will allow me to remove the cap.

Who is online

Users browsing this forum: Google [Bot] and 81 guests