2002-07-04 16:09:23 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright (C) 2002 by Linus Nielsen Feltzing
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
#include "sh7034.h"
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "config.h"
|
|
|
|
#include "adc.h"
|
2002-09-25 19:28:01 +00:00
|
|
|
#include "kernel.h"
|
2003-11-06 01:34:50 +00:00
|
|
|
#include "system.h"
|
2002-07-04 16:09:23 +00:00
|
|
|
#include "power.h"
|
|
|
|
|
2002-08-06 10:50:50 +00:00
|
|
|
#ifdef HAVE_CHARGE_CTRL
|
2003-08-25 08:57:49 +00:00
|
|
|
bool charger_enabled;
|
2002-08-06 10:50:50 +00:00
|
|
|
#endif
|
|
|
|
|
2002-07-04 16:09:23 +00:00
|
|
|
#ifndef SIMULATOR
|
|
|
|
|
2003-08-25 08:57:49 +00:00
|
|
|
void power_init(void)
|
|
|
|
{
|
|
|
|
#ifdef HAVE_CHARGE_CTRL
|
2003-11-07 12:15:24 +00:00
|
|
|
or_b(0x20, &PBIORL); /* Set charging control bit to output */
|
2003-11-06 01:34:50 +00:00
|
|
|
charger_enable(false); /* Default to charger OFF */
|
2003-08-25 08:57:49 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2002-07-04 16:09:23 +00:00
|
|
|
bool charger_inserted(void)
|
|
|
|
{
|
2003-01-16 15:11:29 +00:00
|
|
|
#ifdef HAVE_CHARGE_CTRL
|
2003-02-13 21:45:19 +00:00
|
|
|
/* Recorder */
|
|
|
|
return adc_read(ADC_EXT_POWER) > 0x100;
|
|
|
|
#else
|
2003-01-16 15:11:29 +00:00
|
|
|
#ifdef HAVE_FMADC
|
2004-02-05 13:44:04 +00:00
|
|
|
/* FM or V2, can also charge from the USB port */
|
|
|
|
return (adc_read(ADC_CHARGE_REGULATOR) < 0x1FF) ||
|
|
|
|
(adc_read(ADC_USB_POWER) < 0x1FF);
|
2003-01-16 15:11:29 +00:00
|
|
|
#else
|
2003-02-13 21:45:19 +00:00
|
|
|
/* Player */
|
2002-07-04 16:09:23 +00:00
|
|
|
return (PADR & 1) == 0;
|
2003-02-13 21:45:19 +00:00
|
|
|
#endif /* HAVE_FMADC */
|
|
|
|
#endif /* HAVE_CHARGE_CTRL */
|
2002-07-04 16:09:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void charger_enable(bool on)
|
|
|
|
{
|
2002-08-06 10:50:50 +00:00
|
|
|
#ifdef HAVE_CHARGE_CTRL
|
2003-11-06 01:34:50 +00:00
|
|
|
if(on)
|
|
|
|
{
|
2003-11-07 12:15:24 +00:00
|
|
|
and_b(~0x20, &PBDRL);
|
2002-08-06 10:50:50 +00:00
|
|
|
charger_enabled = 1;
|
2003-11-06 01:34:50 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2003-11-07 12:15:24 +00:00
|
|
|
or_b(0x20, &PBDRL);
|
2002-08-06 10:50:50 +00:00
|
|
|
charger_enabled = 0;
|
|
|
|
}
|
2002-07-04 16:09:23 +00:00
|
|
|
#else
|
|
|
|
on = on;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
void ide_power_enable(bool on)
|
|
|
|
{
|
2003-12-03 01:03:54 +00:00
|
|
|
(void)on;
|
|
|
|
bool touched = false;
|
|
|
|
|
|
|
|
#ifdef NEEDS_ATA_POWER_ON
|
2003-07-17 20:15:57 +00:00
|
|
|
if(on)
|
2003-12-03 01:03:54 +00:00
|
|
|
{
|
2003-11-07 12:15:24 +00:00
|
|
|
or_b(0x20, &PADRL);
|
2003-12-03 01:03:54 +00:00
|
|
|
touched = true;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_ATA_POWER_OFF
|
|
|
|
if(!on)
|
|
|
|
{
|
2003-11-07 12:15:24 +00:00
|
|
|
and_b(~0x20, &PADRL);
|
2003-12-03 01:03:54 +00:00
|
|
|
touched = true;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* late port preparation, else problems with read/modify/write
|
|
|
|
of other bits on same port, while input and floating high */
|
|
|
|
if (touched)
|
|
|
|
{
|
|
|
|
or_b(0x20, &PAIORL); /* PA5 is an output */
|
|
|
|
PACR2 &= 0xFBFF; /* GPIO for PA5 */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool ide_powered(void)
|
|
|
|
{
|
|
|
|
#if defined(NEEDS_ATA_POWER_ON) || defined(HAVE_ATA_POWER_OFF)
|
2003-12-03 18:50:19 +00:00
|
|
|
if ((PACR2 & 0x0400) || !(PAIOR & 0x0020)) /* not configured for output */
|
|
|
|
return true; /* would be floating high, disk on */
|
2003-12-03 01:03:54 +00:00
|
|
|
else
|
|
|
|
return (PADR & 0x0020) != 0;
|
2002-07-04 16:09:23 +00:00
|
|
|
#else
|
2003-12-03 18:50:19 +00:00
|
|
|
return true; /* pretend always powered if not controlable */
|
2002-07-04 16:09:23 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2003-12-03 01:03:54 +00:00
|
|
|
|
2002-07-05 07:10:22 +00:00
|
|
|
void power_off(void)
|
|
|
|
{
|
2004-03-02 11:32:59 +00:00
|
|
|
set_irq_level(HIGHEST_IRQ_LEVEL);
|
2003-01-21 19:37:29 +00:00
|
|
|
#ifdef HAVE_POWEROFF_ON_PBDR
|
2003-11-07 12:15:24 +00:00
|
|
|
and_b(~0x10, &PBDRL);
|
|
|
|
or_b(0x10, &PBIORL);
|
2003-02-21 01:12:00 +00:00
|
|
|
#elif defined(HAVE_POWEROFF_ON_PB5)
|
2003-11-07 12:15:24 +00:00
|
|
|
and_b(~0x20, &PBDRL);
|
|
|
|
or_b(0x20, &PBIORL);
|
2002-07-05 07:10:22 +00:00
|
|
|
#else
|
2004-07-14 10:06:02 +00:00
|
|
|
/* Disable the backlight */
|
|
|
|
and_b(~0x40, &PAIORH);
|
|
|
|
|
2003-11-07 12:15:24 +00:00
|
|
|
and_b(~0x08, &PADRH);
|
|
|
|
or_b(0x08, &PAIORH);
|
2002-07-05 07:10:22 +00:00
|
|
|
#endif
|
2002-09-25 19:28:01 +00:00
|
|
|
while(1);
|
2002-07-05 07:10:22 +00:00
|
|
|
}
|
|
|
|
|
2002-07-04 16:09:23 +00:00
|
|
|
#else
|
|
|
|
|
|
|
|
bool charger_inserted(void)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void charger_enable(bool on)
|
|
|
|
{
|
|
|
|
on = on;
|
|
|
|
}
|
|
|
|
|
2002-07-05 07:10:22 +00:00
|
|
|
void power_off(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2003-07-20 00:08:47 +00:00
|
|
|
void ide_power_enable(bool on)
|
|
|
|
{
|
|
|
|
on = on;
|
|
|
|
}
|
|
|
|
|
2002-07-04 16:09:23 +00:00
|
|
|
#endif /* SIMULATOR */
|