Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 1 | /*************************************************************************** |
| 2 | * __________ __ ___. |
| 3 | * Open \______ \ ____ ____ | | _\_ |__ _______ ___ |
| 4 | * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / |
| 5 | * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < |
| 6 | * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ |
| 7 | * \/ \/ \/ \/ \/ |
| 8 | * $Id$ |
| 9 | * |
| 10 | * Copyright (C) 2002 by Linus Nielsen Feltzing |
| 11 | * |
| 12 | * All files in this archive are subject to the GNU General Public License. |
| 13 | * See the file COPYING in the source tree root for full license agreement. |
| 14 | * |
| 15 | * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY |
| 16 | * KIND, either express or implied. |
| 17 | * |
| 18 | ****************************************************************************/ |
| 19 | #include "sh7034.h" |
| 20 | #include <stdbool.h> |
| 21 | #include "config.h" |
| 22 | #include "adc.h" |
Linus Nielsen Feltzing | 297a256 | 2002-09-25 19:28:01 +0000 | [diff] [blame] | 23 | #include "kernel.h" |
Jörg Hohensohn | 75bab49 | 2003-11-06 01:34:50 +0000 | [diff] [blame] | 24 | #include "system.h" |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 25 | #include "power.h" |
| 26 | |
Heikki Hannikainen | 3f809e7 | 2002-08-06 10:50:50 +0000 | [diff] [blame] | 27 | #ifdef HAVE_CHARGE_CTRL |
Linus Nielsen Feltzing | 53ee344 | 2003-08-25 08:57:49 +0000 | [diff] [blame] | 28 | bool charger_enabled; |
Heikki Hannikainen | 3f809e7 | 2002-08-06 10:50:50 +0000 | [diff] [blame] | 29 | #endif |
| 30 | |
Jörg Hohensohn | 91f9350 | 2004-10-17 08:53:18 +0000 | [diff] [blame] | 31 | |
| 32 | #ifdef CONFIG_TUNER |
| 33 | |
| 34 | static int fmstatus = 0; |
| 35 | |
| 36 | void radio_set_status(int status) |
| 37 | { |
| 38 | fmstatus = status; |
| 39 | #ifdef HAVE_TUNER_PWR_CTRL |
| 40 | if (status) |
| 41 | { |
Jörg Hohensohn | 954e588 | 2004-10-17 09:58:05 +0000 | [diff] [blame] | 42 | and_b(~0x04, &PADRL); /* drive PA2 low for tuner enable */ |
Jörg Hohensohn | 91f9350 | 2004-10-17 08:53:18 +0000 | [diff] [blame] | 43 | sleep(1); /* let the voltage settle */ |
| 44 | } |
| 45 | else |
Jörg Hohensohn | 954e588 | 2004-10-17 09:58:05 +0000 | [diff] [blame] | 46 | or_b(0x04, &PADRL); /* drive PA2 high for tuner disable */ |
Jörg Hohensohn | 91f9350 | 2004-10-17 08:53:18 +0000 | [diff] [blame] | 47 | #endif |
| 48 | } |
| 49 | |
| 50 | int radio_get_status(void) |
| 51 | { |
| 52 | return fmstatus; |
| 53 | } |
| 54 | |
| 55 | #endif /* #ifdef CONFIG_TUNER */ |
| 56 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 57 | #ifndef SIMULATOR |
| 58 | |
Linus Nielsen Feltzing | 53ee344 | 2003-08-25 08:57:49 +0000 | [diff] [blame] | 59 | void power_init(void) |
| 60 | { |
| 61 | #ifdef HAVE_CHARGE_CTRL |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 62 | or_b(0x20, &PBIORL); /* Set charging control bit to output */ |
Jörg Hohensohn | 75bab49 | 2003-11-06 01:34:50 +0000 | [diff] [blame] | 63 | charger_enable(false); /* Default to charger OFF */ |
Linus Nielsen Feltzing | 53ee344 | 2003-08-25 08:57:49 +0000 | [diff] [blame] | 64 | #endif |
Jörg Hohensohn | 91f9350 | 2004-10-17 08:53:18 +0000 | [diff] [blame] | 65 | #ifdef HAVE_TUNER_PWR_CTRL |
Jörg Hohensohn | 954e588 | 2004-10-17 09:58:05 +0000 | [diff] [blame] | 66 | PACR2 &= ~0x0030; /* GPIO for PA2 */ |
| 67 | or_b(0x04, &PADRL); /* drive PA2 high for tuner disable */ |
| 68 | or_b(0x04, &PAIORL); /* output for PA2 */ |
Jörg Hohensohn | 91f9350 | 2004-10-17 08:53:18 +0000 | [diff] [blame] | 69 | #endif |
Linus Nielsen Feltzing | 53ee344 | 2003-08-25 08:57:49 +0000 | [diff] [blame] | 70 | } |
| 71 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 72 | bool charger_inserted(void) |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 73 | { |
| 74 | #ifdef HAVE_CHARGING |
Daniel Stenberg | d7b4645 | 2003-01-16 15:11:29 +0000 | [diff] [blame] | 75 | #ifdef HAVE_CHARGE_CTRL |
Uwe Freese | cc9b62f | 2003-02-13 21:45:19 +0000 | [diff] [blame] | 76 | /* Recorder */ |
| 77 | return adc_read(ADC_EXT_POWER) > 0x100; |
| 78 | #else |
Daniel Stenberg | d7b4645 | 2003-01-16 15:11:29 +0000 | [diff] [blame] | 79 | #ifdef HAVE_FMADC |
Linus Nielsen Feltzing | a258fe1 | 2004-02-05 13:44:04 +0000 | [diff] [blame] | 80 | /* FM or V2, can also charge from the USB port */ |
| 81 | return (adc_read(ADC_CHARGE_REGULATOR) < 0x1FF) || |
| 82 | (adc_read(ADC_USB_POWER) < 0x1FF); |
Daniel Stenberg | d7b4645 | 2003-01-16 15:11:29 +0000 | [diff] [blame] | 83 | #else |
Uwe Freese | cc9b62f | 2003-02-13 21:45:19 +0000 | [diff] [blame] | 84 | /* Player */ |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 85 | return (PADR & 1) == 0; |
Uwe Freese | cc9b62f | 2003-02-13 21:45:19 +0000 | [diff] [blame] | 86 | #endif /* HAVE_FMADC */ |
| 87 | #endif /* HAVE_CHARGE_CTRL */ |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 88 | #else |
| 89 | /* Ondio */ |
| 90 | return false; |
| 91 | #endif /* HAVE_CHARGING */ |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 92 | } |
| 93 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 94 | void charger_enable(bool on) |
| 95 | { |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 96 | (void)on; |
Heikki Hannikainen | 3f809e7 | 2002-08-06 10:50:50 +0000 | [diff] [blame] | 97 | #ifdef HAVE_CHARGE_CTRL |
Jörg Hohensohn | 75bab49 | 2003-11-06 01:34:50 +0000 | [diff] [blame] | 98 | if(on) |
| 99 | { |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 100 | and_b(~0x20, &PBDRL); |
Heikki Hannikainen | 3f809e7 | 2002-08-06 10:50:50 +0000 | [diff] [blame] | 101 | charger_enabled = 1; |
Jörg Hohensohn | 75bab49 | 2003-11-06 01:34:50 +0000 | [diff] [blame] | 102 | } |
| 103 | else |
| 104 | { |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 105 | or_b(0x20, &PBDRL); |
Heikki Hannikainen | 3f809e7 | 2002-08-06 10:50:50 +0000 | [diff] [blame] | 106 | charger_enabled = 0; |
| 107 | } |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 108 | #endif |
| 109 | } |
| 110 | |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 111 | #ifndef HAVE_MMC |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 112 | void ide_power_enable(bool on) |
| 113 | { |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 114 | (void)on; |
| 115 | bool touched = false; |
| 116 | |
| 117 | #ifdef NEEDS_ATA_POWER_ON |
Jörg Hohensohn | 61750ac | 2003-07-17 20:15:57 +0000 | [diff] [blame] | 118 | if(on) |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 119 | { |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 120 | or_b(0x20, &PADRL); |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 121 | touched = true; |
| 122 | } |
| 123 | #endif |
| 124 | #ifdef HAVE_ATA_POWER_OFF |
| 125 | if(!on) |
| 126 | { |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 127 | and_b(~0x20, &PADRL); |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 128 | touched = true; |
| 129 | } |
| 130 | #endif |
| 131 | |
| 132 | /* late port preparation, else problems with read/modify/write |
| 133 | of other bits on same port, while input and floating high */ |
| 134 | if (touched) |
| 135 | { |
| 136 | or_b(0x20, &PAIORL); /* PA5 is an output */ |
| 137 | PACR2 &= 0xFBFF; /* GPIO for PA5 */ |
| 138 | } |
| 139 | } |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 140 | #endif /* !HAVE_MMC */ |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 141 | |
| 142 | |
| 143 | bool ide_powered(void) |
| 144 | { |
| 145 | #if defined(NEEDS_ATA_POWER_ON) || defined(HAVE_ATA_POWER_OFF) |
Jörg Hohensohn | 816234f | 2003-12-03 18:50:19 +0000 | [diff] [blame] | 146 | if ((PACR2 & 0x0400) || !(PAIOR & 0x0020)) /* not configured for output */ |
| 147 | return true; /* would be floating high, disk on */ |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 148 | else |
| 149 | return (PADR & 0x0020) != 0; |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 150 | #else |
Jörg Hohensohn | 816234f | 2003-12-03 18:50:19 +0000 | [diff] [blame] | 151 | return true; /* pretend always powered if not controlable */ |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 152 | #endif |
| 153 | } |
| 154 | |
Jörg Hohensohn | 4429816 | 2003-12-03 01:03:54 +0000 | [diff] [blame] | 155 | |
Linus Nielsen Feltzing | 4edf8ae | 2002-07-05 07:10:22 +0000 | [diff] [blame] | 156 | void power_off(void) |
| 157 | { |
Linus Nielsen Feltzing | 111a972 | 2004-03-02 11:32:59 +0000 | [diff] [blame] | 158 | set_irq_level(HIGHEST_IRQ_LEVEL); |
Daniel Stenberg | aaa8443 | 2003-01-21 19:37:29 +0000 | [diff] [blame] | 159 | #ifdef HAVE_POWEROFF_ON_PBDR |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 160 | and_b(~0x10, &PBDRL); |
| 161 | or_b(0x10, &PBIORL); |
Linus Nielsen Feltzing | 70e3331 | 2003-02-21 01:12:00 +0000 | [diff] [blame] | 162 | #elif defined(HAVE_POWEROFF_ON_PB5) |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 163 | and_b(~0x20, &PBDRL); |
| 164 | or_b(0x20, &PBIORL); |
Linus Nielsen Feltzing | 4edf8ae | 2002-07-05 07:10:22 +0000 | [diff] [blame] | 165 | #else |
Linus Nielsen Feltzing | b1af93c | 2004-07-14 10:06:02 +0000 | [diff] [blame] | 166 | /* Disable the backlight */ |
| 167 | and_b(~0x40, &PAIORH); |
| 168 | |
Linus Nielsen Feltzing | bef7ab0 | 2003-11-07 12:15:24 +0000 | [diff] [blame] | 169 | and_b(~0x08, &PADRH); |
| 170 | or_b(0x08, &PAIORH); |
Linus Nielsen Feltzing | 4edf8ae | 2002-07-05 07:10:22 +0000 | [diff] [blame] | 171 | #endif |
Linus Nielsen Feltzing | 297a256 | 2002-09-25 19:28:01 +0000 | [diff] [blame] | 172 | while(1); |
Linus Nielsen Feltzing | 4edf8ae | 2002-07-05 07:10:22 +0000 | [diff] [blame] | 173 | } |
| 174 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 175 | #else |
| 176 | |
| 177 | bool charger_inserted(void) |
| 178 | { |
| 179 | return false; |
| 180 | } |
| 181 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 182 | void charger_enable(bool on) |
| 183 | { |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 184 | (void)on; |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 185 | } |
| 186 | |
Linus Nielsen Feltzing | 4edf8ae | 2002-07-05 07:10:22 +0000 | [diff] [blame] | 187 | void power_off(void) |
| 188 | { |
| 189 | } |
| 190 | |
Mats Lidell | bd49e5f | 2003-07-20 00:08:47 +0000 | [diff] [blame] | 191 | void ide_power_enable(bool on) |
| 192 | { |
Jens Arnold | 0fc34c7 | 2004-10-13 23:21:57 +0000 | [diff] [blame] | 193 | (void)on; |
Mats Lidell | bd49e5f | 2003-07-20 00:08:47 +0000 | [diff] [blame] | 194 | } |
| 195 | |
Linus Nielsen Feltzing | 7cafe7a | 2002-07-04 16:09:23 +0000 | [diff] [blame] | 196 | #endif /* SIMULATOR */ |