1 /* 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 60 /* 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 66 /* 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 84 #define SOF_TKN_INTEL_SSP_BCLK_DELAY 506 85 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 95 #define SOF_TKN_INTEL_DMIC_UNMUTE_RAMP_TIME_MS 610 96 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 115 /* SAI */ 116 #define SOF_TKN_IMX_SAI_MCLK_ID 1000 117 118 /* ESAI */ 119 #define SOF_TKN_IMX_ESAI_MCLK_ID 1100 120 121 /* Stream */ 122 #define SOF_TKN_STREAM_PLAYBACK_COMPATIBLE_D0I3 1200 123 #define SOF_TKN_STREAM_CAPTURE_COMPATIBLE_D0I3 1201 124 125 /* Led control for mute switches */ 126 #define SOF_TKN_MUTE_LED_USE 1300 127 #define SOF_TKN_MUTE_LED_DIRECTION 1301 128 129 #endif 130