1
0
Fork 0
forked from len0rd/rockbox

No more spinning disk while charging flashed FM+V2 (you need the new bootloader to utilize it). ToDo: remove now false voltage reading from charging screen.

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@4095 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Jörg Hohensohn 2003-12-03 01:03:54 +00:00
parent 99c218a272
commit 44298163ba
8 changed files with 53 additions and 11 deletions

View file

@ -144,7 +144,6 @@ void init(void)
if (rc == 1 || rc == 2) /* charger removed or "Off/Stop" pressed */ if (rc == 1 || rc == 2) /* charger removed or "Off/Stop" pressed */
power_off(); power_off();
/* "On" pressed or USB connected: proceed */ /* "On" pressed or USB connected: proceed */
ide_power_enable(true);
} }
rc = ata_init(); rc = ata_init();

View file

@ -795,6 +795,12 @@ int ata_init(void)
ata_enable(true); ata_enable(true);
if ( !initialized ) { if ( !initialized ) {
if (!ide_powered()) /* somebody has switched it off */
{
ide_power_enable(true);
sleep(HZ); /* allow voltage to build up */
}
if (coldstart) if (coldstart)
{ {
/* Reset both master and slave, we don't yet know what's in */ /* Reset both master and slave, we don't yet know what's in */

View file

@ -36,11 +36,6 @@ void power_init(void)
or_b(0x20, &PBIORL); /* Set charging control bit to output */ or_b(0x20, &PBIORL); /* Set charging control bit to output */
charger_enable(false); /* Default to charger OFF */ charger_enable(false); /* Default to charger OFF */
#endif #endif
#ifdef HAVE_ATA_POWER_OFF
or_b(0x20, &PADRL); /* leave the disk on */
or_b(0x20, &PAIORL);
PACR2 &= 0xFBFF;
#endif
} }
bool charger_inserted(void) bool charger_inserted(void)
@ -79,16 +74,47 @@ void charger_enable(bool on)
void ide_power_enable(bool on) void ide_power_enable(bool on)
{ {
#ifdef HAVE_ATA_POWER_OFF (void)on;
bool touched = false;
#ifdef NEEDS_ATA_POWER_ON
if(on) if(on)
{
or_b(0x20, &PADRL); or_b(0x20, &PADRL);
else touched = true;
}
#endif
#ifdef HAVE_ATA_POWER_OFF
if(!on)
{
and_b(~0x20, &PADRL); and_b(~0x20, &PADRL);
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)
if ((PACR2 & 0x0400) || !(PAIOR & 0x0020)) // not configured for output
return true; // would be floating high, disk on
else
return (PADR & 0x0020) != 0;
#else #else
on = on; return TRUE; /* pretend always powered if not controlable */
#endif #endif
} }
void power_off(void) void power_off(void)
{ {
set_irq_level(15); set_irq_level(15);

View file

@ -19,6 +19,9 @@
/* Define this if you have a LiIon battery */ /* Define this if you have a LiIon battery */
#define HAVE_LIION #define HAVE_LIION
/* Define this if you need to power on ATA */
#define NEEDS_ATA_POWER_ON
/* Define this to the CPU frequency */ /* Define this to the CPU frequency */
#define CPU_FREQ 11059200 #define CPU_FREQ 11059200

View file

@ -19,6 +19,9 @@
/* Define this if you have ATA power-off control */ /* Define this if you have ATA power-off control */
#define HAVE_ATA_POWER_OFF #define HAVE_ATA_POWER_OFF
/* Define this if you need to power on ATA */
#define NEEDS_ATA_POWER_ON
/* Define this to the CPU frequency */ /* Define this to the CPU frequency */
#define CPU_FREQ 11059200 #define CPU_FREQ 11059200

View file

@ -19,6 +19,9 @@
/* Define this if you have a LiIon battery */ /* Define this if you have a LiIon battery */
#define HAVE_LIION #define HAVE_LIION
/* Define this if you need to power on ATA */
#define NEEDS_ATA_POWER_ON
/* Define this to the CPU frequency */ /* Define this to the CPU frequency */
#define CPU_FREQ 11059200 #define CPU_FREQ 11059200

View file

@ -27,6 +27,7 @@ void power_init(void);
bool charger_inserted(void); bool charger_inserted(void);
void charger_enable(bool on); void charger_enable(bool on);
void ide_power_enable(bool on); void ide_power_enable(bool on);
bool ide_powered(void);
void power_off(void); void power_off(void);
#endif #endif

View file

@ -139,8 +139,9 @@ void PlatformInit(void)
PBDR |= 0x20; // set PB5 to keep power (fixes the ON-holding problem) PBDR |= 0x20; // set PB5 to keep power (fixes the ON-holding problem)
PBIOR |= 0x20; // make PB5 an output PBIOR |= 0x20; // make PB5 an output
if (ReadADC(0) < 0x1FF) // charger plugged? if (ReadADC(0) < 0x1FF) // charger plugged?
{ { // switch off the HD, else a flat battery may not start
// how do we switch this off? PACR2 &= 0xFBFF; // GPIO for PA5
PAIOR |= 0x20; // make PA5 an output (low by default)
} }
#endif #endif