欢迎来到虫虫下载站 | 资源下载 资源专辑 关于我们
虫虫下载站

mc146818rtc_32.h

linux 内核源代码
H
字号:
/* * Machine dependent access functions for RTC registers. */#ifndef _ASM_MC146818RTC_H#define _ASM_MC146818RTC_H#include <asm/io.h>#include <asm/system.h>#include <asm/processor.h>#include <linux/mc146818rtc.h>#ifndef RTC_PORT#define RTC_PORT(x)	(0x70 + (x))#define RTC_ALWAYS_BCD	1	/* RTC operates in binary mode */#endif#ifdef __HAVE_ARCH_CMPXCHG/* * This lock provides nmi access to the CMOS/RTC registers.  It has some * special properties.  It is owned by a CPU and stores the index register * currently being accessed (if owned).  The idea here is that it works * like a normal lock (normally).  However, in an NMI, the NMI code will * first check to see if its CPU owns the lock, meaning that the NMI * interrupted during the read/write of the device.  If it does, it goes ahead * and performs the access and then restores the index register.  If it does * not, it locks normally. * * Note that since we are working with NMIs, we need this lock even in * a non-SMP machine just to mark that the lock is owned. * * This only works with compare-and-swap.  There is no other way to * atomically claim the lock and set the owner. */#include <linux/smp.h>extern volatile unsigned long cmos_lock;/* * All of these below must be called with interrupts off, preempt * disabled, etc. */static inline void lock_cmos(unsigned char reg){	unsigned long new;	new = ((smp_processor_id()+1) << 8) | reg;	for (;;) {		if (cmos_lock) {			cpu_relax();			continue;		}		if (__cmpxchg(&cmos_lock, 0, new, sizeof(cmos_lock)) == 0)			return;	}}static inline void unlock_cmos(void){	cmos_lock = 0;}static inline int do_i_have_lock_cmos(void){	return (cmos_lock >> 8) == (smp_processor_id()+1);}static inline unsigned char current_lock_cmos_reg(void){	return cmos_lock & 0xff;}#define lock_cmos_prefix(reg) \	do {					\		unsigned long cmos_flags;	\		local_irq_save(cmos_flags);	\		lock_cmos(reg)#define lock_cmos_suffix(reg) \		unlock_cmos();			\		local_irq_restore(cmos_flags);	\	} while (0)#else#define lock_cmos_prefix(reg) do {} while (0)#define lock_cmos_suffix(reg) do {} while (0)#define lock_cmos(reg)#define unlock_cmos()#define do_i_have_lock_cmos() 0#define current_lock_cmos_reg() 0#endif/* * The yet supported machines all access the RTC index register via * an ISA port access but the way to access the date register differs ... */#define CMOS_READ(addr) rtc_cmos_read(addr)#define CMOS_WRITE(val, addr) rtc_cmos_write(val, addr)unsigned char rtc_cmos_read(unsigned char addr);void rtc_cmos_write(unsigned char val, unsigned char addr);#define RTC_IRQ 8#endif /* _ASM_MC146818RTC_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -