27 Sep, 2011

1 commit


23 Sep, 2011

1 commit


22 Sep, 2011

3 commits

  • Reasons for the replacement:
    The current driver for McPDM was developed to support the legacy mode only.
    In preparation for the ABE support the current driver stack need the be
    replaced.
    The new driver is much simpler, easier to extend, and it also fixes some of the
    issues with the old stack.

    Main changes:
    - single file for omap-mcpdm (mcpdm.c/h removed)
    - Define names for registers, bits cleaned up, prefixed
    - Full-duplex audio operation (arecord | aplay) has been fixed
    - Less code

    McPDM need to be turned off after all streams has been stopped.
    This might cause pop noise on the output, if the codec's DAC is
    still powered at this time.

    Signed-off-by: Misael Lopez Cruz
    Signed-off-by: Liam Girdwood
    Signed-off-by: Sebastien Guiriec
    Signed-off-by: Peter Ujfalusi
    Acked-by: Mark Brown

    Misael Lopez Cruz
     
  • In order to probe, and operate correctly, the OMAP McPDM driver needs to
    be converted to use hwmod.
    The device name has been changed to probe the driver.
    Replace the clk_* with pm_runtime_* calls to manage the clocks correctly.
    Missing request_mem_region/release_mem_region added.

    Signed-off-by: Peter Ujfalusi
    Acked-by: Mark Brown
    Acked-by: Liam Girdwood

    Peter Ujfalusi
     
  • DMA packet_size must be configured based on the McPDM FIFO threshold
    value, number of channels.
    Due to the FIFO operation the DMA muse be configured differently for
    playback, and capture.
    At the same time fix the McPDM threshold values used for playback, and
    capture to avoid broken code.

    Signed-off-by: Peter Ujfalusi
    Acked-by: Mark Brown
    Acked-by: Liam Girdwood

    Peter Ujfalusi
     

26 Oct, 2010

1 commit

  • * 'omap-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tmlind/linux-omap-2.6: (163 commits)
    omap: complete removal of machine_desc.io_pg_offst and .phys_io
    omap: UART: fix wakeup registers for OMAP24xx UART2
    omap: Fix spotty MMC voltages
    ASoC: OMAP4: MCPDM: Remove unnecessary include of plat/control.h
    serial: omap-serial: fix signess error
    OMAP3: DMA: Errata i541: sDMA FIFO draining does not finish
    omap: dma: Fix buffering disable bit setting for omap24xx
    omap: serial: Fix the boot-up crash/reboot without CONFIG_PM
    OMAP3: PM: fix scratchpad memory accesses for off-mode
    omap4: pandaboard: enable the ehci port on pandaboard
    omap4: pandaboard: Fix the init if CONFIG_MMC_OMAP_HS is not set
    omap4: pandaboard: remove unused hsmmc definition
    OMAP: McBSP: Remove null omap44xx ops comment
    OMAP: McBSP: Swap CLKS source definition
    OMAP: McBSP: Fix CLKR and FSR signal muxing
    OMAP2+: clock: reduce the amount of standard debugging while disabling unused clocks
    OMAP: control: move plat-omap/control.h to mach-omap2/control.h
    OMAP: split plat-omap/common.c
    OMAP: McBSP: implement functional clock switching via clock framework
    OMAP: McBSP: implement McBSP CLKR and FSR signal muxing via mach-omap2/mcbsp.c
    ...

    Fixed up trivial conflicts in arch/arm/mach-omap2/
    {board-zoom-peripherals.c,devices.c} as per Tony

    Linus Torvalds
     

13 Oct, 2010

1 commit

  • Commit 346a5c890 (OMAP: control: move plat-omap/control.h
    to mach-omap2/control.h) in the linux-omap tree removed
    plat/control.h and most of its callers. This one slipped
    through - breaking the build as below when
    CONFIG_SND_OMAP_SOC_MCPDM is defined. Fix this.

    CC sound/soc/omap/omap-mcpdm.o
    sound/soc/omap/omap-mcpdm.c:35: fatal error: plat/control.h: No such file or directory
    compilation terminated.
    make[3]: *** [sound/soc/omap/omap-mcpdm.o] Error 1
    make[2]: *** [sound/soc/omap] Error 2
    make[1]: *** [sound/soc] Error 2
    make: *** [sound] Error 2

    Signed-off-by: Anand Gadiyar
    Cc: Misael Lopez Cruz
    Cc: Liam Girdwood
    Cc: Mark Brown
    Cc: Paul Walmsley
    Acked-by: Mark Brown
    Acked-by: Jarkko Nikula
    Acked-by: Paul Walmsley
    Signed-off-by: Tony Lindgren

    Anand Gadiyar
     

12 Aug, 2010

1 commit

  • This patch extends the ASoC API to allow sound cards to have more than one
    CODEC and more than one platform DMA controller. This is achieved by dividing
    some current ASoC structures that contain both driver data and device data into
    structures that only either contain device data or driver data. i.e.

    struct snd_soc_codec ---> struct snd_soc_codec (device data)
    +-> struct snd_soc_codec_driver (driver data)

    struct snd_soc_platform ---> struct snd_soc_platform (device data)
    +-> struct snd_soc_platform_driver (driver data)

    struct snd_soc_dai ---> struct snd_soc_dai (device data)
    +-> struct snd_soc_dai_driver (driver data)

    struct snd_soc_device ---> deleted

    This now allows ASoC to be more tightly aligned with the Linux driver model and
    also means that every ASoC codec, platform and (platform) DAI is a kernel
    device. ASoC component private data is now stored as device private data.

    The ASoC sound card struct snd_soc_card has also been updated to store lists
    of it's components rather than a pointer to a codec and platform. The PCM
    runtime struct soc_pcm_runtime now has pointers to all its components.

    This patch adds DAPM support for ASoC multi-component and removes struct
    snd_soc_socdev from DAPM core. All DAPM calls are now made on a card, codec
    or runtime PCM level basis rather than using snd_soc_socdev.

    Other notable multi-component changes:-

    * Stream operations now de-reference less structures.
    * close_delayed work() now runs on a DAI basis rather than looping all DAIs
    in a card.
    * PM suspend()/resume() operations can now handle N CODECs and Platforms
    per sound card.
    * Added soc_bind_dai_link() to bind the component devices to the sound card.
    * Added soc_dai_link_probe() and soc_dai_link_remove() to probe and remove
    DAI link components.
    * sysfs entries can now be registered per component per card.
    * snd_soc_new_pcms() functionailty rolled into dai_link_probe().
    * snd_soc_register_codec() now does all the codec list and mutex init.

    This patch changes the probe() and remove() of the CODEC drivers as follows:-

    o Make CODEC driver a platform driver
    o Moved all struct snd_soc_codec list, mutex, etc initialiasation to core.
    o Removed all static codec pointers (drivers now support > 1 codec dev)
    o snd_soc_register_pcms() now done by core.
    o snd_soc_register_dai() folded into snd_soc_register_codec().

    CS4270 portions:
    Acked-by: Timur Tabi

    Some TLV320aic23 and Cirrus platform fixes.
    Signed-off-by: Ryan Mallon

    TI CODEC and OMAP fixes
    Signed-off-by: Peter Ujfalusi
    Signed-off-by: Janusz Krzysztofik
    Signed-off-by: Jarkko Nikula

    Samsung platform and misc fixes :-
    Signed-off-by: Chanwoo Choi
    Signed-off-by: Joonyoung Shim
    Signed-off-by: Kyungmin Park
    Reviewed-by: Jassi Brar
    Signed-off-by: Seungwhan Youn

    MPC8610 and PPC fixes.
    Signed-off-by: Timur Tabi

    i.MX fixes and some core fixes.
    Signed-off-by: Sascha Hauer

    J4740 platform fixes:-
    Signed-off-by: Lars-Peter Clausen

    CC: Tony Lindgren
    CC: Nicolas Ferre
    CC: Kevin Hilman
    CC: Sascha Hauer
    CC: Atsushi Nemoto
    CC: Kuninori Morimoto
    CC: Daniel Gloeckner
    CC: Manuel Lauss
    CC: Mike Frysinger
    CC: Arnaud Patard
    CC: Wan ZongShun

    Acked-by: Mark Brown
    Signed-off-by: Liam Girdwood

    Liam Girdwood
     

06 Apr, 2010

1 commit

  • This fixes a memory corruption when ASoC devices are used in
    full-duplex mode. Specifically for pxa-ssp code, where this pointer
    is dynamically allocated for each direction and destroyed upon each
    stream start.

    All other platforms are fixed blindly, I couldn't even compile-test
    them. Sorry for any breakage I may have caused.

    [Note that this is a backported version for 2.6.34.
    Upstream commit is fd23b7dee]

    Signed-off-by: Daniel Mack
    Reported-by: Sven Neumann
    Reported-by: Michael Hirsch
    Acked-by: Liam Girdwood
    Signed-off-by: Mark Brown

    Daniel Mack
     

23 Feb, 2010

1 commit

  • McPDM platform driver is configured to use sDMA in order to transfer
    to/from memory. Support for interfacing with ABE will be added later.

    McPDM dai currently supports up to 4 downlink channels and 2 uplink
    channels simultaneously, as well as 88.2 and 96 KHz, and a sample
    size of 32 bits.

    Signed-off-by: Misael Lopez Cruz
    Signed-off-by: Margarita Olaya
    Signed-off-by: Jorge Eduardo Candelaria
    Acked-by: Liam Girdwood
    Signed-off-by: Mark Brown

    Misael Lopez Cruz