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

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

?? time.c

?? 自己根據lkd和情境分析
?? C
字號:
/* * linux/arch/m68k/atari/time.c * * Atari time and real time clock stuff * * Assembled of parts of former atari/config.c 97-12-18 by Roman Hodek *   * This file is subject to the terms and conditions of the GNU General Public * License.  See the file COPYING in the main directory of this archive * for more details. */#include <linux/types.h>#include <linux/mc146818rtc.h>#include <linux/interrupt.h>#include <linux/init.h>#include <asm/rtc.h>void __initatari_sched_init(void (*timer_routine)(int, void *, struct pt_regs *)){    /* set Timer C data Register */    mfp.tim_dt_c = INT_TICKS;    /* start timer C, div = 1:100 */    mfp.tim_ct_cd = (mfp.tim_ct_cd & 15) | 0x60;     /* install interrupt service routine for MFP Timer C */    request_irq(IRQ_MFP_TIMC, timer_routine, IRQ_TYPE_SLOW,                "timer", timer_routine);}/* ++andreas: gettimeoffset fixed to check for pending interrupt */#define TICK_SIZE 10000  /* This is always executed with interrupts disabled.  */unsigned long atari_gettimeoffset (void){  unsigned long ticks, offset = 0;  /* read MFP timer C current value */  ticks = mfp.tim_dt_c;  /* The probability of underflow is less than 2% */  if (ticks > INT_TICKS - INT_TICKS / 50)    /* Check for pending timer interrupt */    if (mfp.int_pn_b & (1 << 5))      offset = TICK_SIZE;  ticks = INT_TICKS - ticks;  ticks = ticks * 10000L / INT_TICKS;  return ticks + offset;}static void mste_read(struct MSTE_RTC *val){#define COPY(v) val->v=(mste_rtc.v & 0xf)	do {		COPY(sec_ones) ; COPY(sec_tens) ; COPY(min_ones) ; 		COPY(min_tens) ; COPY(hr_ones) ; COPY(hr_tens) ; 		COPY(weekday) ; COPY(day_ones) ; COPY(day_tens) ; 		COPY(mon_ones) ; COPY(mon_tens) ; COPY(year_ones) ;		COPY(year_tens) ;	/* prevent from reading the clock while it changed */	} while (val->sec_ones != (mste_rtc.sec_ones & 0xf));#undef COPY}static void mste_write(struct MSTE_RTC *val){#define COPY(v) mste_rtc.v=val->v	do {		COPY(sec_ones) ; COPY(sec_tens) ; COPY(min_ones) ; 		COPY(min_tens) ; COPY(hr_ones) ; COPY(hr_tens) ; 		COPY(weekday) ; COPY(day_ones) ; COPY(day_tens) ; 		COPY(mon_ones) ; COPY(mon_tens) ; COPY(year_ones) ;		COPY(year_tens) ;	/* prevent from writing the clock while it changed */	} while (val->sec_ones != (mste_rtc.sec_ones & 0xf));#undef COPY}#define	RTC_READ(reg)				\    ({	unsigned char	__val;			\		(void) writeb(reg,&tt_rtc.regsel);	\		__val = tt_rtc.data;		\		__val;				\	})#define	RTC_WRITE(reg,val)			\    do {					\		writeb(reg,&tt_rtc.regsel);	\		tt_rtc.data = (val);		\	} while(0)void atari_mste_gettod (int *yearp, int *monp, int *dayp,			int *hourp, int *minp, int *secp){    int hr24=0, hour;    struct MSTE_RTC val;    mste_rtc.mode=(mste_rtc.mode | 1);    hr24=mste_rtc.mon_tens & 1;    mste_rtc.mode=(mste_rtc.mode & ~1);    mste_read(&val);    *secp = val.sec_ones + val.sec_tens * 10;    *minp = val.min_ones + val.min_tens * 10;    hour = val.hr_ones + val.hr_tens * 10;    if (!hr24) {        if (hour == 12 || hour == 12 + 20)	    hour -= 12;	if (hour >= 20)	    hour += 12 - 20;    }    *hourp = hour;    *dayp = val.day_ones + val.day_tens * 10;    *monp = val.mon_ones + val.mon_tens * 10;    *yearp = val.year_ones + val.year_tens * 10 + 80;	}  void atari_tt_gettod (int *yearp, int *monp, int *dayp,		      int *hourp, int *minp, int *secp){    unsigned char	ctrl;    int hour, pm;    while (!(RTC_READ(RTC_FREQ_SELECT) & RTC_UIP)) ;    while (RTC_READ(RTC_FREQ_SELECT) & RTC_UIP) ;    *secp  = RTC_READ(RTC_SECONDS);    *minp  = RTC_READ(RTC_MINUTES);    hour = RTC_READ(RTC_HOURS);    *dayp  = RTC_READ(RTC_DAY_OF_MONTH);    *monp  = RTC_READ(RTC_MONTH);    *yearp = RTC_READ(RTC_YEAR);    pm = hour & 0x80;    hour &= ~0x80;    ctrl = RTC_READ(RTC_CONTROL);     if (!(ctrl & RTC_DM_BINARY)) {        BCD_TO_BIN(*secp);        BCD_TO_BIN(*minp);        BCD_TO_BIN(hour);        BCD_TO_BIN(*dayp);        BCD_TO_BIN(*monp);        BCD_TO_BIN(*yearp);    }    if (!(ctrl & RTC_24H)) {	if (!pm && hour == 12)	    hour = 0;	else if (pm && hour != 12)            hour += 12;    }    *hourp = hour;    /* Adjust values (let the setup valid) */    *yearp += atari_rtc_year_offset;}#define HWCLK_POLL_INTERVAL	5int atari_mste_hwclk( int op, struct hwclk_time *t ){    int hour, year;    int hr24=0;    struct MSTE_RTC val;        mste_rtc.mode=(mste_rtc.mode | 1);    hr24=mste_rtc.mon_tens & 1;    mste_rtc.mode=(mste_rtc.mode & ~1);    if (op) {        /* write: prepare values */                val.sec_ones = t->sec % 10;        val.sec_tens = t->sec / 10;        val.min_ones = t->min % 10;        val.min_tens = t->min / 10;        hour = t->hour;        if (!hr24) {	    if (hour > 11)		hour += 20 - 12;	    if (hour == 0 || hour == 20)		hour += 12;        }        val.hr_ones = hour % 10;        val.hr_tens = hour / 10;        val.day_ones = t->day % 10;        val.day_tens = t->day / 10;        val.mon_ones = (t->mon+1) % 10;        val.mon_tens = (t->mon+1) / 10;        year = t->year - 80;        val.year_ones = year % 10;        val.year_tens = year / 10;        val.weekday = t->wday;        mste_write(&val);        mste_rtc.mode=(mste_rtc.mode | 1);        val.year_ones = (year % 4);	/* leap year register */        mste_rtc.mode=(mste_rtc.mode & ~1);    }    else {        mste_read(&val);        t->sec = val.sec_ones + val.sec_tens * 10;        t->min = val.min_ones + val.min_tens * 10;        hour = val.hr_ones + val.hr_tens * 10;	if (!hr24) {	    if (hour == 12 || hour == 12 + 20)		hour -= 12;	    if (hour >= 20)                hour += 12 - 20;        }	t->hour = hour;	t->day = val.day_ones + val.day_tens * 10;        t->mon = val.mon_ones + val.mon_tens * 10 - 1;        t->year = val.year_ones + val.year_tens * 10 + 80;        t->wday = val.weekday;    }    return 0;}int atari_tt_hwclk( int op, struct hwclk_time *t ){    int sec=0, min=0, hour=0, day=0, mon=0, year=0, wday=0;     unsigned long 	flags;    unsigned char	ctrl;    int pm = 0;    ctrl = RTC_READ(RTC_CONTROL); /* control registers are                                   * independent from the UIP */    if (op) {        /* write: prepare values */                sec  = t->sec;        min  = t->min;        hour = t->hour;        day  = t->day;        mon  = t->mon + 1;        year = t->year - atari_rtc_year_offset;        wday = t->wday + (t->wday >= 0);                if (!(ctrl & RTC_24H)) {	    if (hour > 11) {		pm = 0x80;		if (hour != 12)		    hour -= 12;	    }	    else if (hour == 0)		hour = 12;        }                if (!(ctrl & RTC_DM_BINARY)) {            BIN_TO_BCD(sec);            BIN_TO_BCD(min);            BIN_TO_BCD(hour);            BIN_TO_BCD(day);            BIN_TO_BCD(mon);            BIN_TO_BCD(year);            if (wday >= 0) BIN_TO_BCD(wday);        }    }        /* Reading/writing the clock registers is a bit critical due to     * the regular update cycle of the RTC. While an update is in     * progress, registers 0..9 shouldn't be touched.     * The problem is solved like that: If an update is currently in     * progress (the UIP bit is set), the process sleeps for a while     * (50ms). This really should be enough, since the update cycle     * normally needs 2 ms.     * If the UIP bit reads as 0, we have at least 244 usecs until the     * update starts. This should be enough... But to be sure,     * additionally the RTC_SET bit is set to prevent an update cycle.     */    while( RTC_READ(RTC_FREQ_SELECT) & RTC_UIP ) {        current->state = TASK_INTERRUPTIBLE;        schedule_timeout(HWCLK_POLL_INTERVAL);    }    save_flags(flags);    cli();    RTC_WRITE( RTC_CONTROL, ctrl | RTC_SET );    if (!op) {        sec  = RTC_READ( RTC_SECONDS );        min  = RTC_READ( RTC_MINUTES );        hour = RTC_READ( RTC_HOURS );        day  = RTC_READ( RTC_DAY_OF_MONTH );        mon  = RTC_READ( RTC_MONTH );        year = RTC_READ( RTC_YEAR );        wday = RTC_READ( RTC_DAY_OF_WEEK );    }    else {        RTC_WRITE( RTC_SECONDS, sec );        RTC_WRITE( RTC_MINUTES, min );        RTC_WRITE( RTC_HOURS, hour + pm);        RTC_WRITE( RTC_DAY_OF_MONTH, day );        RTC_WRITE( RTC_MONTH, mon );        RTC_WRITE( RTC_YEAR, year );        if (wday >= 0) RTC_WRITE( RTC_DAY_OF_WEEK, wday );    }    RTC_WRITE( RTC_CONTROL, ctrl & ~RTC_SET );    restore_flags(flags);    if (!op) {        /* read: adjust values */                if (hour & 0x80) {	    hour &= ~0x80;	    pm = 1;	}	if (!(ctrl & RTC_DM_BINARY)) {            BCD_TO_BIN(sec);            BCD_TO_BIN(min);            BCD_TO_BIN(hour);            BCD_TO_BIN(day);            BCD_TO_BIN(mon);            BCD_TO_BIN(year);            BCD_TO_BIN(wday);        }        if (!(ctrl & RTC_24H)) {	    if (!pm && hour == 12)		hour = 0;	    else if (pm && hour != 12)		hour += 12;        }        t->sec  = sec;        t->min  = min;        t->hour = hour;        t->day  = day;        t->mon  = mon - 1;        t->year = year + atari_rtc_year_offset;        t->wday = wday - 1;    }    return( 0 );}int atari_mste_set_clock_mmss (unsigned long nowtime){    short real_seconds = nowtime % 60, real_minutes = (nowtime / 60) % 60;    struct MSTE_RTC val;    unsigned char rtc_minutes;    mste_read(&val);      rtc_minutes= val.min_ones + val.min_tens * 10;    if ((rtc_minutes < real_minutes         ? real_minutes - rtc_minutes         : rtc_minutes - real_minutes) < 30)    {        val.sec_ones = real_seconds % 10;        val.sec_tens = real_seconds / 10;        val.min_ones = real_minutes % 10;        val.min_tens = real_minutes / 10;        mste_write(&val);    }    else        return -1;    return 0;}int atari_tt_set_clock_mmss (unsigned long nowtime){    int retval = 0;    short real_seconds = nowtime % 60, real_minutes = (nowtime / 60) % 60;    unsigned char save_control, save_freq_select, rtc_minutes;    save_control = RTC_READ (RTC_CONTROL); /* tell the clock it's being set */    RTC_WRITE (RTC_CONTROL, save_control | RTC_SET);    save_freq_select = RTC_READ (RTC_FREQ_SELECT); /* stop and reset prescaler */    RTC_WRITE (RTC_FREQ_SELECT, save_freq_select | RTC_DIV_RESET2);    rtc_minutes = RTC_READ (RTC_MINUTES);    if (!(save_control & RTC_DM_BINARY))        BCD_TO_BIN (rtc_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 30 minutes.  */    if ((rtc_minutes < real_minutes         ? real_minutes - rtc_minutes         : rtc_minutes - real_minutes) < 30)        {            if (!(save_control & RTC_DM_BINARY))                {                    BIN_TO_BCD (real_seconds);                    BIN_TO_BCD (real_minutes);                }            RTC_WRITE (RTC_SECONDS, real_seconds);            RTC_WRITE (RTC_MINUTES, real_minutes);        }    else        retval = -1;    RTC_WRITE (RTC_FREQ_SELECT, save_freq_select);    RTC_WRITE (RTC_CONTROL, save_control);    return retval;}/* * Local variables: *  c-indent-level: 4 *  tab-width: 8 * End: */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡高清视频| 日韩免费视频一区| 欧美一区二区免费视频| 免费成人小视频| 国产欧美精品一区二区色综合朱莉| 日韩高清不卡一区| 亚洲女女做受ⅹxx高潮| 色婷婷久久综合| 欧美一级精品大片| 一区二区在线免费观看| 国产精品福利一区| 国产成人av资源| 欧美日韩高清一区二区不卡| 日韩一区二区三区电影在线观看| 精品国产免费久久| 五月天国产精品| 欧美撒尿777hd撒尿| 国产精品久久久久久久午夜片 | 国产精品1024久久| 欧美色综合久久| 亚洲不卡在线观看| 一本大道久久a久久综合婷婷| 亚洲欧洲精品成人久久奇米网| 亚洲国产视频a| 成人免费三级在线| 男人操女人的视频在线观看欧美| 欧美日韩性生活| 日本成人在线看| 久久人人爽人人爽| 日本电影亚洲天堂一区| 激情欧美日韩一区二区| 日本欧美大码aⅴ在线播放| 亚洲人成网站色在线观看| 1024成人网| 欧美激情一区二区三区蜜桃视频| 久久久精品国产免费观看同学| 69堂国产成人免费视频| 91蝌蚪porny| 国产一区在线不卡| 国产一区视频导航| 韩国精品主播一区二区在线观看| 国产一区二区三区日韩| 国产成人夜色高潮福利影视| 成人高清视频在线| 91视频国产观看| 欧美日韩国产另类一区| 日韩色在线观看| 久久久久久久久久久久电影 | 2021中文字幕一区亚洲| 中文字幕乱码亚洲精品一区 | 日本欧美韩国一区三区| 国产精品亚洲成人| 久久久精品日韩欧美| 99re这里只有精品首页| 日韩精品专区在线影院重磅| 精品一区二区在线视频| 日韩三级av在线播放| 国产资源在线一区| 国产精品精品国产色婷婷| 91看片淫黄大片一级在线观看| 久久久国际精品| 777午夜精品视频在线播放| 精品美女在线观看| 亚洲mv大片欧洲mv大片精品| 99久久亚洲一区二区三区青草| 91麻豆精品国产91久久久更新时间 | 日韩丝袜美女视频| 亚洲国产色一区| 欧美美女激情18p| 天天综合网天天综合色| 在线欧美日韩精品| 亚洲一区二区三区不卡国产欧美| 色综合久久久久综合| 怡红院av一区二区三区| 欧美视频在线一区二区三区| 亚洲午夜国产一区99re久久| 欧美日韩高清在线播放| 麻豆精品精品国产自在97香蕉| 在线成人小视频| 久久99国产乱子伦精品免费| 日韩一区二区电影在线| 青草av.久久免费一区| 日韩一区二区麻豆国产| 国产最新精品精品你懂的| 亚洲国产精品高清| jizz一区二区| 日本一道高清亚洲日美韩| 欧美群妇大交群中文字幕| 青青草精品视频| 亚洲天堂久久久久久久| 在线不卡免费av| 成人小视频免费观看| 亚洲成人动漫在线观看| 国产亚洲成年网址在线观看| 成人性色生活片| 日本欧美一区二区三区乱码| 久久看人人爽人人| 6080亚洲精品一区二区| 高清国产一区二区三区| 日韩精品免费视频人成| 国产精品妹子av| xnxx国产精品| 一道本成人在线| 成人av网站在线| 国产成人精品一区二区三区网站观看 | 婷婷开心激情综合| 亚洲日本一区二区三区| 日本一区二区高清| 亚洲国产高清在线| 国产精品网站在线观看| 精品三级在线观看| 久久综合五月天婷婷伊人| 91精品国产福利| 日韩精品一区国产麻豆| 制服丝袜在线91| 日韩视频在线永久播放| 精品日产卡一卡二卡麻豆| 日韩你懂的在线观看| 久久久亚洲高清| 国产欧美中文在线| 欧美经典一区二区| 国产精品国产馆在线真实露脸| 中文字幕一区二区三区四区不卡| 久久精品欧美日韩精品| 中文字幕一区在线观看| 一区二区三区 在线观看视频| 亚洲婷婷在线视频| 五月天精品一区二区三区| 丝袜国产日韩另类美女| 欧美96一区二区免费视频| 国产在线一区二区| 色狠狠色噜噜噜综合网| 欧美一区二区精品| 国产精品久久免费看| 日本美女一区二区三区视频| 国产suv一区二区三区88区| 91福利在线观看| xnxx国产精品| 午夜精品一区二区三区三上悠亚| 免费日本视频一区| 99视频国产精品| 久久综合五月天婷婷伊人| 亚洲电影视频在线| 成人avav在线| 国产亚洲精品久| 理论电影国产精品| 欧美性大战久久| 亚洲色大成网站www久久九九| 蜜臀av一区二区三区| 制服视频三区第一页精品| 自拍偷自拍亚洲精品播放| 韩国中文字幕2020精品| 日韩午夜精品视频| 蜜桃视频一区二区三区| 欧美福利视频导航| 青青草原综合久久大伊人精品优势| 色综合咪咪久久| 亚洲综合清纯丝袜自拍| 欧美色爱综合网| 免费不卡在线视频| 日韩欧美在线影院| 国产麻豆91精品| 亚洲欧洲日韩在线| 欧洲精品在线观看| 婷婷久久综合九色综合伊人色| 欧美性色黄大片| 婷婷一区二区三区| 精品国产乱码久久久久久老虎 | 欧美日韩一区二区三区高清 | 亚洲综合丁香婷婷六月香| 欧美日韩国产综合一区二区三区| 婷婷综合五月天| 日韩精品专区在线| 国产99精品视频| 樱花草国产18久久久久| 欧美sm美女调教| 岛国av在线一区| 一区二区三区欧美日| 精品处破学生在线二十三| 国产成人在线视频网址| 午夜精品一区二区三区电影天堂 | 婷婷综合在线观看| 欧美国产一区二区| 在线国产电影不卡| 丁香婷婷综合激情五月色| 丝袜美腿一区二区三区| 亚洲精品视频免费观看| 日本一区二区三区高清不卡| 欧美久久久久久蜜桃| 色综合久久久久综合体桃花网| 国产一区二区三区电影在线观看 | 欧美大片国产精品| 欧美精品高清视频| 欧美性猛交xxxxxxxx| 一本到三区不卡视频| 一本色道综合亚洲| 一本久道中文字幕精品亚洲嫩| 成人午夜av影视| 97久久人人超碰| jlzzjlzz亚洲女人18|