diff options
author | Paul Mackerras <paulus@samba.org> | 2005-10-19 09:11:21 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2005-10-19 09:11:21 -0400 |
commit | 143a1dec7e04e0a9712ff93e779aabfb21dfd97c (patch) | |
tree | 3a60a4e630d792fb3cdc6e962ce0ecfd94bb2672 /arch | |
parent | 7ed476d17f04473f70d796cb6c172bdcfcc9b8e5 (diff) |
powerpc: Merge machdep.h
A few things change for consistency between ppc32 and ppc64:
idle functions return void; *_get_boot_time functions return
unsigned long (i.e. time_t) rather than filling in a struct rtc_time
(since that's useful to the callers and easier for pmac to
generate); *_get_rtc_time and *_set_rtc_time functions take
a struct rtc_time; irq_canonicalize is gone; nvram_sync returns
void.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/powerpc/platforms/iseries/mf.c | 12 | ||||
-rw-r--r-- | arch/powerpc/platforms/iseries/setup.c | 12 | ||||
-rw-r--r-- | arch/powerpc/platforms/iseries/setup.h | 2 | ||||
-rw-r--r-- | arch/powerpc/platforms/powermac/pmac.h | 7 | ||||
-rw-r--r-- | arch/powerpc/platforms/powermac/setup.c | 2 | ||||
-rw-r--r-- | arch/powerpc/platforms/powermac/time.c | 24 | ||||
-rw-r--r-- | arch/powerpc/platforms/pseries/setup.c | 12 | ||||
-rw-r--r-- | arch/ppc64/kernel/idle.c | 8 | ||||
-rw-r--r-- | arch/ppc64/kernel/maple_setup.c | 2 | ||||
-rw-r--r-- | arch/ppc64/kernel/maple_time.c | 7 | ||||
-rw-r--r-- | arch/ppc64/kernel/pmac.h | 2 | ||||
-rw-r--r-- | arch/ppc64/kernel/pmac_nvram.c | 4 | ||||
-rw-r--r-- | arch/ppc64/kernel/pmac_time.c | 21 | ||||
-rw-r--r-- | arch/ppc64/kernel/rtas-proc.c | 1 | ||||
-rw-r--r-- | arch/ppc64/kernel/rtc.c | 11 |
15 files changed, 62 insertions, 65 deletions
diff --git a/arch/powerpc/platforms/iseries/mf.c b/arch/powerpc/platforms/iseries/mf.c index 3f25f7fc79fc..e5de31aa0015 100644 --- a/arch/powerpc/platforms/iseries/mf.c +++ b/arch/powerpc/platforms/iseries/mf.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <linux/delay.h> | 32 | #include <linux/delay.h> |
33 | #include <linux/dma-mapping.h> | 33 | #include <linux/dma-mapping.h> |
34 | #include <linux/bcd.h> | 34 | #include <linux/bcd.h> |
35 | #include <linux/rtc.h> | ||
35 | 36 | ||
36 | #include <asm/time.h> | 37 | #include <asm/time.h> |
37 | #include <asm/uaccess.h> | 38 | #include <asm/uaccess.h> |
@@ -1307,11 +1308,14 @@ int iSeries_set_rtc_time(struct rtc_time *tm) | |||
1307 | return 0; | 1308 | return 0; |
1308 | } | 1309 | } |
1309 | 1310 | ||
1310 | void iSeries_get_boot_time(struct rtc_time *tm) | 1311 | unsigned long iSeries_get_boot_time(void) |
1311 | { | 1312 | { |
1313 | struct rtc_time tm; | ||
1314 | |||
1312 | if (piranha_simulator) | 1315 | if (piranha_simulator) |
1313 | return; | 1316 | return 0; |
1314 | 1317 | ||
1315 | mf_get_boot_rtc(tm); | 1318 | mf_get_boot_rtc(&tm); |
1316 | tm->tm_mon -= 1; | 1319 | return mktime(tm.tm_year + 1900, tm.tm_mon, tm.tm_mday, |
1320 | tm.tm_hour, tm.tm_min, tm.tm_sec); | ||
1317 | } | 1321 | } |
diff --git a/arch/powerpc/platforms/iseries/setup.c b/arch/powerpc/platforms/iseries/setup.c index 93852c2ee5de..41cd5b689545 100644 --- a/arch/powerpc/platforms/iseries/setup.c +++ b/arch/powerpc/platforms/iseries/setup.c | |||
@@ -73,8 +73,8 @@ extern void hvlog(char *fmt, ...); | |||
73 | extern void ppcdbg_initialize(void); | 73 | extern void ppcdbg_initialize(void); |
74 | 74 | ||
75 | static void build_iSeries_Memory_Map(void); | 75 | static void build_iSeries_Memory_Map(void); |
76 | static int iseries_shared_idle(void); | 76 | static void iseries_shared_idle(void); |
77 | static int iseries_dedicated_idle(void); | 77 | static void iseries_dedicated_idle(void); |
78 | #ifdef CONFIG_PCI | 78 | #ifdef CONFIG_PCI |
79 | extern void iSeries_pci_final_fixup(void); | 79 | extern void iSeries_pci_final_fixup(void); |
80 | #else | 80 | #else |
@@ -693,7 +693,7 @@ static void yield_shared_processor(void) | |||
693 | process_iSeries_events(); | 693 | process_iSeries_events(); |
694 | } | 694 | } |
695 | 695 | ||
696 | static int iseries_shared_idle(void) | 696 | static void iseries_shared_idle(void) |
697 | { | 697 | { |
698 | while (1) { | 698 | while (1) { |
699 | while (!need_resched() && !hvlpevent_is_pending()) { | 699 | while (!need_resched() && !hvlpevent_is_pending()) { |
@@ -715,11 +715,9 @@ static int iseries_shared_idle(void) | |||
715 | 715 | ||
716 | schedule(); | 716 | schedule(); |
717 | } | 717 | } |
718 | |||
719 | return 0; | ||
720 | } | 718 | } |
721 | 719 | ||
722 | static int iseries_dedicated_idle(void) | 720 | static void iseries_dedicated_idle(void) |
723 | { | 721 | { |
724 | long oldval; | 722 | long oldval; |
725 | 723 | ||
@@ -749,8 +747,6 @@ static int iseries_dedicated_idle(void) | |||
749 | ppc64_runlatch_on(); | 747 | ppc64_runlatch_on(); |
750 | schedule(); | 748 | schedule(); |
751 | } | 749 | } |
752 | |||
753 | return 0; | ||
754 | } | 750 | } |
755 | 751 | ||
756 | #ifndef CONFIG_PCI | 752 | #ifndef CONFIG_PCI |
diff --git a/arch/powerpc/platforms/iseries/setup.h b/arch/powerpc/platforms/iseries/setup.h index 6da89ae991ce..5213044ec411 100644 --- a/arch/powerpc/platforms/iseries/setup.h +++ b/arch/powerpc/platforms/iseries/setup.h | |||
@@ -17,7 +17,7 @@ | |||
17 | #ifndef __ISERIES_SETUP_H__ | 17 | #ifndef __ISERIES_SETUP_H__ |
18 | #define __ISERIES_SETUP_H__ | 18 | #define __ISERIES_SETUP_H__ |
19 | 19 | ||
20 | extern void iSeries_get_boot_time(struct rtc_time *tm); | 20 | extern unsigned long iSeries_get_boot_time(void); |
21 | extern int iSeries_set_rtc_time(struct rtc_time *tm); | 21 | extern int iSeries_set_rtc_time(struct rtc_time *tm); |
22 | extern void iSeries_get_rtc_time(struct rtc_time *tm); | 22 | extern void iSeries_get_rtc_time(struct rtc_time *tm); |
23 | 23 | ||
diff --git a/arch/powerpc/platforms/powermac/pmac.h b/arch/powerpc/platforms/powermac/pmac.h index 81f52512b046..0a9ba704865e 100644 --- a/arch/powerpc/platforms/powermac/pmac.h +++ b/arch/powerpc/platforms/powermac/pmac.h | |||
@@ -10,9 +10,12 @@ | |||
10 | * pmac_* files. Mostly for use by pmac_setup | 10 | * pmac_* files. Mostly for use by pmac_setup |
11 | */ | 11 | */ |
12 | 12 | ||
13 | struct rtc_time; | ||
14 | |||
13 | extern long pmac_time_init(void); | 15 | extern long pmac_time_init(void); |
14 | extern unsigned long pmac_get_rtc_time(void); | 16 | extern unsigned long pmac_get_boot_time(void); |
15 | extern int pmac_set_rtc_time(unsigned long nowtime); | 17 | extern void pmac_get_rtc_time(struct rtc_time *); |
18 | extern int pmac_set_rtc_time(struct rtc_time *); | ||
16 | extern void pmac_read_rtc_time(void); | 19 | extern void pmac_read_rtc_time(void); |
17 | extern void pmac_calibrate_decr(void); | 20 | extern void pmac_calibrate_decr(void); |
18 | extern void pmac_pcibios_fixup(void); | 21 | extern void pmac_pcibios_fixup(void); |
diff --git a/arch/powerpc/platforms/powermac/setup.c b/arch/powerpc/platforms/powermac/setup.c index 7eb0c34b6994..b6414e7c37d4 100644 --- a/arch/powerpc/platforms/powermac/setup.c +++ b/arch/powerpc/platforms/powermac/setup.c | |||
@@ -562,7 +562,6 @@ void __init pmac_init(void) | |||
562 | ppc_md.setup_arch = pmac_setup_arch; | 562 | ppc_md.setup_arch = pmac_setup_arch; |
563 | ppc_md.show_cpuinfo = pmac_show_cpuinfo; | 563 | ppc_md.show_cpuinfo = pmac_show_cpuinfo; |
564 | ppc_md.show_percpuinfo = pmac_show_percpuinfo; | 564 | ppc_md.show_percpuinfo = pmac_show_percpuinfo; |
565 | ppc_md.irq_canonicalize = NULL; | ||
566 | ppc_md.init_IRQ = pmac_pic_init; | 565 | ppc_md.init_IRQ = pmac_pic_init; |
567 | ppc_md.get_irq = pmac_get_irq; /* Changed later on ... */ | 566 | ppc_md.get_irq = pmac_get_irq; /* Changed later on ... */ |
568 | 567 | ||
@@ -578,6 +577,7 @@ void __init pmac_init(void) | |||
578 | ppc_md.time_init = pmac_time_init; | 577 | ppc_md.time_init = pmac_time_init; |
579 | ppc_md.set_rtc_time = pmac_set_rtc_time; | 578 | ppc_md.set_rtc_time = pmac_set_rtc_time; |
580 | ppc_md.get_rtc_time = pmac_get_rtc_time; | 579 | ppc_md.get_rtc_time = pmac_get_rtc_time; |
580 | ppc_md.get_boot_time = pmac_get_boot_time; | ||
581 | ppc_md.calibrate_decr = pmac_calibrate_decr; | 581 | ppc_md.calibrate_decr = pmac_calibrate_decr; |
582 | 582 | ||
583 | ppc_md.feature_call = pmac_do_feature_call; | 583 | ppc_md.feature_call = pmac_do_feature_call; |
diff --git a/arch/powerpc/platforms/powermac/time.c b/arch/powerpc/platforms/powermac/time.c index edb9fcc64790..3ee6d8aa14c4 100644 --- a/arch/powerpc/platforms/powermac/time.c +++ b/arch/powerpc/platforms/powermac/time.c | |||
@@ -77,8 +77,7 @@ pmac_time_init(void) | |||
77 | #endif | 77 | #endif |
78 | } | 78 | } |
79 | 79 | ||
80 | unsigned long | 80 | unsigned long pmac_get_boot_time(void) |
81 | pmac_get_rtc_time(void) | ||
82 | { | 81 | { |
83 | #if defined(CONFIG_ADB_CUDA) || defined(CONFIG_ADB_PMU) | 82 | #if defined(CONFIG_ADB_CUDA) || defined(CONFIG_ADB_PMU) |
84 | struct adb_request req; | 83 | struct adb_request req; |
@@ -118,20 +117,33 @@ pmac_get_rtc_time(void) | |||
118 | return 0; | 117 | return 0; |
119 | } | 118 | } |
120 | 119 | ||
121 | int | 120 | void pmac_get_rtc_time(struct rtc_time *tm) |
122 | pmac_set_rtc_time(unsigned long nowtime) | ||
123 | { | 121 | { |
122 | unsigned long now; | ||
123 | |||
124 | now = pmac_get_boot_time(); | ||
125 | to_tm(now, tm); | ||
126 | tm->tm_year -= 1900; | ||
127 | tm->tm_mon -= 1; /* month is 0-based */ | ||
128 | } | ||
129 | |||
130 | int pmac_set_rtc_time(struct rtc_time *tm) | ||
131 | { | ||
132 | unsigned long nowtime; | ||
124 | #if defined(CONFIG_ADB_CUDA) || defined(CONFIG_ADB_PMU) | 133 | #if defined(CONFIG_ADB_CUDA) || defined(CONFIG_ADB_PMU) |
125 | struct adb_request req; | 134 | struct adb_request req; |
126 | #endif | 135 | #endif |
127 | 136 | ||
137 | nowtime = mktime(tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday, | ||
138 | tm->tm_hour, tm->tm_min, tm->tm_sec); | ||
128 | nowtime += RTC_OFFSET; | 139 | nowtime += RTC_OFFSET; |
129 | 140 | ||
130 | switch (sys_ctrler) { | 141 | switch (sys_ctrler) { |
131 | #ifdef CONFIG_ADB_CUDA | 142 | #ifdef CONFIG_ADB_CUDA |
132 | case SYS_CTRLER_CUDA: | 143 | case SYS_CTRLER_CUDA: |
133 | if (cuda_request(&req, NULL, 6, CUDA_PACKET, CUDA_SET_TIME, | 144 | if (cuda_request(&req, NULL, 6, CUDA_PACKET, CUDA_SET_TIME, |
134 | nowtime >> 24, nowtime >> 16, nowtime >> 8, nowtime) < 0) | 145 | nowtime >> 24, nowtime >> 16, nowtime >> 8, |
146 | nowtime) < 0) | ||
135 | return 0; | 147 | return 0; |
136 | while (!req.complete) | 148 | while (!req.complete) |
137 | cuda_poll(); | 149 | cuda_poll(); |
@@ -221,7 +233,7 @@ time_sleep_notify(struct pmu_sleep_notifier *self, int when) | |||
221 | case PBOOK_SLEEP_NOW: | 233 | case PBOOK_SLEEP_NOW: |
222 | do { | 234 | do { |
223 | seq = read_seqbegin_irqsave(&xtime_lock, flags); | 235 | seq = read_seqbegin_irqsave(&xtime_lock, flags); |
224 | time_diff = xtime.tv_sec - pmac_get_rtc_time(); | 236 | time_diff = xtime.tv_sec - pmac_get_boot_time(); |
225 | } while (read_seqretry_irqrestore(&xtime_lock, seq, flags)); | 237 | } while (read_seqretry_irqrestore(&xtime_lock, seq, flags)); |
226 | break; | 238 | break; |
227 | case PBOOK_WAKE: | 239 | case PBOOK_WAKE: |
diff --git a/arch/powerpc/platforms/pseries/setup.c b/arch/powerpc/platforms/pseries/setup.c index eb25ee2eead8..0c84a44b43b4 100644 --- a/arch/powerpc/platforms/pseries/setup.c +++ b/arch/powerpc/platforms/pseries/setup.c | |||
@@ -84,8 +84,8 @@ int fwnmi_active; /* TRUE if an FWNMI handler is present */ | |||
84 | extern void pSeries_system_reset_exception(struct pt_regs *regs); | 84 | extern void pSeries_system_reset_exception(struct pt_regs *regs); |
85 | extern int pSeries_machine_check_exception(struct pt_regs *regs); | 85 | extern int pSeries_machine_check_exception(struct pt_regs *regs); |
86 | 86 | ||
87 | static int pseries_shared_idle(void); | 87 | static void pseries_shared_idle(void); |
88 | static int pseries_dedicated_idle(void); | 88 | static void pseries_dedicated_idle(void); |
89 | 89 | ||
90 | static volatile void __iomem * chrp_int_ack_special; | 90 | static volatile void __iomem * chrp_int_ack_special; |
91 | struct mpic *pSeries_mpic; | 91 | struct mpic *pSeries_mpic; |
@@ -488,8 +488,8 @@ static inline void dedicated_idle_sleep(unsigned int cpu) | |||
488 | } | 488 | } |
489 | } | 489 | } |
490 | 490 | ||
491 | static int pseries_dedicated_idle(void) | 491 | static void pseries_dedicated_idle(void) |
492 | { | 492 | { |
493 | long oldval; | 493 | long oldval; |
494 | struct paca_struct *lpaca = get_paca(); | 494 | struct paca_struct *lpaca = get_paca(); |
495 | unsigned int cpu = smp_processor_id(); | 495 | unsigned int cpu = smp_processor_id(); |
@@ -544,7 +544,7 @@ static int pseries_dedicated_idle(void) | |||
544 | } | 544 | } |
545 | } | 545 | } |
546 | 546 | ||
547 | static int pseries_shared_idle(void) | 547 | static void pseries_shared_idle(void) |
548 | { | 548 | { |
549 | struct paca_struct *lpaca = get_paca(); | 549 | struct paca_struct *lpaca = get_paca(); |
550 | unsigned int cpu = smp_processor_id(); | 550 | unsigned int cpu = smp_processor_id(); |
@@ -586,8 +586,6 @@ static int pseries_shared_idle(void) | |||
586 | if (cpu_is_offline(cpu) && system_state == SYSTEM_RUNNING) | 586 | if (cpu_is_offline(cpu) && system_state == SYSTEM_RUNNING) |
587 | cpu_die(); | 587 | cpu_die(); |
588 | } | 588 | } |
589 | |||
590 | return 0; | ||
591 | } | 589 | } |
592 | 590 | ||
593 | static int pSeries_pci_probe_mode(struct pci_bus *bus) | 591 | static int pSeries_pci_probe_mode(struct pci_bus *bus) |
diff --git a/arch/ppc64/kernel/idle.c b/arch/ppc64/kernel/idle.c index 954395d42636..8abd2ad92832 100644 --- a/arch/ppc64/kernel/idle.c +++ b/arch/ppc64/kernel/idle.c | |||
@@ -31,7 +31,7 @@ | |||
31 | 31 | ||
32 | extern void power4_idle(void); | 32 | extern void power4_idle(void); |
33 | 33 | ||
34 | int default_idle(void) | 34 | void default_idle(void) |
35 | { | 35 | { |
36 | long oldval; | 36 | long oldval; |
37 | unsigned int cpu = smp_processor_id(); | 37 | unsigned int cpu = smp_processor_id(); |
@@ -64,11 +64,9 @@ int default_idle(void) | |||
64 | if (cpu_is_offline(cpu) && system_state == SYSTEM_RUNNING) | 64 | if (cpu_is_offline(cpu) && system_state == SYSTEM_RUNNING) |
65 | cpu_die(); | 65 | cpu_die(); |
66 | } | 66 | } |
67 | |||
68 | return 0; | ||
69 | } | 67 | } |
70 | 68 | ||
71 | int native_idle(void) | 69 | void native_idle(void) |
72 | { | 70 | { |
73 | while (1) { | 71 | while (1) { |
74 | ppc64_runlatch_off(); | 72 | ppc64_runlatch_off(); |
@@ -85,8 +83,6 @@ int native_idle(void) | |||
85 | system_state == SYSTEM_RUNNING) | 83 | system_state == SYSTEM_RUNNING) |
86 | cpu_die(); | 84 | cpu_die(); |
87 | } | 85 | } |
88 | |||
89 | return 0; | ||
90 | } | 86 | } |
91 | 87 | ||
92 | void cpu_idle(void) | 88 | void cpu_idle(void) |
diff --git a/arch/ppc64/kernel/maple_setup.c b/arch/ppc64/kernel/maple_setup.c index 22987675f544..a107ed69a355 100644 --- a/arch/ppc64/kernel/maple_setup.c +++ b/arch/ppc64/kernel/maple_setup.c | |||
@@ -70,7 +70,7 @@ | |||
70 | 70 | ||
71 | extern int maple_set_rtc_time(struct rtc_time *tm); | 71 | extern int maple_set_rtc_time(struct rtc_time *tm); |
72 | extern void maple_get_rtc_time(struct rtc_time *tm); | 72 | extern void maple_get_rtc_time(struct rtc_time *tm); |
73 | extern void maple_get_boot_time(struct rtc_time *tm); | 73 | extern unsigned long maple_get_boot_time(void); |
74 | extern void maple_calibrate_decr(void); | 74 | extern void maple_calibrate_decr(void); |
75 | extern void maple_pci_init(void); | 75 | extern void maple_pci_init(void); |
76 | extern void maple_pcibios_fixup(void); | 76 | extern void maple_pcibios_fixup(void); |
diff --git a/arch/ppc64/kernel/maple_time.c b/arch/ppc64/kernel/maple_time.c index d65210abcd03..cf5186335900 100644 --- a/arch/ppc64/kernel/maple_time.c +++ b/arch/ppc64/kernel/maple_time.c | |||
@@ -156,8 +156,9 @@ int maple_set_rtc_time(struct rtc_time *tm) | |||
156 | return 0; | 156 | return 0; |
157 | } | 157 | } |
158 | 158 | ||
159 | void __init maple_get_boot_time(struct rtc_time *tm) | 159 | unsigned long __init maple_get_boot_time(void) |
160 | { | 160 | { |
161 | struct rtc_time tm; | ||
161 | struct device_node *rtcs; | 162 | struct device_node *rtcs; |
162 | 163 | ||
163 | rtcs = find_compatible_devices("rtc", "pnpPNP,b00"); | 164 | rtcs = find_compatible_devices("rtc", "pnpPNP,b00"); |
@@ -170,6 +171,8 @@ void __init maple_get_boot_time(struct rtc_time *tm) | |||
170 | "legacy address (0x%x)\n", maple_rtc_addr); | 171 | "legacy address (0x%x)\n", maple_rtc_addr); |
171 | } | 172 | } |
172 | 173 | ||
173 | maple_get_rtc_time(tm); | 174 | maple_get_rtc_time(&tm); |
175 | return mktime(time->tm_year+1900, time->tm_mon+1, time->tm_mday, | ||
176 | time->tm_hour, time->tm_min, time->tm_sec); | ||
174 | } | 177 | } |
175 | 178 | ||
diff --git a/arch/ppc64/kernel/pmac.h b/arch/ppc64/kernel/pmac.h index 40e1c5030f74..fa59f2a5c722 100644 --- a/arch/ppc64/kernel/pmac.h +++ b/arch/ppc64/kernel/pmac.h | |||
@@ -9,7 +9,7 @@ | |||
9 | * pmac_* files. Mostly for use by pmac_setup | 9 | * pmac_* files. Mostly for use by pmac_setup |
10 | */ | 10 | */ |
11 | 11 | ||
12 | extern void pmac_get_boot_time(struct rtc_time *tm); | 12 | extern unsigned long pmac_get_boot_time(void); |
13 | extern void pmac_get_rtc_time(struct rtc_time *tm); | 13 | extern void pmac_get_rtc_time(struct rtc_time *tm); |
14 | extern int pmac_set_rtc_time(struct rtc_time *tm); | 14 | extern int pmac_set_rtc_time(struct rtc_time *tm); |
15 | extern void pmac_read_rtc_time(void); | 15 | extern void pmac_read_rtc_time(void); |
diff --git a/arch/ppc64/kernel/pmac_nvram.c b/arch/ppc64/kernel/pmac_nvram.c index 11586d535f81..5fe9785ad7d8 100644 --- a/arch/ppc64/kernel/pmac_nvram.c +++ b/arch/ppc64/kernel/pmac_nvram.c | |||
@@ -341,7 +341,7 @@ static int amd_write_bank(int bank, u8* datas) | |||
341 | } | 341 | } |
342 | 342 | ||
343 | 343 | ||
344 | static int core99_nvram_sync(void) | 344 | static void core99_nvram_sync(void) |
345 | { | 345 | { |
346 | struct core99_header* hdr99; | 346 | struct core99_header* hdr99; |
347 | unsigned long flags; | 347 | unsigned long flags; |
@@ -369,8 +369,6 @@ static int core99_nvram_sync(void) | |||
369 | printk("nvram: Error writing bank %d\n", core99_bank); | 369 | printk("nvram: Error writing bank %d\n", core99_bank); |
370 | bail: | 370 | bail: |
371 | spin_unlock_irqrestore(&nv_lock, flags); | 371 | spin_unlock_irqrestore(&nv_lock, flags); |
372 | |||
373 | return 0; | ||
374 | } | 372 | } |
375 | 373 | ||
376 | int __init pmac_nvram_init(void) | 374 | int __init pmac_nvram_init(void) |
diff --git a/arch/ppc64/kernel/pmac_time.c b/arch/ppc64/kernel/pmac_time.c index 9d8c97decd32..c89bfefbbecd 100644 --- a/arch/ppc64/kernel/pmac_time.c +++ b/arch/ppc64/kernel/pmac_time.c | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/adb.h> | 21 | #include <linux/adb.h> |
22 | #include <linux/pmu.h> | 22 | #include <linux/pmu.h> |
23 | #include <linux/interrupt.h> | 23 | #include <linux/interrupt.h> |
24 | #include <linux/rtc.h> | ||
24 | 25 | ||
25 | #include <asm/sections.h> | 26 | #include <asm/sections.h> |
26 | #include <asm/prom.h> | 27 | #include <asm/prom.h> |
@@ -135,23 +136,13 @@ int pmac_set_rtc_time(struct rtc_time *tm) | |||
135 | } | 136 | } |
136 | } | 137 | } |
137 | 138 | ||
138 | void __init pmac_get_boot_time(struct rtc_time *tm) | 139 | unsigned long __init pmac_get_boot_time(void) |
139 | { | 140 | { |
140 | pmac_get_rtc_time(tm); | 141 | struct rtc_time tm; |
141 | 142 | ||
142 | #ifdef disabled__CONFIG_NVRAM | 143 | pmac_get_rtc_time(&tm); |
143 | s32 delta = 0; | 144 | return mktime(tm.tm_year+1900, tm.tm_mon+1, tm.tm_mday, |
144 | int dst; | 145 | tm.tm_hour, tm.tm_min, tm.tm_sec); |
145 | |||
146 | delta = ((s32)pmac_xpram_read(PMAC_XPRAM_MACHINE_LOC + 0x9)) << 16; | ||
147 | delta |= ((s32)pmac_xpram_read(PMAC_XPRAM_MACHINE_LOC + 0xa)) << 8; | ||
148 | delta |= pmac_xpram_read(PMAC_XPRAM_MACHINE_LOC + 0xb); | ||
149 | if (delta & 0x00800000UL) | ||
150 | delta |= 0xFF000000UL; | ||
151 | dst = ((pmac_xpram_read(PMAC_XPRAM_MACHINE_LOC + 0x8) & 0x80) != 0); | ||
152 | printk("GMT Delta read from XPRAM: %d minutes, DST: %s\n", delta/60, | ||
153 | dst ? "on" : "off"); | ||
154 | #endif | ||
155 | } | 146 | } |
156 | 147 | ||
157 | /* | 148 | /* |
diff --git a/arch/ppc64/kernel/rtas-proc.c b/arch/ppc64/kernel/rtas-proc.c index 1f3ff860fdf0..5bdd5b079d96 100644 --- a/arch/ppc64/kernel/rtas-proc.c +++ b/arch/ppc64/kernel/rtas-proc.c | |||
@@ -23,6 +23,7 @@ | |||
23 | #include <linux/init.h> | 23 | #include <linux/init.h> |
24 | #include <linux/seq_file.h> | 24 | #include <linux/seq_file.h> |
25 | #include <linux/bitops.h> | 25 | #include <linux/bitops.h> |
26 | #include <linux/rtc.h> | ||
26 | 27 | ||
27 | #include <asm/uaccess.h> | 28 | #include <asm/uaccess.h> |
28 | #include <asm/processor.h> | 29 | #include <asm/processor.h> |
diff --git a/arch/ppc64/kernel/rtc.c b/arch/ppc64/kernel/rtc.c index 88ae13f81c46..79e7ed2858dd 100644 --- a/arch/ppc64/kernel/rtc.c +++ b/arch/ppc64/kernel/rtc.c | |||
@@ -265,7 +265,7 @@ static int rtc_read_proc(char *page, char **start, off_t off, | |||
265 | #ifdef CONFIG_PPC_RTAS | 265 | #ifdef CONFIG_PPC_RTAS |
266 | #define MAX_RTC_WAIT 5000 /* 5 sec */ | 266 | #define MAX_RTC_WAIT 5000 /* 5 sec */ |
267 | #define RTAS_CLOCK_BUSY (-2) | 267 | #define RTAS_CLOCK_BUSY (-2) |
268 | void rtas_get_boot_time(struct rtc_time *rtc_tm) | 268 | unsigned long rtas_get_boot_time(void) |
269 | { | 269 | { |
270 | int ret[8]; | 270 | int ret[8]; |
271 | int error, wait_time; | 271 | int error, wait_time; |
@@ -285,15 +285,10 @@ void rtas_get_boot_time(struct rtc_time *rtc_tm) | |||
285 | if (error != 0 && printk_ratelimit()) { | 285 | if (error != 0 && printk_ratelimit()) { |
286 | printk(KERN_WARNING "error: reading the clock failed (%d)\n", | 286 | printk(KERN_WARNING "error: reading the clock failed (%d)\n", |
287 | error); | 287 | error); |
288 | return; | 288 | return 0; |
289 | } | 289 | } |
290 | 290 | ||
291 | rtc_tm->tm_sec = ret[5]; | 291 | return mktime(ret[0], ret[1], ret[2], ret[3], ret[4], ret[5]); |
292 | rtc_tm->tm_min = ret[4]; | ||
293 | rtc_tm->tm_hour = ret[3]; | ||
294 | rtc_tm->tm_mday = ret[2]; | ||
295 | rtc_tm->tm_mon = ret[1] - 1; | ||
296 | rtc_tm->tm_year = ret[0] - 1900; | ||
297 | } | 292 | } |
298 | 293 | ||
299 | /* NOTE: get_rtc_time will get an error if executed in interrupt context | 294 | /* NOTE: get_rtc_time will get an error if executed in interrupt context |