9992ba7232
Mostly many small changes spread as seen in diffstat in sound/* directory by this update. A significant change in the subsystem level is the introduction of snd_soc_component, which will help more generic handling of SoC and off-SoC components. Also, snd_BUG_ON() macro is enabled unconditionally now due to its misuses, so people might hit kernel warnings (it's a good thing for us). - compress-offload: support for capture by Charles Keepax - HD-audio: codec delay support by Dylan Reid - HD-audio: improvements/fixes in generic parser: better headphone mic and headset mic support, jack_modes hint consolidation, proper beep attach/detachment, generalized power filter controls by David Henningsson, et al - HD-audio: Improved management of HDMI codec pins/converters - HD-audio: Better pin/DAC assignment for VIA codecs - HD-audio: Haswell HDMI workarounds - HD-audio: ALC268 codec support, a few new quirks for Chromebooks - USB: regression fixes: USB-MIDI autopm fix, the recent ISO latency fix by Clemens Ladisch - USB: support for DSD formats by Daniel Mack - USB: A few UAC2 device endian/cock fixes by Eldad Zack - USB: quirks for Emu 192kHz support, Novation Twitch DJ controller, Yamaha THRxx devices - HDSPM: updates for TCO controls by Adrian Knoth - ASoC: Add a snd_soc_component object type for generic handling of SoC and off-SoC components by Kuninori Morimoto, - dmaengine: a large set of cleanups and conversions by Lars-Peter Clausen - ASoC DAPM: performance optimizations from Ryo Tsutsui - ASoC DAPM: support for mixer control sharing by Stephen Warren - ASoC: multiplatform ARM cleanups from Arnd Bergmann - ASoC: new codec drivers for AK5385 and TAS5086 from Daniel Mack -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.19 (GNU/Linux) iQIcBAABAgAGBQJRg2bUAAoJEGwxgFQ9KSmksasQAIq1ypbylrLA3vf7PUXmL7Jb hMtC5tzasZqJsIZ2fyhiZL8J5yQ78Z5dhjehFWlCbJEaKhsjZVyb67RpuK597b6K Ypa30OghbWuCoKjmaXK9AFTuijTxdefmewIJfgwVMYtgA5rBU70qt96NC/b/UQXk gEPI740i7EFJL2wfcqRpGoKGO1o80yMuKzIj3gHUZMFHYYhPgvVuGt9cCe3cXwLV IBT77PjMoGt1Q7iJQkX4DGlB5n526l1G8a6VptdCou0qyEWfhgSik5I3msNuAXte 1KYE4zj0Rq4xqN28/D/eAF1o3q+X9aiLttGpG0sJLiwGagdWVFaXLyJDMhZxCbwz 1F4k+B8UCucojw3HtNzoIQJezoRX2aHMjlAZ50b416hITkg5VQe5+sJBxpjIJo4I GSmizUiNahDk9jtI/PEGo7yr8CdRTY3v38mdZRGYxyWgJ1a8sNwQwqUdH6A0D/w6 3wMp4Y9Zt8AK/kiWLLWvsDVvwRptqplrXistTvv4v2xVJgvU+klDsDpa5Lz7kG7Z q43RA4o+yWdG6d1hTgMXp7FGwUkcer7WKWEmAZsQmX03Q0zjZqMhfUwVUtaHIx9c 6YipHdVMAJ0sz/dYrKnZ92hbZcXNj/A9zfqYWeFlA/18FCO6u4BXODBup8BLwyUm hfOv+M/q6haNA98GDHS9 =sYiI -----END PGP SIGNATURE----- Merge tag 'sound-3.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound Pull sound updates from Takashi Iwai: "Mostly many small changes spread as seen in diffstat in sound/* directory by this update. A significant change in the subsystem level is the introduction of snd_soc_component, which will help more generic handling of SoC and off-SoC components. Also, snd_BUG_ON() macro is enabled unconditionally now due to its misuses, so people might hit kernel warnings (it's a good thing for us). - compress-offload: support for capture by Charles Keepax - HD-audio: codec delay support by Dylan Reid - HD-audio: improvements/fixes in generic parser: better headphone mic and headset mic support, jack_modes hint consolidation, proper beep attach/detachment, generalized power filter controls by David Henningsson, et al - HD-audio: Improved management of HDMI codec pins/converters - HD-audio: Better pin/DAC assignment for VIA codecs - HD-audio: Haswell HDMI workarounds - HD-audio: ALC268 codec support, a few new quirks for Chromebooks - USB: regression fixes: USB-MIDI autopm fix, the recent ISO latency fix by Clemens Ladisch - USB: support for DSD formats by Daniel Mack - USB: A few UAC2 device endian/cock fixes by Eldad Zack - USB: quirks for Emu 192kHz support, Novation Twitch DJ controller, Yamaha THRxx devices - HDSPM: updates for TCO controls by Adrian Knoth - ASoC: Add a snd_soc_component object type for generic handling of SoC and off-SoC components by Kuninori Morimoto, - dmaengine: a large set of cleanups and conversions by Lars-Peter Clausen - ASoC DAPM: performance optimizations from Ryo Tsutsui - ASoC DAPM: support for mixer control sharing by Stephen Warren - ASoC: multiplatform ARM cleanups from Arnd Bergmann - ASoC: new codec drivers for AK5385 and TAS5086 from Daniel Mack" * tag 'sound-3.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (315 commits) ALSA: usb-audio: caiaq: fix endianness bug in snd_usb_caiaq_maschine_dispatch ALSA: asihpi: add format support check in snd_card_asihpi_capture_formats ALSA: pcm_format_to_bits strong-typed conversion ALSA: compress: fix the states to check for allowing read ALSA: hda - Move Thinkpad X220 to use auto parser ALSA: USB: adjust for changed 3.8 USB API ALSA: usb - Avoid unnecessary sample rate changes on USB 2.0 clock sources sound: oss/dmabuf: use dma_map_single ALSA: ali5451: use mdelay instead of large udelay constants ALSA: hda - Add the support for ALC286 codec ALSA: usb-audio: USB quirk for Yamaha THR10C ALSA: usb-audio: USB quirk for Yamaha THR5A ALSA: usb-audio: USB quirk for Yamaha THR10 ALSA: usb-audio: Fix autopm error during probing ALSA: snd-usb: try harder to find USB_DT_CS_ENDPOINT ALSA: sound kconfig typo ALSA: emu10k1: Fix dock firmware loading ASoC: ux500: forward declare msp_i2s_platform_data ASoC: davinci-mcasp: Add Support BCLK-to-LRCLK ratio for TDM modes ASoC: davinci-pcm, davinci-mcasp: Clean up active_serializers ...
193 lines
4.7 KiB
C
193 lines
4.7 KiB
C
/* linux/arch/arm/mach-s3c2440/dma.c
|
|
*
|
|
* Copyright (c) 2006 Simtec Electronics
|
|
* Ben Dooks <ben@simtec.co.uk>
|
|
*
|
|
* S3C2440 DMA selection
|
|
*
|
|
* http://armlinux.simtec.co.uk/
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/init.h>
|
|
#include <linux/device.h>
|
|
#include <linux/serial_core.h>
|
|
|
|
#include <mach/map.h>
|
|
#include <mach/dma.h>
|
|
|
|
#include <plat/dma-s3c24xx.h>
|
|
#include <plat/cpu.h>
|
|
|
|
#include <plat/regs-serial.h>
|
|
#include <mach/regs-gpio.h>
|
|
#include <plat/regs-dma.h>
|
|
#include <mach/regs-lcd.h>
|
|
#include <plat/regs-spi.h>
|
|
|
|
static struct s3c24xx_dma_map __initdata s3c2440_dma_mappings[] = {
|
|
[DMACH_XD0] = {
|
|
.name = "xdreq0",
|
|
.channels[0] = S3C2410_DCON_CH0_XDREQ0 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_XD1] = {
|
|
.name = "xdreq1",
|
|
.channels[1] = S3C2410_DCON_CH1_XDREQ1 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_SDI] = {
|
|
.name = "sdi",
|
|
.channels[0] = S3C2410_DCON_CH0_SDI | DMA_CH_VALID,
|
|
.channels[1] = S3C2440_DCON_CH1_SDI | DMA_CH_VALID,
|
|
.channels[2] = S3C2410_DCON_CH2_SDI | DMA_CH_VALID,
|
|
.channels[3] = S3C2410_DCON_CH3_SDI | DMA_CH_VALID,
|
|
},
|
|
[DMACH_SPI0] = {
|
|
.name = "spi0",
|
|
.channels[1] = S3C2410_DCON_CH1_SPI | DMA_CH_VALID,
|
|
},
|
|
[DMACH_SPI1] = {
|
|
.name = "spi1",
|
|
.channels[3] = S3C2410_DCON_CH3_SPI | DMA_CH_VALID,
|
|
},
|
|
[DMACH_UART0] = {
|
|
.name = "uart0",
|
|
.channels[0] = S3C2410_DCON_CH0_UART0 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_UART1] = {
|
|
.name = "uart1",
|
|
.channels[1] = S3C2410_DCON_CH1_UART1 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_UART2] = {
|
|
.name = "uart2",
|
|
.channels[3] = S3C2410_DCON_CH3_UART2 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_TIMER] = {
|
|
.name = "timer",
|
|
.channels[0] = S3C2410_DCON_CH0_TIMER | DMA_CH_VALID,
|
|
.channels[2] = S3C2410_DCON_CH2_TIMER | DMA_CH_VALID,
|
|
.channels[3] = S3C2410_DCON_CH3_TIMER | DMA_CH_VALID,
|
|
},
|
|
[DMACH_I2S_IN] = {
|
|
.name = "i2s-sdi",
|
|
.channels[1] = S3C2410_DCON_CH1_I2SSDI | DMA_CH_VALID,
|
|
.channels[2] = S3C2410_DCON_CH2_I2SSDI | DMA_CH_VALID,
|
|
},
|
|
[DMACH_I2S_OUT] = {
|
|
.name = "i2s-sdo",
|
|
.channels[0] = S3C2440_DCON_CH0_I2SSDO | DMA_CH_VALID,
|
|
.channels[2] = S3C2410_DCON_CH2_I2SSDO | DMA_CH_VALID,
|
|
},
|
|
[DMACH_PCM_IN] = {
|
|
.name = "pcm-in",
|
|
.channels[0] = S3C2440_DCON_CH0_PCMIN | DMA_CH_VALID,
|
|
.channels[2] = S3C2440_DCON_CH2_PCMIN | DMA_CH_VALID,
|
|
},
|
|
[DMACH_PCM_OUT] = {
|
|
.name = "pcm-out",
|
|
.channels[1] = S3C2440_DCON_CH1_PCMOUT | DMA_CH_VALID,
|
|
.channels[3] = S3C2440_DCON_CH3_PCMOUT | DMA_CH_VALID,
|
|
},
|
|
[DMACH_MIC_IN] = {
|
|
.name = "mic-in",
|
|
.channels[2] = S3C2440_DCON_CH2_MICIN | DMA_CH_VALID,
|
|
.channels[3] = S3C2440_DCON_CH3_MICIN | DMA_CH_VALID,
|
|
},
|
|
[DMACH_USB_EP1] = {
|
|
.name = "usb-ep1",
|
|
.channels[0] = S3C2410_DCON_CH0_USBEP1 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_USB_EP2] = {
|
|
.name = "usb-ep2",
|
|
.channels[1] = S3C2410_DCON_CH1_USBEP2 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_USB_EP3] = {
|
|
.name = "usb-ep3",
|
|
.channels[2] = S3C2410_DCON_CH2_USBEP3 | DMA_CH_VALID,
|
|
},
|
|
[DMACH_USB_EP4] = {
|
|
.name = "usb-ep4",
|
|
.channels[3] = S3C2410_DCON_CH3_USBEP4 | DMA_CH_VALID,
|
|
},
|
|
};
|
|
|
|
static void s3c2440_dma_select(struct s3c2410_dma_chan *chan,
|
|
struct s3c24xx_dma_map *map)
|
|
{
|
|
chan->dcon = map->channels[chan->number] & ~DMA_CH_VALID;
|
|
}
|
|
|
|
static struct s3c24xx_dma_selection __initdata s3c2440_dma_sel = {
|
|
.select = s3c2440_dma_select,
|
|
.dcon_mask = 7 << 24,
|
|
.map = s3c2440_dma_mappings,
|
|
.map_size = ARRAY_SIZE(s3c2440_dma_mappings),
|
|
};
|
|
|
|
static struct s3c24xx_dma_order __initdata s3c2440_dma_order = {
|
|
.channels = {
|
|
[DMACH_SDI] = {
|
|
.list = {
|
|
[0] = 3 | DMA_CH_VALID,
|
|
[1] = 2 | DMA_CH_VALID,
|
|
[2] = 1 | DMA_CH_VALID,
|
|
[3] = 0 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
[DMACH_I2S_IN] = {
|
|
.list = {
|
|
[0] = 1 | DMA_CH_VALID,
|
|
[1] = 2 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
[DMACH_I2S_OUT] = {
|
|
.list = {
|
|
[0] = 2 | DMA_CH_VALID,
|
|
[1] = 1 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
[DMACH_PCM_IN] = {
|
|
.list = {
|
|
[0] = 2 | DMA_CH_VALID,
|
|
[1] = 1 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
[DMACH_PCM_OUT] = {
|
|
.list = {
|
|
[0] = 1 | DMA_CH_VALID,
|
|
[1] = 3 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
[DMACH_MIC_IN] = {
|
|
.list = {
|
|
[0] = 3 | DMA_CH_VALID,
|
|
[1] = 2 | DMA_CH_VALID,
|
|
},
|
|
},
|
|
},
|
|
};
|
|
|
|
static int __init s3c2440_dma_add(struct device *dev,
|
|
struct subsys_interface *sif)
|
|
{
|
|
s3c2410_dma_init();
|
|
s3c24xx_dma_order_set(&s3c2440_dma_order);
|
|
return s3c24xx_dma_init_map(&s3c2440_dma_sel);
|
|
}
|
|
|
|
static struct subsys_interface s3c2440_dma_interface = {
|
|
.name = "s3c2440_dma",
|
|
.subsys = &s3c2440_subsys,
|
|
.add_dev = s3c2440_dma_add,
|
|
};
|
|
|
|
static int __init s3c2440_dma_init(void)
|
|
{
|
|
return subsys_interface_register(&s3c2440_dma_interface);
|
|
}
|
|
|
|
arch_initcall(s3c2440_dma_init);
|
|
|