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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? skyeye_mach_sharp.c

?? skyeye是一個可以模擬嵌入式硬件開發(fā)板的系統(tǒng)軟件
?? C
字號:
#include <sys/time.h>#include <sys/types.h>#include <unistd.h>#include "armdefs.h"#include "sharp.h"#define F_CORE (200 * 1024 * 1024)	//core frequence#define F_OS    508469		//OS timer#define OS_SCALE (F_CORE / F_OS / 10)/* 2007-01-18 added by Anthony Lee : for new uart device frame */#include "skyeye_uart.h"typedef struct shp_io_t{	INTCREGS intc;	TIMERREGS timer1;	TIMERREGS timer2;	UARTREGS uart2;	u32 timer1_scale;	u32 timer2_scale;	u32 uart_scale;} shp_io_t;static shp_io_t shp_io;static void refresh_irq (ARMul_State *);static voidshp_io_reset (){	memset (&shp_io, 0, sizeof (shp_io));}static voidshp_io_write_byte (ARMul_State * state, ARMword addr, ARMword data){	shp_ioregnum_t ioregaddr = addr;	switch (ioregaddr) {	case CPLDKEYSTATE:		break;	case CPLDINTSTATE:		break;	case CPLDINTMASK:		break;	case CPLDPWRIO:		break;	case CPLDEXTIO:		break;	default:		printf ("SKYEYE: shp_io_write_byte %08x error, PC %x\n", addr,			state->Reg[15]);	}	return;}static voidshp_io_write_halfword (ARMul_State * state, ARMword addr, ARMword data){	printf ("SKYEYE: shp_io_write_halfword error\n");	skyeye_exit (-1);}static voidshp_io_write_word (ARMul_State * state, ARMword addr, ARMword data){	shp_ioregnum_t ioregaddr = addr;	switch (ioregaddr) {		/* Interrupt controller */	case INTSR:		//RO		break;	case INTRSR:		//RO		break;	case INTENS:/* BUGBUG: Writing a bit as 1 in this register enables the corresponding interrupt source. Clearing a bit    by writing a 0 in INTENS will not change that bit nor disable the interrupt. Use the INTENC    register to disable interrupt sources. */		shp_io.intc.enableset = data;		break;	case INTENC:		//WO/* BUGBUG: Reading this register returns 0. Set a bit to 1 in this register to clear the corresponding bit in    INTENS and disable the corresponding interrupt source. An attempt to clear a bit by writing    a 0 in this register does not change INTENS. */		shp_io.intc.enableclear = data;		break;		/* timer 1 */	case TIMERLOAD1:		shp_io.timer1.load = data & 0xffff;		shp_io.timer1.value = shp_io.timer1.load;	//reset		break;	case TIMERVALUE1:	//RO		break;	case TIMERCONTROL1:		shp_io.timer1.control = data & 0xc4;		break;	case TIMERTCEOI1:	//WO		shp_io.timer1.clear = 0;		break;		/* timer 2 */	case TIMERLOAD2:		shp_io.timer2.load = data & 0xffff;		shp_io.timer2.value = shp_io.timer2.load;	//reset		break;	case TIMERVALUE2:	//RO		break;	case TIMERCONTROL2:		shp_io.timer2.control = data & 0xc4;		break;	case TIMERTCEOI2:	//WO		shp_io.timer2.clear = 0;		break;		/*UART 2 */	case UART2DATA:		shp_io.uart2.data = data & 0xfff;		{			unsigned char c = shp_io.uart2.data;			/* 2007-01-18 modified by Anthony Lee : for new uart device frame */			skyeye_uart_write(-1, &c, 1, NULL);			shp_io.uart2.status &= ~UART_STATUS_TXFF;		}		break;	case UART2FCON:		shp_io.uart2.lcr = data & 0xff;		break;	case UART2BRCON:		shp_io.uart2.bcr = data & 0xffff;		break;	case UART2CON:		shp_io.uart2.control = data & 0xff;		break;	case UART2STATUS:	//RO		break;	case UART2RAWISR:	//WO		shp_io.uart2.intraw = 0;		break;	case UART2INTEN:		shp_io.uart2.inte = data & 0xf;		break;	case UART2ISR:		//RO		break;	default:		printf ("SKYEYE: shp_io_write_word: unknown addr 0x%x, reg15 0x%x \n", addr, state->Reg[15]);	}}static ARMwordshp_io_read_byte (ARMul_State * state, ARMword addr){	u32 data = 0;	shp_ioregnum_t ioregaddr = addr;	switch (ioregaddr) {	case CPLDKEYSTATE:		break;	case CPLDINTSTATE:		break;	case CPLDINTMASK:		break;	case CPLDPWRIO:		break;	case CPLDEXTIO:		break;	default:		printf ("SKYEYE: shp_io_read_byte %08x error, PC %x\n", addr,			state->Reg[15]);	}//  printf("SKYEYE: shp_io_read_byte error\n");	return data;}static ARMwordshp_io_read_halfword (ARMul_State * state, ARMword addr){	printf ("SKYEYE: shp_io_read_halfword error\n");	skyeye_exit (-1);}static ARMwordshp_io_read_word (ARMul_State * state, ARMword addr){	u32 data;	shp_ioregnum_t ioregaddr = addr;	switch (addr) {		/* Interrupt controller */	case INTSR:		//RO		data = shp_io.intc.status;		break;	case INTRSR:		//RO		data = shp_io.intc.rawstatus;		break;	case INTENS:		data = shp_io.intc.enableset;		break;	case INTENC:		//WO		break;		/* timer 1 */	case TIMERLOAD1:		data = shp_io.timer1.load & 0xffff;		break;	case TIMERVALUE1:	//RO		data = 0xffff;	//shp_io.timer1.value & 0xffff;		break;	case TIMERCONTROL1:		data = shp_io.timer1.control & 0xc4;		break;	case TIMERTCEOI1:	//WO		data = 0;		break;		/* timer 2 */	case TIMERLOAD2:		data = shp_io.timer2.load & 0xffff;		break;	case TIMERVALUE2:	//RO		data = shp_io.timer2.value & 0xffff;		break;	case TIMERCONTROL2:		data = shp_io.timer2.control & 0xc4;		break;	case TIMERTCEOI2:	//WO		data = 0;		break;		/*UART 2 */	case UART2DATA:		data = shp_io.uart2.data & 0xfff;		shp_io.uart2.status |= UART_STATUS_RXFE;		break;	case UART2FCON:		data = shp_io.uart2.lcr & 0xff;		break;	case UART2BRCON:		data = shp_io.uart2.bcr & 0xffff;		break;	case UART2CON:		data = shp_io.uart2.control & 0xff;		break;	case UART2STATUS:		data = shp_io.uart2.status & 0xff;		break;	case UART2RAWISR:	//WO		data = shp_io.uart2.intraw & 0xf;		break;	case UART2INTEN:		data = shp_io.uart2.inte & 0xf;		break;	case UART2ISR:		data = shp_io.uart2.intr & 0xf;		break;	default:		printf ("SKYEYE: shp_io_read_word: unknown addr 0x%x, reg15 0x%x \n", addr, state->Reg[15]);	}	return data;}static voidshp_io_do_cycle (ARMul_State * state){		/*timer1 */	if (++shp_io.timer1_scale >= 5000) {		shp_io.timer1_scale = 0;		if (shp_io.timer1.control & TIMER_CTRL_ENABLE) {			if (shp_io.timer1.value-- == 0) {				shp_io.timer1.clear = 1;	//note timer intrrupt				if (shp_io.timer1.				    control & TIMER_CTRL_PERIODIC)					shp_io.timer1.value =						shp_io.timer1.load;				else					shp_io.timer1.value = 0xffff;			}		}	}	/*timer2 */	if (++shp_io.timer2_scale >= 5000) {		shp_io.timer2_scale = 0;		if (shp_io.timer2.control & TIMER_CTRL_ENABLE) {			if (shp_io.timer2.value-- == 0) {				shp_io.timer2.clear = 1;	//note timer intrrupt				if (shp_io.timer2.				    control & TIMER_CTRL_PERIODIC)					shp_io.timer2.value =						shp_io.timer2.load;				else					shp_io.timer2.value = 0xffff;			}		}	}	/*uart2 */	if (++shp_io.uart_scale >= 512) {		shp_io.uart_scale = 0;		if (shp_io.uart2.control & UART_CONTROL_EN) {			/* 2007-01-18 modified by Anthony Lee : for new uart device frame */			struct timeval tv;			unsigned char c;			tv.tv_sec = 0;			tv.tv_usec = 0;			if(skyeye_uart_read(-1, &c, 1, &tv, NULL) > 0)			{				shp_io.uart2.data = (int) c;				shp_io.uart2.status &= ~UART_STATUS_RXFE;			}		}	}	/*reset interrupt pin status */	refresh_irq (state);};static voidrefresh_irq (ARMul_State * state){	//BUGBUG: when update interrupt status?	shp_io.intc.rawstatus = 0;	/*timer1 */	if (shp_io.timer1.clear) {		shp_io.intc.rawstatus |= INTC_TC1OINTR;	}	/*timer2 */	if (shp_io.timer2.clear) {		shp_io.intc.rawstatus |= INTC_TC2OINTR;	}	shp_io.intc.status = shp_io.intc.rawstatus & shp_io.intc.enableset;	state->NirqSig = shp_io.intc.status ? LOW : HIGH;}voidshp_mach_init (ARMul_State * state, machine_config_t * mc){	ARMul_SelectProcessor (state,			       ARM_XScale_Prop | ARM_v5_Prop | ARM_v5e_Prop);	state->lateabtSig = LOW;	state->Reg[1] = 89;	/*BUGBUG: lubbock machine id. */	shp_io_reset ();	mc->mach_io_do_cycle = shp_io_do_cycle;	mc->mach_io_reset = shp_io_reset;	mc->mach_io_read_byte = shp_io_read_byte;	mc->mach_io_write_byte = shp_io_write_byte;	mc->mach_io_read_halfword = shp_io_read_halfword;	mc->mach_io_write_halfword = shp_io_write_halfword;	mc->mach_io_read_word = shp_io_read_word;	mc->mach_io_write_word = shp_io_write_word;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区中文免费| 国产日韩欧美精品一区| 99久久综合精品| 麻豆免费看一区二区三区| 午夜精品久久久久久久99樱桃| 国产精品国产三级国产普通话蜜臀 | 欧美日韩视频第一区| 91蜜桃传媒精品久久久一区二区| av中文字幕一区| 色综合久久久久网| 在线视频你懂得一区二区三区| 欧美在线free| 欧美色爱综合网| 欧美日韩一级大片网址| 欧美自拍丝袜亚洲| 成人av网站在线观看免费| 精品久久国产字幕高潮| 精品免费一区二区三区| 亚洲成a人v欧美综合天堂| 国产麻豆视频一区二区| 欧美丝袜丝交足nylons图片| 国产欧美日韩另类视频免费观看 | 亚洲欧美另类图片小说| 久久精品999| 欧美高清激情brazzers| 欧美激情一区二区三区在线| 26uuu精品一区二区| 亚洲欧美日韩久久| 国产精品久久久久精k8| 麻豆精品精品国产自在97香蕉 | 国产91露脸合集magnet| 欧美在线观看18| 国产精品亲子伦对白| 久久99精品国产.久久久久 | 成人av网站大全| 精品国产麻豆免费人成网站| 日韩经典中文字幕一区| 91国偷自产一区二区三区成为亚洲经典 | 一区二区日韩电影| 色综合网色综合| 亚洲国产婷婷综合在线精品| thepron国产精品| 国产婷婷色一区二区三区四区| 欧美激情综合在线| 懂色av中文一区二区三区| 精品精品国产高清一毛片一天堂| 久久机这里只有精品| 欧美一区二区三区四区久久| 久久影音资源网| 一卡二卡三卡日韩欧美| 欧美在线三级电影| 一区二区三区欧美| 成人一区二区三区视频| 国产精品美女久久久久久久久久久 | 中文字幕亚洲在| 97aⅴ精品视频一二三区| 国产精品久久久久影院老司| 中文字幕亚洲欧美在线不卡| 色婷婷激情综合| 亚洲精品你懂的| 91精品国产综合久久蜜臀| 午夜欧美一区二区三区在线播放| 日韩欧美色电影| 另类小说图片综合网| 久久精品一级爱片| 成av人片一区二区| 亚洲成人高清在线| 欧美一区二区免费| 国产91精品精华液一区二区三区 | 国产欧美一区在线| 欧美在线观看禁18| 蜜桃久久精品一区二区| 久久网站热最新地址| 国产精品电影院| 亚洲人成影院在线观看| 国产精品一二一区| 日韩欧美123| 亚洲电影在线免费观看| 成人蜜臀av电影| 日本韩国一区二区三区视频| 91麻豆精品久久久久蜜臀 | 国产成人av福利| 欧美精品自拍偷拍| 成人免费一区二区三区视频| 蜜臀久久99精品久久久久久9| 色婷婷香蕉在线一区二区| 国产精品欧美一区喷水| 国产一区二区网址| 欧美成人精品1314www| 日韩中文字幕区一区有砖一区| 一本到高清视频免费精品| 中文字幕+乱码+中文字幕一区| 久久精品国产精品亚洲红杏| 欧美精品日日鲁夜夜添| 亚洲mv在线观看| 日本久久精品电影| 日本一区二区三区四区在线视频| 成人一道本在线| 久久久久国产一区二区三区四区 | 91精品国产综合久久久久久久久久 | 国模无码大尺度一区二区三区| 欧美日韩免费一区二区三区| 亚洲综合清纯丝袜自拍| 欧美三片在线视频观看| 亚洲高清中文字幕| 色狠狠综合天天综合综合| 国产精品女主播在线观看| 成人黄色777网| 亚洲欧美在线视频观看| 色哟哟国产精品免费观看| 亚洲综合在线五月| 欧美一区在线视频| 激情图区综合网| 日本一区二区免费在线| 国产成人精品免费一区二区| 欧美电影影音先锋| 国内精品久久久久影院薰衣草| 久久精品免视看| 99精品久久久久久| 午夜精品一区二区三区三上悠亚| 91精品国产欧美一区二区18| 国产在线精品免费av| 亚洲欧洲精品一区二区三区不卡 | 五月婷婷久久综合| 在线观看免费亚洲| 日韩电影免费一区| 中文字幕乱码日本亚洲一区二区| 97se亚洲国产综合自在线| 亚洲国产wwwccc36天堂| 日韩精品一区二区三区四区视频| 大胆欧美人体老妇| 日本aⅴ亚洲精品中文乱码| 国产三级精品三级| 欧洲国内综合视频| 国内精品伊人久久久久影院对白| 中文字幕精品一区二区精品绿巨人 | 国产露脸91国语对白| 综合婷婷亚洲小说| 欧美一级精品在线| 99视频国产精品| 日韩高清在线不卡| 亚洲图片激情小说| 欧美精品123区| 国产精品资源站在线| 国产精品福利影院| 国产网站一区二区| 欧美精品精品一区| 成人精品免费视频| 久久99久国产精品黄毛片色诱| 中文字幕视频一区| 久久一日本道色综合| 欧美日韩你懂的| av在线综合网| 国产a区久久久| 黄色精品一二区| 亚洲国产美女搞黄色| 国产精品天美传媒沈樵| 日韩一级片网址| 91福利区一区二区三区| 色哟哟国产精品| 色综合久久综合| 丁香婷婷综合网| 麻豆国产一区二区| 青青青伊人色综合久久| 亚洲国产日韩综合久久精品| 亚洲欧美欧美一区二区三区| 国产精品国产精品国产专区不蜜| 精品毛片乱码1区2区3区| 欧美精品粉嫩高潮一区二区| 91麻豆swag| 国产精品18久久久久久久久久久久 | 另类成人小视频在线| 国产精品麻豆视频| 中文字幕不卡在线| 国产精品乱人伦中文| 国产三级欧美三级日产三级99 | 在线亚洲免费视频| 91美女片黄在线观看| 91丝袜高跟美女视频| 成人黄色免费短视频| 91久久奴性调教| 欧美日韩一区二区在线观看视频| 在线看国产日韩| 7777精品伊人久久久大香线蕉最新版 | 91福利国产成人精品照片| 色狠狠桃花综合| 欧美日韩精品欧美日韩精品| 欧美色区777第一页| 7777精品伊人久久久大香线蕉的| 欧美妇女性影城| 欧美岛国在线观看| 久久伊人中文字幕| 国产精品无遮挡| 又紧又大又爽精品一区二区| 亚洲成a人在线观看| 久久国产精品露脸对白| 久久超级碰视频| 99久久精品免费看| 欧美日韩在线综合| 精品国产制服丝袜高跟|