diff options
author | Jayachandran C <jchandra@broadcom.com> | 2013-01-14 16:12:00 +0100 |
---|---|---|
committer | John Crispin <blogic@openwrt.org> | 2013-02-17 00:15:21 +0100 |
commit | 37a7059bc4228613867645be50120aff17a162a1 (patch) | |
tree | 2079e8eeecc7947dd804fbe520326dfa72d4ce99 /arch/mips/netlogic | |
parent | MIPS: Netlogic: No hazards needed for XLR/XLS (diff) | |
download | linux-37a7059bc4228613867645be50120aff17a162a1.tar.xz linux-37a7059bc4228613867645be50120aff17a162a1.zip |
MIPS: Netlogic: use preset loops per jiffy
Doing calibrate delay on a hardware thread will be inaccurate since
it depends on the load on other threads in the core. It will also
slow down the boot process when done for 128 hardware threads. Switch
to a pre-computed loops per jiffy based on the core frequency. The
value is computed based on the core frequency and roughly matches the
value calculated by calibrate_delay().
Signed-off-by: Jayachandran C <jchandra@broadcom.com>
Patchwork: http://patchwork.linux-mips.org/patch/4791/
Signed-off-by: John Crispin <blogic@openwrt.org>
Diffstat (limited to 'arch/mips/netlogic')
-rw-r--r-- | arch/mips/netlogic/common/time.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/mips/netlogic/common/time.c b/arch/mips/netlogic/common/time.c index 20f89bc0507f..5c56555380bb 100644 --- a/arch/mips/netlogic/common/time.c +++ b/arch/mips/netlogic/common/time.c @@ -98,6 +98,10 @@ void __init plat_time_init(void) { nlm_init_pic_timer(); mips_hpt_frequency = nlm_get_cpu_frequency(); + if (current_cpu_type() == CPU_XLR) + preset_lpj = mips_hpt_frequency / (3 * HZ); + else + preset_lpj = mips_hpt_frequency / (2 * HZ); pr_info("MIPS counter frequency [%ld]\n", (unsigned long)mips_hpt_frequency); } |