2006-11-22 00:30:24 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 by Daniel Ankers
|
|
|
|
*
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
|
2006-12-10 22:58:59 +00:00
|
|
|
#include <stdbool.h>
|
2007-07-07 03:51:50 +00:00
|
|
|
#include "system.h"
|
2006-12-10 22:58:59 +00:00
|
|
|
#include "cpu.h"
|
2007-01-31 17:10:01 +00:00
|
|
|
#include "i2c-pp.h"
|
2007-07-14 11:20:31 +00:00
|
|
|
#include "tuner.h"
|
2006-12-10 22:58:59 +00:00
|
|
|
|
2006-11-22 00:30:24 +00:00
|
|
|
void power_init(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void power_off(void)
|
|
|
|
{
|
2007-01-31 19:30:32 +00:00
|
|
|
char byte;
|
2007-07-07 03:51:50 +00:00
|
|
|
|
|
|
|
/* Disable interrupts on this core */
|
|
|
|
set_interrupt_status(IRQ_FIQ_DISABLED, IRQ_FIQ_STATUS);
|
|
|
|
|
|
|
|
/* Mask them on both cores */
|
|
|
|
CPU_INT_CLR = -1;
|
|
|
|
COP_INT_CLR = -1;
|
|
|
|
|
|
|
|
/* Send shutdown command to PMU */
|
2007-01-31 19:30:32 +00:00
|
|
|
byte = i2c_readbyte(0x46, 0x20);
|
|
|
|
byte &= ~0x1;
|
|
|
|
pp_i2c_send(0x46, 0x20, byte);
|
2007-07-07 03:51:50 +00:00
|
|
|
|
|
|
|
/* Halt everything and wait for device to power off */
|
|
|
|
while (1)
|
|
|
|
{
|
|
|
|
CPU_CTL = PROC_SLEEP;
|
|
|
|
COP_CTL = PROC_SLEEP;
|
|
|
|
}
|
2006-11-22 00:30:24 +00:00
|
|
|
}
|
2006-12-10 22:58:59 +00:00
|
|
|
|
|
|
|
bool charger_inserted(void)
|
|
|
|
{
|
2007-09-06 03:28:58 +00:00
|
|
|
#ifdef SANSA_E200
|
2006-12-10 22:58:59 +00:00
|
|
|
if(GPIOB_INPUT_VAL & 0x10)
|
2007-09-06 03:28:58 +00:00
|
|
|
#else /* SANSA_C200 */
|
|
|
|
if(GPIOH_INPUT_VAL & 0x2)
|
|
|
|
#endif
|
2006-12-10 22:58:59 +00:00
|
|
|
return true;
|
|
|
|
return false;
|
|
|
|
}
|
2006-12-10 23:12:59 +00:00
|
|
|
|
|
|
|
void ide_power_enable(bool on)
|
|
|
|
{
|
|
|
|
(void)on;
|
|
|
|
}
|
2007-07-14 11:20:31 +00:00
|
|
|
|
2007-09-06 03:28:58 +00:00
|
|
|
#if CONFIG_TUNER
|
2007-07-14 11:20:31 +00:00
|
|
|
/** Tuner **/
|
|
|
|
static bool powered = false;
|
|
|
|
|
2007-07-14 22:00:50 +00:00
|
|
|
bool tuner_power_nolock(bool status)
|
2007-07-14 11:20:31 +00:00
|
|
|
{
|
2007-07-14 22:00:50 +00:00
|
|
|
bool old_status;
|
|
|
|
|
|
|
|
old_status = powered;
|
2007-07-14 11:20:31 +00:00
|
|
|
|
|
|
|
if (status != old_status)
|
|
|
|
{
|
|
|
|
if (status)
|
|
|
|
{
|
|
|
|
/* init mystery amplification device */
|
2007-10-02 21:04:10 +00:00
|
|
|
#if defined(SANSA_E200)
|
2007-07-14 11:20:31 +00:00
|
|
|
outl(inl(0x70000084) | 0x1, 0x70000084);
|
2007-10-02 21:04:10 +00:00
|
|
|
#else /* SANSA_C200 */
|
|
|
|
DEV_INIT &= ~0x800;
|
|
|
|
#endif
|
2007-07-14 11:20:31 +00:00
|
|
|
udelay(5);
|
|
|
|
|
|
|
|
/* When power up, host should initialize the 3-wire bus
|
|
|
|
in host read mode: */
|
|
|
|
|
|
|
|
/* 1. Set direction of the DATA-line to input-mode. */
|
|
|
|
GPIOH_OUTPUT_EN &= ~(1 << 5);
|
|
|
|
GPIOH_ENABLE |= (1 << 5);
|
|
|
|
|
|
|
|
/* 2. Drive NR_W low */
|
|
|
|
GPIOH_OUTPUT_VAL &= ~(1 << 3);
|
|
|
|
GPIOH_OUTPUT_EN |= (1 << 3);
|
|
|
|
GPIOH_ENABLE |= (1 << 3);
|
|
|
|
|
|
|
|
/* 3. Drive CLOCK high */
|
|
|
|
GPIOH_OUTPUT_VAL |= (1 << 4);
|
|
|
|
GPIOH_OUTPUT_EN |= (1 << 4);
|
|
|
|
GPIOH_ENABLE |= (1 << 4);
|
|
|
|
|
|
|
|
lv24020lp_power(true);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
lv24020lp_power(false);
|
|
|
|
|
|
|
|
/* set all as inputs */
|
|
|
|
GPIOH_OUTPUT_EN &= ~((1 << 5) | (1 << 3) | (1 << 4));
|
|
|
|
GPIOH_ENABLE &= ~((1 << 5) | (1 << 3) | (1 << 4));
|
|
|
|
|
|
|
|
/* turn off mystery amplification device */
|
2007-10-02 21:04:10 +00:00
|
|
|
#if defined (SANSA_E200)
|
2007-07-14 11:20:31 +00:00
|
|
|
outl(inl(0x70000084) & ~0x1, 0x70000084);
|
2007-10-02 21:04:10 +00:00
|
|
|
#else
|
|
|
|
DEV_INIT |= 0x800;
|
|
|
|
#endif
|
2007-07-14 11:20:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
powered = status;
|
|
|
|
}
|
|
|
|
|
|
|
|
return old_status;
|
|
|
|
}
|
|
|
|
|
2007-07-14 22:00:50 +00:00
|
|
|
bool tuner_power(bool status)
|
|
|
|
{
|
|
|
|
bool old_status;
|
|
|
|
lv24020lp_lock();
|
|
|
|
old_status = tuner_power_nolock(status);
|
|
|
|
lv24020lp_unlock();
|
|
|
|
return old_status;
|
|
|
|
}
|
2007-09-06 03:28:58 +00:00
|
|
|
|
|
|
|
#endif
|