blob: 2a25cd8da5033e1cb9ed502d23979118adb4300b [file] [log] [blame]
Liam Girdwood44831512019-04-12 11:05:15 -05001/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) */
2/*
3 * This file is provided under a dual BSD/GPLv2 license. When using or
4 * redistributing this file, you may do so under either license.
5 *
6 * Copyright(c) 2018 Intel Corporation. All rights reserved.
7 * Author: Liam Girdwood <liam.r.girdwood@linux.intel.com>
8 * Keyon Jie <yang.jie@linux.intel.com>
9 */
10
11/*
12 * Topology IDs and tokens.
13 *
14 * ** MUST BE ALIGNED WITH TOPOLOGY CONFIGURATION TOKEN VALUES **
15 */
16
17#ifndef __INCLUDE_UAPI_SOF_TOPOLOGY_H__
18#define __INCLUDE_UAPI_SOF_TOPOLOGY_H__
19
20/*
21 * Kcontrol IDs
22 */
23#define SOF_TPLG_KCTL_VOL_ID 256
24#define SOF_TPLG_KCTL_ENUM_ID 257
25#define SOF_TPLG_KCTL_BYTES_ID 258
26#define SOF_TPLG_KCTL_SWITCH_ID 259
27
28/*
29 * Tokens - must match values in topology configurations
30 */
31
32/* buffers */
33#define SOF_TKN_BUF_SIZE 100
34#define SOF_TKN_BUF_CAPS 101
35
36/* DAI */
37/* Token retired with ABI 3.2, do not use for new capabilities
38 * #define SOF_TKN_DAI_DMAC_CONFIG 153
39 */
40#define SOF_TKN_DAI_TYPE 154
41#define SOF_TKN_DAI_INDEX 155
42#define SOF_TKN_DAI_DIRECTION 156
43
44/* scheduling */
45#define SOF_TKN_SCHED_PERIOD 200
46#define SOF_TKN_SCHED_PRIORITY 201
47#define SOF_TKN_SCHED_MIPS 202
48#define SOF_TKN_SCHED_CORE 203
49#define SOF_TKN_SCHED_FRAMES 204
50#define SOF_TKN_SCHED_TIME_DOMAIN 205
51
52/* volume */
53#define SOF_TKN_VOLUME_RAMP_STEP_TYPE 250
54#define SOF_TKN_VOLUME_RAMP_STEP_MS 251
55
56/* SRC */
57#define SOF_TKN_SRC_RATE_IN 300
58#define SOF_TKN_SRC_RATE_OUT 301
59
Seppo Ingalsuo433363e2019-12-09 18:48:47 -060060/* ASRC */
61#define SOF_TKN_ASRC_RATE_IN 320
62#define SOF_TKN_ASRC_RATE_OUT 321
63#define SOF_TKN_ASRC_ASYNCHRONOUS_MODE 322
64#define SOF_TKN_ASRC_OPERATION_MODE 323
65
Liam Girdwood44831512019-04-12 11:05:15 -050066/* PCM */
67#define SOF_TKN_PCM_DMAC_CONFIG 353
68
69/* Generic components */
70#define SOF_TKN_COMP_PERIOD_SINK_COUNT 400
71#define SOF_TKN_COMP_PERIOD_SOURCE_COUNT 401
72#define SOF_TKN_COMP_FORMAT 402
73/* Token retired with ABI 3.2, do not use for new capabilities
74 * #define SOF_TKN_COMP_PRELOAD_COUNT 403
75 */
76
77/* SSP */
78#define SOF_TKN_INTEL_SSP_CLKS_CONTROL 500
79#define SOF_TKN_INTEL_SSP_MCLK_ID 501
80#define SOF_TKN_INTEL_SSP_SAMPLE_BITS 502
81#define SOF_TKN_INTEL_SSP_FRAME_PULSE_WIDTH 503
82#define SOF_TKN_INTEL_SSP_QUIRKS 504
83#define SOF_TKN_INTEL_SSP_TDM_PADDING_PER_SLOT 505
Janusz Jankowski6298b782019-07-22 09:14:02 -050084#define SOF_TKN_INTEL_SSP_BCLK_DELAY 506
Liam Girdwood44831512019-04-12 11:05:15 -050085
86/* DMIC */
87#define SOF_TKN_INTEL_DMIC_DRIVER_VERSION 600
88#define SOF_TKN_INTEL_DMIC_CLK_MIN 601
89#define SOF_TKN_INTEL_DMIC_CLK_MAX 602
90#define SOF_TKN_INTEL_DMIC_DUTY_MIN 603
91#define SOF_TKN_INTEL_DMIC_DUTY_MAX 604
92#define SOF_TKN_INTEL_DMIC_NUM_PDM_ACTIVE 605
93#define SOF_TKN_INTEL_DMIC_SAMPLE_RATE 608
94#define SOF_TKN_INTEL_DMIC_FIFO_WORD_LENGTH 609
Seppo Ingalsuo7df43912019-06-12 12:01:47 -050095#define SOF_TKN_INTEL_DMIC_UNMUTE_RAMP_TIME_MS 610
Liam Girdwood44831512019-04-12 11:05:15 -050096
97/* DMIC PDM */
98#define SOF_TKN_INTEL_DMIC_PDM_CTRL_ID 700
99#define SOF_TKN_INTEL_DMIC_PDM_MIC_A_Enable 701
100#define SOF_TKN_INTEL_DMIC_PDM_MIC_B_Enable 702
101#define SOF_TKN_INTEL_DMIC_PDM_POLARITY_A 703
102#define SOF_TKN_INTEL_DMIC_PDM_POLARITY_B 704
103#define SOF_TKN_INTEL_DMIC_PDM_CLK_EDGE 705
104#define SOF_TKN_INTEL_DMIC_PDM_SKEW 706
105
106/* Tone */
107#define SOF_TKN_TONE_SAMPLE_RATE 800
108
109/* Processing Components */
110#define SOF_TKN_PROCESS_TYPE 900
111
112/* for backward compatibility */
113#define SOF_TKN_EFFECT_TYPE SOF_TKN_PROCESS_TYPE
114
Daniel Balutaf59b16e2019-08-15 14:20:15 -0500115/* SAI */
Guido Roncarolo9c1d4cf2019-12-17 18:26:15 -0600116#define SOF_TKN_IMX_SAI_MCLK_ID 1000
Daniel Balutaf59b16e2019-08-15 14:20:15 -0500117
118/* ESAI */
Daniel Balutab4be4272019-10-08 11:44:39 -0500119#define SOF_TKN_IMX_ESAI_MCLK_ID 1100
Daniel Balutaf59b16e2019-08-15 14:20:15 -0500120
Keyon Jie4a949402019-10-25 17:41:04 -0500121/* Stream */
122#define SOF_TKN_STREAM_PLAYBACK_COMPATIBLE_D0I3 1200
123#define SOF_TKN_STREAM_CAPTURE_COMPATIBLE_D0I3 1201
124
Jaska Uimonen5d430012019-10-08 11:44:43 -0500125/* Led control for mute switches */
126#define SOF_TKN_MUTE_LED_USE 1300
127#define SOF_TKN_MUTE_LED_DIRECTION 1301
128
Liam Girdwood44831512019-04-12 11:05:15 -0500129#endif