2008-02-08 20:19:31 +08:00
|
|
|
/* MN10300 Architecture time management specifications
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 Red Hat, Inc. All Rights Reserved.
|
|
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public Licence
|
|
|
|
* as published by the Free Software Foundation; either version
|
|
|
|
* 2 of the Licence, or (at your option) any later version.
|
|
|
|
*/
|
|
|
|
#ifndef _ASM_TIMEX_H
|
|
|
|
#define _ASM_TIMEX_H
|
|
|
|
|
|
|
|
#include <asm/hardirq.h>
|
2009-04-10 21:33:48 +08:00
|
|
|
#include <unit/timex.h>
|
2008-02-08 20:19:31 +08:00
|
|
|
|
|
|
|
#define TICK_SIZE (tick_nsec / 1000)
|
|
|
|
|
2010-10-28 00:28:55 +08:00
|
|
|
#define CLOCK_TICK_RATE MN10300_JCCLK /* Underlying HZ */
|
2008-02-08 20:19:31 +08:00
|
|
|
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
|
2010-10-28 00:28:57 +08:00
|
|
|
extern cycles_t cacheflush_time;
|
|
|
|
|
2008-02-08 20:19:31 +08:00
|
|
|
static inline cycles_t get_cycles(void)
|
|
|
|
{
|
|
|
|
return read_timestamp_counter();
|
|
|
|
}
|
|
|
|
|
2010-10-28 00:28:57 +08:00
|
|
|
extern int init_clockevents(void);
|
|
|
|
extern int init_clocksource(void);
|
|
|
|
|
|
|
|
static inline void setup_jiffies_interrupt(int irq,
|
|
|
|
struct irqaction *action)
|
|
|
|
{
|
|
|
|
u16 tmp;
|
|
|
|
setup_irq(irq, action);
|
|
|
|
set_intr_level(irq, NUM2GxICR_LEVEL(CONFIG_TIMER_IRQ_LEVEL));
|
|
|
|
GxICR(irq) |= GxICR_ENABLE | GxICR_DETECT | GxICR_REQUEST;
|
|
|
|
tmp = GxICR(irq);
|
|
|
|
}
|
|
|
|
|
2008-02-08 20:19:31 +08:00
|
|
|
#endif /* __KERNEL__ */
|
|
|
|
|
|
|
|
#endif /* _ASM_TIMEX_H */
|