/* * ads117x.c -- Driver for ads1174/8 ADC chips * * Copyright 2009 ShotSpotter Inc. * Author: Graeme Gregory * * 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 #include #include #include #include #include #include #include #include #include #define ADS117X_RATES (SNDRV_PCM_RATE_8000_48000) #define ADS117X_FORMATS (SNDRV_PCM_FMTBIT_S16_LE) static const struct snd_soc_dapm_widget ads117x_dapm_widgets[] = { SND_SOC_DAPM_INPUT("Input1"), SND_SOC_DAPM_INPUT("Input2"), SND_SOC_DAPM_INPUT("Input3"), SND_SOC_DAPM_INPUT("Input4"), SND_SOC_DAPM_INPUT("Input5"), SND_SOC_DAPM_INPUT("Input6"), SND_SOC_DAPM_INPUT("Input7"), SND_SOC_DAPM_INPUT("Input8"), }; static const struct snd_soc_dapm_route ads117x_dapm_routes[] = { { "Capture", NULL, "Input1" }, { "Capture", NULL, "Input2" }, { "Capture", NULL, "Input3" }, { "Capture", NULL, "Input4" }, { "Capture", NULL, "Input5" }, { "Capture", NULL, "Input6" }, { "Capture", NULL, "Input7" }, { "Capture", NULL, "Input8" }, }; static struct snd_soc_dai_driver ads117x_dai = { /* ADC */ .name = "ads117x-hifi", .capture = { .stream_name = "Capture", .channels_min = 1, .channels_max = 32, .rates = ADS117X_RATES, .formats = ADS117X_FORMATS,}, }; static struct snd_soc_codec_driver soc_codec_dev_ads117x = { .component_driver = { .dapm_widgets = ads117x_dapm_widgets, .num_dapm_widgets = ARRAY_SIZE(ads117x_dapm_widgets), .dapm_routes = ads117x_dapm_routes, .num_dapm_routes = ARRAY_SIZE(ads117x_dapm_routes), }, }; static int ads117x_probe(struct platform_device *pdev) { return snd_soc_register_codec(&pdev->dev, &soc_codec_dev_ads117x, &ads117x_dai, 1); } static int ads117x_remove(struct platform_device *pdev) { snd_soc_unregister_codec(&pdev->dev); return 0; } #if defined(CONFIG_OF) static const struct of_device_id ads117x_dt_ids[] = { { .compatible = "ti,ads1174" }, { .compatible = "ti,ads1178" }, { }, }; MODULE_DEVICE_TABLE(of, ads117x_dt_ids); #endif static struct platform_driver ads117x_codec_driver = { .driver = { .name = "ads117x-codec", .of_match_table = of_match_ptr(ads117x_dt_ids), }, .probe = ads117x_probe, .remove = ads117x_remove, }; module_platform_driver(ads117x_codec_driver); MODULE_DESCRIPTION("ASoC ads117x driver"); MODULE_AUTHOR("Graeme Gregory"); MODULE_LICENSE("GPL"); '>committer
diff options
context:
space:
mode:
authorHelge Deller <deller@gmx.de>2017-01-28 11:52:02 +0100
committerHelge Deller <deller@gmx.de>2017-01-28 21:54:23 +0100
commit2ad5d52d42810bed95100a3d912679d8864421ec (patch)
tree7f93e2f906b1c86f5b76c0f4c0978d41a8a29861 /drivers/usb/misc/idmouse.c
parent83b5d1e3d3013dbf90645a5d07179d018c8243fa (diff)
parisc: Don't use BITS_PER_LONG in userspace-exported swab.h header
In swab.h the "#if BITS_PER_LONG > 32" breaks compiling userspace programs if BITS_PER_LONG is #defined by userspace with the sizeof() compiler builtin. Solve this problem by using __BITS_PER_LONG instead. Since we now #include asm/bitsperlong.h avoid further potential userspace pollution by moving the #define of SHIFT_PER_LONG to bitops.h which is not exported to userspace. This patch unbreaks compiling qemu on hppa/parisc. Signed-off-by: Helge Deller <deller@gmx.de> Cc: <stable@vger.kernel.org>
Diffstat (limited to 'drivers/usb/misc/idmouse.c')