18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * SH-Mobile Timer 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (C) 2010 Magnus Damm 68c2ecf20Sopenharmony_ci * Copyright (C) 2002 - 2009 Paul Mundt 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci#include <linux/platform_device.h> 98c2ecf20Sopenharmony_ci#include <linux/clocksource.h> 108c2ecf20Sopenharmony_ci#include <linux/delay.h> 118c2ecf20Sopenharmony_ci#include <linux/of_address.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#include "common.h" 148c2ecf20Sopenharmony_ci 158c2ecf20Sopenharmony_civoid __init shmobile_init_delay(void) 168c2ecf20Sopenharmony_ci{ 178c2ecf20Sopenharmony_ci struct device_node *np; 188c2ecf20Sopenharmony_ci u32 max_freq = 0; 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_ci for_each_of_cpu_node(np) { 218c2ecf20Sopenharmony_ci u32 freq; 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_ci if (!of_property_read_u32(np, "clock-frequency", &freq)) 248c2ecf20Sopenharmony_ci max_freq = max(max_freq, freq); 258c2ecf20Sopenharmony_ci } 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_ci if (!max_freq) 288c2ecf20Sopenharmony_ci return; 298c2ecf20Sopenharmony_ci 308c2ecf20Sopenharmony_ci /* 318c2ecf20Sopenharmony_ci * Calculate a worst-case loops-per-jiffy value 328c2ecf20Sopenharmony_ci * based on maximum cpu core hz setting and the 338c2ecf20Sopenharmony_ci * __delay() implementation in arch/arm/lib/delay.S. 348c2ecf20Sopenharmony_ci * 358c2ecf20Sopenharmony_ci * This will result in a longer delay than expected 368c2ecf20Sopenharmony_ci * when the cpu core runs on lower frequencies. 378c2ecf20Sopenharmony_ci */ 388c2ecf20Sopenharmony_ci 398c2ecf20Sopenharmony_ci if (!preset_lpj) 408c2ecf20Sopenharmony_ci preset_lpj = max_freq / HZ; 418c2ecf20Sopenharmony_ci} 42