1 /* SPDX-License-Identifier: (GPL-2.0 OR BSD-3-Clause) */
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.
6 * Copyright(c) 2019 Intel Corporation. All rights reserved.
8 * Author: Ranjani Sridharan <ranjani.sridharan@linux.intel.com>
11 #ifndef __SOUND_SOC_SOF_AUDIO_H
12 #define __SOUND_SOC_SOF_AUDIO_H
14 #include <linux/workqueue.h>
16 #include <sound/soc.h>
17 #include <sound/control.h>
18 #include <sound/sof/stream.h> /* needs to be included before control.h */
19 #include <sound/sof/control.h>
20 #include <sound/sof/dai.h>
21 #include <sound/sof/topology.h>
24 #define SOF_AUDIO_PCM_DRV_NAME "sof-audio-component"
26 /* max number of FE PCMs before BEs */
27 #define SOF_BE_PCM_BASE 16
29 #define DMA_CHAN_INVALID 0xFFFFFFFF
31 /* PCM stream, mapped to FW component */
32 struct snd_sof_pcm_stream
{
34 struct snd_dma_buffer page_table
;
35 struct sof_ipc_stream_posn posn
;
36 struct snd_pcm_substream
*substream
;
37 struct work_struct period_elapsed_work
;
38 bool d0i3_compatible
; /* DSP can be in D0I3 when this pcm is opened */
40 * flag to indicate that the DSP pipelines should be kept
41 * active or not while suspending the stream
46 /* ALSA SOF PCM device */
48 struct snd_soc_component
*scomp
;
49 struct snd_soc_tplg_pcm pcm
;
50 struct snd_sof_pcm_stream stream
[2];
51 struct list_head list
; /* list in sdev pcm list */
52 struct snd_pcm_hw_params params
[2];
53 bool prepared
[2]; /* PCM_PARAMS set successfully */
56 struct snd_sof_led_control
{
58 unsigned int direction
;
59 unsigned int led_value
;
62 /* ALSA SOF Kcontrol device */
63 struct snd_sof_control
{
64 struct snd_soc_component
*scomp
;
66 int min_volume_step
; /* min volume step for volume_table */
67 int max_volume_step
; /* max volume step for volume_table */
69 u32 readback_offset
; /* offset to mmapped data if used */
70 struct sof_ipc_ctrl_data
*control_data
;
71 u32 size
; /* cdata size */
72 enum sof_ipc_ctrl_cmd cmd
;
73 u32
*volume_table
; /* volume table computed from tlv data*/
75 struct list_head list
; /* list in sdev control list */
77 struct snd_sof_led_control led_ctl
;
80 /* ASoC SOF DAPM widget */
81 struct snd_sof_widget
{
82 struct snd_soc_component
*scomp
;
88 struct snd_soc_dapm_widget
*widget
;
89 struct list_head list
; /* list in sdev widget list */
91 void *private; /* core does not touch this */
94 /* ASoC SOF DAPM route */
95 struct snd_sof_route
{
96 struct snd_soc_component
*scomp
;
98 struct snd_soc_dapm_route
*route
;
99 struct list_head list
; /* list in sdev route list */
104 /* ASoC DAI device */
106 struct snd_soc_component
*scomp
;
108 const char *cpu_dai_name
;
110 struct sof_ipc_comp_dai comp_dai
;
111 struct sof_ipc_dai_config
*dai_config
;
112 struct list_head list
; /* list in sdev dai list */
119 int snd_sof_volume_get(struct snd_kcontrol
*kcontrol
,
120 struct snd_ctl_elem_value
*ucontrol
);
121 int snd_sof_volume_put(struct snd_kcontrol
*kcontrol
,
122 struct snd_ctl_elem_value
*ucontrol
);
123 int snd_sof_switch_get(struct snd_kcontrol
*kcontrol
,
124 struct snd_ctl_elem_value
*ucontrol
);
125 int snd_sof_switch_put(struct snd_kcontrol
*kcontrol
,
126 struct snd_ctl_elem_value
*ucontrol
);
127 int snd_sof_enum_get(struct snd_kcontrol
*kcontrol
,
128 struct snd_ctl_elem_value
*ucontrol
);
129 int snd_sof_enum_put(struct snd_kcontrol
*kcontrol
,
130 struct snd_ctl_elem_value
*ucontrol
);
131 int snd_sof_bytes_get(struct snd_kcontrol
*kcontrol
,
132 struct snd_ctl_elem_value
*ucontrol
);
133 int snd_sof_bytes_put(struct snd_kcontrol
*kcontrol
,
134 struct snd_ctl_elem_value
*ucontrol
);
135 int snd_sof_bytes_ext_put(struct snd_kcontrol
*kcontrol
,
136 const unsigned int __user
*binary_data
,
138 int snd_sof_bytes_ext_get(struct snd_kcontrol
*kcontrol
,
139 unsigned int __user
*binary_data
,
144 * There is no snd_sof_free_topology since topology components will
145 * be freed by snd_soc_unregister_component,
147 int snd_sof_load_topology(struct snd_soc_component
*scomp
, const char *file
);
148 int snd_sof_complete_pipeline(struct device
*dev
,
149 struct snd_sof_widget
*swidget
);
151 int sof_load_pipeline_ipc(struct device
*dev
,
152 struct sof_ipc_pipe_new
*pipeline
,
153 struct sof_ipc_comp_reply
*r
);
158 int snd_sof_ipc_stream_posn(struct snd_soc_component
*scomp
,
159 struct snd_sof_pcm
*spcm
, int direction
,
160 struct sof_ipc_stream_posn
*posn
);
162 struct snd_sof_widget
*snd_sof_find_swidget(struct snd_soc_component
*scomp
,
164 struct snd_sof_widget
*
165 snd_sof_find_swidget_sname(struct snd_soc_component
*scomp
,
166 const char *pcm_name
, int dir
);
167 struct snd_sof_dai
*snd_sof_find_dai(struct snd_soc_component
*scomp
,
171 struct snd_sof_pcm
*snd_sof_find_spcm_dai(struct snd_soc_component
*scomp
,
172 struct snd_soc_pcm_runtime
*rtd
)
174 struct snd_sof_dev
*sdev
= snd_soc_component_get_drvdata(scomp
);
176 struct snd_sof_pcm
*spcm
= NULL
;
178 list_for_each_entry(spcm
, &sdev
->pcm_list
, list
) {
179 if (le32_to_cpu(spcm
->pcm
.dai_id
) == rtd
->dai_link
->id
)
186 struct snd_sof_pcm
*snd_sof_find_spcm_name(struct snd_soc_component
*scomp
,
188 struct snd_sof_pcm
*snd_sof_find_spcm_comp(struct snd_soc_component
*scomp
,
189 unsigned int comp_id
,
191 struct snd_sof_pcm
*snd_sof_find_spcm_pcm_id(struct snd_soc_component
*scomp
,
192 unsigned int pcm_id
);
193 void snd_sof_pcm_period_elapsed(struct snd_pcm_substream
*substream
);
194 void snd_sof_pcm_period_elapsed_work(struct work_struct
*work
);
199 int snd_sof_ipc_set_get_comp_data(struct snd_sof_control
*scontrol
,
201 enum sof_ipc_ctrl_type ctrl_type
,
202 enum sof_ipc_ctrl_cmd ctrl_cmd
,
206 int sof_restore_pipelines(struct device
*dev
);
207 int sof_set_hw_params_upon_resume(struct device
*dev
);
208 bool snd_sof_stream_suspend_ignored(struct snd_sof_dev
*sdev
);
209 bool snd_sof_dsp_only_d0i3_compatible_stream_active(struct snd_sof_dev
*sdev
);
211 /* Machine driver enumeration */
212 int sof_machine_register(struct snd_sof_dev
*sdev
, void *pdata
);
213 void sof_machine_unregister(struct snd_sof_dev
*sdev
, void *pdata
);