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

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

?? time.h

?? 內核linux2.4.20,可跟rtlinux3.2打補丁 組成實時linux系統,編譯內核
?? H
字號:
/* *  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/mc146818rtc.h>#include <asm/hardware/dec21285.h>#include <asm/leds.h>#include <asm/mach-types.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;	count = (count + (mSEC_10_from_14/6)/2) / (mSEC_10_from_14/6);	return count;}static void isa_timer_interrupt(int irq, void *dev_id, struct pt_regs *regs){	if (machine_is_netwinder())		do_leds();	do_timer(regs);	do_set_rtc();	do_profile(regs);}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_gettimeoffset (void){	unsigned long value = LATCH - *CSR_TIMER1_VALUE;	return (tick * value) / LATCH;}static void timer1_interrupt(int irq, void *dev_id, struct pt_regs *regs){	*CSR_TIMER1_CLR = 0;	/* Do the LEDs things */	do_leds();	do_timer(regs);	do_set_rtc();	do_profile(regs);}/* * Set up timer interrupt. */static inline void setup_timer(void){	int irq;	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) {			/*			 * We have a RTC.  Check the battery			 */			if ((reg_d & 0x80) == 0)				printk(KERN_WARNING "RTC: *** warning: CMOS battery bad\n");			xtime.tv_sec = get_isa_cmos_time();			set_rtc = set_isa_cmos_time;		} else			rtc_base = 0;	}	if (machine_is_ebsa285() ||	    machine_is_co285() ||	    machine_is_personal_server()) {		gettimeoffset = timer1_gettimeoffset;		*CSR_TIMER1_CLR  = 0;		*CSR_TIMER1_LOAD = LATCH;		*CSR_TIMER1_CNTL = TIMER_CNTL_ENABLE | TIMER_CNTL_AUTORELOAD | TIMER_CNTL_DIV16;		timer_irq.handler = timer1_interrupt;		irq = IRQ_TIMER1;	} 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;		timer_irq.handler = isa_timer_interrupt;		irq = IRQ_ISA_TIMER;	}	setup_arm_irq(irq, &timer_irq);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂成人国产精品一区| 亚洲国产精品天堂| 一区二区成人在线观看| 激情六月婷婷久久| 91精品办公室少妇高潮对白| 337p粉嫩大胆色噜噜噜噜亚洲| 亚洲欧美区自拍先锋| 国产一区福利在线| 69久久夜色精品国产69蝌蚪网| 中文字幕一区二区三中文字幕| 精彩视频一区二区| 日韩一区二区三区三四区视频在线观看| 欧美韩国一区二区| 韩国欧美国产1区| 在线成人高清不卡| 亚洲成av人片一区二区三区| 成人av手机在线观看| 久久先锋影音av| 美女网站色91| 欧美一级久久久| 亚洲国产你懂的| 色就色 综合激情| 一区二区在线观看av| 99久久精品久久久久久清纯| 国产清纯白嫩初高生在线观看91| 免费高清在线一区| 日韩欧美不卡在线观看视频| 日韩成人午夜精品| 欧美一级黄色大片| 免费观看在线综合色| 欧美一级久久久久久久大片| 美女视频黄频大全不卡视频在线播放| 欧美日韩精品专区| 日韩黄色一级片| 老司机精品视频导航| 7777精品久久久大香线蕉| 欧美主播一区二区三区美女| 国产精品久久久久影院亚瑟 | 日韩欧美成人一区二区| 亚洲成人av中文| 欧美日韩一区二区在线观看视频| 亚洲激情在线播放| 884aa四虎影成人精品一区| 石原莉奈在线亚洲二区| 欧美一区二区三区在线观看视频| 亚洲mv在线观看| 欧美一区二区三级| 老司机一区二区| 国产亚洲精品7777| 99re热这里只有精品视频| 亚洲欧美色一区| 欧美视频一区在线观看| 亚洲国产精品久久人人爱| 中文字幕久久午夜不卡| 久久成人av少妇免费| 久久亚洲综合色一区二区三区| 国产在线精品一区二区不卡了| 国产精品久久久久永久免费观看| 99久久99久久久精品齐齐| 亚洲一卡二卡三卡四卡| 精品国产乱码久久久久久蜜臀| 国产成人av电影在线观看| 亚洲另类在线视频| 日韩视频一区在线观看| 国产成人av资源| 亚洲国产精品嫩草影院| 国产午夜精品一区二区| 色悠悠久久综合| 精品中文字幕一区二区小辣椒| 国产精品久久久久久久浪潮网站| 欧美图区在线视频| 国产一区二区网址| 亚洲午夜久久久久久久久久久| 精品噜噜噜噜久久久久久久久试看| 成人av免费观看| 久久精品72免费观看| 亚洲激情男女视频| 国产亚洲美州欧州综合国| 欧美在线一区二区三区| 丰满白嫩尤物一区二区| 日韩精品91亚洲二区在线观看 | 国产91精品在线观看| 亚洲小说春色综合另类电影| 国产欧美日韩在线视频| 9191精品国产综合久久久久久| 成人午夜电影久久影院| 日韩va亚洲va欧美va久久| ...av二区三区久久精品| 日韩欧美亚洲国产另类| 欧美在线免费观看亚洲| 成人午夜激情影院| 国内精品国产成人| 日韩黄色片在线观看| 一区二区三区在线播放| 中文字幕一区二区三区在线不卡| 精品国产免费人成在线观看| 欧美日高清视频| 在线日韩av片| 色综合久久久久综合99| 北条麻妃一区二区三区| 国产精品亚洲一区二区三区在线| 日韩激情一区二区| 香蕉加勒比综合久久| 亚洲精品高清在线| 亚洲色图视频网站| 中文字幕在线一区免费| 国产欧美精品一区aⅴ影院 | 亚洲成人自拍偷拍| 亚洲免费高清视频在线| 中文字幕国产一区二区| 国产欧美日韩综合精品一区二区 | 成人黄色免费短视频| 国产成人丝袜美腿| 成人综合婷婷国产精品久久蜜臀| 国产夫妻精品视频| 国产白丝精品91爽爽久久| 国产精品99久久久久久久女警 | 欧美日韩视频第一区| 欧美性极品少妇| 欧美军同video69gay| 欧美性受xxxx| 欧美性大战xxxxx久久久| 欧美视频中文字幕| 欧美一区二区播放| 欧美大片拔萝卜| 国产日韩欧美精品在线| 亚洲国产成人在线| 国产精品妹子av| 一区二区三国产精华液| 亚洲小少妇裸体bbw| 视频一区视频二区在线观看| 日本不卡中文字幕| 久久国产精品99精品国产| 国模一区二区三区白浆| 国产精品一品二品| 91麻豆高清视频| 欧美日韩国产不卡| 欧美变态口味重另类| 国产三级精品三级| 一区二区三区**美女毛片| 天堂成人国产精品一区| 国产一区二三区| 色综合咪咪久久| 日韩欧美国产一区在线观看| 久久久精品欧美丰满| 亚洲欧美日韩一区| 日本三级亚洲精品| 成人影视亚洲图片在线| 欧美性欧美巨大黑白大战| 久久伊99综合婷婷久久伊| 欧美成人国产一区二区| av中文字幕在线不卡| 欧美日韩一区中文字幕| 欧美电影免费观看高清完整版在线观看| 久久久蜜桃精品| 一区二区免费视频| 国产精品一区二区久久不卡| av不卡免费在线观看| 91精品国产美女浴室洗澡无遮挡| 久久久美女毛片| 亚洲一线二线三线久久久| 国产一区二区网址| 欧美日韩一区视频| 中文字幕av不卡| 蜜桃av一区二区三区电影| 91片在线免费观看| 久久久久久一二三区| 亚洲一区二区三区四区在线免费观看| 久久99日本精品| 欧美亚洲愉拍一区二区| 中文一区二区在线观看| 久久精品久久综合| 日本韩国精品在线| 日本一区二区三区免费乱视频| 青青青伊人色综合久久| 91原创在线视频| 国产亚洲一区字幕| 美女在线视频一区| 欧美巨大另类极品videosbest | 精品国产1区二区| 亚洲成av人片在www色猫咪| 成人午夜电影网站| 久久久久久9999| 美女国产一区二区三区| 欧美日韩一区二区三区不卡| 亚洲青青青在线视频| 国产精品一区二区三区99| 欧美一二三区在线| 日韩国产欧美一区二区三区| 在线观看亚洲精品| 一区二区三区在线免费视频| 91香蕉国产在线观看软件| 欧美激情一区二区三区不卡| 国产一区二区按摩在线观看| 精品三级在线看| 久久电影国产免费久久电影| 9191久久久久久久久久久| 午夜久久久久久久久| 欧美美女喷水视频| 日韩av电影免费观看高清完整版 |