mb/starlabs/starlite_adl: Configure CNVi Bluetooth I2S GPIOs
[coreboot2.git] / src / soc / intel / cannonlake / nhlt.c
blobb22f3a2d64f7038239738025845c589c26df8777
1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 #include <nhlt.h>
4 #include <soc/nhlt.h>
6 static const struct nhlt_format_config dmic_1ch_formats[] = {
7 /* 48 KHz 16-bits per sample. */
9 .num_channels = 1,
10 .sample_freq_khz = 48,
11 .container_bits_per_sample = 16,
12 .valid_bits_per_sample = 16,
13 .settings_file = "dmic-1ch-48khz-16b.bin",
17 static const struct nhlt_dmic_array_config dmic_1ch_mic_config = {
18 .tdm_config = {
19 .config_type = NHLT_TDM_MIC_ARRAY,
21 .array_type = NHLT_MIC_ARRAY_VENDOR_DEFINED,
24 static const struct nhlt_endp_descriptor dmic_1ch_descriptors[] = {
26 .link = NHLT_LINK_PDM,
27 .device = NHLT_PDM_DEV,
28 .direction = NHLT_DIR_CAPTURE,
29 .vid = NHLT_VID,
30 .did = NHLT_DID_DMIC,
31 .cfg = &dmic_1ch_mic_config,
32 .cfg_size = sizeof(dmic_1ch_mic_config),
33 .formats = dmic_1ch_formats,
34 .num_formats = ARRAY_SIZE(dmic_1ch_formats),
38 static const struct nhlt_format_config dmic_2ch_formats[] = {
39 /* 48 KHz 16-bits per sample. */
41 .num_channels = 2,
42 .sample_freq_khz = 48,
43 .container_bits_per_sample = 16,
44 .valid_bits_per_sample = 16,
45 .settings_file = "dmic-2ch-48khz-16b.bin",
49 static const struct nhlt_dmic_array_config dmic_2ch_mic_config = {
50 .tdm_config = {
51 .config_type = NHLT_TDM_MIC_ARRAY,
53 .array_type = NHLT_MIC_ARRAY_2CH_SMALL,
56 static const struct nhlt_endp_descriptor dmic_2ch_descriptors[] = {
58 .link = NHLT_LINK_PDM,
59 .device = NHLT_PDM_DEV,
60 .direction = NHLT_DIR_CAPTURE,
61 .vid = NHLT_VID,
62 .did = NHLT_DID_DMIC,
63 .cfg = &dmic_2ch_mic_config,
64 .cfg_size = sizeof(dmic_2ch_mic_config),
65 .formats = dmic_2ch_formats,
66 .num_formats = ARRAY_SIZE(dmic_2ch_formats),
70 static const struct nhlt_format_config dmic_4ch_formats[] = {
71 /* 48 KHz 16-bits per sample. */
73 .num_channels = 4,
74 .sample_freq_khz = 48,
75 .container_bits_per_sample = 16,
76 .valid_bits_per_sample = 16,
77 .settings_file = "dmic-4ch-48khz-16b.bin",
81 static const struct nhlt_dmic_array_config dmic_4ch_mic_config = {
82 .tdm_config = {
83 .config_type = NHLT_TDM_MIC_ARRAY,
85 .array_type = NHLT_MIC_ARRAY_4CH_L_SHAPED,
88 static const struct nhlt_endp_descriptor dmic_4ch_descriptors[] = {
90 .link = NHLT_LINK_PDM,
91 .device = NHLT_PDM_DEV,
92 .direction = NHLT_DIR_CAPTURE,
93 .vid = NHLT_VID,
94 .did = NHLT_DID_DMIC,
95 .cfg = &dmic_4ch_mic_config,
96 .cfg_size = sizeof(dmic_4ch_mic_config),
97 .formats = dmic_4ch_formats,
98 .num_formats = ARRAY_SIZE(dmic_4ch_formats),
102 static const struct nhlt_format_config da7219_formats[] = {
103 /* 48 KHz 24-bits per sample. */
105 .num_channels = 2,
106 .sample_freq_khz = 48,
107 .container_bits_per_sample = 32,
108 .valid_bits_per_sample = 24,
109 .settings_file = "dialog-2ch-48khz-24b.bin",
113 static const struct nhlt_tdm_config tdm_config = {
114 .virtual_slot = 0,
115 .config_type = NHLT_TDM_BASIC,
118 static const struct nhlt_endp_descriptor da7219_descriptors[] = {
119 /* Render Endpoint */
121 .link = NHLT_LINK_SSP,
122 .device = NHLT_SSP_DEV_I2S,
123 .direction = NHLT_DIR_RENDER,
124 .vid = NHLT_VID,
125 .did = NHLT_DID_SSP,
126 .cfg = &tdm_config,
127 .cfg_size = sizeof(tdm_config),
128 .formats = da7219_formats,
129 .num_formats = ARRAY_SIZE(da7219_formats),
131 /* Capture Endpoint */
133 .link = NHLT_LINK_SSP,
134 .device = NHLT_SSP_DEV_I2S,
135 .direction = NHLT_DIR_CAPTURE,
136 .vid = NHLT_VID,
137 .did = NHLT_DID_SSP,
138 .cfg = &tdm_config,
139 .cfg_size = sizeof(tdm_config),
140 .formats = da7219_formats,
141 .num_formats = ARRAY_SIZE(da7219_formats),
145 static const struct nhlt_format_config max98357_formats[] = {
146 /* 48 KHz 24-bits per sample. */
148 .num_channels = 2,
149 .sample_freq_khz = 48,
150 .container_bits_per_sample = 32,
151 .valid_bits_per_sample = 24,
152 .settings_file = "max98357-render-2ch-48khz-24b.bin",
156 static const struct nhlt_endp_descriptor max98357_descriptors[] = {
158 .link = NHLT_LINK_SSP,
159 .device = NHLT_SSP_DEV_I2S,
160 .direction = NHLT_DIR_RENDER,
161 .vid = NHLT_VID,
162 .did = NHLT_DID_SSP,
163 .formats = max98357_formats,
164 .num_formats = ARRAY_SIZE(max98357_formats),
168 static const struct nhlt_format_config max98373_render_formats[] = {
169 /* 48 KHz 24-bits per sample. */
171 .num_channels = 2,
172 .sample_freq_khz = 48,
173 .container_bits_per_sample = 32,
174 .valid_bits_per_sample = 24,
175 .speaker_mask = SPEAKER_FRONT_LEFT | SPEAKER_FRONT_RIGHT,
176 .settings_file = "max98373-render-2ch-48khz-24b.bin",
178 /* 48 KHz 16-bits per sample. */
180 .num_channels = 2,
181 .sample_freq_khz = 48,
182 .container_bits_per_sample = 16,
183 .valid_bits_per_sample = 16,
184 .speaker_mask = SPEAKER_FRONT_LEFT | SPEAKER_FRONT_RIGHT,
185 .settings_file = "max98373-render-2ch-48khz-16b.bin",
189 static const struct nhlt_format_config max98373_capture_formats[] = {
190 /* 48 KHz 16-bits per sample. */
192 .num_channels = 2,
193 .sample_freq_khz = 48,
194 .container_bits_per_sample = 16,
195 .valid_bits_per_sample = 16,
196 .speaker_mask = SPEAKER_FRONT_LEFT | SPEAKER_FRONT_RIGHT,
197 .settings_file = "max98373-render-2ch-48khz-16b.bin",
201 static const struct nhlt_endp_descriptor max98373_descriptors[] = {
203 .link = NHLT_LINK_SSP,
204 .device = NHLT_SSP_DEV_I2S,
205 .direction = NHLT_DIR_RENDER,
206 .vid = NHLT_VID,
207 .did = NHLT_DID_SSP,
208 .formats = max98373_render_formats,
209 .num_formats = ARRAY_SIZE(max98373_render_formats),
212 .link = NHLT_LINK_SSP,
213 .device = NHLT_SSP_DEV_I2S,
214 .direction = NHLT_DIR_CAPTURE,
215 .vid = NHLT_VID,
216 .did = NHLT_DID_SSP,
217 .formats = max98373_capture_formats,
218 .num_formats = ARRAY_SIZE(max98373_capture_formats),
222 int nhlt_soc_add_dmic_array(struct nhlt *nhlt, int num_channels)
224 switch (num_channels) {
225 case 1:
226 return nhlt_add_endpoints(nhlt, dmic_1ch_descriptors,
227 ARRAY_SIZE(dmic_1ch_descriptors));
228 case 2:
229 return nhlt_add_endpoints(nhlt, dmic_2ch_descriptors,
230 ARRAY_SIZE(dmic_2ch_descriptors));
231 case 4:
232 return nhlt_add_endpoints(nhlt, dmic_4ch_descriptors,
233 ARRAY_SIZE(dmic_4ch_descriptors));
234 default:
235 return -1;
239 int nhlt_soc_add_da7219(struct nhlt *nhlt, int hwlink)
241 /* Virtual bus id of SSP links are the hardware port ids proper. */
242 return nhlt_add_ssp_endpoints(nhlt, hwlink, da7219_descriptors,
243 ARRAY_SIZE(da7219_descriptors));
246 int nhlt_soc_add_max98357(struct nhlt *nhlt, int hwlink)
248 /* Virtual bus id of SSP links are the hardware port ids proper. */
249 return nhlt_add_ssp_endpoints(nhlt, hwlink, max98357_descriptors,
250 ARRAY_SIZE(max98357_descriptors));
253 int nhlt_soc_add_max98373(struct nhlt *nhlt, int hwlink)
255 /* Virtual bus id of SSP links are the hardware port ids proper. */
256 return nhlt_add_ssp_endpoints(nhlt, hwlink, max98373_descriptors,
257 ARRAY_SIZE(max98373_descriptors));