1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2002 by Alan Korr
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
33 long cpu_frequency SHAREDBSS_ATTR
= CPU_FREQ
;
35 #ifdef HAVE_ADJUSTABLE_CPU_FREQ
36 static int boost_counter SHAREDBSS_ATTR
= 0;
37 static bool cpu_idle SHAREDBSS_ATTR
= false;
39 static struct corelock boostctrl_cl SHAREDBSS_ATTR
;
40 void cpu_boost_init(void)
42 corelock_init(&boostctrl_cl
);
46 int get_cpu_boost_counter(void)
50 #ifdef CPU_BOOST_LOGGING
51 #define MAX_BOOST_LOG 64
52 static char cpu_boost_calls
[MAX_BOOST_LOG
][MAX_PATH
];
53 static int cpu_boost_first
= 0;
54 static int cpu_boost_calls_count
= 0;
55 static int cpu_boost_track_message
= 0;
56 int cpu_boost_log_getcount(void)
58 return cpu_boost_calls_count
;
60 char * cpu_boost_log_getlog_first(void)
63 corelock_lock(&boostctrl_cl
);
67 if (cpu_boost_calls_count
)
69 cpu_boost_track_message
= 1;
70 first
= cpu_boost_calls
[cpu_boost_first
];
73 corelock_unlock(&boostctrl_cl
);
77 char * cpu_boost_log_getlog_next(void)
82 corelock_lock(&boostctrl_cl
);
84 message
= (cpu_boost_track_message
+cpu_boost_first
)%MAX_BOOST_LOG
;
87 if (cpu_boost_track_message
< cpu_boost_calls_count
)
89 cpu_boost_track_message
++;
90 next
= cpu_boost_calls
[message
];
93 corelock_unlock(&boostctrl_cl
);
97 void cpu_boost_(bool on_off
, char* location
, int line
)
99 corelock_lock(&boostctrl_cl
);
101 if (cpu_boost_calls_count
== MAX_BOOST_LOG
)
103 cpu_boost_first
= (cpu_boost_first
+1)%MAX_BOOST_LOG
;
104 cpu_boost_calls_count
--;
105 if (cpu_boost_calls_count
< 0)
106 cpu_boost_calls_count
= 0;
108 if (cpu_boost_calls_count
< MAX_BOOST_LOG
)
110 int message
= (cpu_boost_first
+cpu_boost_calls_count
)%MAX_BOOST_LOG
;
111 snprintf(cpu_boost_calls
[message
], MAX_PATH
,
112 "%c %s:%d",on_off
?'B':'U',location
,line
);
113 cpu_boost_calls_count
++;
116 void cpu_boost(bool on_off
)
118 corelock_lock(&boostctrl_cl
);
119 #endif /* CPU_BOOST_LOGGING */
122 /* Boost the frequency if not already boosted */
123 if(++boost_counter
== 1)
124 set_cpu_frequency(CPUFREQ_MAX
);
128 /* Lower the frequency if the counter reaches 0 */
129 if(--boost_counter
<= 0)
132 set_cpu_frequency(CPUFREQ_DEFAULT
);
134 set_cpu_frequency(CPUFREQ_NORMAL
);
137 if (boost_counter
< 0)
144 corelock_unlock(&boostctrl_cl
);
147 void cpu_idle_mode(bool on_off
)
149 corelock_lock(&boostctrl_cl
);
153 /* We need to adjust the frequency immediately if the CPU
155 if(boost_counter
== 0)
158 set_cpu_frequency(CPUFREQ_DEFAULT
);
160 set_cpu_frequency(CPUFREQ_NORMAL
);
163 corelock_unlock(&boostctrl_cl
);
165 #endif /* HAVE_ADJUSTABLE_CPU_FREQ */
168 #ifdef HAVE_FLASHED_ROCKBOX
169 static bool detect_flash_header(uint8_t *addr
)
172 int oldmode
= system_memory_guard(MEMGUARD_NONE
);
174 struct flash_header hdr
;
175 memcpy(&hdr
, addr
, sizeof(struct flash_header
));
177 system_memory_guard(oldmode
);
179 return hdr
.magic
== FLASH_MAGIC
;
183 bool detect_flashed_romimage(void)
185 #ifdef HAVE_FLASHED_ROCKBOX
186 return detect_flash_header((uint8_t *)FLASH_ROMIMAGE_ENTRY
);
189 #endif /* HAVE_FLASHED_ROCKBOX */
192 bool detect_flashed_ramimage(void)
194 #ifdef HAVE_FLASHED_ROCKBOX
195 return detect_flash_header((uint8_t *)FLASH_RAMIMAGE_ENTRY
);
198 #endif /* HAVE_FLASHED_ROCKBOX */
201 bool detect_original_firmware(void)
203 return !(detect_flashed_ramimage() || detect_flashed_romimage());