Skip to content

Feature/advanced biamp#187

Open
craigmillard86 wants to merge 60 commits intoCarlosDerSeher:developfrom
anabolyc:feature/advanced-biamp
Open

Feature/advanced biamp#187
craigmillard86 wants to merge 60 commits intoCarlosDerSeher:developfrom
anabolyc:feature/advanced-biamp

Conversation

@craigmillard86
Copy link
Copy Markdown
Contributor

PR: Advanced TAS58505 Bi-Amp Crossover with PEQ, Loudness Compensation, and UI Improvements

Summary

This PR introduces a comprehensive advanced bi-amp crossover system with parametric EQ, loudness compensation, and significant improvements to the web UI and HTTP server reliability.

  • Add bi-amp crossover with configurable high-pass/low-pass filters and 6-band parametric EQ per channel
  • Implement loudness compensation curves with zone-based volume adjustments
  • Add bi-amp preset export/import functionality for shareable speaker configurations
  • Expand PEQ to 6 bands with improved UI controls
  • Add dedicated DAC Settings and EQ tabs with full TAS5805M configuration support
  • Fix mobile browser reliability issues with HTTP server socket handling
  • Add retry logic and error recovery for DAC/EQ pages on resource-constrained connections

Key Features

  • Advanced Bi-Amp Crossover: Configurable crossover frequencies with independent high-pass and low-pass filters
  • 6-Band Parametric EQ: Per-channel parametric equalization with frequency, gain, and Q controls
  • Loudness Compensation: ISO 226:2003 equal-loudness contour curves with configurable zones
  • Preset System: Export/import bi-amp configurations as shareable presets
  • DAC Settings UI: Full control over TAS5805M bridge mode, modulation, switching frequency, and analog gain
  • 15-Band Graphic EQ: Alternative to parametric mode with ISO center frequencies

Bug Fixes

  • Fix player reconnection crash in bi-amp mode
  • Fix EQ UI gains showing 0 on page load before music starts
  • Guard tas5805m_loudness_apply with CONFIG_DAC_TAS5805M_EQ_SUPPORT to prevent build errors
  • Fix channel gains not being restored on device reboot
  • Fix WiFi power save interfering with low latency audio
  • Fix mobile UI loading errors for DAC/EQ pages with retry logic
  • Add Connection: close headers to large HTTP responses (EQ schema 64KB, DAC schema 36KB)
  • Increase delay between schema/settings requests to allow ESP32 memory recovery
  • Add HTTP server timeouts and connection backlog for improved socket handling

Andriy Malyshenko added 30 commits January 6, 2026 18:43
…mponent to apply stored settings at startup and expose settings structure to http component, Updated html for the UI
…l_settings component architecture. Fully data-driven front-end
…equency, analog gain. Added support for readonly parameters
- Fix division by zero crash in player.c when reconnecting (chkInFrames=0)
- Add 300ms debouncing to EQ settings sliders to prevent flooding device
- Change frequency sliders to 1 Hz increments (crossover, PEQ)
- Change gain sliders to 0.5 dB increments using x2 fixed-point storage
- Remove debug biquad logging from tas5805m.c and tas5805m_biamp.c
- Update preset export/import to handle new gain format
- Increase HTTP server stack size for bi-amp schema generation
- Increase PEQ bands from 3 to 6 per channel (12 total)
- Update biquad allocation: bands 6-11 for PEQ, band 12 spare
- Reorganize loudness UI to group parameters by zone
- Each zone shows volume range, threshold, bass, and treble together
- Add renderLoudnessZone() function and CSS for grouped layout
Bug fixes:
- Fix loudness not applying (static cache never initialized from NVS)
- Fix loudness always on when disabled (now resets bands to passthrough)
- Fix phase/crossover not working (missing ADVANCED_BIAMP case in EQ mode switch)
- Fix I2C mutex race condition with spinlock for initialization
- Fix baffle placement showing as slider instead of dropdown

Security hardening:
- Fix buffer overflow in find_key_value() with size parameter
- Add URL decode hex digit validation
- Restrict CORS to localhost and private IP ranges
- Add gain overflow validation and Q5.27 range clamping
- Add crossover frequency bounds validation (20-20000 Hz)

Documentation:
- Add comprehensive doxygen-style documentation to tas5805m_biamp.h
- Add comprehensive doxygen-style documentation to tas5805m_biamp.c
- Add ADVANCED_BIAMP_USER_GUIDE.md with full feature documentation
Mobile UI improvements:
- Add responsive navigation that stacks vertically on mobile
- Add responsive styles for EQ settings (PEQ, radio buttons, presets)
- Enhance shared styles.css with mobile breakpoints
- Improve touch targets and prevent iOS zoom on input focus

Bug fix:
- Add defer attribute to all script tags to prevent "settingsUI is not defined" race condition on fast page loads
The function uses tas5805m_write_biquad_coefficients which is only
available when EQ support is enabled. Wrap the implementation in
a preprocessor conditional to avoid implicit declaration errors
when building without EQ support.
- Remove defer from script tags to ensure scripts load before DOMContentLoaded
- Add automatic retry with 500ms delay for transient failures
- Add 100ms delay between EQ schema/settings requests to reduce ESP32 memory pressure
- Show actual error messages and add Retry button for user recovery
- Add check for getRequest function availability on DAC page
- Keep max_open_sockets at 7 (LWIP_MAX_SOCKETS limit)
- Add recv/send timeouts (5s) to cleanup idle connections faster
- Increase backlog_conn to 10 for pending connection queue
- Add Connection: close header to large schema responses (DAC/EQ)
  to free sockets immediately after 36KB/64KB transfers
- Add missing Connection: close header to EQ settings handler (16KB response)
- Increase delay between EQ schema and settings requests from 100ms to 300ms
- Allows ESP32 memory recovery after 64KB schema response before 16KB settings
The fault monitoring task was crashing with stack overflow when faults
were detected. The tas5805m_decode_faults() function can make up to 12
ESP_LOGW calls with formatted strings, each consuming 200-400 bytes of
stack for vsnprintf operations. Combined with I2C operations and task
overhead, this exceeded the 2048 byte allocation.

Increased stack from 2048 to 4096 bytes to provide adequate headroom.
@anabolyc
Copy link
Copy Markdown
Contributor

@craigmillard86 can you include screeshot here for reference as well. I'm porting some of that into Raspberry Pi kernel driver, looking which options can be of use in Bi-Amp setup.

@craigmillard86
Copy link
Copy Markdown
Contributor Author

@craigmillard86 can you include screeshot here for reference as well. I'm porting some of that into Raspberry Pi kernel driver, looking which options can be of use in Bi-Amp setup.

No Problem, attached

advanced_biamp1
advanced_biamp2

craigmillard86 added a commit to anabolyc/esp32-snapclient that referenced this pull request Jan 25, 2026
# Conflicts:
#	components/lightsnapcast/player.c
@CarlosDerSeher
Copy link
Copy Markdown
Owner

Ok, so I missed that one and now there are conflicts @craigmillard86

Copilot AI review requested due to automatic review settings April 3, 2026 22:34
@craigmillard86
Copy link
Copy Markdown
Contributor Author

@CarlosDerSeher have removed all the merge conflicts

Copy link
Copy Markdown

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR adds an “Advanced Bi-Amp” DSP configuration path for TAS5805M (active crossover + per-output PEQ + loudness), plus corresponding preset export/import/reset APIs and substantial web UI + HTTP server robustness improvements (mobile reliability, retries, socket cleanup).

Changes:

  • Introduces advanced bi-amp DSP + persistence (NVS), loudness compensation, and preset export/import/reset plumbing.
  • Extends EQ web UI to render the new Advanced Bi-Amp schema layout (sections/subgroups/radio) and adds mobile responsiveness + retry/debounce behavior.
  • Improves HTTP server reliability (timeouts/backlog, large-response connection close) and tightens query parsing/CORS behavior.

Reviewed changes

Copilot reviewed 14 out of 16 changed files in this pull request and generated 11 comments.

Show a summary per file
File Description
partitions.csv Fixes missing partition index for ota_1.
docs/ADVANCED_BIAMP_USER_GUIDE.md Adds end-user documentation for advanced bi-amp crossover/PEQ/loudness/presets.
components/ui_http_server/ui_http_server.c Hardens URL decode + query parsing, modifies CORS handling, adds bi-amp preset/reset endpoints, adjusts HTTP server config/timeouts.
components/ui_http_server/html/styles.css Adds mobile responsiveness improvements for shared styles.
components/ui_http_server/html/settings-ui.js Adds radio controls, conditional visibility, and grouped renderers for bi-amp/loudness UI layouts.
components/ui_http_server/html/index.html Adds responsive navigation styling for mobile.
components/ui_http_server/html/eq-settings.html Adds bi-amp UI rendering, preset buttons, retry logic, and debounced setting updates.
components/ui_http_server/html/dac-settings.html Adds retry logic and better error messaging if scripts aren’t loaded.
components/tas5805m_settings/tas5805m_settings.c Adds advanced bi-amp + loudness settings persistence/apply, schema generation updates, and preset import/export/reset.
components/tas5805m_settings/tas5805m_biamp.c New DSP/biquad coefficient generation and targeted apply helpers for advanced bi-amp.
components/tas5805m_settings/include/tas5805m_settings.h Adds types/NVS keys/APIs for bi-amp, loudness, and presets; introduces new EQ UI mode.
components/tas5805m_settings/include/tas5805m_biamp.h New public bi-amp DSP API and band allocation definitions.
components/tas5805m_settings/CMakeLists.txt Adds tas5805m_biamp.c to the component build.
components/lightsnapcast/player.c Minor formatting change.
components/custom_board/tas5805m/tas5805m.c Adds I2C mutexing, fault task stack increase, loudness-on-volume-change hook, and biquad feedback sign convention adjustment.
components/custom_board/CMakeLists.txt Adds dependency/include path wiring for tas5805m_settings when TAS5805M is enabled.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread components/ui_http_server/ui_http_server.c Outdated
Comment thread components/ui_http_server/ui_http_server.c Outdated
Comment thread components/ui_http_server/ui_http_server.c
Comment thread components/ui_http_server/html/eq-settings.html
Comment thread components/ui_http_server/html/eq-settings.html Outdated
Comment thread components/tas5805m_settings/tas5805m_biamp.c
Comment thread components/tas5805m_settings/tas5805m_biamp.c
Comment thread components/custom_board/tas5805m/tas5805m.c
Comment thread components/custom_board/tas5805m/tas5805m.c Outdated
Comment thread docs/ADVANCED_BIAMP_USER_GUIDE.md Outdated
Comment thread components/lightsnapcast/player.c
Comment thread docs/ADVANCED_BIAMP_USER_GUIDE.md Outdated
@CarlosDerSeher
Copy link
Copy Markdown
Owner

Also please address Copilot comments where necessary

craigmillard86 added a commit to craigmillard86/snapclient that referenced this pull request Apr 23, 2026
…and cleanup fixes

- Fix CORS origin validation: replace prefix matching with is_local_origin()
  that verifies next char is digit/terminator, validates 172.16-31 range
- Add httpd_recv_all() helper to handle partial reads in all POST handlers
- Add 32KB max body size check (413 Payload Too Large) to all POST handlers
- Fix biquad read/write asymmetry: negate a1/a2 on read to match write convention
- Remove mutex creation from portENTER_CRITICAL section in tas5805m_init()
- Remove unused BW/LR filter type selector from UI (always Linkwitz-Riley)
- Fix frontend URLs to use getBackendUrl() for preset export/import/reset/sendBeacon
- Fix documentation treble frequency (~5 kHz -> ~4 kHz to match code)
- Revert whitespace-only changes in player.c
@craigmillard86
Copy link
Copy Markdown
Contributor Author

Also please address Copilot comments where necessary

All now updated.

@luar123
Copy link
Copy Markdown
Contributor

luar123 commented Apr 24, 2026

The commit is missing here. You pushed to a different branch.

…and cleanup fixes

- Fix CORS origin validation: replace prefix matching with is_local_origin()
  that verifies next char is digit/terminator, validates 172.16-31 range
- Add httpd_recv_all() helper to handle partial reads in all POST handlers
- Add 32KB max body size check (413 Payload Too Large) to all POST handlers
- Fix biquad read/write asymmetry: negate a1/a2 on read to match write convention
- Remove mutex creation from portENTER_CRITICAL section in tas5805m_init()
- Remove unused BW/LR filter type selector from UI (always Linkwitz-Riley)
- Fix frontend URLs to use getBackendUrl() for preset export/import/reset/sendBeacon
- Fix documentation treble frequency (~5 kHz -> ~4 kHz to match code)
- Revert whitespace-only changes in player.c
Replace Promise.all([schema, settings]) with staged sequential fetches
(schema -> 300ms delay -> settings) in both the mode-change and
auto-mode gain/preset reload paths, matching the pattern already used
in loadSettings(). Prevents socket/memory issues on mobile clients.
@craigmillard86
Copy link
Copy Markdown
Contributor Author

The commit is missing here. You pushed to a different branch.

Done, pushed to my repo instead of @anabolyc

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants