17 #include <linux/errno.h>
18 #include <linux/module.h>
19 #include <linux/sched.h>
20 #include <linux/kernel.h>
22 #include <linux/string.h>
25 #include <linux/time.h>
26 #include <linux/rtc.h>
28 #include <linux/timex.h>
32 #include <linux/pci.h>
39 #include <asm/oplib.h>
40 #include <asm/timex.h>
41 #include <asm/timer.h>
44 #include <asm/idprom.h>
47 #include <asm/irq_regs.h>
48 #include <asm/setup.h>
53 static __volatile__
u64 timer_cs_internal_counter = 0;
54 static char timer_cs_enabled = 0;
56 static struct clock_event_device timer_ce;
57 static char timer_ce_enabled = 0;
70 extern char __copy_user_begin[], __copy_user_end[];
71 extern char __bzero_begin[], __bzero_end[];
73 unsigned long pc = regs->
pc;
76 (pc >= (
unsigned long) __copy_user_begin &&
77 pc < (
unsigned long) __copy_user_end) ||
78 (pc >= (
unsigned long) __bzero_begin &&
79 pc < (
unsigned long) __bzero_end))
95 if (timer_cs_enabled) {
96 write_seqlock(&timer_cs_lock);
97 timer_cs_internal_counter++;
99 write_sequnlock(&timer_cs_lock);
104 if (timer_ce_enabled)
105 timer_ce.event_handler(&timer_ce);
110 static void timer_ce_set_mode(
enum clock_event_mode
mode,
111 struct clock_event_device *
evt)
114 case CLOCK_EVT_MODE_PERIODIC:
115 case CLOCK_EVT_MODE_RESUME:
116 timer_ce_enabled = 1;
118 case CLOCK_EVT_MODE_SHUTDOWN:
119 timer_ce_enabled = 0;
127 static __init void setup_timer_ce(
void)
129 struct clock_event_device *
ce = &timer_ce;
133 ce->name =
"timer_ce";
135 ce->features = CLOCK_EVT_FEAT_PERIODIC;
136 ce->set_mode = timer_ce_set_mode;
144 static unsigned int sbus_cycles_offset(
void)
164 seq = read_seqbegin(&timer_cs_lock);
166 cycles = timer_cs_internal_counter;
168 }
while (read_seqretry(&timer_cs_lock, seq));
180 .read = timer_cs_read,
186 static __init int setup_timer_cs(
void)
188 timer_cs_enabled = 1;
196 static void percpu_ce_setup(
enum clock_event_mode mode,
197 struct clock_event_device *evt)
202 case CLOCK_EVT_MODE_PERIODIC:
206 case CLOCK_EVT_MODE_ONESHOT:
207 case CLOCK_EVT_MODE_SHUTDOWN:
208 case CLOCK_EVT_MODE_UNUSED:
216 static int percpu_ce_set_next_event(
unsigned long delta,
217 struct clock_event_device *evt)
220 unsigned int next = (
unsigned int)delta;
226 void register_percpu_ce(
int cpu)
228 struct clock_event_device *ce = &
per_cpu(sparc32_clockevent, cpu);
229 unsigned int features = CLOCK_EVT_FEAT_PERIODIC;
232 features |= CLOCK_EVT_FEAT_ONESHOT;
234 ce->name =
"percpu_ce";
237 ce->set_mode = percpu_ce_setup;
238 ce->set_next_event = percpu_ce_set_next_event;
250 static unsigned char mostek_read_byte(
struct device *
dev,
u32 ofs)
258 static void mostek_write_byte(
struct device *
dev,
u32 ofs,
u8 val)
267 .read_byte = mostek_read_byte,
268 .write_byte = mostek_write_byte,
273 .name =
"rtc-m48t59",
277 .platform_data = &m48t59_data,
294 if (!
strcmp(model,
"mk48t02")) {
299 }
else if (!
strcmp(model,
"mk48t08")) {
320 .probe = clock_probe,
324 .of_match_table = clock_match,
330 static int __init clock_init(
void)
340 static void __init sparc32_late_time_init(
void)
351 static void __init sbus_time_init(
void)