cregit-Linux how code gets into the kernel

Release 4.13 sound/soc/soc-utils.c

Directory: sound/soc
/*
 * soc-util.c  --  ALSA SoC Audio Layer utility functions
 *
 * Copyright 2009 Wolfson Microelectronics PLC.
 *
 * Author: Mark Brown <broonie@opensource.wolfsonmicro.com>
 *         Liam Girdwood <lrg@slimlogic.co.uk>
 *         
 *
 *  This program is free software; you can redistribute  it and/or modify it
 *  under  the terms of  the GNU General  Public License as published by the
 *  Free Software Foundation;  either version 2 of the  License, or (at your
 *  option) any later version.
 */

#include <linux/platform_device.h>
#include <linux/export.h>
#include <sound/core.h>
#include <sound/pcm.h>
#include <sound/pcm_params.h>
#include <sound/soc.h>


int snd_soc_calc_frame_size(int sample_size, int channels, int tdm_slots) { return sample_size * channels * tdm_slots; }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown21100.00%1100.00%
Total21100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_calc_frame_size);
int snd_soc_params_to_frame_size(struct snd_pcm_hw_params *params) { int sample_size; sample_size = snd_pcm_format_width(params_format(params)); if (sample_size < 0) return sample_size; return snd_soc_calc_frame_size(sample_size, params_channels(params), 1); }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown45100.00%2100.00%
Total45100.00%2100.00%

EXPORT_SYMBOL_GPL(snd_soc_params_to_frame_size);
int snd_soc_calc_bclk(int fs, int sample_size, int channels, int tdm_slots) { return fs * snd_soc_calc_frame_size(sample_size, channels, tdm_slots); }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown29100.00%1100.00%
Total29100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_calc_bclk);
int snd_soc_params_to_bclk(struct snd_pcm_hw_params *params) { int ret; ret = snd_soc_params_to_frame_size(params); if (ret > 0) return ret * params_rate(params); else return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown38100.00%1100.00%
Total38100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_params_to_bclk);
int snd_soc_component_enable_pin(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_enable_pin(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_enable_pin(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_enable_pin);
int snd_soc_component_enable_pin_unlocked(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_enable_pin_unlocked(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_enable_pin_unlocked(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_enable_pin_unlocked);
int snd_soc_component_disable_pin(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_disable_pin(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_disable_pin(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_disable_pin);
int snd_soc_component_disable_pin_unlocked(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_disable_pin_unlocked(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_disable_pin_unlocked(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_disable_pin_unlocked);
int snd_soc_component_nc_pin(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_nc_pin(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_nc_pin(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_nc_pin);
int snd_soc_component_nc_pin_unlocked(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_nc_pin_unlocked(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_nc_pin_unlocked(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_nc_pin_unlocked);
int snd_soc_component_get_pin_status(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_get_pin_status(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_get_pin_status(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_get_pin_status);
int snd_soc_component_force_enable_pin(struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_force_enable_pin(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_force_enable_pin(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_force_enable_pin);
int snd_soc_component_force_enable_pin_unlocked( struct snd_soc_component *component, const char *pin) { struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component); char *full_name; int ret; if (!component->name_prefix) return snd_soc_dapm_force_enable_pin_unlocked(dapm, pin); full_name = kasprintf(GFP_KERNEL, "%s %s", component->name_prefix, pin); if (!full_name) return -ENOMEM; ret = snd_soc_dapm_force_enable_pin_unlocked(dapm, full_name); kfree(full_name); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald88100.00%1100.00%
Total88100.00%1100.00%

EXPORT_SYMBOL_GPL(snd_soc_component_force_enable_pin_unlocked); static const struct snd_pcm_hardware dummy_dma_hardware = { /* Random values to keep userspace happy when checking constraints */ .info = SNDRV_PCM_INFO_INTERLEAVED | SNDRV_PCM_INFO_BLOCK_TRANSFER, .buffer_bytes_max = 128*1024, .period_bytes_min = PAGE_SIZE, .period_bytes_max = PAGE_SIZE*2, .periods_min = 2, .periods_max = 128, };
static int dummy_dma_open(struct snd_pcm_substream *substream) { struct snd_soc_pcm_runtime *rtd = substream->private_data; /* BE's dont need dummy params */ if (!rtd->dai_link->no_pcm) snd_soc_set_runtime_hwparams(substream, &dummy_dma_hardware); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown2253.66%150.00%
Liam Girdwood1946.34%150.00%
Total41100.00%2100.00%

static const struct snd_pcm_ops dummy_dma_ops = { .open = dummy_dma_open, .ioctl = snd_pcm_lib_ioctl, }; static struct snd_soc_platform_driver dummy_platform = { .ops = &dummy_dma_ops, }; static struct snd_soc_codec_driver dummy_codec; #define STUB_RATES SNDRV_PCM_RATE_8000_192000 #define STUB_FORMATS (SNDRV_PCM_FMTBIT_S8 | \ SNDRV_PCM_FMTBIT_U8 | \ SNDRV_PCM_FMTBIT_S16_LE | \ SNDRV_PCM_FMTBIT_U16_LE | \ SNDRV_PCM_FMTBIT_S24_LE | \ SNDRV_PCM_FMTBIT_U24_LE | \ SNDRV_PCM_FMTBIT_S32_LE | \ SNDRV_PCM_FMTBIT_U32_LE | \ SNDRV_PCM_FMTBIT_IEC958_SUBFRAME_LE) /* * The dummy CODEC is only meant to be used in situations where there is no * actual hardware. * * If there is actual hardware even if it does not have a control bus * the hardware will still have constraints like supported samplerates, etc. * which should be modelled. And the data flow graph also should be modelled * using DAPM. */ static struct snd_soc_dai_driver dummy_dai = { .name = "snd-soc-dummy-dai", .playback = { .stream_name = "Playback", .channels_min = 1, .channels_max = 384, .rates = STUB_RATES, .formats = STUB_FORMATS, }, .capture = { .stream_name = "Capture", .channels_min = 1, .channels_max = 384, .rates = STUB_RATES, .formats = STUB_FORMATS, }, };
int snd_soc_dai_is_dummy(struct snd_soc_dai *dai) { if (dai->driver == &dummy_dai) return 1; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Liam Girdwood25100.00%1100.00%
Total25100.00%1100.00%


static int snd_soc_dummy_probe(struct platform_device *pdev) { int ret; ret = snd_soc_register_codec(&pdev->dev, &dummy_codec, &dummy_dai, 1); if (ret < 0) return ret; ret = snd_soc_register_platform(&pdev->dev, &dummy_platform); if (ret < 0) { snd_soc_unregister_codec(&pdev->dev); return ret; } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Liam Girdwood5369.74%150.00%
Mark Brown2330.26%150.00%
Total76100.00%2100.00%


static int snd_soc_dummy_remove(struct platform_device *pdev) { snd_soc_unregister_platform(&pdev->dev); snd_soc_unregister_codec(&pdev->dev); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown2273.33%150.00%
Liam Girdwood826.67%150.00%
Total30100.00%2100.00%

static struct platform_driver soc_dummy_driver = { .driver = { .name = "snd-soc-dummy", }, .probe = snd_soc_dummy_probe, .remove = snd_soc_dummy_remove, }; static struct platform_device *soc_dummy_dev;
int __init snd_soc_util_init(void) { int ret; soc_dummy_dev = platform_device_register_simple("snd-soc-dummy", -1, NULL, 0); if (IS_ERR(soc_dummy_dev)) return PTR_ERR(soc_dummy_dev); ret = platform_driver_register(&soc_dummy_driver); if (ret != 0) platform_device_unregister(soc_dummy_dev); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown5286.67%150.00%
Uwe Kleine-König813.33%150.00%
Total60100.00%2100.00%


void __exit snd_soc_util_exit(void) { platform_device_unregister(soc_dummy_dev); platform_driver_unregister(&soc_dummy_driver); }

Contributors

PersonTokensPropCommitsCommitProp
Mark Brown19100.00%1100.00%
Total19100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Richard Fitzgerald83757.53%17.14%
Mark Brown41528.52%535.71%
Liam Girdwood1228.38%321.43%
Stas Sergeev684.67%17.14%
Uwe Kleine-König80.55%17.14%
Paul Gortmaker30.21%17.14%
Anatol Pomozov10.07%17.14%
Julia Lawall10.07%17.14%
Total1455100.00%14100.00%
Directory: sound/soc
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.