rockbox/firmware/target/coldfire/mpio/audio-mpio.c
Marcin Bukat 9a24892e2e MPIO HD300 - initial commit
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@28680 a1c6a512-1295-4272-9138-f99709370657
2010-11-26 23:28:08 +00:00

109 lines
3.3 KiB
C

/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Copyright (C) 2010 Marcin Bukat
*
* 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.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#include "system.h"
#include "cpu.h"
#include "audio.h"
#include "sound.h"
static inline void enable_mclk(bool enable)
{
if(enable)
and_l(~(1<<10), &GPIO1_FUNCTION);
else
or_l((1<<10), &GPIO1_FUNCTION);
}
void audio_set_output_source(int source)
{
static const unsigned char txsrc_select[AUDIO_NUM_SOURCES+1] =
{
[AUDIO_SRC_PLAYBACK+1] = 3, /* PDOR3 */
#if (INPUT_SRC_CAPS & SRC_CAP_MIC)
[AUDIO_SRC_MIC+1] = 4, /* IIS1 RcvData */
#endif
#if (INPUT_SRC_CAPS & SRC_CAP_LINEIN)
[AUDIO_SRC_LINEIN+1] = 4, /* IIS1 RcvData */
#endif
#if (INPUT_SRC_CAPS & SRC_CAP_FMRADIO)
[AUDIO_SRC_FMRADIO+1] = 4, /* IIS1 RcvData */
#endif
};
int level = set_irq_level(DMA_IRQ_LEVEL);
if ((unsigned)source >= AUDIO_NUM_SOURCES)
source = AUDIO_SRC_PLAYBACK;
/* route incoming audio samples to DAC */
IIS2CONFIG = (IIS2CONFIG & ~(7 << 8)) | (txsrc_select[source+1] << 8);
restore_irq(level);
}
void audio_input_mux(int source, unsigned flags)
{
/* Prevent pops from unneeded switching */
static int last_source = AUDIO_SRC_PLAYBACK;
bool recording = flags & SRCF_RECORDING;
static bool last_recording = false;
switch(source)
{
default:
/* playback - no recording */
source = AUDIO_SRC_PLAYBACK;
case AUDIO_SRC_PLAYBACK:
if (source != last_source)
{
audiohw_set_recsrc(source,false);
coldfire_set_dataincontrol(0);
}
break;
case AUDIO_SRC_MIC:
#if (INPUT_SRC_CAPS & SRC_CAP_LINEIN)
case AUDIO_SRC_LINEIN:
#endif
/* recording only */
if (source != last_source)
{
audiohw_set_recsrc(source,true);
/* Int. when 6 samples in FIFO, PDIR2 src = iis1RcvData */
coldfire_set_dataincontrol((3 << 14) | (4 << 3));
}
break;
case AUDIO_SRC_FMRADIO:
if (source == last_source && recording == last_recording)
break;
last_recording = recording;
audiohw_set_recsrc(source,recording);
/* Int. when 6 samples in FIFO, PDIR2 src = iis1RcvData */
coldfire_set_dataincontrol(recording ?
((3 << 14) | (4 << 3)) : 0);
break;
}
last_source = source;
}