Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
044836d4
Commit
044836d4
authored
Oct 05, 2004
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://bk.arm.linux.org.uk/linux-2.6-rmk
into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents
7e5829c1
ee206dc5
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
54 additions
and
9 deletions
+54
-9
arch/arm/kernel/time.c
arch/arm/kernel/time.c
+33
-0
arch/arm/mach-pxa/pm.c
arch/arm/mach-pxa/pm.c
+7
-3
arch/arm/mach-sa1100/pm.c
arch/arm/mach-sa1100/pm.c
+8
-4
arch/arm/mm/init.c
arch/arm/mm/init.c
+1
-0
include/asm-arm/mach/time.h
include/asm-arm/mach/time.h
+5
-2
No files found.
arch/arm/kernel/time.c
View file @
044836d4
...
@@ -304,6 +304,39 @@ int do_settimeofday(struct timespec *tv)
...
@@ -304,6 +304,39 @@ int do_settimeofday(struct timespec *tv)
EXPORT_SYMBOL
(
do_settimeofday
);
EXPORT_SYMBOL
(
do_settimeofday
);
/**
* save_time_delta - Save the offset between system time and RTC time
* @delta: pointer to timespec to store delta
* @rtc: pointer to timespec for current RTC time
*
* Return a delta between the system time and the RTC time, such
* that system time can be restored later with restore_time_delta()
*/
void
save_time_delta
(
struct
timespec
*
delta
,
struct
timespec
*
rtc
)
{
set_normalized_timespec
(
delta
,
xtime
.
tv_sec
-
rtc
->
tv_sec
,
xtime
.
tv_nsec
-
rtc
->
tv_nsec
);
}
EXPORT_SYMBOL
(
save_time_delta
);
/**
* restore_time_delta - Restore the current system time
* @delta: delta returned by save_time_delta()
* @rtc: pointer to timespec for current RTC time
*/
void
restore_time_delta
(
struct
timespec
*
delta
,
struct
timespec
*
rtc
)
{
struct
timespec
ts
;
set_normalized_timespec
(
&
ts
,
delta
->
tv_sec
+
rtc
->
tv_sec
,
delta
->
tv_nsec
+
rtc
->
tv_nsec
);
do_settimeofday
(
&
ts
);
}
EXPORT_SYMBOL
(
restore_time_delta
);
void
timer_tick
(
struct
pt_regs
*
regs
)
void
timer_tick
(
struct
pt_regs
*
regs
)
{
{
profile_tick
(
CPU_PROFILING
,
regs
);
profile_tick
(
CPU_PROFILING
,
regs
);
...
...
arch/arm/mach-pxa/pm.c
View file @
044836d4
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
#include <asm/system.h>
#include <asm/system.h>
#include <asm/arch/pxa-regs.h>
#include <asm/arch/pxa-regs.h>
#include <asm/arch/lubbock.h>
#include <asm/arch/lubbock.h>
#include <asm/mach/time.h>
/*
/*
...
@@ -69,14 +70,16 @@ static int pxa_pm_enter(u32 state)
...
@@ -69,14 +70,16 @@ static int pxa_pm_enter(u32 state)
{
{
unsigned
long
sleep_save
[
SLEEP_SAVE_SIZE
];
unsigned
long
sleep_save
[
SLEEP_SAVE_SIZE
];
unsigned
long
checksum
=
0
;
unsigned
long
checksum
=
0
;
unsigned
long
delta
;
struct
timespec
delta
,
rtc
;
int
i
;
int
i
;
if
(
state
!=
PM_SUSPEND_MEM
)
if
(
state
!=
PM_SUSPEND_MEM
)
return
-
EINVAL
;
return
-
EINVAL
;
/* preserve current time */
/* preserve current time */
delta
=
xtime
.
tv_sec
-
RCNR
;
rtc
.
tv_sec
=
RCNR
;
rtc
.
tv_nsec
=
0
;
save_time_delta
(
&
delta
,
&
rtc
);
/* save vital registers */
/* save vital registers */
SAVE
(
OSMR0
);
SAVE
(
OSMR0
);
...
@@ -161,7 +164,8 @@ static int pxa_pm_enter(u32 state)
...
@@ -161,7 +164,8 @@ static int pxa_pm_enter(u32 state)
RESTORE
(
ICMR
);
RESTORE
(
ICMR
);
/* restore current time */
/* restore current time */
xtime
.
tv_sec
=
RCNR
+
delta
;
rtc
.
tv_sec
=
RCNR
;
restore_time_delta
(
&
delta
,
&
rtc
);
#ifdef DEBUG
#ifdef DEBUG
printk
(
KERN_DEBUG
"*** made it back from resume
\n
"
);
printk
(
KERN_DEBUG
"*** made it back from resume
\n
"
);
...
...
arch/arm/mach-sa1100/pm.c
View file @
044836d4
...
@@ -30,6 +30,7 @@
...
@@ -30,6 +30,7 @@
#include <asm/hardware.h>
#include <asm/hardware.h>
#include <asm/memory.h>
#include <asm/memory.h>
#include <asm/system.h>
#include <asm/system.h>
#include <asm/mach/time.h>
extern
void
sa1100_cpu_suspend
(
void
);
extern
void
sa1100_cpu_suspend
(
void
);
extern
void
sa1100_cpu_resume
(
void
);
extern
void
sa1100_cpu_resume
(
void
);
...
@@ -58,14 +59,16 @@ enum { SLEEP_SAVE_SP = 0,
...
@@ -58,14 +59,16 @@ enum { SLEEP_SAVE_SP = 0,
static
int
sa11x0_pm_enter
(
u32
state
)
static
int
sa11x0_pm_enter
(
u32
state
)
{
{
unsigned
long
sleep_save
[
SLEEP_SAVE_SIZE
];
unsigned
long
gpio
,
sleep_save
[
SLEEP_SAVE_SIZE
];
unsigned
long
delta
,
gpio
;
struct
timespec
delta
,
rtc
;
if
(
state
!=
PM_SUSPEND_MEM
)
if
(
state
!=
PM_SUSPEND_MEM
)
return
-
EINVAL
;
return
-
EINVAL
;
/* preserve current time */
/* preserve current time */
delta
=
xtime
.
tv_sec
-
RCNR
;
rtc
.
tv_sec
=
RCNR
;
rtc
.
tv_nsec
=
0
;
save_time_delta
(
&
delta
,
&
rtc
);
gpio
=
GPLR
;
gpio
=
GPLR
;
/* save vital registers */
/* save vital registers */
...
@@ -136,7 +139,8 @@ static int sa11x0_pm_enter(u32 state)
...
@@ -136,7 +139,8 @@ static int sa11x0_pm_enter(u32 state)
OSCR
=
OSMR0
-
LATCH
;
OSCR
=
OSMR0
-
LATCH
;
/* restore current time */
/* restore current time */
xtime
.
tv_sec
=
RCNR
+
delta
;
rtc
.
tv_sec
=
RCNR
;
restore_time_delta
(
&
delta
,
&
rtc
);
return
0
;
return
0
;
}
}
...
...
arch/arm/mm/init.c
View file @
044836d4
...
@@ -14,6 +14,7 @@
...
@@ -14,6 +14,7 @@
#include <linux/swap.h>
#include <linux/swap.h>
#include <linux/init.h>
#include <linux/init.h>
#include <linux/bootmem.h>
#include <linux/bootmem.h>
#include <linux/mman.h>
#include <linux/initrd.h>
#include <linux/initrd.h>
#include <asm/mach-types.h>
#include <asm/mach-types.h>
...
...
include/asm-arm/mach/time.h
View file @
044836d4
...
@@ -13,8 +13,11 @@
...
@@ -13,8 +13,11 @@
extern
void
(
*
init_arch_time
)(
void
);
extern
void
(
*
init_arch_time
)(
void
);
extern
int
(
*
set_rtc
)(
void
);
extern
int
(
*
set_rtc
)(
void
);
extern
unsigned
long
(
*
gettimeoffset
)(
void
);
extern
unsigned
long
(
*
gettimeoffset
)(
void
);
void
timer_tick
(
struct
pt_regs
*
);
extern
void
timer_tick
(
struct
pt_regs
*
);
extern
void
save_time_delta
(
struct
timespec
*
delta
,
struct
timespec
*
rtc
);
extern
void
restore_time_delta
(
struct
timespec
*
delta
,
struct
timespec
*
rtc
);
#endif
#endif
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment