mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
2874c5fd28
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation either version 2 of the license or at your option any later version extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 3029 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070032.746973796@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
74 lines
1.6 KiB
C
74 lines
1.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Copyright (C) 2001, 2002, MontaVista Software Inc.
|
|
* Author: Jun Sun, jsun@mvista.com or jsun@junsun.net
|
|
* Copyright (c) 2003 Maciej W. Rozycki
|
|
*
|
|
* include/asm-mips/time.h
|
|
* header file for the new style time.c file and time services.
|
|
*/
|
|
#ifndef _ASM_TIME_H
|
|
#define _ASM_TIME_H
|
|
|
|
#include <linux/rtc.h>
|
|
#include <linux/spinlock.h>
|
|
#include <linux/clockchips.h>
|
|
#include <linux/clocksource.h>
|
|
|
|
extern spinlock_t rtc_lock;
|
|
|
|
/*
|
|
* board specific routines required by time_init().
|
|
*/
|
|
extern void plat_time_init(void);
|
|
|
|
/*
|
|
* mips_hpt_frequency - must be set if you intend to use an R4k-compatible
|
|
* counter as a timer interrupt source.
|
|
*/
|
|
extern unsigned int mips_hpt_frequency;
|
|
|
|
/*
|
|
* The performance counter IRQ on MIPS is a close relative to the timer IRQ
|
|
* so it lives here.
|
|
*/
|
|
extern int (*perf_irq)(void);
|
|
extern int __weak get_c0_perfcount_int(void);
|
|
|
|
/*
|
|
* Initialize the calling CPU's compare interrupt as clockevent device
|
|
*/
|
|
extern unsigned int get_c0_compare_int(void);
|
|
extern int r4k_clockevent_init(void);
|
|
|
|
static inline int mips_clockevent_init(void)
|
|
{
|
|
#ifdef CONFIG_CEVT_R4K
|
|
return r4k_clockevent_init();
|
|
#else
|
|
return -ENXIO;
|
|
#endif
|
|
}
|
|
|
|
/*
|
|
* Initialize the count register as a clocksource
|
|
*/
|
|
extern int init_r4k_clocksource(void);
|
|
|
|
static inline int init_mips_clocksource(void)
|
|
{
|
|
#ifdef CONFIG_CSRC_R4K
|
|
return init_r4k_clocksource();
|
|
#else
|
|
return 0;
|
|
#endif
|
|
}
|
|
|
|
static inline void clockevent_set_clock(struct clock_event_device *cd,
|
|
unsigned int clock)
|
|
{
|
|
clockevents_calc_mult_shift(cd, clock, 4);
|
|
}
|
|
|
|
#endif /* _ASM_TIME_H */
|