Commit 37a7059b authored by Jayachandran C's avatar Jayachandran C Committed by John Crispin

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: default avatarJayachandran C <jchandra@broadcom.com>
Patchwork: http://patchwork.linux-mips.org/patch/4791/Signed-off-by: default avatarJohn Crispin <blogic@openwrt.org>
parent 5a4cbe38
...@@ -98,6 +98,10 @@ void __init plat_time_init(void) ...@@ -98,6 +98,10 @@ void __init plat_time_init(void)
{ {
nlm_init_pic_timer(); nlm_init_pic_timer();
mips_hpt_frequency = nlm_get_cpu_frequency(); 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", pr_info("MIPS counter frequency [%ld]\n",
(unsigned long)mips_hpt_frequency); (unsigned long)mips_hpt_frequency);
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment