xref: /openbmc/linux/sound/soc/tegra/Kconfig (revision 1ac731c529cd4d6adbce134754b51ff7d822b145)
1ec8f24b7SThomas Gleixner# SPDX-License-Identifier: GPL-2.0-only
22ba9471bSStephen Warrenconfig SND_SOC_TEGRA
38b75d714SStephen Warren	tristate "SoC Audio for the Tegra System-on-Chip"
422abf843SMark Brown	depends on (ARCH_TEGRA && TEGRA20_APB_DMA) || COMPILE_TEST
55185e0acSStephen Warren	depends on COMMON_CLK
65185e0acSStephen Warren	depends on RESET_CONTROLLER
7d19e779bSStephen Warren	select REGMAP_MMIO
82086d078SMark Brown	select SND_SOC_GENERIC_DMAENGINE_PCM
98b75d714SStephen Warren	help
108b75d714SStephen Warren	  Say Y or M here if you want support for SoC audio on Tegra.
118b75d714SStephen Warren
12e86caa01SGeert Uytterhoevenif SND_SOC_TEGRA
13e86caa01SGeert Uytterhoeven
14609dad9bSLucas Stachconfig SND_SOC_TEGRA20_AC97
153bcfe80fSPaul Kocialkowski	tristate "Tegra20 AC97 interface"
16609dad9bSLucas Stach	select SND_SOC_AC97_BUS
17609dad9bSLucas Stach	select SND_SOC_TEGRA20_DAS
18609dad9bSLucas Stach	help
19609dad9bSLucas Stach	  Say Y or M if you want to add support for codecs attached to the
20609dad9bSLucas Stach	  Tegra20 AC97 interface. You will also need to select the individual
21609dad9bSLucas Stach	  machine drivers to support below.
22609dad9bSLucas Stach
23896637acSStephen Warrenconfig SND_SOC_TEGRA20_DAS
243bcfe80fSPaul Kocialkowski	tristate "Tegra20 DAS module"
25d9bba496SStephen Warren	help
26896637acSStephen Warren	  Say Y or M if you want to add support for the Tegra20 DAS module.
27d9bba496SStephen Warren	  You will also need to select the individual machine drivers to
28d9bba496SStephen Warren	  support below.
29d9bba496SStephen Warren
30896637acSStephen Warrenconfig SND_SOC_TEGRA20_I2S
313bcfe80fSPaul Kocialkowski	tristate "Tegra20 I2S interface"
32896637acSStephen Warren	select SND_SOC_TEGRA20_DAS
338b75d714SStephen Warren	help
348b75d714SStephen Warren	  Say Y or M if you want to add support for codecs attached to the
35896637acSStephen Warren	  Tegra20 I2S interface. You will also need to select the individual
368b75d714SStephen Warren	  machine drivers to support below.
378b75d714SStephen Warren
38896637acSStephen Warrenconfig SND_SOC_TEGRA20_SPDIF
393bcfe80fSPaul Kocialkowski	tristate "Tegra20 SPDIF interface"
40774fec33SStephen Warren	help
41896637acSStephen Warren	  Say Y or M if you want to add support for the Tegra20 SPDIF interface.
42774fec33SStephen Warren	  You will also need to select the individual machine drivers to support
43774fec33SStephen Warren	  below.
44774fec33SStephen Warren
45cdc04fd1SStephen Warrenconfig SND_SOC_TEGRA30_AHUB
463bcfe80fSPaul Kocialkowski	tristate "Tegra30 AHUB module"
47cdc04fd1SStephen Warren	help
483bcfe80fSPaul Kocialkowski	  Say Y or M if you want to add support for the Tegra30 AHUB module.
49cdc04fd1SStephen Warren	  You will also need to select the individual machine drivers to
50cdc04fd1SStephen Warren	  support below.
51cdc04fd1SStephen Warren
52cdc04fd1SStephen Warrenconfig SND_SOC_TEGRA30_I2S
533bcfe80fSPaul Kocialkowski	tristate "Tegra30 I2S interface"
54cdc04fd1SStephen Warren	select SND_SOC_TEGRA30_AHUB
55cdc04fd1SStephen Warren	help
56cdc04fd1SStephen Warren	  Say Y or M if you want to add support for codecs attached to the
57cdc04fd1SStephen Warren	  Tegra30 I2S interface. You will also need to select the individual
58cdc04fd1SStephen Warren	  machine drivers to support below.
59cdc04fd1SStephen Warren
6016e1bcc2SSameer Pujarconfig SND_SOC_TEGRA210_AHUB
6116e1bcc2SSameer Pujar	tristate "Tegra210 AHUB module"
6216e1bcc2SSameer Pujar	help
6316e1bcc2SSameer Pujar	  Config to enable Audio Hub (AHUB) module, which comprises of a
6416e1bcc2SSameer Pujar	  switch called Audio Crossbar (AXBAR) used to configure or modify
6516e1bcc2SSameer Pujar	  the audio routing path between various HW accelerators present in
6616e1bcc2SSameer Pujar	  AHUB.
6716e1bcc2SSameer Pujar	  Say Y or M if you want to add support for Tegra210 AHUB module.
6816e1bcc2SSameer Pujar
698c8ff982SSameer Pujarconfig SND_SOC_TEGRA210_DMIC
708c8ff982SSameer Pujar	tristate "Tegra210 DMIC module"
718c8ff982SSameer Pujar	help
728c8ff982SSameer Pujar	  Config to enable the Digital MIC (DMIC) controller which is used
738c8ff982SSameer Pujar	  to interface with Pulse Density Modulation (PDM) input devices.
748c8ff982SSameer Pujar	  The DMIC controller implements a converter to convert PDM signals
758c8ff982SSameer Pujar	  to Pulse Code Modulation (PCM) signals. This can be viewed as a
768c8ff982SSameer Pujar	  PDM receiver.
778c8ff982SSameer Pujar	  Say Y or M if you want to add support for Tegra210 DMIC module.
788c8ff982SSameer Pujar
79c0bfa983SSameer Pujarconfig SND_SOC_TEGRA210_I2S
80c0bfa983SSameer Pujar	tristate "Tegra210 I2S module"
81c0bfa983SSameer Pujar	help
82c0bfa983SSameer Pujar	  Config to enable the Inter-IC Sound (I2S) Controller which
83c0bfa983SSameer Pujar	  implements full-duplex and bidirectional and single direction
84c0bfa983SSameer Pujar	  point-to-point serial interfaces. It can interface with I2S
85c0bfa983SSameer Pujar	  compatible devices.
86c0bfa983SSameer Pujar	  Say Y or M if you want to add support for Tegra210 I2S module.
87c0bfa983SSameer Pujar
887358a803SSameer Pujarconfig SND_SOC_TEGRA210_OPE
897358a803SSameer Pujar	tristate "Tegra210 OPE module"
907358a803SSameer Pujar	help
917358a803SSameer Pujar	  Config to enable the Output Processing Engine (OPE) which includes
927358a803SSameer Pujar	  Parametric Equalizer (PEQ) and Multi Band Dynamic Range Compressor
937358a803SSameer Pujar	  (MBDRC) sub blocks for data processing. It can support up to 8
947358a803SSameer Pujar	  channels.
957358a803SSameer Pujar	  Say Y or M if you want to add support for Tegra210 OPE module.
967358a803SSameer Pujar
97a2df8c2dSSameer Pujarconfig SND_SOC_TEGRA186_ASRC
98a2df8c2dSSameer Pujar	tristate "Tegra186 ASRC module"
99a2df8c2dSSameer Pujar	help
100a2df8c2dSSameer Pujar	  Config to enable the Asynchronous Sample Rate Converter (ASRC),
101a2df8c2dSSameer Pujar	  which converts the sampling frequency of the input signal from
102a2df8c2dSSameer Pujar	  one frequency to another. It can handle over a wide range of
103a2df8c2dSSameer Pujar	  sample rate ratios (freq_in/freq_out) from 1:24 to 24:1.
104a2df8c2dSSameer Pujar	  ASRC has two modes of operation. One where ratio can be programmed
105a2df8c2dSSameer Pujar	  in SW and the other where it gets information from ratio estimator
106a2df8c2dSSameer Pujar	  module.
107a2df8c2dSSameer Pujar	  Say Y or M if you want to add support for Tegra186 ASRC module.
108a2df8c2dSSameer Pujar
109327ef647SSameer Pujarconfig SND_SOC_TEGRA186_DSPK
110327ef647SSameer Pujar	tristate "Tegra186 DSPK module"
111327ef647SSameer Pujar	help
112327ef647SSameer Pujar	  Config to enable the Digital Speaker Controller (DSPK) which
113327ef647SSameer Pujar	  converts the multi-bit Pulse Code Modulation (PCM) audio input to
114327ef647SSameer Pujar	  oversampled 1-bit Pulse Density Modulation (PDM) output. From the
115327ef647SSameer Pujar	  signal flow perspective DSPK can be viewed as a PDM transmitter
116327ef647SSameer Pujar	  that up-samples the input to the desired sampling rate by
117327ef647SSameer Pujar	  interpolation and then converts the oversampled PCM input to
118327ef647SSameer Pujar	  the desired 1-bit output via Delta Sigma Modulation (DSM).
119327ef647SSameer Pujar	  Say Y or M if you want to add support for Tegra186 DSPK module.
120327ef647SSameer Pujar
121f74028e1SSameer Pujarconfig SND_SOC_TEGRA210_ADMAIF
122f74028e1SSameer Pujar	tristate "Tegra210 ADMAIF module"
123f74028e1SSameer Pujar	help
124f74028e1SSameer Pujar	  Config to enable ADMAIF which is the interface between ADMA and
125f74028e1SSameer Pujar	  Audio Hub (AHUB). Each ADMA channel that sends/receives data to/
126f74028e1SSameer Pujar	  from AHUB must interface through an ADMAIF channel. ADMA channel
127f74028e1SSameer Pujar	  sending data to AHUB pairs with an ADMAIF Tx channel, where as
128f74028e1SSameer Pujar	  ADMA channel receiving data from AHUB pairs with an ADMAIF Rx
129f74028e1SSameer Pujar	  channel. Buffer size is configurable for each ADMAIIF channel.
130f74028e1SSameer Pujar	  Say Y or M if you want to add support for Tegra210 ADMAIF module.
131f74028e1SSameer Pujar
132e539891fSSameer Pujarconfig SND_SOC_TEGRA210_MVC
133e539891fSSameer Pujar	tristate "Tegra210 MVC module"
134e539891fSSameer Pujar	help
135e539891fSSameer Pujar	  Config to enable the digital Master Volume Controller (MVC) which
136e539891fSSameer Pujar	  provides gain or attenuation to a digital signal path. It can be
137e539891fSSameer Pujar	  used in input or output signal path. It can be used either for
138e539891fSSameer Pujar	  per-stream volume control or for master volume control.
139e539891fSSameer Pujar	  Say Y or M if you want to add support for Tegra210 MVC module.
140e539891fSSameer Pujar
141b2f74ec5SSameer Pujarconfig SND_SOC_TEGRA210_SFC
142b2f74ec5SSameer Pujar	tristate "Tegra210 SFC module"
143b2f74ec5SSameer Pujar	help
144b2f74ec5SSameer Pujar	  Config to enable the Sampling Frequency Converter (SFC) which
145b2f74ec5SSameer Pujar	  converts the sampling frequency of input signal to another
146b2f74ec5SSameer Pujar	  frequency. It supports sampling frequency conversion of streams
147b2f74ec5SSameer Pujar	  up to 2 channels (stereo).
148b2f74ec5SSameer Pujar	  Say Y or M if you want to add support for Tegra210 SFC module.
149b2f74ec5SSameer Pujar
15077f7df34SSameer Pujarconfig SND_SOC_TEGRA210_AMX
15177f7df34SSameer Pujar	tristate "Tegra210 AMX module"
15277f7df34SSameer Pujar	help
15377f7df34SSameer Pujar	  Config to enable the Audio Multiplexer (AMX) which can multiplex
15477f7df34SSameer Pujar	  four input streams (each of up to 16 channels) and generate
15577f7df34SSameer Pujar	  output stream (of up to 16 channels). A byte RAM helps to form an
15677f7df34SSameer Pujar	  output frame by any combination of bytes from the input frames.
15777f7df34SSameer Pujar	  Say Y or M if you want to add support for Tegra210 AMX module.
15877f7df34SSameer Pujar
159a99ab6f3SSameer Pujarconfig SND_SOC_TEGRA210_ADX
160a99ab6f3SSameer Pujar	tristate "Tegra210 ADX module"
161a99ab6f3SSameer Pujar	help
162a99ab6f3SSameer Pujar	  Config to enable the Audio Demultiplexer (ADX) which takes an
163a99ab6f3SSameer Pujar	  input stream (up to 16 channels) and demultiplexes it into four
164a99ab6f3SSameer Pujar	  output streams (each of up to 16 channels). A byte RAM helps to
165a99ab6f3SSameer Pujar	  form output frames by any combination of bytes from the input
166a99ab6f3SSameer Pujar	  frame. Its design is identical to that of byte RAM in the AMX
167a99ab6f3SSameer Pujar	  except that the data flow direction is reversed.
168a99ab6f3SSameer Pujar	  Say Y or M if you want to add support for Tegra210 ADX module.
169a99ab6f3SSameer Pujar
17005bb3d5eSSameer Pujarconfig SND_SOC_TEGRA210_MIXER
17105bb3d5eSSameer Pujar	tristate "Tegra210 Mixer module"
17205bb3d5eSSameer Pujar	help
17305bb3d5eSSameer Pujar	  Config to enable the Mixer module which can help to mix multiple
17405bb3d5eSSameer Pujar	  audio streams. It supports mixing of up to 10 input streams,
17505bb3d5eSSameer Pujar	  where each stream can contain maximum of 8 channels. It supports
17605bb3d5eSSameer Pujar	  5 output each of which can be a mix of any combination of 10
17705bb3d5eSSameer Pujar	  input streams.
17805bb3d5eSSameer Pujar	  Say Y or M if you want to add support for Tegra210 Mixer module.
17905bb3d5eSSameer Pujar
180202e2f77SSameer Pujarconfig SND_SOC_TEGRA_AUDIO_GRAPH_CARD
181202e2f77SSameer Pujar	tristate "Audio Graph Card based Tegra driver"
182202e2f77SSameer Pujar	depends on SND_AUDIO_GRAPH_CARD
183202e2f77SSameer Pujar	help
184202e2f77SSameer Pujar	  Config to enable Tegra audio machine driver based on generic
185202e2f77SSameer Pujar	  audio graph driver. It is a thin driver written to customize
186202e2f77SSameer Pujar	  few things for Tegra audio. Most of the code is re-used from
187202e2f77SSameer Pujar	  audio graph driver and the same DT bindings are used.
188202e2f77SSameer Pujar
189cc8f70f5SDmitry Osipenkoconfig SND_SOC_TEGRA_MACHINE_DRV
190cc8f70f5SDmitry Osipenko	tristate
191cc8f70f5SDmitry Osipenko
19244b2fc2eSSvyatoslav Ryhelconfig SND_SOC_TEGRA_RT5631
19344b2fc2eSSvyatoslav Ryhel	tristate "SoC Audio support for Tegra boards using an RT5631 codec"
19444b2fc2eSSvyatoslav Ryhel	depends on SND_SOC_TEGRA && I2C && GPIOLIB
19544b2fc2eSSvyatoslav Ryhel	select SND_SOC_TEGRA_MACHINE_DRV
19644b2fc2eSSvyatoslav Ryhel	select SND_SOC_RT5631
19744b2fc2eSSvyatoslav Ryhel	help
19844b2fc2eSSvyatoslav Ryhel	  Say Y or M here if you want to add support for SoC audio on Tegra
19944b2fc2eSSvyatoslav Ryhel	  boards using the RT5631 codec, such as Transformer.
20044b2fc2eSSvyatoslav Ryhel
201040a62cfSStephen Warrenconfig SND_SOC_TEGRA_RT5640
202040a62cfSStephen Warren	tristate "SoC Audio support for Tegra boards using an RT5640 codec"
203e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
204cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
205040a62cfSStephen Warren	select SND_SOC_RT5640
206040a62cfSStephen Warren	help
207040a62cfSStephen Warren	  Say Y or M here if you want to add support for SoC audio on Tegra
208040a62cfSStephen Warren	  boards using the RT5640 codec, such as Dalmore.
209040a62cfSStephen Warren
210d8259ca5SStephen Warrenconfig SND_SOC_TEGRA_WM8753
211d8259ca5SStephen Warren	tristate "SoC Audio support for Tegra boards using a WM8753 codec"
212e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
213cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
214d8259ca5SStephen Warren	select SND_SOC_WM8753
215d8259ca5SStephen Warren	help
216d8259ca5SStephen Warren	  Say Y or M here if you want to add support for SoC audio on Tegra
217d8259ca5SStephen Warren	  boards using the WM8753 codec, such as Whistler.
218d8259ca5SStephen Warren
2192ba9471bSStephen Warrenconfig SND_SOC_TEGRA_WM8903
220dc0a50afSStephen Warren	tristate "SoC Audio support for Tegra boards using a WM8903 codec"
221e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
222cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
2238b75d714SStephen Warren	select SND_SOC_WM8903
2248b75d714SStephen Warren	help
225dc0a50afSStephen Warren	  Say Y or M here if you want to add support for SoC audio on Tegra
226773b1d3dSStephen Warren	  boards using the WM8093 codec. Currently, the supported boards are
227773b1d3dSStephen Warren	  Harmony, Ventana, Seaboard, Kaen, and Aebl.
2288b75d714SStephen Warren
2296995b8cbSLucas Stachconfig SND_SOC_TEGRA_WM9712
2306995b8cbSLucas Stach	tristate "SoC Audio support for Tegra boards using a WM9712 codec"
231e86caa01SGeert Uytterhoeven	depends on GPIOLIB
232cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
2336995b8cbSLucas Stach	select SND_SOC_TEGRA20_AC97
2346995b8cbSLucas Stach	select SND_SOC_WM9712
2356995b8cbSLucas Stach	help
2366995b8cbSLucas Stach	  Say Y or M here if you want to add support for SoC audio on Tegra
2376995b8cbSLucas Stach	  boards using the WM9712 (or compatible) codec.
2386995b8cbSLucas Stach
2391307394aSMike Rapoportconfig SND_SOC_TEGRA_TRIMSLICE
2401307394aSMike Rapoport	tristate "SoC Audio support for TrimSlice board"
241e86caa01SGeert Uytterhoeven	depends on I2C
242cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
243cc1bc54aSMax Filippov	select SND_SOC_TLV320AIC23_I2C
2441307394aSMike Rapoport	help
2451307394aSMike Rapoport	  Say Y or M here if you want to add support for SoC audio on the
2461307394aSMike Rapoport	  TrimSlice platform.
24758783fafSLeon Romanovsky
24858783fafSLeon Romanovskyconfig SND_SOC_TEGRA_ALC5632
24958783fafSLeon Romanovsky	tristate "SoC Audio support for Tegra boards using an ALC5632 codec"
250e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
251cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
25258783fafSLeon Romanovsky	select SND_SOC_ALC5632
25358783fafSLeon Romanovsky	help
25458783fafSLeon Romanovsky	  Say Y or M here if you want to add support for SoC audio on the
25558783fafSLeon Romanovsky	  Toshiba AC100 netbook.
2567637af2eSStephen Warren
2577637af2eSStephen Warrenconfig SND_SOC_TEGRA_MAX98090
2587637af2eSStephen Warren	tristate "SoC Audio support for Tegra boards using a MAX98090 codec"
259e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
260cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
2617637af2eSStephen Warren	select SND_SOC_MAX98090
2627637af2eSStephen Warren	help
2637637af2eSStephen Warren	  Say Y or M here if you want to add support for SoC audio on Tegra
2647637af2eSStephen Warren	  boards using the MAX98090 codec, such as Venice2.
265a37f1b8fSAnatol Pomozov
266*d007a87bSSvyatoslav Ryhelconfig SND_SOC_TEGRA_MAX98088
267*d007a87bSSvyatoslav Ryhel	tristate "SoC Audio support for Tegra boards using a MAX9808x codec"
268*d007a87bSSvyatoslav Ryhel	depends on I2C && GPIOLIB
269*d007a87bSSvyatoslav Ryhel	select SND_SOC_TEGRA_MACHINE_DRV
270*d007a87bSSvyatoslav Ryhel	select SND_SOC_MAX98088
271*d007a87bSSvyatoslav Ryhel	help
272*d007a87bSSvyatoslav Ryhel	  Say Y or M here if you want to add support for SoC audio on Tegra
273*d007a87bSSvyatoslav Ryhel	  boards using the MAX98088 codec, such as LG X3.
274*d007a87bSSvyatoslav Ryhel
275a37f1b8fSAnatol Pomozovconfig SND_SOC_TEGRA_RT5677
276a37f1b8fSAnatol Pomozov	tristate "SoC Audio support for Tegra boards using a RT5677 codec"
277e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
278cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
279a37f1b8fSAnatol Pomozov	select SND_SOC_RT5677
280a37f1b8fSAnatol Pomozov	help
281a37f1b8fSAnatol Pomozov	  Say Y or M here if you want to add support for SoC audio on Tegra
282a37f1b8fSAnatol Pomozov	  boards using the RT5677 codec, such as Ryu.
28304445681SMarcel Ziswiler
28404445681SMarcel Ziswilerconfig SND_SOC_TEGRA_SGTL5000
28504445681SMarcel Ziswiler	tristate "SoC Audio support for Tegra boards using a SGTL5000 codec"
286e86caa01SGeert Uytterhoeven	depends on I2C && GPIOLIB
287cc8f70f5SDmitry Osipenko	select SND_SOC_TEGRA_MACHINE_DRV
28804445681SMarcel Ziswiler	select SND_SOC_SGTL5000
28904445681SMarcel Ziswiler	help
29004445681SMarcel Ziswiler	  Say Y or M here if you want to add support for SoC audio on Tegra
29104445681SMarcel Ziswiler	  boards using the SGTL5000 codec, such as Apalis T30, Apalis TK1 or
29204445681SMarcel Ziswiler	  Colibri T30.
293e86caa01SGeert Uytterhoeven
294e86caa01SGeert Uytterhoevenendif
295