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 274483151eSLiam Girdwood 284483151eSLiam Girdwood /* 294483151eSLiam Girdwood * Tokens - must match values in topology configurations 304483151eSLiam Girdwood */ 314483151eSLiam Girdwood 324483151eSLiam Girdwood /* buffers */ 334483151eSLiam Girdwood #define SOF_TKN_BUF_SIZE 100 344483151eSLiam Girdwood #define SOF_TKN_BUF_CAPS 101 354483151eSLiam Girdwood 364483151eSLiam Girdwood /* DAI */ 374483151eSLiam Girdwood /* Token retired with ABI 3.2, do not use for new capabilities 384483151eSLiam Girdwood * #define SOF_TKN_DAI_DMAC_CONFIG 153 394483151eSLiam Girdwood */ 404483151eSLiam Girdwood #define SOF_TKN_DAI_TYPE 154 414483151eSLiam Girdwood #define SOF_TKN_DAI_INDEX 155 424483151eSLiam Girdwood #define SOF_TKN_DAI_DIRECTION 156 434483151eSLiam Girdwood 444483151eSLiam Girdwood /* scheduling */ 454483151eSLiam Girdwood #define SOF_TKN_SCHED_PERIOD 200 464483151eSLiam Girdwood #define SOF_TKN_SCHED_PRIORITY 201 474483151eSLiam Girdwood #define SOF_TKN_SCHED_MIPS 202 484483151eSLiam Girdwood #define SOF_TKN_SCHED_CORE 203 494483151eSLiam Girdwood #define SOF_TKN_SCHED_FRAMES 204 504483151eSLiam Girdwood #define SOF_TKN_SCHED_TIME_DOMAIN 205 514483151eSLiam Girdwood 524483151eSLiam Girdwood /* volume */ 534483151eSLiam Girdwood #define SOF_TKN_VOLUME_RAMP_STEP_TYPE 250 544483151eSLiam Girdwood #define SOF_TKN_VOLUME_RAMP_STEP_MS 251 554483151eSLiam Girdwood 564483151eSLiam Girdwood /* SRC */ 574483151eSLiam Girdwood #define SOF_TKN_SRC_RATE_IN 300 584483151eSLiam Girdwood #define SOF_TKN_SRC_RATE_OUT 301 594483151eSLiam Girdwood 60433363e7SSeppo Ingalsuo /* ASRC */ 61433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_RATE_IN 320 62433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_RATE_OUT 321 63433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_ASYNCHRONOUS_MODE 322 64433363e7SSeppo Ingalsuo #define SOF_TKN_ASRC_OPERATION_MODE 323 65433363e7SSeppo Ingalsuo 664483151eSLiam Girdwood /* PCM */ 674483151eSLiam Girdwood #define SOF_TKN_PCM_DMAC_CONFIG 353 684483151eSLiam Girdwood 694483151eSLiam Girdwood /* Generic components */ 704483151eSLiam Girdwood #define SOF_TKN_COMP_PERIOD_SINK_COUNT 400 714483151eSLiam Girdwood #define SOF_TKN_COMP_PERIOD_SOURCE_COUNT 401 724483151eSLiam Girdwood #define SOF_TKN_COMP_FORMAT 402 734483151eSLiam Girdwood /* Token retired with ABI 3.2, do not use for new capabilities 744483151eSLiam Girdwood * #define SOF_TKN_COMP_PRELOAD_COUNT 403 754483151eSLiam Girdwood */ 764483151eSLiam Girdwood 774483151eSLiam Girdwood /* SSP */ 784483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_CLKS_CONTROL 500 794483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_MCLK_ID 501 804483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_SAMPLE_BITS 502 814483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_FRAME_PULSE_WIDTH 503 824483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_QUIRKS 504 834483151eSLiam Girdwood #define SOF_TKN_INTEL_SSP_TDM_PADDING_PER_SLOT 505 846298b787SJanusz Jankowski #define SOF_TKN_INTEL_SSP_BCLK_DELAY 506 854483151eSLiam Girdwood 864483151eSLiam Girdwood /* DMIC */ 874483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DRIVER_VERSION 600 884483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_CLK_MIN 601 894483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_CLK_MAX 602 904483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DUTY_MIN 603 914483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_DUTY_MAX 604 924483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_NUM_PDM_ACTIVE 605 934483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_SAMPLE_RATE 608 944483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_FIFO_WORD_LENGTH 609 957df43911SSeppo Ingalsuo #define SOF_TKN_INTEL_DMIC_UNMUTE_RAMP_TIME_MS 610 964483151eSLiam Girdwood 974483151eSLiam Girdwood /* DMIC PDM */ 984483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_CTRL_ID 700 994483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_MIC_A_Enable 701 1004483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_MIC_B_Enable 702 1014483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_POLARITY_A 703 1024483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_POLARITY_B 704 1034483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_CLK_EDGE 705 1044483151eSLiam Girdwood #define SOF_TKN_INTEL_DMIC_PDM_SKEW 706 1054483151eSLiam Girdwood 1064483151eSLiam Girdwood /* Tone */ 1074483151eSLiam Girdwood #define SOF_TKN_TONE_SAMPLE_RATE 800 1084483151eSLiam Girdwood 1094483151eSLiam Girdwood /* Processing Components */ 1104483151eSLiam Girdwood #define SOF_TKN_PROCESS_TYPE 900 1114483151eSLiam Girdwood 1124483151eSLiam Girdwood /* for backward compatibility */ 1134483151eSLiam Girdwood #define SOF_TKN_EFFECT_TYPE SOF_TKN_PROCESS_TYPE 1144483151eSLiam Girdwood 115f59b16efSDaniel Baluta /* SAI */ 1169c1d4cf6SGuido Roncarolo #define SOF_TKN_IMX_SAI_MCLK_ID 1000 117f59b16efSDaniel Baluta 118f59b16efSDaniel Baluta /* ESAI */ 119b4be4276SDaniel Baluta #define SOF_TKN_IMX_ESAI_MCLK_ID 1100 120f59b16efSDaniel Baluta 1214a949409SKeyon Jie /* Stream */ 1224a949409SKeyon Jie #define SOF_TKN_STREAM_PLAYBACK_COMPATIBLE_D0I3 1200 1234a949409SKeyon Jie #define SOF_TKN_STREAM_CAPTURE_COMPATIBLE_D0I3 1201 1244a949409SKeyon Jie 1255d43001aSJaska Uimonen /* Led control for mute switches */ 1265d43001aSJaska Uimonen #define SOF_TKN_MUTE_LED_USE 1300 1275d43001aSJaska Uimonen #define SOF_TKN_MUTE_LED_DIRECTION 1301 1285d43001aSJaska Uimonen 1294483151eSLiam Girdwood #endif 130