2006-10-20 17:12:42 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Portalplayer specific code for Wolfson audio codecs
|
|
|
|
*
|
|
|
|
* Based on code from the ipodlinux project - http://ipodlinux.org/
|
|
|
|
* Adapted for Rockbox in December 2005
|
|
|
|
*
|
|
|
|
* Original file: linux/arch/armnommu/mach-ipod/audio.c
|
|
|
|
*
|
|
|
|
* Copyright (c) 2003-2005 Bernard Leach (leachbj@bouncycastle.org)
|
|
|
|
*
|
2008-06-28 18:10:04 +00:00
|
|
|
* 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.
|
2006-10-20 17:12:42 +00:00
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
2006-12-09 19:18:18 +00:00
|
|
|
|
2006-10-20 17:12:42 +00:00
|
|
|
#include "system.h"
|
2007-10-02 07:48:50 +00:00
|
|
|
#include "audiohw.h"
|
2007-01-27 20:39:09 +00:00
|
|
|
#include "i2c-pp.h"
|
2008-11-26 14:25:45 +00:00
|
|
|
#include "i2s.h"
|
2008-07-16 11:02:14 +00:00
|
|
|
#include "wmcodec.h"
|
2006-10-20 17:12:42 +00:00
|
|
|
|
2008-12-12 04:56:25 +00:00
|
|
|
#if defined(IRIVER_H10) || defined(IRIVER_H10_5GB) || \
|
|
|
|
defined(MROBE_100) || defined(PHILIPS_HDD1630)
|
2006-10-27 11:24:23 +00:00
|
|
|
/* The H10's audio codec uses an I2C address of 0x1b */
|
|
|
|
#define I2C_AUDIO_ADDRESS 0x1b
|
|
|
|
#else
|
2008-12-12 04:56:25 +00:00
|
|
|
/* The iPod's audio codecs use an I2C address of 0x1a */
|
2006-10-27 11:24:23 +00:00
|
|
|
#define I2C_AUDIO_ADDRESS 0x1a
|
|
|
|
#endif
|
|
|
|
|
2006-10-20 17:12:42 +00:00
|
|
|
|
|
|
|
/*
|
2007-02-21 22:25:14 +00:00
|
|
|
* Initialise the PP I2C and I2S.
|
2006-10-20 17:12:42 +00:00
|
|
|
*/
|
2008-11-26 14:25:45 +00:00
|
|
|
void audiohw_init(void)
|
|
|
|
{
|
2007-07-02 05:16:40 +00:00
|
|
|
#ifdef CPU_PP502x
|
2006-10-20 17:12:42 +00:00
|
|
|
/* normal outputs for CDI and I2S pin groups */
|
2007-10-16 10:48:16 +00:00
|
|
|
DEV_INIT2 &= ~0x300;
|
2006-10-20 17:12:42 +00:00
|
|
|
|
|
|
|
/*mini2?*/
|
2007-11-05 14:26:47 +00:00
|
|
|
DEV_INIT1 &=~0x3000000;
|
2006-10-20 17:12:42 +00:00
|
|
|
/*mini2?*/
|
|
|
|
|
2008-02-10 05:39:20 +00:00
|
|
|
/* I2S device reset */
|
2007-11-05 14:26:47 +00:00
|
|
|
DEV_RS |= DEV_I2S;
|
|
|
|
DEV_RS &=~DEV_I2S;
|
2006-10-20 17:12:42 +00:00
|
|
|
|
2008-02-10 05:39:20 +00:00
|
|
|
/* I2S device enable */
|
|
|
|
DEV_EN |= DEV_I2S;
|
2006-10-20 17:12:42 +00:00
|
|
|
|
|
|
|
/* enable external dev clock clocks */
|
2008-02-10 05:39:20 +00:00
|
|
|
DEV_EN |= DEV_EXTCLOCKS;
|
2006-10-20 17:12:42 +00:00
|
|
|
|
|
|
|
/* external dev clock to 24MHz */
|
|
|
|
outl(inl(0x70000018) & ~0xc, 0x70000018);
|
|
|
|
#else
|
|
|
|
/* device reset */
|
|
|
|
outl(inl(0xcf005030) | 0x80, 0xcf005030);
|
|
|
|
outl(inl(0xcf005030) & ~0x80, 0xcf005030);
|
|
|
|
|
|
|
|
/* device enable */
|
|
|
|
outl(inl(0xcf005000) | 0x80, 0xcf005000);
|
|
|
|
|
|
|
|
/* GPIO D06 enable for output */
|
|
|
|
outl(inl(0xcf00000c) | 0x40, 0xcf00000c);
|
|
|
|
outl(inl(0xcf00001c) & ~0x40, 0xcf00001c);
|
2007-07-27 18:15:03 +00:00
|
|
|
#ifdef IPOD_1G2G
|
|
|
|
/* bits 11,10 == 10 */
|
|
|
|
outl(inl(0xcf004040) & ~0x400, 0xcf004040);
|
|
|
|
outl(inl(0xcf004040) | 0x800, 0xcf004040);
|
|
|
|
#else /* IPOD_3G */
|
2006-10-20 17:12:42 +00:00
|
|
|
/* bits 11,10 == 01 */
|
|
|
|
outl(inl(0xcf004040) | 0x400, 0xcf004040);
|
|
|
|
outl(inl(0xcf004040) & ~0x800, 0xcf004040);
|
|
|
|
|
|
|
|
outl(inl(0xcf004048) & ~0x1, 0xcf004048);
|
|
|
|
|
|
|
|
outl(inl(0xcf000004) & ~0xf, 0xcf000004);
|
|
|
|
outl(inl(0xcf004044) & ~0xf, 0xcf004044);
|
|
|
|
|
|
|
|
/* C03 = 0 */
|
|
|
|
outl(inl(0xcf000008) | 0x8, 0xcf000008);
|
|
|
|
outl(inl(0xcf000018) | 0x8, 0xcf000018);
|
|
|
|
outl(inl(0xcf000028) & ~0x8, 0xcf000028);
|
2007-07-27 18:15:03 +00:00
|
|
|
#endif /* IPOD_1G2G/3G */
|
2006-10-20 17:12:42 +00:00
|
|
|
#endif
|
2008-11-26 14:25:45 +00:00
|
|
|
|
|
|
|
/* reset the I2S controller into known state */
|
|
|
|
i2s_reset();
|
2008-12-12 04:56:25 +00:00
|
|
|
|
2007-10-02 07:48:50 +00:00
|
|
|
audiohw_preinit();
|
2006-10-20 17:12:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void wmcodec_write(int reg, int data)
|
|
|
|
{
|
2006-10-27 11:24:23 +00:00
|
|
|
pp_i2c_send(I2C_AUDIO_ADDRESS, (reg<<1) | ((data&0x100)>>8),data&0xff);
|
2006-10-20 17:12:42 +00:00
|
|
|
}
|