blob: 0fac5c1707fd3140ba62b6332e9a3577a92a5df1 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
wdenk15809242002-09-08 20:56:32 +00002/*
3 * (C) Copyright 2002
4 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
5 * Marius Groeger <mgroeger@sysgo.de>
6 *
7 * (C) Copyright 2002
8 * Sysgo Real-Time Solutions, GmbH <www.elinos.com>
9 * Alex Zuepke <azu@sysgo.de>
wdenk15809242002-09-08 20:56:32 +000010 */
11
12#include <common.h>
13#include <SA-1100.h>
14
Patrick Delaunay9858a602018-10-05 11:33:52 +020015static ulong get_timer_masked (void)
wdenk15809242002-09-08 20:56:32 +000016{
Patrick Delaunay9858a602018-10-05 11:33:52 +020017 return OSCR;
wdenk15809242002-09-08 20:56:32 +000018}
19
Patrick Delaunay9858a602018-10-05 11:33:52 +020020ulong get_timer (ulong base)
wdenk15809242002-09-08 20:56:32 +000021{
Patrick Delaunay9858a602018-10-05 11:33:52 +020022 return get_timer_masked ();
wdenk15809242002-09-08 20:56:32 +000023}
24
Patrick Delaunay94a08592018-10-05 11:33:51 +020025void __udelay (unsigned long usec)
wdenk15809242002-09-08 20:56:32 +000026{
27 ulong tmo;
wdenk7af1f9d2005-04-04 12:08:28 +000028 ulong endtime;
29 signed long diff;
wdenk15809242002-09-08 20:56:32 +000030
wdenk7af1f9d2005-04-04 12:08:28 +000031 if (usec >= 1000) {
32 tmo = usec / 1000;
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020033 tmo *= CONFIG_SYS_HZ;
wdenk7af1f9d2005-04-04 12:08:28 +000034 tmo /= 1000;
35 } else {
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020036 tmo = usec * CONFIG_SYS_HZ;
wdenk7af1f9d2005-04-04 12:08:28 +000037 tmo /= (1000*1000);
38 }
wdenk15809242002-09-08 20:56:32 +000039
wdenk7af1f9d2005-04-04 12:08:28 +000040 endtime = get_timer_masked () + tmo;
wdenk15809242002-09-08 20:56:32 +000041
wdenk7af1f9d2005-04-04 12:08:28 +000042 do {
43 ulong now = get_timer_masked ();
44 diff = endtime - now;
45 } while (diff >= 0);
wdenk15809242002-09-08 20:56:32 +000046}
wdenke28cf632004-03-14 15:20:55 +000047
48/*
49 * This function is derived from PowerPC code (read timebase as long long).
50 * On ARM it just returns the timer value.
51 */
52unsigned long long get_ticks(void)
53{
54 return get_timer(0);
55}
56
57/*
58 * This function is derived from PowerPC code (timebase clock frequency).
59 * On ARM it returns the number of timer ticks per second.
60 */
61ulong get_tbclk (void)
62{
Masahiro Yamada04cfea52016-09-06 22:17:38 +090063 return CONFIG_SYS_HZ;
wdenke28cf632004-03-14 15:20:55 +000064}