forked from Minki/linux
ARM: mach-shmobile: Introduce shmobile_setup_delay()
Add the function shmobile_setup_delay() to let platforms configure their maximum loops per jiffy delay. With this jiffies calculation done the dependency on early timer is removed. In the future this allows us to assign timers using the regular driver model via the device tree. Signed-off-by: Magnus Damm <damm@opensource.se> Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
This commit is contained in:
parent
0034102808
commit
0f2c9f20e4
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
extern void shmobile_earlytimer_init(void);
|
extern void shmobile_earlytimer_init(void);
|
||||||
extern struct sys_timer shmobile_timer;
|
extern struct sys_timer shmobile_timer;
|
||||||
|
extern void shmobile_setup_delay(unsigned int max_cpu_core_mhz,
|
||||||
|
unsigned int mult, unsigned int div);
|
||||||
struct twd_local_timer;
|
struct twd_local_timer;
|
||||||
void shmobile_twd_init(struct twd_local_timer *twd_local_timer);
|
void shmobile_twd_init(struct twd_local_timer *twd_local_timer);
|
||||||
extern void shmobile_setup_console(void);
|
extern void shmobile_setup_console(void);
|
||||||
|
@ -19,9 +19,26 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
|
#include <linux/delay.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
#include <asm/smp_twd.h>
|
#include <asm/smp_twd.h>
|
||||||
|
|
||||||
|
void __init shmobile_setup_delay(unsigned int max_cpu_core_mhz,
|
||||||
|
unsigned int mult, unsigned int div)
|
||||||
|
{
|
||||||
|
/* calculate a worst-case loops-per-jiffy value
|
||||||
|
* based on maximum cpu core mhz setting and the
|
||||||
|
* __delay() implementation in arch/arm/lib/delay.S
|
||||||
|
*
|
||||||
|
* this will result in a longer delay than expected
|
||||||
|
* when the cpu core runs on lower frequencies.
|
||||||
|
*/
|
||||||
|
|
||||||
|
unsigned int value = (1000000 * mult) / (HZ * div);
|
||||||
|
|
||||||
|
lpj_fine = max_cpu_core_mhz * value;
|
||||||
|
}
|
||||||
|
|
||||||
static void __init shmobile_late_time_init(void)
|
static void __init shmobile_late_time_init(void)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user