14483151eSLiam Girdwood /* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) */ 24483151eSLiam Girdwood /* 34483151eSLiam Girdwood * This file is provided under a dual BSD/GPLv2 license. When using or 44483151eSLiam Girdwood * redistributing this file, you may do so under either license. 54483151eSLiam Girdwood * 64483151eSLiam Girdwood * Copyright(c) 2018 Intel Corporation. All rights reserved. 74483151eSLiam Girdwood * Author: Liam Girdwood <liam.r.girdwood@linux.intel.com> 84483151eSLiam Girdwood * Keyon Jie <yang.jie@linux.intel.com> 94483151eSLiam Girdwood */ 104483151eSLiam Girdwood 114483151eSLiam Girdwood /* 124483151eSLiam Girdwood * Topology IDs and tokens. 134483151eSLiam Girdwood * 144483151eSLiam Girdwood * ** MUST BE ALIGNED WITH TOPOLOGY CONFIGURATION TOKEN VALUES ** 154483151eSLiam Girdwood */ 164483151eSLiam Girdwood 174483151eSLiam Girdwood #ifndef __INCLUDE_UAPI_SOF_TOPOLOGY_H__ 184483151eSLiam Girdwood #define __INCLUDE_UAPI_SOF_TOPOLOGY_H__ 194483151eSLiam Girdwood 204483151eSLiam Girdwood /* 214483151eSLiam Girdwood * Kcontrol IDs 224483151eSLiam Girdwood */ 234483151eSLiam Girdwood #define SOF_TPLG_KCTL_VOL_ID 256 244483151eSLiam Girdwood #define SOF_TPLG_KCTL_ENUM_ID 257 254483151eSLiam Girdwood #define SOF_TPLG_KCTL_BYTES_ID 258 264483151eSLiam Girdwood #define SOF_TPLG_KCTL_SWITCH_ID 259 27783560d0SDharageswari R #define SOF_TPLG_KCTL_BYTES_VOLATILE_RO 260 28783560d0SDharageswari R #define SOF_TPLG_KCTL_BYTES_VOLATILE_RW 261 29783560d0SDharageswari R #define SOF_TPLG_KCTL_BYTES_WO_ID 262 304483151eSLiam Girdwood 314483151eSLiam Girdwood /* 324483151eSLiam Girdwood * Tokens - must match values in topology configurations 334483151eSLiam Girdwood */ 344483151eSLiam Girdwood 354483151eSLiam Girdwood /* buffers */ 364483151eSLiam Girdwood #define SOF_TKN_BUF_SIZE 100 374483151eSLiam Girdwood #define SOF_TKN_BUF_CAPS 101 384483151eSLiam Girdwood 394483151eSLiam Girdwood /* DAI */ 404483151eSLiam Girdwood /* Token retired with ABI 3.2, do not use for new capabilities 414483151eSLiam Girdwood * #define SOF_TKN_DAI_DMAC_CONFIG 153 424483151eSLiam Girdwood */ 434483151eSLiam Girdwood #define SOF_TKN_DAI_TYPE 154 444483151eSLiam Girdwood #define SOF_TKN_DAI_INDEX 155 454483151eSLiam Girdwood #define SOF_TKN_DAI_DIRECTION 156 464483151eSLiam Girdwood 474483151eSLiam Girdwood /* scheduling */ 484483151eSLiam Girdwood #define SOF_TKN_SCHED_PERIOD 200 494483151eSLiam Girdwood #define SOF_TKN_SCHED_PRIORITY 201 504483151eSLiam Girdwood #define SOF_TKN_SCHED_MIPS 202 514483151eSLiam Girdwood #define SOF_TKN_SCHED_CORE 203 524483151eSLiam Girdwood #define SOF_TKN_SCHED_FRAMES 204 534483151eSLiam Girdwood #define SOF_TKN_SCHED_TIME_DOMAIN 205 542c28ecadSRanjani Sridharan #define SOF_TKN_SCHED_DYNAMIC_PIPELINE 206 55bd10cd5eSRanjani Sridharan #define SOF_TKN_SCHED_LP_MODE 207 56bd10cd5eSRanjani Sridharan #define SOF_TKN_SCHED_MEM_USAGE 208 574483151eSLiam Girdwood 584483151eSLiam Girdwood /* volume */ 594483151eSLiam Girdwood #define SOF_TKN_VOLUME_RAMP_STEP_TYPE 250 604483151eSLiam Girdwood #define SOF_TKN_VOLUME_RAMP_STEP_MS 251 614483151eSLiam Girdwood 62bd10cd5eSRanjani Sridharan #define SOF_TKN_GAIN_RAMP_TYPE 260 63bd10cd5eSRanjani Sridharan #define SOF_TKN_GAIN_RAMP_DURATION 261 64bd10cd5eSRanjani Sridharan #define SOF_TKN_GAIN_VAL 262 65bd10cd5eSRanjani Sridharan 664483151eSLiam Girdwood /* SRC */ 674483151eSLiam Girdwood #define SOF_TKN_SRC_RATE_IN 300 684483151eSLiam Girdwood #define SOF_TKN_SRC_RATE_OUT 301 694483151eSLiam Girdwood 70433363e7SSeppo Ingalsuo /* ASRC */ 71433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_RATE_IN 320 72433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_RATE_OUT 321 73433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_ASYNCHRONOUS_MODE 322 74433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_OPERATION_MODE 323 75433363e7SSeppo Ingalsuo 764483151eSLiam Girdwood /* PCM */ 774483151eSLiam Girdwood #define SOF_TKN_PCM_DMAC_CONFIG 353 784483151eSLiam Girdwood 794483151eSLiam Girdwood /* Generic components */ 804483151eSLiam Girdwood #define SOF_TKN_COMP_PERIOD_SINK_COUNT 400 814483151eSLiam Girdwood #define SOF_TKN_COMP_PERIOD_SOURCE_COUNT 401 824483151eSLiam Girdwood #define SOF_TKN_COMP_FORMAT 402 834483151eSLiam Girdwood /* Token retired with ABI 3.2, do not use for new capabilities 844483151eSLiam Girdwood * #define SOF_TKN_COMP_PRELOAD_COUNT 403 854483151eSLiam Girdwood */ 86d1c6c4a9SGuennadi Liakhovetski #define SOF_TKN_COMP_CORE_ID 404 8743fbb086SKeyon Jie #define SOF_TKN_COMP_UUID 405 88bd10cd5eSRanjani Sridharan #define SOF_TKN_COMP_CPC 406 89bd10cd5eSRanjani Sridharan #define SOF_TKN_COMP_IS_PAGES 409 90bd10cd5eSRanjani Sridharan #define SOF_TKN_COMP_NUM_AUDIO_FORMATS 410 91bb79f2a6SRanjani Sridharan #define SOF_TKN_COMP_NUM_INPUT_PINS 411 92bb79f2a6SRanjani Sridharan #define SOF_TKN_COMP_NUM_OUTPUT_PINS 412 933b3acedbSChao Song /* 94bb79f2a6SRanjani Sridharan * The token for input/output pin binding, it specifies the widget 95bb79f2a6SRanjani Sridharan * name that the input/output pin is connected from/to. 963b3acedbSChao Song */ 97bb79f2a6SRanjani Sridharan #define SOF_TKN_COMP_INPUT_PIN_BINDING_WNAME 413 98bb79f2a6SRanjani Sridharan #define SOF_TKN_COMP_OUTPUT_PIN_BINDING_WNAME 414 993b3acedbSChao Song 1004483151eSLiam Girdwood 1014483151eSLiam Girdwood /* SSP */ 1024483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_CLKS_CONTROL 500 1034483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_MCLK_ID 501 1044483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_SAMPLE_BITS 502 1054483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_FRAME_PULSE_WIDTH 503 1064483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_QUIRKS 504 1074483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_TDM_PADDING_PER_SLOT 505 1086298b787SJanusz Jankowski #define SOF_TKN_INTEL_SSP_BCLK_DELAY 506 1094483151eSLiam Girdwood 1104483151eSLiam Girdwood /* DMIC */ 1114483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DRIVER_VERSION 600 1124483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_CLK_MIN 601 1134483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_CLK_MAX 602 1144483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DUTY_MIN 603 1154483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DUTY_MAX 604 1164483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_NUM_PDM_ACTIVE 605 1174483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_SAMPLE_RATE 608 1184483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_FIFO_WORD_LENGTH 609 1197df43911SSeppo Ingalsuo #define SOF_TKN_INTEL_DMIC_UNMUTE_RAMP_TIME_MS 610 1204483151eSLiam Girdwood 1214483151eSLiam Girdwood /* DMIC PDM */ 1224483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_CTRL_ID 700 1234483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_MIC_A_Enable 701 1244483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_MIC_B_Enable 702 1254483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_POLARITY_A 703 1264483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_POLARITY_B 704 1274483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_CLK_EDGE 705 1284483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_SKEW 706 1294483151eSLiam Girdwood 1304483151eSLiam Girdwood /* Tone */ 1314483151eSLiam Girdwood #define SOF_TKN_TONE_SAMPLE_RATE 800 1324483151eSLiam Girdwood 1334483151eSLiam Girdwood /* Processing Components */ 1344483151eSLiam Girdwood #define SOF_TKN_PROCESS_TYPE 900 1354483151eSLiam Girdwood 1364483151eSLiam Girdwood /* for backward compatibility */ 1374483151eSLiam Girdwood #define SOF_TKN_EFFECT_TYPE SOF_TKN_PROCESS_TYPE 1384483151eSLiam Girdwood 139f59b16efSDaniel Baluta /* SAI */ 1409c1d4cf6SGuido Roncarolo #define SOF_TKN_IMX_SAI_MCLK_ID 1000 141f59b16efSDaniel Baluta 142f59b16efSDaniel Baluta /* ESAI */ 143b4be4276SDaniel Baluta #define SOF_TKN_IMX_ESAI_MCLK_ID 1100 144f59b16efSDaniel Baluta 1454a949409SKeyon Jie /* Stream */ 1464a949409SKeyon Jie #define SOF_TKN_STREAM_PLAYBACK_COMPATIBLE_D0I3 1200 1474a949409SKeyon Jie #define SOF_TKN_STREAM_CAPTURE_COMPATIBLE_D0I3 1201 1484a949409SKeyon Jie 1495d43001aSJaska Uimonen /* Led control for mute switches */ 1505d43001aSJaska Uimonen #define SOF_TKN_MUTE_LED_USE 1300 1515d43001aSJaska Uimonen #define SOF_TKN_MUTE_LED_DIRECTION 1301 1525d43001aSJaska Uimonen 153c7fc96dfSBard Liao /* ALH */ 154c7fc96dfSBard Liao #define SOF_TKN_INTEL_ALH_RATE 1400 155c7fc96dfSBard Liao #define SOF_TKN_INTEL_ALH_CH 1401 156c7fc96dfSBard Liao 15718aaab64SBard Liao /* HDA */ 15818aaab64SBard Liao #define SOF_TKN_INTEL_HDA_RATE 1500 15918aaab64SBard Liao #define SOF_TKN_INTEL_HDA_CH 1501 16018aaab64SBard Liao 161e6feefa5SYC Hung /* AFE */ 162e6feefa5SYC Hung #define SOF_TKN_MEDIATEK_AFE_RATE 1600 163e6feefa5SYC Hung #define SOF_TKN_MEDIATEK_AFE_CH 1601 164e6feefa5SYC Hung #define SOF_TKN_MEDIATEK_AFE_FORMAT 1602 165e6feefa5SYC Hung 166bd10cd5eSRanjani Sridharan /* MIXER */ 167bd10cd5eSRanjani Sridharan #define SOF_TKN_MIXER_TYPE 1700 168bd10cd5eSRanjani Sridharan 169689614ceSAjit Kumar Pandey /* ACPDMIC */ 170689614ceSAjit Kumar Pandey #define SOF_TKN_AMD_ACPDMIC_RATE 1800 171689614ceSAjit Kumar Pandey #define SOF_TKN_AMD_ACPDMIC_CH 1801 172689614ceSAjit Kumar Pandey 173bd10cd5eSRanjani Sridharan /* CAVS AUDIO FORMAT */ 174bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_RATE 1900 175bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_BIT_DEPTH 1901 1763f738e4aSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_VALID_BIT_DEPTH 1902 177bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_CHANNELS 1903 178bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_CH_MAP 1904 179bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_CH_CFG 1905 180bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_INTERLEAVING_STYLE 1906 181bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_FMT_CFG 1907 182bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IN_SAMPLE_TYPE 1908 183*7ab6b1e8SRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_PIN_INDEX 1909 184bd10cd5eSRanjani Sridharan /* intentional token numbering discontinuity, reserved for future use */ 185bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_RATE 1930 186bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_BIT_DEPTH 1931 1873f738e4aSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_VALID_BIT_DEPTH 1932 188bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_CHANNELS 1933 189bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_CH_MAP 1934 190bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_CH_CFG 1935 191bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_INTERLEAVING_STYLE 1936 192bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_FMT_CFG 1937 193bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OUT_SAMPLE_TYPE 1938 194bd10cd5eSRanjani Sridharan /* intentional token numbering discontinuity, reserved for future use */ 195bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_IBS 1970 196bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_OBS 1971 197bd10cd5eSRanjani Sridharan #define SOF_TKN_CAVS_AUDIO_FORMAT_DMA_BUFFER_SIZE 1972 198bd10cd5eSRanjani Sridharan 199bd10cd5eSRanjani Sridharan /* COPIER */ 200bd10cd5eSRanjani Sridharan #define SOF_TKN_INTEL_COPIER_NODE_TYPE 1980 201594c1bb9SRanjani Sridharan #define SOF_TKN_INTEL_COPIER_DEEP_BUFFER_DMA_MS 1981 202bd10cd5eSRanjani Sridharan 20375af4199SV sujith kumar Reddy /* ACP I2S */ 20475af4199SV sujith kumar Reddy #define SOF_TKN_AMD_ACPI2S_RATE 1700 20575af4199SV sujith kumar Reddy #define SOF_TKN_AMD_ACPI2S_CH 1701 20675af4199SV sujith kumar Reddy #define SOF_TKN_AMD_ACPI2S_TDM_MODE 1702 20775af4199SV sujith kumar Reddy 2084483151eSLiam Girdwood #endif 209