-
-
Notifications
You must be signed in to change notification settings - Fork 3.5k
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
PDM Microphone samples are not recognized at the input, Amplitude sits at 0 #4583
Comments
When checking the log, the setup indeed looks as expected. I am at a loss as to why in proper PDM mode the data pin is seemingly not read. Can anyone give guidance how to further debug?
|
Perhaps a bug in Audioreactive usermod. |
I've had success with PDM mics in WLED-MM with no major issues. Sometimes I've had to set @markusdd could you cross-test with WLED-MM mdev and see if that helps? WLED-MM has forked pretty far from mainstream WLED, but the AudioReactive fixes should be easy to backport if needed. |
after the hint of @blazoncek I tried the MM fork yesterday. The behavior is identical as far as I could make out. [env:esp32S3_8MB_PSRAM_M]
extends = esp32_4MB_V4_M_base
board = esp32-s3-devkitc-1 ;; generic S3 dev board; the next line adds PSRAM support
board_build.arduino.memory_type = qio_opi ;; use with PSRAM: 8MB or 16MB
;; board_build.arduino.memory_type = qio_qspi ;; use with PSRAM: 2MB or 4MB
board_build.flash_mode = qio ;; use "dio" if your board gets unstable with "qio"; also change then previous lines accordingly (memory_type)
build_unflags = ${env:esp32S3_8MB_M.build_unflags} ;; use the same as "normal" S3 buildenv
build_flags = ${common.build_flags} ${esp32s3.build_flags} -Wno-misleading-indentation -Wno-format-truncation
${common_mm.build_flags_S} ${common_mm.build_flags_M}
# ${common_mm.HUB75_build_flags}
-DBOARD_HAS_PSRAM ;; -D WLED_USE_PSRAM ;; your board supports PSRAM
-D WLED_USE_PSRAM_JSON -DALL_JSON_TO_PSRAM ; WLEDMM --> force all JSON stuff into PSRAM; gives more free heap
-D WLED_RELEASE_NAME=esp32S3_8MB_PSRAM_M
-DARDUINO_USB_MODE=1 -DARDUINO_USB_CDC_ON_BOOT=0 -DARDUINO_USB_MSC_ON_BOOT=0 -DARDUINO_USB_DFU_ON_BOOT=0 ;; for Serial-to-USB chip
;;-DARDUINO_USB_MODE=1 -DARDUINO_USB_CDC_ON_BOOT=1 -DARDUINO_USB_MSC_ON_BOOT=0 -DARDUINO_USB_DFU_ON_BOOT=1 ;; for Hardware-CDC USB mode
;;-D WLED_DISABLE_ADALIGHT ;; disables serial protocols - recommended for Hardware-CDC USB (Serial RX will receive junk commands when RX pin is unconnected, unless its pulled down by resistor)
-D WLED_WATCHDOG_TIMEOUT=0 -D CONFIG_ASYNC_TCP_USE_WDT=0
;;-D WLEDMM_FASTPATH ; WLEDMM experimental option. Reduces audio lag (latency), and allows for faster LED framerates. May break compatibility with previous versions.
-D WLED_DISABLE_LOXONE ; FLASH 1272 bytes
-D WLED_DISABLE_ALEXA ; RAM 116 bytes; FLASH 13524 bytes
; -D WLED_DISABLE_MQTT ; RAM 216 bytes; FLASH 16496 bytes
; -D WLED_DISABLE_HUESYNC ;RAM 122 bytes; FLASH 6308 bytes
; -D WLED_DISABLE_INFRARED ;RAM 136 bytes; FLASH 24492 bytes
-D LEDPIN=38
;;-D DATA_PINS=21,48,3 -D PIXEL_COUNTS=30,1,144 ;; just an example: my board has a builtin neopixel on gpio48
; -D STATUSLED=2
-D BTNPIN=-1 -D RLYPIN=-1 -D IRPIN=-1
-D HW_PIN_SDA=-1 -D HW_PIN_SCL=-1
-D AUDIOPIN=-1
-D SR_DMTYPE=5 -D I2S_SDPIN=5 -D I2S_CKPIN=-1 -D I2S_WSPIN=4 -D MCLK_PIN=-1
;;-D ES7243_SDAPIN=8 -D ES7243_SCLPIN=18
-D WLED_DEBUG
-D SR_DEBUG
; -D MIC_LOGGER
lib_deps = ${esp32s3.lib_deps} ${common_mm.lib_deps_S} ${common_mm.lib_deps_V4_M}
;${common_mm.HUB75_lib_deps}
;lib_ignore = IRremoteESP8266 ; use with WLED_DISABLE_INFRARED for faster compilation
board_build.partitions = tools/WLED_ESP32_8MB.csv
; RAM: [== ] 21.1% (used 69156 bytes from 327680 bytes)
; Flash: [======== ] 75.9% (used 1591817 bytes from 2097152 bytes) According to the logs the config is fine and PDM master driver is starting up.
EDIT: pasted correct config I actually ended up using. |
Any thoughts from the experts on what to try next? I think we have found modes where there certainly is an input being recognized but in any case whatever is there is way too low, even when holding the input high. So I assume it must be some magic setting in the software. |
See recent discussion on PDM - https://discord.com/channels/700041398778331156/1076072513102168084/1339765830371639408 |
It says I do not have access to this. |
What happened?
I have (new) boards sitting here with a TDK T3902 PDM MEMS Microphone and I am trying to get this to work.
ESP is an ESP32S3-N16R8.
I have tried WLED 0.15 as well my own build from latest/greatest master branch.
Issue I am observing: In PDM mode I am using GPIO4 as Clock out and GPIO5 as data in.
With an oscilloscope I can see the clock leaving the ESP and the data returning (yellow clock, blue data):
This gives me pretty high confidence that the hardware is fine.
Also, to exclude channel left/right woes, I reworked one board to have a left channel output and the other right channel output. The datasheet of the mic is here: https://www.lcsc.com/datasheet/lcsc_datasheet_2411220511_TDK-InvenSense-MMICT390200012_C3171752.pdf
To me, this looks like a very 'run of the mill' PDM mic with hardly any specialties, the protocol is super simple. Rising edge right channel, falling edge left channel, that's it.
My pin config is as follows:
I also tried using WS as clk, same picture. I get proper output/input on the scope, but my console does this: (I have compiled with
-D MIC_LOGGER -D SR_DEBUG
):Absolutely dead. I also tried forcing the data pin high from 3.3V, as this should result in a pegged high maximum volume. Also nothing.
When I configure it as a normal I2S Microphone, I do see this:
Level and Real sit around 30k constantly and volume is fluctuating. But there is zero 'real' reaction to music or clapping, which is logical, because this isn't a PCM signal but a PDM signal on the input, so essentially these numbers are random garbage, they will never be interpreted correctly in non-PDM mode.
I've tried everything I could think of, but I do not understand why there is zero reading of PDM data although it is there.
I tried skimming the C-Code of the audioreactive mod and there are numerous comments in the code regading PDM that I cannot make sense of, like this:
I do not assume we have an actual clock issue because it comes out.
I rather suspect these 2 (I have not touched any of the code, everything like it is on master except the debug defines):
So for some reason the data is not being sampled. I am at a loss for why.
Any guidance?
To Reproduce Bug
See above, but I guess you'd need such a mic or at least a PDM mic combined with an ESP32S3
Expected Behavior
PDM data is being sampled and audioreactive works.
Install Method
Self-Compiled
What version of WLED?
0.15 and 0.16alpha@master
Which microcontroller/board are you seeing the problem on?
ESP32-S3
Relevant log/trace output
Anything else?
No response
Code of Conduct
The text was updated successfully, but these errors were encountered: