x86: isolate the rtc code for sharing
The mach-default/mach_time.h code inline is moved to arch/x86/kernel/rtc.c and the header files are adjusted. Shrink the 3 dozen includes to the ones we really need. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
6ce60b07e6
commit
fe599f9fbc
|
@ -8,7 +8,7 @@ CPPFLAGS_vmlinux.lds += -Ui386
|
||||||
obj-y := process_32.o signal_32.o entry_32.o traps_32.o irq_32.o \
|
obj-y := process_32.o signal_32.o entry_32.o traps_32.o irq_32.o \
|
||||||
ptrace_32.o time_32.o ioport_32.o ldt.o setup_32.o i8259_32.o sys_i386_32.o \
|
ptrace_32.o time_32.o ioport_32.o ldt.o setup_32.o i8259_32.o sys_i386_32.o \
|
||||||
pci-dma_32.o i386_ksyms_32.o i387_32.o bootflag.o e820_32.o\
|
pci-dma_32.o i386_ksyms_32.o i387_32.o bootflag.o e820_32.o\
|
||||||
quirks.o i8237.o topology.o alternative.o i8253.o tsc_32.o io_delay.o
|
quirks.o i8237.o topology.o alternative.o i8253.o tsc_32.o io_delay.o rtc.o
|
||||||
|
|
||||||
obj-$(CONFIG_STACKTRACE) += stacktrace.o
|
obj-$(CONFIG_STACKTRACE) += stacktrace.o
|
||||||
obj-y += cpu/
|
obj-y += cpu/
|
||||||
|
|
|
@ -1,18 +1,10 @@
|
||||||
/*
|
/*
|
||||||
* include/asm-i386/mach-default/mach_time.h
|
* RTC related functions
|
||||||
*
|
|
||||||
* Machine specific set RTC function for generic.
|
|
||||||
* Split out from time.c by Osamu Tomita <tomita@cinet.co.jp>
|
|
||||||
*/
|
*/
|
||||||
#ifndef _MACH_TIME_H
|
#include <linux/bcd.h>
|
||||||
#define _MACH_TIME_H
|
|
||||||
|
|
||||||
#include <linux/mc146818rtc.h>
|
#include <linux/mc146818rtc.h>
|
||||||
|
|
||||||
/* for check timing call set_rtc_mmss() 500ms */
|
#include <asm/time.h>
|
||||||
/* used in arch/i386/time.c::do_timer_interrupt() */
|
|
||||||
#define USEC_AFTER 500000
|
|
||||||
#define USEC_BEFORE 500000
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* In order to set the CMOS clock precisely, set_rtc_mmss has to be
|
* In order to set the CMOS clock precisely, set_rtc_mmss has to be
|
||||||
|
@ -24,7 +16,7 @@
|
||||||
* BUG: This routine does not handle hour overflow properly; it just
|
* BUG: This routine does not handle hour overflow properly; it just
|
||||||
* sets the minutes. Usually you'll only notice that after reboot!
|
* sets the minutes. Usually you'll only notice that after reboot!
|
||||||
*/
|
*/
|
||||||
static inline int mach_set_rtc_mmss(unsigned long nowtime)
|
int mach_set_rtc_mmss(unsigned long nowtime)
|
||||||
{
|
{
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
int real_seconds, real_minutes, cmos_minutes;
|
int real_seconds, real_minutes, cmos_minutes;
|
||||||
|
@ -79,7 +71,7 @@ static inline int mach_set_rtc_mmss(unsigned long nowtime)
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned long mach_get_cmos_time(void)
|
unsigned long mach_get_cmos_time(void)
|
||||||
{
|
{
|
||||||
unsigned int year, mon, day, hour, min, sec;
|
unsigned int year, mon, day, hour, min, sec;
|
||||||
|
|
||||||
|
@ -108,4 +100,67 @@ static inline unsigned long mach_get_cmos_time(void)
|
||||||
return mktime(year, mon, day, hour, min, sec);
|
return mktime(year, mon, day, hour, min, sec);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* !_MACH_TIME_H */
|
DEFINE_SPINLOCK(rtc_lock);
|
||||||
|
EXPORT_SYMBOL(rtc_lock);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a special lock that is owned by the CPU and holds the index
|
||||||
|
* register we are working with. It is required for NMI access to the
|
||||||
|
* CMOS/RTC registers. See include/asm-i386/mc146818rtc.h for details.
|
||||||
|
*/
|
||||||
|
volatile unsigned long cmos_lock = 0;
|
||||||
|
EXPORT_SYMBOL(cmos_lock);
|
||||||
|
|
||||||
|
/* Routines for accessing the CMOS RAM/RTC. */
|
||||||
|
unsigned char rtc_cmos_read(unsigned char addr)
|
||||||
|
{
|
||||||
|
unsigned char val;
|
||||||
|
|
||||||
|
lock_cmos_prefix(addr);
|
||||||
|
outb_p(addr, RTC_PORT(0));
|
||||||
|
val = inb_p(RTC_PORT(1));
|
||||||
|
lock_cmos_suffix(addr);
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(rtc_cmos_read);
|
||||||
|
|
||||||
|
void rtc_cmos_write(unsigned char val, unsigned char addr)
|
||||||
|
{
|
||||||
|
lock_cmos_prefix(addr);
|
||||||
|
outb_p(addr, RTC_PORT(0));
|
||||||
|
outb_p(val, RTC_PORT(1));
|
||||||
|
lock_cmos_suffix(addr);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(rtc_cmos_write);
|
||||||
|
|
||||||
|
static int set_rtc_mmss(unsigned long nowtime)
|
||||||
|
{
|
||||||
|
int retval;
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
/* gets recalled with irq locally disabled */
|
||||||
|
/* XXX - does irqsave resolve this? -johnstul */
|
||||||
|
spin_lock_irqsave(&rtc_lock, flags);
|
||||||
|
retval = set_wallclock(nowtime);
|
||||||
|
spin_unlock_irqrestore(&rtc_lock, flags);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* not static: needed by APM */
|
||||||
|
unsigned long read_persistent_clock(void)
|
||||||
|
{
|
||||||
|
unsigned long retval;
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
spin_lock_irqsave(&rtc_lock, flags);
|
||||||
|
retval = get_wallclock();
|
||||||
|
spin_unlock_irqrestore(&rtc_lock, flags);
|
||||||
|
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
|
int update_persistent_clock(struct timespec now)
|
||||||
|
{
|
||||||
|
return set_rtc_mmss(now.tv_sec);
|
||||||
|
}
|
|
@ -28,98 +28,21 @@
|
||||||
* serialize accesses to xtime/lost_ticks).
|
* serialize accesses to xtime/lost_ticks).
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/errno.h>
|
#include <linux/init.h>
|
||||||
#include <linux/sched.h>
|
|
||||||
#include <linux/kernel.h>
|
|
||||||
#include <linux/param.h>
|
|
||||||
#include <linux/string.h>
|
|
||||||
#include <linux/mm.h>
|
|
||||||
#include <linux/interrupt.h>
|
#include <linux/interrupt.h>
|
||||||
#include <linux/time.h>
|
#include <linux/time.h>
|
||||||
#include <linux/delay.h>
|
|
||||||
#include <linux/init.h>
|
|
||||||
#include <linux/smp.h>
|
|
||||||
#include <linux/module.h>
|
|
||||||
#include <linux/sysdev.h>
|
|
||||||
#include <linux/bcd.h>
|
|
||||||
#include <linux/efi.h>
|
|
||||||
#include <linux/mca.h>
|
#include <linux/mca.h>
|
||||||
|
|
||||||
#include <asm/io.h>
|
#include <asm/arch_hooks.h>
|
||||||
#include <asm/smp.h>
|
#include <asm/hpet.h>
|
||||||
#include <asm/irq.h>
|
|
||||||
#include <asm/msr.h>
|
|
||||||
#include <asm/delay.h>
|
|
||||||
#include <asm/mpspec.h>
|
|
||||||
#include <asm/uaccess.h>
|
|
||||||
#include <asm/processor.h>
|
|
||||||
#include <asm/timer.h>
|
|
||||||
#include <asm/time.h>
|
#include <asm/time.h>
|
||||||
|
|
||||||
#include "mach_time.h"
|
|
||||||
|
|
||||||
#include <linux/timex.h>
|
|
||||||
|
|
||||||
#include <asm/hpet.h>
|
|
||||||
|
|
||||||
#include <asm/arch_hooks.h>
|
|
||||||
|
|
||||||
#include "io_ports.h"
|
#include "io_ports.h"
|
||||||
|
|
||||||
#include <asm/i8259.h>
|
|
||||||
|
|
||||||
#include "do_timer.h"
|
#include "do_timer.h"
|
||||||
|
|
||||||
unsigned int cpu_khz; /* Detected as we calibrate the TSC */
|
unsigned int cpu_khz; /* Detected as we calibrate the TSC */
|
||||||
EXPORT_SYMBOL(cpu_khz);
|
EXPORT_SYMBOL(cpu_khz);
|
||||||
|
|
||||||
DEFINE_SPINLOCK(rtc_lock);
|
|
||||||
EXPORT_SYMBOL(rtc_lock);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This is a special lock that is owned by the CPU and holds the index
|
|
||||||
* register we are working with. It is required for NMI access to the
|
|
||||||
* CMOS/RTC registers. See include/asm-i386/mc146818rtc.h for details.
|
|
||||||
*/
|
|
||||||
volatile unsigned long cmos_lock = 0;
|
|
||||||
EXPORT_SYMBOL(cmos_lock);
|
|
||||||
|
|
||||||
/* Routines for accessing the CMOS RAM/RTC. */
|
|
||||||
unsigned char rtc_cmos_read(unsigned char addr)
|
|
||||||
{
|
|
||||||
unsigned char val;
|
|
||||||
lock_cmos_prefix(addr);
|
|
||||||
outb_p(addr, RTC_PORT(0));
|
|
||||||
val = inb_p(RTC_PORT(1));
|
|
||||||
lock_cmos_suffix(addr);
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(rtc_cmos_read);
|
|
||||||
|
|
||||||
void rtc_cmos_write(unsigned char val, unsigned char addr)
|
|
||||||
{
|
|
||||||
lock_cmos_prefix(addr);
|
|
||||||
outb_p(addr, RTC_PORT(0));
|
|
||||||
outb_p(val, RTC_PORT(1));
|
|
||||||
lock_cmos_suffix(addr);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(rtc_cmos_write);
|
|
||||||
|
|
||||||
static int set_rtc_mmss(unsigned long nowtime)
|
|
||||||
{
|
|
||||||
int retval;
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
/* gets recalled with irq locally disabled */
|
|
||||||
/* XXX - does irqsave resolve this? -johnstul */
|
|
||||||
spin_lock_irqsave(&rtc_lock, flags);
|
|
||||||
retval = set_wallclock(nowtime);
|
|
||||||
spin_unlock_irqrestore(&rtc_lock, flags);
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int timer_ack;
|
int timer_ack;
|
||||||
|
|
||||||
unsigned long profile_pc(struct pt_regs *regs)
|
unsigned long profile_pc(struct pt_regs *regs)
|
||||||
|
@ -193,26 +116,6 @@ irqreturn_t timer_interrupt(int irq, void *dev_id)
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* not static: needed by APM */
|
|
||||||
unsigned long read_persistent_clock(void)
|
|
||||||
{
|
|
||||||
unsigned long retval;
|
|
||||||
unsigned long flags;
|
|
||||||
|
|
||||||
spin_lock_irqsave(&rtc_lock, flags);
|
|
||||||
|
|
||||||
retval = get_wallclock();
|
|
||||||
|
|
||||||
spin_unlock_irqrestore(&rtc_lock, flags);
|
|
||||||
|
|
||||||
return retval;
|
|
||||||
}
|
|
||||||
|
|
||||||
int update_persistent_clock(struct timespec now)
|
|
||||||
{
|
|
||||||
return set_rtc_mmss(now.tv_sec);
|
|
||||||
}
|
|
||||||
|
|
||||||
extern void (*late_time_init)(void);
|
extern void (*late_time_init)(void);
|
||||||
/* Duplicate of time_init() below, with hpet_enable part added */
|
/* Duplicate of time_init() below, with hpet_enable part added */
|
||||||
void __init hpet_time_init(void)
|
void __init hpet_time_init(void)
|
||||||
|
|
|
@ -92,6 +92,9 @@ static inline unsigned char current_lock_cmos_reg(void)
|
||||||
unsigned char rtc_cmos_read(unsigned char addr);
|
unsigned char rtc_cmos_read(unsigned char addr);
|
||||||
void rtc_cmos_write(unsigned char val, unsigned char addr);
|
void rtc_cmos_write(unsigned char val, unsigned char addr);
|
||||||
|
|
||||||
|
extern int mach_set_rtc_mmss(unsigned long nowtime);
|
||||||
|
extern unsigned long mach_get_cmos_time(void);
|
||||||
|
|
||||||
#define RTC_IRQ 8
|
#define RTC_IRQ 8
|
||||||
|
|
||||||
#endif /* _ASM_MC146818RTC_H */
|
#endif /* _ASM_MC146818RTC_H */
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
#define _ASMi386_TIME_H
|
#define _ASMi386_TIME_H
|
||||||
|
|
||||||
#include <linux/efi.h>
|
#include <linux/efi.h>
|
||||||
#include "mach_time.h"
|
#include <asm/mc146818rtc.h>
|
||||||
|
|
||||||
static inline unsigned long native_get_wallclock(void)
|
static inline unsigned long native_get_wallclock(void)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue