2005-04-17 05:20:36 +07:00
|
|
|
/*
|
|
|
|
* include/asm-s390/timer.h
|
|
|
|
*
|
2006-02-03 18:03:50 +07:00
|
|
|
* (C) Copyright IBM Corp. 2003,2006
|
2005-04-17 05:20:36 +07:00
|
|
|
* Virtual CPU timer
|
|
|
|
*
|
|
|
|
* Author: Jan Glauber (jang@de.ibm.com)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ASM_S390_TIMER_H
|
|
|
|
#define _ASM_S390_TIMER_H
|
|
|
|
|
2006-02-03 18:03:50 +07:00
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#include <linux/timer.h>
|
|
|
|
|
|
|
|
#define VTIMER_MAX_SLICE (0x7ffffffffffff000LL)
|
|
|
|
|
|
|
|
struct vtimer_list {
|
|
|
|
struct list_head entry;
|
|
|
|
|
|
|
|
int cpu;
|
|
|
|
__u64 expires;
|
|
|
|
__u64 interval;
|
|
|
|
|
|
|
|
spinlock_t lock;
|
|
|
|
unsigned long magic;
|
|
|
|
|
2006-10-11 20:31:26 +07:00
|
|
|
void (*function)(unsigned long);
|
2005-04-17 05:20:36 +07:00
|
|
|
unsigned long data;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* the offset value will wrap after ca. 71 years */
|
|
|
|
struct vtimer_queue {
|
|
|
|
struct list_head list;
|
|
|
|
spinlock_t lock;
|
|
|
|
__u64 to_expire; /* current event expire time */
|
|
|
|
__u64 offset; /* list offset to zero */
|
|
|
|
__u64 idle; /* temp var for idle */
|
|
|
|
};
|
|
|
|
|
|
|
|
extern void init_virt_timer(struct vtimer_list *timer);
|
|
|
|
extern void add_virt_timer(void *new);
|
|
|
|
extern void add_virt_timer_periodic(void *new);
|
|
|
|
extern int mod_virt_timer(struct vtimer_list *timer, __u64 expires);
|
|
|
|
extern int del_virt_timer(struct vtimer_list *timer);
|
|
|
|
|
2007-02-06 03:16:47 +07:00
|
|
|
extern void init_cpu_vtimer(void);
|
|
|
|
extern void vtime_init(void);
|
|
|
|
|
2006-02-03 18:03:50 +07:00
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
|
|
|
|
#endif /* _ASM_S390_TIMER_H */
|