From dbef83adf9fd0d70f5daa22c2661d66014e33550 Mon Sep 17 00:00:00 2001 From: Seppo Ingalsuo Date: Thu, 24 Oct 2024 13:01:36 +0300 Subject: [PATCH] Tools: Topology2: Fix configuration blobs for Aria The blob data in aria.conf results to illegal value outside of allowed range 0 - 3 for the attenuation parameter. The new blobs passthrough.conf, and blobs for parameter values 1 - 3 can be used instead. The benchmark topologies are changed to use parameter value 2 (+12 dB level boost target) Signed-off-by: Seppo Ingalsuo --- tools/topology/topology2/cavs-benchmark-hda.conf | 6 ++++++ .../topology2/development/tplg-targets-bench.cmake | 2 +- .../topology/topology2/development/tplg-targets.cmake | 2 +- .../topology2/include/bench/aria_controls_capture.conf | 6 ++++++ .../include/bench/aria_controls_playback.conf | 6 ++++++ tools/topology/topology2/include/components/aria.conf | 8 -------- .../topology2/include/components/aria/param_1.conf | 10 ++++++++++ .../topology2/include/components/aria/param_2.conf | 10 ++++++++++ .../topology2/include/components/aria/param_3.conf | 10 ++++++++++ .../topology2/include/components/aria/passthrough.conf | 10 ++++++++++ 10 files changed, 60 insertions(+), 10 deletions(-) create mode 100644 tools/topology/topology2/include/components/aria/param_1.conf create mode 100644 tools/topology/topology2/include/components/aria/param_2.conf create mode 100644 tools/topology/topology2/include/components/aria/param_3.conf create mode 100644 tools/topology/topology2/include/components/aria/passthrough.conf diff --git a/tools/topology/topology2/cavs-benchmark-hda.conf b/tools/topology/topology2/cavs-benchmark-hda.conf index 7d6f7f38a00a..bd4aaf2229c4 100644 --- a/tools/topology/topology2/cavs-benchmark-hda.conf +++ b/tools/topology/topology2/cavs-benchmark-hda.conf @@ -161,6 +161,12 @@ IncludeByKey.BENCH_CONFIG { ] Object.Control.bytes."1" { name '$ANALOG_PLAYBACK_PCM ARIA bytes' + IncludeByKey.BENCH_ARIA_PARAMS { + "passthrough" "include/components/aria/passthrough.conf" + "param_1" "include/components/aria/param_1.conf" + "param_2" "include/components/aria/param_2.conf" + "param_3" "include/components/aria/param_3.conf" + } } } Object.Widget.mixout.1 { diff --git a/tools/topology/topology2/development/tplg-targets-bench.cmake b/tools/topology/topology2/development/tplg-targets-bench.cmake index e76aab343443..527dbfce3a20 100644 --- a/tools/topology/topology2/development/tplg-targets-bench.cmake +++ b/tools/topology/topology2/development/tplg-targets-bench.cmake @@ -42,7 +42,7 @@ set(components_s24 ) set(component_parameters_s24 - "BENCH_ARIA_PARAMS=default" + "BENCH_ARIA_PARAMS=param_2" ) # Add components with all sample formats diff --git a/tools/topology/topology2/development/tplg-targets.cmake b/tools/topology/topology2/development/tplg-targets.cmake index f5d5159afba0..1e879bab0568 100644 --- a/tools/topology/topology2/development/tplg-targets.cmake +++ b/tools/topology/topology2/development/tplg-targets.cmake @@ -258,7 +258,7 @@ PREPROCESS_PLUGINS=nhlt,NHLT_BIN=nhlt-sof-nocodec-bt-mtl-lbm.bin" # CAVS HDA topology for benchmarking performance # Copier - peak volume - mixin - mixout - aria - peak volume - mixin - mixout - copier -"sof-hda-generic\;sof-hda-benchmark-generic\;HDA_CONFIG=benchmark,BENCH_CONFIG=benchmark" +"sof-hda-generic\;sof-hda-benchmark-generic\;HDA_CONFIG=benchmark,BENCH_CONFIG=benchmark,BENCH_ARIA_PARAMS=param_2" # Topology to test IPC4 Crossover "development/cavs-nocodec-crossover\;sof-tgl-nocodec-crossover-2way\;PLATFORM=tgl,\ diff --git a/tools/topology/topology2/include/bench/aria_controls_capture.conf b/tools/topology/topology2/include/bench/aria_controls_capture.conf index 9c5f0c476d0d..1b064a64667c 100644 --- a/tools/topology/topology2/include/bench/aria_controls_capture.conf +++ b/tools/topology/topology2/include/bench/aria_controls_capture.conf @@ -3,6 +3,12 @@ Object.Control { bytes."1" { name '$ANALOG_CAPTURE_PCM ARIA bytes' + IncludeByKey.BENCH_ARIA_PARAMS { + "passthrough" "include/components/aria/passthrough.conf" + "param_1" "include/components/aria/param_1.conf" + "param_2" "include/components/aria/param_2.conf" + "param_3" "include/components/aria/param_3.conf" + } } #mixer."1" { # name '$ANALOG_CAPTURE_PCM ARIA switch or volume' diff --git a/tools/topology/topology2/include/bench/aria_controls_playback.conf b/tools/topology/topology2/include/bench/aria_controls_playback.conf index a3ab068b5095..809e4a65c530 100644 --- a/tools/topology/topology2/include/bench/aria_controls_playback.conf +++ b/tools/topology/topology2/include/bench/aria_controls_playback.conf @@ -3,6 +3,12 @@ Object.Control { bytes."1" { name '$ANALOG_PLAYBACK_PCM ARIA bytes' + IncludeByKey.BENCH_ARIA_PARAMS { + "passthrough" "include/components/aria/passthrough.conf" + "param_1" "include/components/aria/param_1.conf" + "param_2" "include/components/aria/param_2.conf" + "param_3" "include/components/aria/param_3.conf" + } } #mixer."1" { # name '$ANALOG_PLAYBACK_PCM ARIA switch or volume' diff --git a/tools/topology/topology2/include/components/aria.conf b/tools/topology/topology2/include/components/aria.conf index 436dbab49ad9..fe34b5cd5070 100644 --- a/tools/topology/topology2/include/components/aria.conf +++ b/tools/topology/topology2/include/components/aria.conf @@ -43,14 +43,6 @@ Class.Widget."aria" { put 0 } max 4096 - Object.Base.data. 1 { - # attenuation for the aria module - bytes "0x53, 0x4f, 0x46, 0x34, 0x01, 0x00, 0x00, 0x00, - 0x4, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, - 0x01, 0x00, 0x00, 0x00" - } } # Attribute categories diff --git a/tools/topology/topology2/include/components/aria/param_1.conf b/tools/topology/topology2/include/components/aria/param_1.conf new file mode 100644 index 000000000000..bfec76526ca6 --- /dev/null +++ b/tools/topology/topology2/include/components/aria/param_1.conf @@ -0,0 +1,10 @@ +# Exported with script sof_aria_blobs.m 24-Oct-2024 +# cd tools/tune/aria; octave sof_aria_blobs.m +Object.Base.data."aria_config" { + bytes " + 0x53,0x4f,0x46,0x34,0x01,0x00,0x00,0x00, + 0x04,0x00,0x00,0x00,0x00,0xa0,0x01,0x03, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x01,0x00,0x00,0x00" +} diff --git a/tools/topology/topology2/include/components/aria/param_2.conf b/tools/topology/topology2/include/components/aria/param_2.conf new file mode 100644 index 000000000000..8cb11358a44b --- /dev/null +++ b/tools/topology/topology2/include/components/aria/param_2.conf @@ -0,0 +1,10 @@ +# Exported with script sof_aria_blobs.m 24-Oct-2024 +# cd tools/tune/aria; octave sof_aria_blobs.m +Object.Base.data."aria_config" { + bytes " + 0x53,0x4f,0x46,0x34,0x01,0x00,0x00,0x00, + 0x04,0x00,0x00,0x00,0x00,0xa0,0x01,0x03, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x02,0x00,0x00,0x00" +} diff --git a/tools/topology/topology2/include/components/aria/param_3.conf b/tools/topology/topology2/include/components/aria/param_3.conf new file mode 100644 index 000000000000..c5cbfa30cb93 --- /dev/null +++ b/tools/topology/topology2/include/components/aria/param_3.conf @@ -0,0 +1,10 @@ +# Exported with script sof_aria_blobs.m 24-Oct-2024 +# cd tools/tune/aria; octave sof_aria_blobs.m +Object.Base.data."aria_config" { + bytes " + 0x53,0x4f,0x46,0x34,0x01,0x00,0x00,0x00, + 0x04,0x00,0x00,0x00,0x00,0xa0,0x01,0x03, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x03,0x00,0x00,0x00" +} diff --git a/tools/topology/topology2/include/components/aria/passthrough.conf b/tools/topology/topology2/include/components/aria/passthrough.conf new file mode 100644 index 000000000000..1fe0ff71adf0 --- /dev/null +++ b/tools/topology/topology2/include/components/aria/passthrough.conf @@ -0,0 +1,10 @@ +# Exported with script sof_aria_blobs.m 24-Oct-2024 +# cd tools/tune/aria; octave sof_aria_blobs.m +Object.Base.data."aria_config" { + bytes " + 0x53,0x4f,0x46,0x34,0x01,0x00,0x00,0x00, + 0x04,0x00,0x00,0x00,0x00,0xa0,0x01,0x03, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00, + 0x00,0x00,0x00,0x00" +}