diff options
author | Christian Gmeiner <christian.gmeiner@gmail.com> | 2008-02-16 12:44:15 +0000 |
---|---|---|
committer | Christian Gmeiner <christian.gmeiner@gmail.com> | 2008-02-16 12:44:15 +0000 |
commit | 868fcce96cf0a131daa615afe87ea8a2287304bd (patch) | |
tree | 2ad39351b1e0bc537f68a057f652ddf634652f22 /firmware | |
parent | b650bc592aa09f8ba74bdfb420ef869b97fbaaf8 (diff) | |
download | rockbox-868fcce96cf0a131daa615afe87ea8a2287304bd.tar.gz rockbox-868fcce96cf0a131daa615afe87ea8a2287304bd.zip |
Shutdown needs about 2 seconds, but it seems to work :)
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@16317 a1c6a512-1295-4272-9138-f99709370657
Diffstat (limited to 'firmware')
-rw-r--r-- | firmware/target/arm/tcc780x/cowond2/power-cowond2.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/firmware/target/arm/tcc780x/cowond2/power-cowond2.c b/firmware/target/arm/tcc780x/cowond2/power-cowond2.c index d8a58570e4..2439676acc 100644 --- a/firmware/target/arm/tcc780x/cowond2/power-cowond2.c +++ b/firmware/target/arm/tcc780x/cowond2/power-cowond2.c @@ -16,9 +16,7 @@ * KIND, either express or implied. * ****************************************************************************/ -#include "config.h" #include "cpu.h" -#include <stdbool.h> #include "kernel.h" #include "system.h" #include "power.h" @@ -61,6 +59,22 @@ void charger_enable(bool on) void power_off(void) { + /* 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; + + /* Shutdown: stop XIN oscillator */ + CLKCTRL &= ~(1 << 31); + + /* Halt everything and wait for device to power off */ + while (1) + { + CPU_CTL = PROC_SLEEP; + COP_CTL = PROC_SLEEP; + } } void ide_power_enable(bool on) |