/* * (C) Copyright 2003 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * SPDX-License-Identifier: GPL-2.0+ */ #include #include static unsigned long timestamp; /* how many counter cycles in a jiffy */ #define CYCLES_PER_JIFFY \ (CONFIG_SYS_MIPS_TIMER_FREQ + CONFIG_SYS_HZ / 2) / CONFIG_SYS_HZ /* * timer without interrupts */ int timer_init(void) { /* Set up the timer for the first expiration. */ write_c0_compare(read_c0_count() + CYCLES_PER_JIFFY); return 0; } ulong get_timer(ulong base) { unsigned int count; unsigned int expirelo = read_c0_compare(); /* Check to see if we have missed any timestamps. */ count = read_c0_count(); while ((count - expirelo) < 0x7fffffff) { expirelo += CYCLES_PER_JIFFY; timestamp++; } write_c0_compare(expirelo); return timestamp - base; } void __udelay(unsigned long usec) { unsigned int tmo; tmo = read_c0_count() + (usec * (CONFIG_SYS_MIPS_TIMER_FREQ / 1000000)); while ((tmo - read_c0_count()) < 0x7fffffff) /*NOP*/; } /* * This function is derived from PowerPC code (read timebase as long long). * On MIPS it just returns the timer value. */ unsigned long long get_ticks(void) { return get_timer(0); } /* * This function is derived from PowerPC code (timebase clock frequency). * On MIPS it returns the number of timer ticks per second. */ ulong get_tbclk(void) { return CONFIG_SYS_HZ; }