亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? time.c

?? Linux Kernel 2.6.9 for OMAP1710
?? C
字號:
/* *  linux/include/asm-arm/arch-ebsa285/time.h * *  Copyright (C) 1998 Russell King. *  Copyright (C) 1998 Phil Blundell * * CATS has a real-time clock, though the evaluation board doesn't. * * Changelog: *  21-Mar-1998	RMK	Created *  27-Aug-1998	PJB	CATS support *  28-Dec-1998	APH	Made leds optional *  20-Jan-1999	RMK	Started merge of EBSA285, CATS and NetWinder *  16-Mar-1999	RMK	More support for EBSA285-like machines with RTCs in */#define RTC_PORT(x)		(rtc_base+(x))#define RTC_ALWAYS_BCD		0#include <linux/timex.h>#include <linux/init.h>#include <linux/interrupt.h>#include <linux/sched.h>#include <linux/mc146818rtc.h>#include <linux/bcd.h>#include <asm/hardware/dec21285.h>#include <asm/hardware.h>#include <asm/irq.h>#include <asm/leds.h>#include <asm/mach-types.h>#include <asm/io.h>#include <asm/hardware/clps7111.h>#include <asm/mach/time.h>static int rtc_base;#define mSEC_10_from_14 ((14318180 + 100) / 200)static unsigned long isa_gettimeoffset(void){	int count;	static int count_p = (mSEC_10_from_14/6);    /* for the first call after boot */	static unsigned long jiffies_p = 0;	/*	 * cache volatile jiffies temporarily; we have IRQs turned off. 	 */	unsigned long jiffies_t;	/* timer count may underflow right here */	outb_p(0x00, 0x43);	/* latch the count ASAP */	count = inb_p(0x40);	/* read the latched count */	/*	 * We do this guaranteed double memory access instead of a _p 	 * postfix in the previous port access. Wheee, hackady hack	 */ 	jiffies_t = jiffies;	count |= inb_p(0x40) << 8;	/* Detect timer underflows.  If we haven't had a timer tick since 	   the last time we were called, and time is apparently going	   backwards, the counter must have wrapped during this routine. */	if ((jiffies_t == jiffies_p) && (count > count_p))		count -= (mSEC_10_from_14/6);	else		jiffies_p = jiffies_t;	count_p = count;	count = (((mSEC_10_from_14/6)-1) - count) * (tick_nsec / 1000);	count = (count + (mSEC_10_from_14/6)/2) / (mSEC_10_from_14/6);	return count;}static irqreturn_tisa_timer_interrupt(int irq, void *dev_id, struct pt_regs *regs){	timer_tick(regs);	return IRQ_HANDLED;}static unsigned long __init get_isa_cmos_time(void){	unsigned int year, mon, day, hour, min, sec;	int i;	// check to see if the RTC makes sense.....	if ((CMOS_READ(RTC_VALID) & RTC_VRT) == 0)		return mktime(1970, 1, 1, 0, 0, 0);	/* The Linux interpretation of the CMOS clock register contents:	 * When the Update-In-Progress (UIP) flag goes from 1 to 0, the	 * RTC registers show the second which has precisely just started.	 * Let's hope other operating systems interpret the RTC the same way.	 */	/* read RTC exactly on falling edge of update flag */	for (i = 0 ; i < 1000000 ; i++) /* may take up to 1 second... */		if (CMOS_READ(RTC_FREQ_SELECT) & RTC_UIP)			break;	for (i = 0 ; i < 1000000 ; i++) /* must try at least 2.228 ms */		if (!(CMOS_READ(RTC_FREQ_SELECT) & RTC_UIP))			break;	do { /* Isn't this overkill ? UIP above should guarantee consistency */		sec  = CMOS_READ(RTC_SECONDS);		min  = CMOS_READ(RTC_MINUTES);		hour = CMOS_READ(RTC_HOURS);		day  = CMOS_READ(RTC_DAY_OF_MONTH);		mon  = CMOS_READ(RTC_MONTH);		year = CMOS_READ(RTC_YEAR);	} while (sec != CMOS_READ(RTC_SECONDS));	if (!(CMOS_READ(RTC_CONTROL) & RTC_DM_BINARY) || RTC_ALWAYS_BCD) {		BCD_TO_BIN(sec);		BCD_TO_BIN(min);		BCD_TO_BIN(hour);		BCD_TO_BIN(day);		BCD_TO_BIN(mon);		BCD_TO_BIN(year);	}	if ((year += 1900) < 1970)		year += 100;	return mktime(year, mon, day, hour, min, sec);}static intset_isa_cmos_time(void){	int retval = 0;	int real_seconds, real_minutes, cmos_minutes;	unsigned char save_control, save_freq_select;	unsigned long nowtime = xtime.tv_sec;	save_control = CMOS_READ(RTC_CONTROL); /* tell the clock it's being set */	CMOS_WRITE((save_control|RTC_SET), RTC_CONTROL);	save_freq_select = CMOS_READ(RTC_FREQ_SELECT); /* stop and reset prescaler */	CMOS_WRITE((save_freq_select|RTC_DIV_RESET2), RTC_FREQ_SELECT);	cmos_minutes = CMOS_READ(RTC_MINUTES);	if (!(save_control & RTC_DM_BINARY) || RTC_ALWAYS_BCD)		BCD_TO_BIN(cmos_minutes);	/*	 * since we're only adjusting minutes and seconds,	 * don't interfere with hour overflow. This avoids	 * messing with unknown time zones but requires your	 * RTC not to be off by more than 15 minutes	 */	real_seconds = nowtime % 60;	real_minutes = nowtime / 60;	if (((abs(real_minutes - cmos_minutes) + 15)/30) & 1)		real_minutes += 30;		/* correct for half hour time zone */	real_minutes %= 60;	if (abs(real_minutes - cmos_minutes) < 30) {		if (!(save_control & RTC_DM_BINARY) || RTC_ALWAYS_BCD) {			BIN_TO_BCD(real_seconds);			BIN_TO_BCD(real_minutes);		}		CMOS_WRITE(real_seconds,RTC_SECONDS);		CMOS_WRITE(real_minutes,RTC_MINUTES);	} else		retval = -1;	/* The following flags have to be released exactly in this order,	 * otherwise the DS12887 (popular MC146818A clone with integrated	 * battery and quartz) will not reset the oscillator and will not	 * update precisely 500 ms later. You won't find this mentioned in	 * the Dallas Semiconductor data sheets, but who believes data	 * sheets anyway ...                           -- Markus Kuhn	 */	CMOS_WRITE(save_control, RTC_CONTROL);	CMOS_WRITE(save_freq_select, RTC_FREQ_SELECT);	return retval;}static unsigned long timer1_latch;static unsigned long timer1_gettimeoffset (void){	unsigned long value = timer1_latch - *CSR_TIMER1_VALUE;	return ((tick_nsec / 1000) * value) / timer1_latch;}static irqreturn_ttimer1_interrupt(int irq, void *dev_id, struct pt_regs *regs){	*CSR_TIMER1_CLR = 0;	timer_tick(regs);	return IRQ_HANDLED;}static struct irqaction footbridge_timer_irq = {	.flags	= SA_INTERRUPT};/* * Set up timer interrupt. */void __init footbridge_init_time(void){	if (machine_is_co285() ||	    machine_is_personal_server())		/*		 * Add-in 21285s shouldn't access the RTC		 */		rtc_base = 0;	else		rtc_base = 0x70;	if (rtc_base) {		int reg_d, reg_b;		/*		 * Probe for the RTC.		 */		reg_d = CMOS_READ(RTC_REG_D);		/*		 * make sure the divider is set		 */		CMOS_WRITE(RTC_REF_CLCK_32KHZ, RTC_REG_A);		/*		 * Set control reg B		 *   (24 hour mode, update enabled)		 */		reg_b = CMOS_READ(RTC_REG_B) & 0x7f;		reg_b |= 2;		CMOS_WRITE(reg_b, RTC_REG_B);		if ((CMOS_READ(RTC_REG_A) & 0x7f) == RTC_REF_CLCK_32KHZ &&		    CMOS_READ(RTC_REG_B) == reg_b) {			struct timespec tv;			/*			 * We have a RTC.  Check the battery			 */			if ((reg_d & 0x80) == 0)				printk(KERN_WARNING "RTC: *** warning: CMOS battery bad\n");			tv.tv_nsec = 0;			tv.tv_sec = get_isa_cmos_time();			do_settimeofday(&tv);			set_rtc = set_isa_cmos_time;		} else			rtc_base = 0;	}	if (machine_is_ebsa285() ||	    machine_is_co285() ||	    machine_is_personal_server()) {		gettimeoffset = timer1_gettimeoffset;		timer1_latch = (mem_fclk_21285 + 8 * HZ) / (16 * HZ);		*CSR_TIMER1_CLR  = 0;		*CSR_TIMER1_LOAD = timer1_latch;		*CSR_TIMER1_CNTL = TIMER_CNTL_ENABLE | TIMER_CNTL_AUTORELOAD | TIMER_CNTL_DIV16;		footbridge_timer_irq.name = "Timer1 Timer Tick";		footbridge_timer_irq.handler = timer1_interrupt;				setup_irq(IRQ_TIMER1, &footbridge_timer_irq);	} else {		/* enable PIT timer */		/* set for periodic (4) and LSB/MSB write (0x30) */		outb(0x34, 0x43);		outb((mSEC_10_from_14/6) & 0xFF, 0x40);		outb((mSEC_10_from_14/6) >> 8, 0x40);		gettimeoffset = isa_gettimeoffset;		footbridge_timer_irq.name = "ISA Timer Tick";		footbridge_timer_irq.handler = isa_timer_interrupt;				setup_irq(IRQ_ISA_TIMER, &footbridge_timer_irq);	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色国产综合视频| 色综合久久88色综合天天| 亚洲无线码一区二区三区| 国产精品久线在线观看| 国产精品色眯眯| 久久久久久一二三区| 亚洲国产激情av| 国产精品青草久久| 中文字幕亚洲不卡| 亚洲人被黑人高潮完整版| 亚洲黄一区二区三区| 亚洲激情图片qvod| 日韩av二区在线播放| 麻豆精品视频在线| 国产乱码字幕精品高清av| 国产成人av网站| 91影院在线免费观看| 在线观看中文字幕不卡| 91精品国产综合久久香蕉麻豆| 欧美精品一级二级| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 91九色02白丝porn| 欧美日韩国产免费一区二区| 制服丝袜av成人在线看| 久久久久久久国产精品影院| 国产精品污www在线观看| 一区二区三区中文字幕精品精品 | 久久色视频免费观看| 欧美高清一级片在线观看| 国产精品系列在线| 午夜久久久久久久久久一区二区| 日韩高清中文字幕一区| 国产成人综合亚洲网站| 欧美唯美清纯偷拍| 日韩欧美激情一区| 综合久久综合久久| 久久精品国产免费| 99re6这里只有精品视频在线观看| 欧美亚日韩国产aⅴ精品中极品| 欧美一区二区三区男人的天堂| 欧美激情艳妇裸体舞| 奇米精品一区二区三区在线观看| 国产综合色产在线精品| 欧美午夜一区二区| 久久精品欧美日韩| 日韩国产成人精品| 91丨porny丨最新| 精品国产乱码91久久久久久网站| 亚洲欧美日韩国产成人精品影院 | 欧亚一区二区三区| 久久久亚洲欧洲日产国码αv| 亚洲视频免费在线| 国产在线国偷精品免费看| 欧美综合天天夜夜久久| 国产三级精品三级| 日韩国产高清影视| 欧美性色黄大片| 日韩美女视频一区| 国产成人av电影在线观看| 欧美一卡二卡三卡| 午夜日韩在线电影| 91麻豆免费看| 亚洲欧洲日韩综合一区二区| 国产精品一二三区在线| 欧美电影免费观看完整版 | 91精品欧美一区二区三区综合在| 国产精品午夜在线| 成人久久视频在线观看| 精品处破学生在线二十三| 日本亚洲电影天堂| 欧美日韩专区在线| 一区二区三区自拍| 91精品91久久久中77777| 国产精品久久久久一区二区三区 | jlzzjlzz国产精品久久| 国产精品天干天干在观线| 成人一级片在线观看| 久久亚洲精精品中文字幕早川悠里| 美国毛片一区二区三区| 日韩视频永久免费| 久久er99热精品一区二区| 精品欧美久久久| 韩国女主播成人在线观看| 精品理论电影在线| 国产成人午夜电影网| 国产精品美女久久久久久久久久久| 成人免费观看视频| 亚洲美腿欧美偷拍| 欧美色老头old∨ideo| 婷婷丁香久久五月婷婷| 制服丝袜亚洲网站| 激情综合色播激情啊| 中文字幕精品一区| 在线视频一区二区三区| 日韩制服丝袜先锋影音| 日韩精品一区二区三区三区免费| 国产一区福利在线| 亚洲欧洲无码一区二区三区| 欧美综合天天夜夜久久| 久久国产剧场电影| 成人免费视频在线观看| 欧美少妇性性性| 国产伦精品一区二区三区视频青涩| 国产精品网站在线观看| 欧美丝袜自拍制服另类| 另类专区欧美蜜桃臀第一页| 久久精品水蜜桃av综合天堂| 91性感美女视频| 日本在线不卡视频| 欧美韩日一区二区三区| 欧洲精品一区二区三区在线观看| 免费成人在线观看视频| 国产精品超碰97尤物18| 欧美精品久久99| 成人av网址在线| 日韩av电影免费观看高清完整版 | 91视频免费观看| 日韩成人精品在线| 中文字幕一区在线观看视频| 欧美一二三区在线| 91丨porny丨国产入口| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品国产三级国产有无不卡 | 精彩视频一区二区| 国产精品福利影院| 精品国精品国产| 在线观看一区日韩| 丁香激情综合五月| 麻豆一区二区三区| 亚洲裸体xxx| 久久久av毛片精品| 91精品国模一区二区三区| 91麻豆免费在线观看| 高清国产午夜精品久久久久久| 天天操天天色综合| 一个色妞综合视频在线观看| 国产女主播视频一区二区| 日韩三级精品电影久久久| 在线亚洲一区二区| 97久久精品人人做人人爽| 国产精品一区二区你懂的| 日韩高清欧美激情| 日韩电影在线一区| 亚洲成av人片在线| 一区二区三区四区亚洲| 中文字幕在线视频一区| 国产日韩欧美综合在线| 久久久久久毛片| 久久影院电视剧免费观看| 精品少妇一区二区三区视频免付费 | 欧美成人官网二区| 91精品国产色综合久久| 欧美日韩免费观看一区二区三区 | 精品国产亚洲在线| 日韩三区在线观看| 日韩三级免费观看| 26uuu色噜噜精品一区| 欧美tk—视频vk| 亚洲精品在线电影| 日韩精品专区在线影院观看| 欧美大胆人体bbbb| 精品国产乱码久久久久久影片| 精品久久久久香蕉网| 久久久777精品电影网影网| 久久久久9999亚洲精品| 欧美激情在线看| 亚洲美女屁股眼交3| 性做久久久久久免费观看| 日韩中文字幕1| 狠狠色综合日日| 成人av网站免费观看| 在线一区二区三区四区五区| 7799精品视频| 精品美女一区二区三区| 中文字幕av在线一区二区三区| 综合自拍亚洲综合图不卡区| 亚洲伊人色欲综合网| 丝袜美腿亚洲综合| 国内精品伊人久久久久av影院 | 婷婷综合久久一区二区三区| 免费看日韩精品| 国产激情偷乱视频一区二区三区 | 蜜臀av性久久久久av蜜臀妖精| 精品一区二区三区香蕉蜜桃| 成人综合在线观看| 欧亚一区二区三区| 国产亚洲欧美在线| 亚洲精品国产成人久久av盗摄| 奇米色一区二区| 色婷婷av一区二区三区之一色屋| 欧美日韩国产另类不卡| 中文字幕不卡在线| 日韩国产高清在线| 91浏览器打开| 欧美精品一区二区三| 亚洲图片欧美一区| 成人永久免费视频| 日韩欧美第一区| 亚洲综合免费观看高清完整版在线| 狠狠色丁香久久婷婷综合丁香|