Linux Kernel
3.7.1
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
File List
Globals
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
arch
arm
mach-rpc
time.c
Go to the documentation of this file.
1
/*
2
* linux/arch/arm/common/time-acorn.c
3
*
4
* Copyright (c) 1996-2000 Russell King.
5
*
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License version 2 as
8
* published by the Free Software Foundation.
9
*
10
* Changelog:
11
* 24-Sep-1996 RMK Created
12
* 10-Oct-1996 RMK Brought up to date with arch-sa110eval
13
* 04-Dec-1997 RMK Updated for new arch/arm/time.c
14
* 13=Jun-2004 DS Moved to arch/arm/common b/c shared w/CLPS7500
15
*/
16
#include <linux/timex.h>
17
#include <
linux/init.h
>
18
#include <
linux/interrupt.h
>
19
#include <
linux/irq.h
>
20
#include <
linux/io.h
>
21
22
#include <mach/hardware.h>
23
#include <
asm/hardware/ioc.h
>
24
25
#include <
asm/mach/time.h
>
26
27
unsigned
long
ioc_timer_gettimeoffset
(
void
)
28
{
29
unsigned
int
count1
,
count2
,
status
;
30
long
offset
;
31
32
ioc_writeb
(0,
IOC_T0LATCH
);
33
barrier
();
34
count1 =
ioc_readb
(
IOC_T0CNTL
) | (
ioc_readb
(
IOC_T0CNTH
) << 8);
35
barrier
();
36
status =
ioc_readb
(
IOC_IRQREQA
);
37
barrier
();
38
ioc_writeb
(0,
IOC_T0LATCH
);
39
barrier
();
40
count2 =
ioc_readb
(
IOC_T0CNTL
) | (
ioc_readb
(
IOC_T0CNTH
) << 8);
41
42
offset =
count2
;
43
if
(count2 < count1) {
44
/*
45
* We have not had an interrupt between reading count1
46
* and count2.
47
*/
48
if
(status & (1 << 5))
49
offset -=
LATCH
;
50
}
else
if
(count2 > count1) {
51
/*
52
* We have just had another interrupt between reading
53
* count1 and count2.
54
*/
55
offset -=
LATCH
;
56
}
57
58
offset = (
LATCH
-
offset
) * (
tick_nsec
/ 1000);
59
return
(offset +
LATCH
/2) /
LATCH
;
60
}
61
62
void
__init
ioctime_init
(
void
)
63
{
64
ioc_writeb
(
LATCH
& 255,
IOC_T0LTCHL
);
65
ioc_writeb
(
LATCH
>> 8,
IOC_T0LTCHH
);
66
ioc_writeb
(0,
IOC_T0GO
);
67
}
68
69
static
irqreturn_t
70
ioc_timer_interrupt(
int
irq,
void
*
dev_id
)
71
{
72
timer_tick
();
73
return
IRQ_HANDLED
;
74
}
75
76
static
struct
irqaction
ioc_timer_irq = {
77
.name =
"timer"
,
78
.flags =
IRQF_DISABLED
,
79
.handler = ioc_timer_interrupt
80
};
81
82
/*
83
* Set up timer interrupt.
84
*/
85
static
void
__init
ioc_timer_init(
void
)
86
{
87
ioctime_init
();
88
setup_irq
(
IRQ_TIMER0
, &ioc_timer_irq);
89
}
90
91
struct
sys_timer
ioc_timer
= {
92
.init = ioc_timer_init,
93
.offset =
ioc_timer_gettimeoffset
,
94
};
95
Generated on Thu Jan 10 2013 12:53:30 for Linux Kernel by
1.8.2