/Linux-v6.6/sound/soc/ |
D | soc-generic-dmaengine-pcm.c | 10 #include <sound/pcm.h> 28 static struct device *dmaengine_dma_dev(struct dmaengine_pcm *pcm, in dmaengine_dma_dev() argument 31 if (!pcm->chan[substream->stream]) in dmaengine_dma_dev() 34 return pcm->chan[substream->stream]->device->dev; in dmaengine_dma_dev() 39 * @substream: PCM substream 80 struct dmaengine_pcm *pcm = soc_component_to_pcm(component); in dmaengine_pcm_hw_params() local 85 if (!pcm->config->prepare_slave_config) in dmaengine_pcm_hw_params() 90 ret = pcm->config->prepare_slave_config(substream, params, &slave_config); in dmaengine_pcm_hw_params() 102 struct dmaengine_pcm *pcm = soc_component_to_pcm(component); in dmaengine_pcm_set_runtime_hwparams() local 103 struct device *dma_dev = dmaengine_dma_dev(pcm, substream); in dmaengine_pcm_set_runtime_hwparams() [all …]
|
/Linux-v6.6/sound/core/ |
D | pcm.c | 3 * Digital Audio (PCM) abstract layer 16 #include <sound/pcm.h> 24 MODULE_DESCRIPTION("Midlevel PCM code for ALSA."); 33 static int snd_pcm_free(struct snd_pcm *pcm); 40 struct snd_pcm *pcm; in snd_pcm_get() local 42 list_for_each_entry(pcm, &snd_pcm_devices, list) { in snd_pcm_get() 43 if (pcm->card == card && pcm->device == device) in snd_pcm_get() 44 return pcm; in snd_pcm_get() 51 struct snd_pcm *pcm; in snd_pcm_next() local 53 list_for_each_entry(pcm, &snd_pcm_devices, list) { in snd_pcm_next() [all …]
|
D | pcm_dmaengine.c | 7 * imx-pcm-dma-mx2.c, Copyright 2009 Sascha Hauer <s.hauer@pengutronix.de> 8 * mxs-pcm.c, Copyright (C) 2011 Freescale Semiconductor, Inc. 9 * ep93xx-pcm.c, Copyright (C) 2006 Lennert Buytenhek <buytenh@wantstofly.org> 16 #include <sound/pcm.h> 45 * @substream: PCM substream 50 * and hw_params in a dmaengine based PCM driver implementation. 92 * @substream: PCM substream 178 * snd_dmaengine_pcm_trigger - dmaengine based PCM trigger implementation 179 * @substream: PCM substream 182 * This function can be used as the PCM trigger callback for dmaengine based PCM [all …]
|
D | pcm_memory.c | 3 * Digital Audio (PCM) abstract layer 15 #include <sound/pcm.h> 22 MODULE_PARM_DESC(preallocate_dma, "Preallocate DMA memory when the PCM devices are initialized."); 107 struct snd_card *card = substream->pcm->card; in preallocate_pcm_pages() 122 substream->pcm->card->number, substream->pcm->device, in preallocate_pcm_pages() 124 substream->pcm->name, orig_size); in preallocate_pcm_pages() 130 * @substream: the pcm substream instance 136 do_free_pages(substream->pcm->card, &substream->dma_buffer); in snd_pcm_lib_preallocate_free() 140 * snd_pcm_lib_preallocate_free_for_all - release all pre-allocated buffers on the pcm 141 * @pcm: the pcm instance [all …]
|
/Linux-v6.6/sound/soc/samsung/ |
D | pcm.c | 3 // ALSA SoC Audio Layer - S3C PCM-Controller driver 20 #include "pcm.h" 106 * struct s3c_pcm_info - S3C PCM Controller information 112 * @pclk: the PCLK_PCM (pcm) clock pointer 154 static void s3c_pcm_snd_txctrl(struct s3c_pcm_info *pcm, int on) in s3c_pcm_snd_txctrl() argument 156 void __iomem *regs = pcm->regs; in s3c_pcm_snd_txctrl() 176 if (!pcm->idleclk) in s3c_pcm_snd_txctrl() 185 static void s3c_pcm_snd_rxctrl(struct s3c_pcm_info *pcm, int on) in s3c_pcm_snd_rxctrl() argument 187 void __iomem *regs = pcm->regs; in s3c_pcm_snd_rxctrl() 207 if (!pcm->idleclk) in s3c_pcm_snd_rxctrl() [all …]
|
/Linux-v6.6/Documentation/sound/designs/ |
D | oss-emulation.rst | 12 The OSS emulation for PCM, mixer and sequencer devices is implemented 13 as add-on kernel modules, snd-pcm-oss, snd-mixer-oss and snd-seq-oss. 14 When you need to access the OSS PCM, mixer or sequencer devices, the 48 PCM: 73 As seen above, PCM and MIDI may have two devices. Usually, the first 74 PCM device (``hw:0,0`` in ALSA) is mapped to /dev/dsp and the secondary 79 snd-pcm-oss and snd-rawmidi. In the case of PCM, the following 80 options are available for snd-pcm-oss: 83 PCM device number assigned to /dev/dspX 86 PCM device number assigned to /dev/adspX [all …]
|
D | tracepoints.rst | 8 Tracepoints in ALSA PCM core 11 ALSA PCM core registers ``snd_pcm`` subsystem to kernel tracepoint system. 12 This subsystem includes two categories of tracepoints; for state of PCM buffer 13 and for processing of PCM hardware parameters. These tracepoints are available 18 Tracepoints for state of PCM buffer 24 Tracepoints for processing of PCM hardware parameters 30 In a design of ALSA PCM core, data transmission is abstracted as PCM substream. 31 Applications manage PCM substream to maintain data transmission for PCM frames. 32 Before starting the data transmission, applications need to configure PCM 33 substream. In this procedure, PCM hardware parameters are decided by [all …]
|
D | procfile.rst | 42 pcm 43 Lists the currently available PCM devices in format of 66 When PCM devices are available on this card, you can see directories 67 like pcm0p or pcm1c. They hold the PCM information for each PCM 68 stream. The number after ``pcm`` is the PCM device number from 0, and 85 PCM Proc Files 88 ``card*/pcm*/info`` 89 The general information of this PCM device: card #, device #, 92 ``card*/pcm*/xrun_debug`` 96 invalid PCM position debug/check of ALSA PCM middle layer. [all …]
|
/Linux-v6.6/sound/pci/ac97/ |
D | ac97_pcm.c | 18 #include <sound/pcm.h> 26 * PCM support 144 static unsigned char get_slot_reg(struct ac97_pcm *pcm, unsigned short cidx, in get_slot_reg() argument 151 if (pcm->spdif) in get_slot_reg() 153 if (pcm->stream == SNDRV_PCM_STREAM_PLAYBACK) in get_slot_reg() 154 return rate_reg_tables[dbl][pcm->r[dbl].rate_table[cidx]][slot - 3]; in get_slot_reg() 393 static unsigned int get_rates(struct ac97_pcm *pcm, unsigned int cidx, unsigned short slots, int db… in get_rates() argument 402 reg = get_slot_reg(pcm, cidx, i, dbl); in get_rates() 411 rates &= pcm->r[dbl].codec[cidx]->rates[idx]; in get_rates() 420 * snd_ac97_pcm_assign - assign AC97 slots to given PCM streams [all …]
|
/Linux-v6.6/sound/soc/codecs/ |
D | hdac_hdmi.c | 147 struct hdac_hdmi_pcm *pcm; in hdac_hdmi_get_pcm_from_cvt() local 149 list_for_each_entry(pcm, &hdmi->pcm_list, head) { in hdac_hdmi_get_pcm_from_cvt() 150 if (pcm->cvt == cvt) in hdac_hdmi_get_pcm_from_cvt() 151 return pcm; in hdac_hdmi_get_pcm_from_cvt() 157 static void hdac_hdmi_jack_report(struct hdac_hdmi_pcm *pcm, in hdac_hdmi_jack_report() argument 166 * for the first time where same PCM is attached to multiple in hdac_hdmi_jack_report() 169 if (pcm->jack_event == 0) { in hdac_hdmi_jack_report() 171 "jack report for pcm=%d\n", in hdac_hdmi_jack_report() 172 pcm->pcm_id); in hdac_hdmi_jack_report() 173 snd_soc_jack_report(pcm->jack, SND_JACK_AVOUT, in hdac_hdmi_jack_report() [all …]
|
D | hda.c | 21 struct hda_pcm *pcm; in hda_codec_create_dais() local 28 pcm = list_first_entry(&codec->pcm_list_head, struct hda_pcm, list); in hda_codec_create_dais() 30 for (i = 0; i < pcm_count; i++, pcm = list_next_entry(pcm, list)) { in hda_codec_create_dais() 34 dev_info(dev, "creating for %s %d\n", pcm->name, i); in hda_codec_create_dais() 36 drvs[i].name = pcm->name; in hda_codec_create_dais() 41 if (!pcm->stream[dir].substreams) { in hda_codec_create_dais() 42 dev_info(dev, "skipping playback dai for %s\n", pcm->name); in hda_codec_create_dais() 47 devm_kasprintf(dev, GFP_KERNEL, "%s %s", pcm->name, in hda_codec_create_dais() 51 stream->channels_min = pcm->stream[dir].channels_min; in hda_codec_create_dais() 52 stream->channels_max = pcm->stream[dir].channels_max; in hda_codec_create_dais() [all …]
|
D | hda-dai.c | 16 struct hda_pcm *pcm; in hda_codec_dai_startup() local 21 pcm = container_of(stream_info, struct hda_pcm, stream[substream->stream]); in hda_codec_dai_startup() 23 dev_dbg(dai->dev, "open stream codec: %08x, info: %p, pcm: %p %s substream: %p\n", in hda_codec_dai_startup() 24 codec->core.vendor_id, stream_info, pcm, pcm->name, substream); in hda_codec_dai_startup() 26 snd_hda_codec_pcm_get(pcm); in hda_codec_dai_startup() 31 snd_hda_codec_pcm_put(pcm); in hda_codec_dai_startup() 42 struct hda_pcm *pcm; in hda_codec_dai_shutdown() local 47 pcm = container_of(stream_info, struct hda_pcm, stream[substream->stream]); in hda_codec_dai_shutdown() 49 dev_dbg(dai->dev, "close stream codec: %08x, info: %p, pcm: %p %s substream: %p\n", in hda_codec_dai_shutdown() 50 codec->core.vendor_id, stream_info, pcm, pcm->name, substream); in hda_codec_dai_shutdown() [all …]
|
/Linux-v6.6/sound/soc/sof/ |
D | ipc3-pcm.c | 49 struct sof_ipc_pcm_params pcm; in sof_ipc3_pcm_hw_params() local 57 memset(&pcm, 0, sizeof(pcm)); in sof_ipc3_pcm_hw_params() 60 pcm.params.buffer.pages = PFN_UP(runtime->dma_bytes); in sof_ipc3_pcm_hw_params() 62 /* set IPC PCM parameters */ in sof_ipc3_pcm_hw_params() 63 pcm.hdr.size = sizeof(pcm); in sof_ipc3_pcm_hw_params() 64 pcm.hdr.cmd = SOF_IPC_GLB_STREAM_MSG | SOF_IPC_STREAM_PCM_PARAMS; in sof_ipc3_pcm_hw_params() 65 pcm.comp_id = spcm->stream[substream->stream].comp_id; in sof_ipc3_pcm_hw_params() 66 pcm.params.hdr.size = sizeof(pcm.params); in sof_ipc3_pcm_hw_params() 67 pcm.params.buffer.phy_addr = spcm->stream[substream->stream].page_table.addr; in sof_ipc3_pcm_hw_params() 68 pcm.params.buffer.size = runtime->dma_bytes; in sof_ipc3_pcm_hw_params() [all …]
|
D | pcm.c | 10 // PCM Layer, interface between ALSA and IPC. 42 * sof pcm period elapse work 59 * sof pcm period elapse, this could be called at irq thread context. 78 * when the PCM is done draining or xrun happened, a STOP IPC will in snd_sof_pcm_period_elapsed() 111 dev_err(sdev->dev, "error: failed widget list set up for pcm %d dir %d\n", in sof_pcm_setup_connected_widgets() 112 spcm->pcm.pcm_id, dir); in sof_pcm_setup_connected_widgets() 128 const struct sof_ipc_pcm_ops *pcm_ops = sof_ipc_get_ops(sdev, pcm); in sof_pcm_hw_params() 154 dev_dbg(component->dev, "pcm: hw params stream %d dir %d\n", in sof_pcm_hw_params() 155 spcm->pcm.pcm_id, substream->stream); in sof_pcm_hw_params() 188 /* save pcm hw_params */ in sof_pcm_hw_params() [all …]
|
D | compress.c | 74 /* use the same workqueue-based solution as for PCM, cf. snd_sof_pcm_elapsed */ in snd_sof_compr_fragment_elapsed() 172 struct sof_ipc_pcm_params *pcm; in sof_compr_set_params() local 195 if (sizeof(*pcm) + ext_data_size > sdev->ipc->max_payload_size) in sof_compr_set_params() 198 pcm = kzalloc(sizeof(*pcm) + ext_data_size, GFP_KERNEL); in sof_compr_set_params() 199 if (!pcm) in sof_compr_set_params() 212 pcm->params.buffer.pages = PFN_UP(crtd->dma_bytes); in sof_compr_set_params() 213 pcm->hdr.size = sizeof(*pcm) + ext_data_size; in sof_compr_set_params() 214 pcm->hdr.cmd = SOF_IPC_GLB_STREAM_MSG | SOF_IPC_STREAM_PCM_PARAMS; in sof_compr_set_params() 216 pcm->comp_id = spcm->stream[cstream->direction].comp_id; in sof_compr_set_params() 217 pcm->params.hdr.size = sizeof(pcm->params) + ext_data_size; in sof_compr_set_params() [all …]
|
/Linux-v6.6/sound/soc/intel/boards/ |
D | skl_hda_dsp_common.c | 11 #include <sound/pcm.h> 25 struct skl_hda_hdmi_pcm *pcm; in skl_hda_hdmi_add_pcm() local 28 pcm = devm_kzalloc(card->dev, sizeof(*pcm), GFP_KERNEL); in skl_hda_hdmi_add_pcm() 29 if (!pcm) in skl_hda_hdmi_add_pcm() 34 pcm->codec_dai = snd_soc_card_get_codec_dai(card, dai_name); in skl_hda_hdmi_add_pcm() 35 if (!pcm->codec_dai) in skl_hda_hdmi_add_pcm() 38 pcm->device = device; in skl_hda_hdmi_add_pcm() 39 list_add_tail(&pcm->head, &ctx->hdmi_pcm_list); in skl_hda_hdmi_add_pcm() 141 struct skl_hda_hdmi_pcm *pcm; in skl_hda_hdmi_jack_init() local 148 list_for_each_entry(pcm, &ctx->hdmi_pcm_list, head) { in skl_hda_hdmi_jack_init() [all …]
|
D | sof_sdw_hdmi.c | 28 struct hdmi_pcm *pcm; in sof_sdw_hdmi_init() local 30 pcm = devm_kzalloc(rtd->card->dev, sizeof(*pcm), GFP_KERNEL); in sof_sdw_hdmi_init() 31 if (!pcm) in sof_sdw_hdmi_init() 34 /* dai_link id is 1:1 mapped to the PCM device */ in sof_sdw_hdmi_init() 35 pcm->device = rtd->dai_link->id; in sof_sdw_hdmi_init() 36 pcm->codec_dai = dai; in sof_sdw_hdmi_init() 38 list_add_tail(&pcm->head, &ctx->hdmi_pcm_list); in sof_sdw_hdmi_init() 47 struct hdmi_pcm *pcm; in sof_sdw_hdmi_card_late_probe() local 56 pcm = list_first_entry(&ctx->hdmi_pcm_list, struct hdmi_pcm, in sof_sdw_hdmi_card_late_probe() 58 component = pcm->codec_dai->component; in sof_sdw_hdmi_card_late_probe()
|
/Linux-v6.6/Documentation/sound/cards/ |
D | sb-live-mixer.rst | 15 IEC958 (S/PDIF) raw PCM 18 This PCM device (it's the 3rd PCM device (index 2!) and first subdevice 22 to 8 raw PCM devices operating at 48kHz, 16-bit little endian. It would 64 This control is used to attenuate samples from left and right PCM FX-bus 65 accumulators. ALSA uses accumulators 0 and 1 for left and right PCM samples. 66 The result samples are forwarded to the front DAC PCM slots of the AC97 codec. 70 This control is used to attenuate samples from left and right PCM FX-bus 71 accumulators. ALSA uses accumulators 0 and 1 for left and right PCM samples. 77 This control is used to attenuate samples from left and right PCM FX-bus 78 accumulators. ALSA uses accumulators 0 and 1 for left and right PCM samples. [all …]
|
/Linux-v6.6/sound/pci/lola/ |
D | lola_pcm.c | 14 #include <sound/pcm.h> 24 return &chip->pcm[substream->stream]; in lola_get_pcm() 29 struct lola_pcm *pcm = lola_get_pcm(substream); in lola_get_stream() local 31 return &pcm->streams[idx]; in lola_get_stream() 128 if (s->pcm->card != substream->pcm->card) in lola_sync_wait_for_fifo() 159 if (s->pcm->card != substream->pcm->card) in lola_sync_pause() 213 struct lola_pcm *pcm = lola_get_pcm(substream); in lola_pcm_open() local 226 runtime->hw.channels_max = pcm->num_streams - str->index; in lola_pcm_open() 246 static void lola_cleanup_slave_streams(struct lola_pcm *pcm, in lola_cleanup_slave_streams() argument 250 for (i = str->index + 1; i < pcm->num_streams; i++) { in lola_cleanup_slave_streams() [all …]
|
/Linux-v6.6/sound/pci/au88x0/ |
D | au88x0_pcm.c | 6 * Vortex PCM ALSA driver. 14 #include <sound/pcm.h> 146 if (VORTEX_PCM_TYPE(substream->pcm) != VORTEX_PCM_WT) { in snd_vortex_pcm_open() 148 if (VORTEX_PCM_TYPE(substream->pcm) == VORTEX_PCM_A3D) { in snd_vortex_pcm_open() 152 if (VORTEX_PCM_TYPE(substream->pcm) == VORTEX_PCM_SPDIF) { in snd_vortex_pcm_open() 166 if (VORTEX_PCM_TYPE(substream->pcm) == VORTEX_PCM_ADB in snd_vortex_pcm_open() 167 || VORTEX_PCM_TYPE(substream->pcm) == VORTEX_PCM_I2S) in snd_vortex_pcm_open() 172 VORTEX_PCM_TYPE(substream->pcm) == VORTEX_PCM_ADB) { in snd_vortex_pcm_open() 219 if (VORTEX_PCM_TYPE(substream->pcm) != VORTEX_PCM_WT) { in snd_vortex_pcm_hw_params() 220 int dma, type = VORTEX_PCM_TYPE(substream->pcm); in snd_vortex_pcm_hw_params() [all …]
|
/Linux-v6.6/include/sound/ |
D | pcm.h | 6 * Digital Audio (PCM) abstract layer 22 #define snd_pcm_chip(pcm) ((pcm)->private_data) argument 448 struct snd_pcm *pcm; member 450 void *private_data; /* copied from pcm->private_data */ 495 struct snd_pcm *pcm; member 527 void (*private_free) (struct snd_pcm *pcm); 528 bool internal; /* pcm is for internal use only */ 529 bool nonatomic; /* whole PCM operations are in non-atomic context */ 548 int snd_pcm_new_stream(struct snd_pcm *pcm, int stream, int substream_count); 552 int (*n_register) (struct snd_pcm * pcm); [all …]
|
/Linux-v6.6/sound/pci/emu10k1/ |
D | emupcm.c | 9 * Routines for control of EMU10K1 chips / PCM routines 1434 struct snd_pcm *pcm; in snd_emu10k1_pcm() local 1438 err = snd_pcm_new(emu->card, "emu10k1", device, 32, 1, &pcm); in snd_emu10k1_pcm() 1442 pcm->private_data = emu; in snd_emu10k1_pcm() 1444 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &snd_emu10k1_playback_ops); in snd_emu10k1_pcm() 1445 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &snd_emu10k1_capture_ops); in snd_emu10k1_pcm() 1447 pcm->info_flags = 0; in snd_emu10k1_pcm() 1448 pcm->dev_subclass = SNDRV_PCM_SUBCLASS_GENERIC_MIX; in snd_emu10k1_pcm() 1449 strcpy(pcm->name, "ADC Capture/Standard PCM Playback"); in snd_emu10k1_pcm() 1450 emu->pcm = pcm; in snd_emu10k1_pcm() [all …]
|
/Linux-v6.6/sound/soc/mediatek/mt8183/ |
D | mt8183-dai-pcm.c | 155 {"PCM 1 Playback", NULL, "PCM_1_PB_CH1"}, 156 {"PCM 1 Playback", NULL, "PCM_1_PB_CH2"}, 157 {"PCM 1 Playback", NULL, "PCM_1_PB_CH4"}, 158 {"PCM 2 Playback", NULL, "PCM_2_PB_CH1"}, 159 {"PCM 2 Playback", NULL, "PCM_2_PB_CH2"}, 160 {"PCM 2 Playback", NULL, "PCM_2_PB_CH4"}, 162 {"PCM 1 Playback", NULL, "PCM_1_EN"}, 163 {"PCM 2 Playback", NULL, "PCM_2_EN"}, 164 {"PCM 1 Capture", NULL, "PCM_1_EN"}, 165 {"PCM 2 Capture", NULL, "PCM_2_EN"}, [all …]
|
/Linux-v6.6/sound/soc/mediatek/mt6797/ |
D | mt6797-dai-pcm.c | 155 {"PCM 1 Playback", NULL, "PCM_1_PB_CH1"}, 156 {"PCM 1 Playback", NULL, "PCM_1_PB_CH2"}, 157 {"PCM 1 Playback", NULL, "PCM_1_PB_CH4"}, 158 {"PCM 2 Playback", NULL, "PCM_2_PB_CH1"}, 159 {"PCM 2 Playback", NULL, "PCM_2_PB_CH2"}, 160 {"PCM 2 Playback", NULL, "PCM_2_PB_CH4"}, 162 {"PCM 1 Playback", NULL, "PCM_1_EN"}, 163 {"PCM 2 Playback", NULL, "PCM_2_EN"}, 164 {"PCM 1 Capture", NULL, "PCM_1_EN"}, 165 {"PCM 2 Capture", NULL, "PCM_2_EN"}, [all …]
|
/Linux-v6.6/sound/pci/ctxfi/ |
D | ctpcm.c | 8 * This file contains the definition of the pcm device functions. 17 #include <sound/pcm.h> 114 /* pcm playback operations */ 128 if (IEC958 == substream->pcm->device) { in ct_pcm_playback_open() 133 if (FRONT == substream->pcm->device) in ct_pcm_playback_open() 168 if (IEC958 == substream->pcm->device) in ct_pcm_playback_close() 205 if (IEC958 == substream->pcm->device) in ct_pcm_playback_prepare() 212 "Preparing pcm playback failed!!!\n"); in ct_pcm_playback_prepare() 260 /* pcm capture operations */ 321 "Preparing pcm capture failed!!!\n"); in ct_pcm_capture_prepare() [all …]
|