root/include/clocksource/timer-goldfish.h
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * goldfish-timer clocksource
 * Registers definition for the goldfish-timer device
 */

#ifndef _CLOCKSOURCE_TIMER_GOLDFISH_H
#define _CLOCKSOURCE_TIMER_GOLDFISH_H

/*
 * TIMER_TIME_LOW        get low bits of current time and update TIMER_TIME_HIGH
 * TIMER_TIME_HIGH       get high bits of time at last TIMER_TIME_LOW read
 * TIMER_ALARM_LOW       set low bits of alarm and activate it
 * TIMER_ALARM_HIGH      set high bits of next alarm
 * TIMER_IRQ_ENABLED     enable alarm interrupt
 * TIMER_CLEAR_ALARM     disarm an existing alarm
 * TIMER_ALARM_STATUS    alarm status (running or not)
 * TIMER_CLEAR_INTERRUPT clear interrupt
 */
#define TIMER_TIME_LOW          0x00
#define TIMER_TIME_HIGH         0x04
#define TIMER_ALARM_LOW         0x08
#define TIMER_ALARM_HIGH        0x0c
#define TIMER_IRQ_ENABLED       0x10
#define TIMER_CLEAR_ALARM       0x14
#define TIMER_ALARM_STATUS      0x18
#define TIMER_CLEAR_INTERRUPT   0x1c

extern int goldfish_timer_init(int irq, void __iomem *base);

#endif /* _CLOCKSOURCE_TIMER_GOLDFISH_H */