Skip to content

Feature/advanced biamp#187

Open
craigmillard86 wants to merge 61 commits into
CarlosDerSeher:developfrom
anabolyc:feature/advanced-biamp
Open

Feature/advanced biamp#187
craigmillard86 wants to merge 61 commits into
CarlosDerSeher: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
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

@craigmillard86
Copy link
Copy Markdown
Contributor Author

@CarlosDerSeher anything else needed on this branch?

@CarlosDerSeher
Copy link
Copy Markdown
Owner

I don't think so. It had conflicts but other than that I think it is ok

static const char *TAG = "TAS5805M";

/* Mutex for thread-safe I2C access */
static SemaphoreHandle_t tas5805m_i2c_mutex = NULL;
Copy link
Copy Markdown
Owner

Choose a reason for hiding this comment

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

I don't think we have this anywhere. Do we really need this?

httpd_config_t config = HTTPD_DEFAULT_CONFIG();
config.server_port = port;
config.max_open_sockets = 7;
config.max_open_sockets = 7; // Max allowed by LWIP_MAX_SOCKETS config
Copy link
Copy Markdown
Owner

Choose a reason for hiding this comment

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

Shouldn't we use the config value here?

Comment thread partitions.csv
Copy link
Copy Markdown
Owner

Choose a reason for hiding this comment

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

I don't see any change

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