162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2001, 2002, MontaVista Software Inc. 462306a36Sopenharmony_ci * Author: Jun Sun, jsun@mvista.com or jsun@junsun.net 562306a36Sopenharmony_ci * Copyright (c) 2003 Maciej W. Rozycki 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * include/asm-mips/time.h 862306a36Sopenharmony_ci * header file for the new style time.c file and time services. 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci#ifndef _ASM_TIME_H 1162306a36Sopenharmony_ci#define _ASM_TIME_H 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include <linux/rtc.h> 1462306a36Sopenharmony_ci#include <linux/spinlock.h> 1562306a36Sopenharmony_ci#include <linux/clockchips.h> 1662306a36Sopenharmony_ci#include <linux/clocksource.h> 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ciextern spinlock_t rtc_lock; 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci/* 2162306a36Sopenharmony_ci * board specific routines required by time_init(). 2262306a36Sopenharmony_ci */ 2362306a36Sopenharmony_ciextern void plat_time_init(void); 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci/* 2662306a36Sopenharmony_ci * mips_hpt_frequency - must be set if you intend to use an R4k-compatible 2762306a36Sopenharmony_ci * counter as a timer interrupt source. 2862306a36Sopenharmony_ci */ 2962306a36Sopenharmony_ciextern unsigned int mips_hpt_frequency; 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_ci/* 3262306a36Sopenharmony_ci * The performance counter IRQ on MIPS is a close relative to the timer IRQ 3362306a36Sopenharmony_ci * so it lives here. 3462306a36Sopenharmony_ci */ 3562306a36Sopenharmony_ciextern int (*perf_irq)(void); 3662306a36Sopenharmony_ciextern int __weak get_c0_perfcount_int(void); 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci/* 3962306a36Sopenharmony_ci * Initialize the calling CPU's compare interrupt as clockevent device 4062306a36Sopenharmony_ci */ 4162306a36Sopenharmony_ciextern unsigned int get_c0_compare_int(void); 4262306a36Sopenharmony_ciextern int r4k_clockevent_init(void); 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_cistatic inline int mips_clockevent_init(void) 4562306a36Sopenharmony_ci{ 4662306a36Sopenharmony_ci#ifdef CONFIG_CEVT_R4K 4762306a36Sopenharmony_ci return r4k_clockevent_init(); 4862306a36Sopenharmony_ci#else 4962306a36Sopenharmony_ci return -ENXIO; 5062306a36Sopenharmony_ci#endif 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci/* 5462306a36Sopenharmony_ci * Initialize the count register as a clocksource 5562306a36Sopenharmony_ci */ 5662306a36Sopenharmony_ciextern int init_r4k_clocksource(void); 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cistatic inline int init_mips_clocksource(void) 5962306a36Sopenharmony_ci{ 6062306a36Sopenharmony_ci#ifdef CONFIG_CSRC_R4K 6162306a36Sopenharmony_ci return init_r4k_clocksource(); 6262306a36Sopenharmony_ci#else 6362306a36Sopenharmony_ci return 0; 6462306a36Sopenharmony_ci#endif 6562306a36Sopenharmony_ci} 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_cistatic inline void clockevent_set_clock(struct clock_event_device *cd, 6862306a36Sopenharmony_ci unsigned int clock) 6962306a36Sopenharmony_ci{ 7062306a36Sopenharmony_ci clockevents_calc_mult_shift(cd, clock, 4); 7162306a36Sopenharmony_ci} 7262306a36Sopenharmony_ci 7362306a36Sopenharmony_ci#endif /* _ASM_TIME_H */ 74