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