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

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

?? decoder.c

?? skyeye是一個可以模擬嵌入式硬件開發(fā)板的系統(tǒng)軟件
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "instr.h"#include "emul.h"#include <stdio.h>/* Anthony Lee: 2006-09-18 */#ifdef __MINGW32__#define sync()	_flushall()#else#include <unistd.h> /* for sync() */#endif/* This monster of a switch statement decodes all CPU instructions. I've * decided against an explicit jump table, as such implementation both * increases the code size and introduced additional overhead to the inner * decoder loop. *//*  WARNING: The below code currently does not simulate any slips. * This should be fixed soon (it's fairly easy to simulate, too.) */const char* regname[32] = {    "$0", "at", "v0", "v1", "a0", "a1", "a2", "a3",    "t0", "t1", "t2", "t3", "t4", "t5", "t6", "t7",    "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",    "t8", "t9", "k0", "k1", "gp", "sp", "s8", "ra"};int decode(MIPS_State* mstate, Instr instr){    	switch (opcode(instr)) {    		case SPECIAL:    		{			/* Special instructions, decoded using the (function) field */			switch (function(instr)) {				case SLL:				{	    				// Shift Left Logical	    				if (rd(instr)) {						UInt32 x = mstate->gpr[rt(instr)];						int s = shamt(instr);						x <<= s;						mstate->gpr[rd(instr)] = x;					}    					return nothing_special;				}				case SRL:				{	    				// Shift Right Logical					UInt32 x = mstate->gpr[rt(instr)];	    				int s = shamt(instr);					x >>= s;	   				mstate->gpr[rd(instr)] = x;				  	return nothing_special;				}				case SRA:				{				    	// Shift Right Arithmetic					UInt32 x = mstate->gpr[rt(instr)];	    				int s = shamt(instr);					x >>= s;	    				mstate->gpr[rd(instr)] = sign_extend_UInt32(x, 32 - s);			    				return nothing_special;				}				case SLLV:				{				    	UInt32 x = mstate->gpr[rt(instr)];				    	int s = bits(mstate->gpr[rs(instr)], 4, 0);					x <<= s;					mstate->gpr[rd(instr)] = sign_extend_UInt32(x, 32 - s);					return nothing_special;				}				case SRLV:				{	    				// Shift Right Logical Variable					UInt32 x = mstate->gpr[rt(instr)];				        int s = bits(mstate->gpr[rs(instr)], 4, 0);					x >>= s;	   				mstate->gpr[rd(instr)] = sign_extend_UInt32(x, 32 - s);					return nothing_special;				}				case SRAV:				{					// Shift Right Arithmetic Variable 					UInt32 x = mstate->gpr[rt(instr)];				        int s = bits(mstate->gpr[rs(instr)], 4, 0);					x >>= s;				        mstate->gpr[rd(instr)] = sign_extend_UInt32(x, 32 - s);					return nothing_special;				}				case JR:				{				    	// Jump Register					mstate->branch_target = mstate->gpr[rs(instr)];	    				if (mstate->pipeline == branch_delay)						printf("Can't handle branch in branch delay slot\n");	   					return bits(mstate->branch_target, 1, 0) ? instr_addr_error : branch_delay;				}				case JALR:				{					// Jump And Link Register					mstate->branch_target = mstate->gpr[rs(instr)];					if(rd(instr) != 31)						mstate->gpr[rd(instr)] = mstate->pc + 8;					else						mstate->gpr[31] = mstate->pc + 8;	    				if (mstate->pipeline == branch_delay)						printf("Can't handle branch in branch delay slot\n");							return bits(mstate->branch_target, 1, 0) ? instr_addr_error : branch_delay;				}				case SYSCALL:				{				        // System Call					process_syscall(mstate);		    				return nothing_special;				}				case BREAK:				{					process_breakpoint(mstate);				    	return nothing_special;				}				case SYNC:				{					// Synchronize					//Fix me Shi yang 2006-08-08					process_reserved_instruction(mstate);					return nothing_special;				}				case MFHI:				{				    	// Move From HI	    				mstate->gpr[rd(instr)] = mstate->hi;					return nothing_special;				}				case MTHI:				{					// Move To HI				    	mstate->hi = mstate->gpr[rs(instr)];					return nothing_special;				}				case MFLO:				{				    	// Move From LO	    				mstate->gpr[rd(instr)] = mstate->lo;						        return nothing_special;				}				case MTLO:				{	    				// Move To LO		    			mstate->lo = mstate->gpr[rs(instr)];				        return nothing_special;				}				case DSLLV:				{			    		// Doubleword Shift Left Logical Variable					process_reserved_instruction(mstate);					return nothing_special;				}				case DSRLV:				{				    	// Doubleword Shift Right Logical Variable					process_reserved_instruction(mstate);					return nothing_special;				}					case DSRAV:				{		    			// Doubleword Shift Right Arithmetic Variable					process_reserved_instruction(mstate);					return nothing_special;				}				case MULT:				{			    		// Multiply				        Int32 x = mstate->gpr[rs(instr)];	    				Int32 y = mstate->gpr[rt(instr)];	    				multiply(x, y);					return nothing_special;				}				case MULTU:				{	    				// Multiply Unsigned				    	UInt32 x = mstate->gpr[rs(instr)];		    			UInt32 y = mstate->gpr[rt(instr)];	   	 			multiply(x, y);				    	return nothing_special;				}				case DIV:				{	    				// Divide					Int32 y = (Int32) mstate->gpr[rt(instr)];					Int32 x = (Int32) mstate->gpr[rs(instr)];					divide_Int32(x, y);									    	return nothing_special;				}				case DIVU:				{				    	UInt32 y = (UInt32) mstate->gpr[rt(instr)];					UInt32 x = (UInt32) mstate->gpr[rs(instr)];					divide_UInt32(x, y);				    	return nothing_special;				}				case DMULT:				{	    				// Doubleword Multiply					process_reserved_instruction(mstate);					return nothing_special;				}				case DMULTU:				{	    				// Doubleword Multiply Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case DDIV:				{			   		 // Doubleword Divide					process_reserved_instruction(mstate);					return nothing_special;				}				case DDIVU:				{	    				// Doubleword Divide Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case ADD:	    			{	    				// Add	    				UInt32 x = mstate->gpr[rs(instr)];	    				UInt32 y = mstate->gpr[rt(instr)];	    				UInt32 z = x + y;				    	// Overflow occurs is sign(x) == sign(y) != sign(z).				    	if (bit(x ^ y, 31) == 0 && bit(x ^ z, 31) != 0)						process_integer_overflow(mstate);					mstate->gpr[rd(instr)] = z;				    	return nothing_special;				}				case ADDU:				{	    				// Add Unsigned					UInt32 x = mstate->gpr[rs(instr)];				    	UInt32 y = mstate->gpr[rt(instr)];					UInt32 z = x + y;	    				mstate->gpr[rd(instr)] = z;				    	return nothing_special;				}				case SUB:				{	    				// Subtract					Int32 x = mstate->gpr[rs(instr)];					Int32 y = mstate->gpr[rt(instr)];	    				Int32 z = (UInt32)x - (UInt32)y;				    	if ((y < 0 && z < x) || (y > 0 && z > x))						process_integer_overflow();				    	mstate->gpr[rd(instr)] = z;					return nothing_special;				}				case SUBU:				{	    				// Subtract Unsigned	    				UInt32 x = mstate->gpr[rs(instr)];	    				UInt32 y = mstate->gpr[rt(instr)];				    	mstate->gpr[rd(instr)] = x - y;					return nothing_special;				}				case AND:				{	    				// And					mstate->gpr[rd(instr)] = mstate->gpr[rs(instr)] & mstate->gpr[rt(instr)];				    	return nothing_special;				}				case OR:				{				    	// Or				    	mstate->gpr[rd(instr)] = mstate->gpr[rs(instr)] | mstate->gpr[rt(instr)];				   	return nothing_special;				}				case XOR:				{			    		// Exclusive Or				        mstate->gpr[rd(instr)] = mstate->gpr[rs(instr)] ^ mstate->gpr[rt(instr)];				    	return nothing_special;				}				case NOR:				{	    				// Nor				        mstate->gpr[rd(instr)] = ~((mstate->gpr[rs(instr)] | mstate->gpr[rt(instr)]));					    	return nothing_special;				}				case SLT:				{	    				// Set On Less Than				    	Int32 x = mstate->gpr[rs(instr)];				    	Int32 y = mstate->gpr[rt(instr)];				    	mstate->gpr[rd(instr)] = (x < y);					    	return nothing_special;				}				case SLTU:				{				    	mstate->gpr[rd(instr)] = (mstate->gpr[rs(instr)] < mstate->gpr[rt(instr)]);				    	return nothing_special;				}				case DADD:				{				    	// Doubleword Add						process_reserved_instruction(mstate);					return nothing_special;				}				case DADDU:				{	    				// Doubleword Add Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case DSUB:				{		    			// Doubleword Subtract					process_reserved_instruction(mstate);					return nothing_special;				}				case DSUBU:				{	    				// Doubleword Subtract Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case TGE:				{			    		// Trap If Greater Than Or Equal					process_reserved_instruction(mstate);					return nothing_special;				}				case TGEU:				{			    		// Trap If Greater Than Or Equal Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case TLT:				{				    	// Trap If Less Than					process_reserved_instruction(mstate);					return nothing_special;				}				case TLTU:				{				    	// Trap If Less Than Unsigned					process_reserved_instruction(mstate);					return nothing_special;				}				case TEQ:				{				    	// Trap If Equal					process_reserved_instruction(mstate);					return nothing_special;				}				case TNE:				{				    	// Trap If Not Equal					process_reserved_instruction(mstate);					return nothing_special;				}				case DSLL:				{				    	// Doubleword Shift Left Logical					process_reserved_instruction(mstate);					return nothing_special;				}				case DSRL:				{				    	// Doubleword Shift Right Logical					process_reserved_instruction(mstate);					return nothing_special;				}				case DSRA:				{			    		// Doubleword Shift Right Arithmetic					process_reserved_instruction(mstate);					return nothing_special;				}				case DSLL32:				{			    		// Doubleword Shift Left Logical + 32					process_reserved_instruction(mstate);					return nothing_special;				}				case DSRL32:				{				    	// Doubleword Shift Right Logical + 32 					process_reserved_instruction(mstate);					return nothing_special;				}				case DSRA32:				{			    		// Doubleword Shift Right Arithmetic + 32					process_reserved_instruction(mstate);					return nothing_special;				}				default:			    		// Reserved instruction					process_reserved_instruction(mstate);				    	return nothing_special;			}		}    			case REGIMM:    		{			switch (rt(instr)) {				case BLTZ:				{	   			 	// Branch On Less Than Zero				    	Int32 x = mstate->gpr[rs(instr)];	    				if (x < 0) {						VA off = sign_extend_UInt32(offset(instr), 16);						mstate->branch_target = mstate->pc + 4 + (off << 2);	    				} else {						mstate->branch_target = mstate->pc + 8;	    				}			    		if (mstate->pipeline == branch_delay) {						printf("Can't handle branch in branch delay slot\n");					}				    	return branch_delay;				}				case BGEZ:				{				    	// Branch On greater Than Zero				    	Int32 x = mstate->gpr[rs(instr)];				    	if (x >= 0) {						VA off = sign_extend_UInt32(offset(instr), 16);						mstate->branch_target = mstate->pc + 4 + (off << 2);	    				} else {						mstate->branch_target = mstate->pc + 8;	    				}			    		if (mstate->pipeline == branch_delay) {						printf("Can't handle branch in branch delay slot\n");					}				    	return branch_delay;				}				case BLTZL:				{			    		// Branch On Less Than Zero Likely					return nothing_special;				}				case BGEZL:				{				    	// Branch On Greater Than Or Equal To Zero Likely					return nothing_special;				}				case TGEI:				{				    	// Trap If Greater Than Or Equal Immediate					return nothing_special;				}				case TGEIU:				{			    		// Trap If Greater Than Or Equal Immediate Unsigned				    	return nothing_special;				}				case TLTI:				{			    		// Trap If Less Than Immediate				    	return nothing_special;				}				case TLTIU:				{			    		// Trap If Less Than Immediate Unsigned				    	return nothing_special;				}				case TEQI:				{			    		// Trap If Equal Immediate				    	return nothing_special;				}				case TNEI:				{			    		// Trap If Not Equal Immediate				    	return nothing_special;				}				case BLTZAL:				{				    	// Branch On Less Than Zero And Link				    	Int32 x = mstate->gpr[rs(instr)];				    	mstate->gpr[31] = mstate->pc + 8;				    	if (x < 0) {						VA off = sign_extend_UInt32(offset(instr), 16);						mstate->branch_target = mstate->pc + 4 + (off << 2);	    				} else {				    		mstate->branch_target = mstate->pc + 8;	    				}	    				if (mstate->pipeline == branch_delay) {						printf("Can't handle branch in branch delay slot\n");					}				    	return branch_delay;				}				case BGEZAL:				{				    	// Branch On Greater Than Or Equal To Zero And Link				    	Int32 x = mstate->gpr[rs(instr)];				    	mstate->gpr[31] = mstate->pc + 8;				    	if (x >= 0) {						VA off = sign_extend_UInt32(offset(instr), 16);						mstate->branch_target = mstate->pc + 4 + (off << 2);					} else {						mstate->branch_target = mstate->pc + 8;	    				}						    	if (mstate->pipeline == branch_delay) {						printf("Can't handle branch in branch delay slot\n");					}				    	return branch_delay;				}				case BLTZALL:				{			    		// Branch On Less Than Zero And Link Likely					return nothing_special;				}				case BGEZALL:				{			    		// Branch On Greater Than Or Equal To Zero And Link Likely

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品福利视频网站| 欧美精品一区二区三区在线播放| 国产日韩高清在线| 国产精品一卡二卡在线观看| 2020国产精品自拍| 国产毛片一区二区| 国产精品久久毛片| 欧美在线免费播放| 日韩av一区二区在线影视| 精品人伦一区二区色婷婷| 国产一区二区看久久| 中文字幕在线不卡国产视频| 在线观看网站黄不卡| 日韩高清在线电影| 精品国产伦一区二区三区观看体验| 韩国女主播一区二区三区| 国产欧美日韩另类视频免费观看| 成人激情小说网站| 亚洲成人av一区二区三区| 欧美成人在线直播| fc2成人免费人成在线观看播放| 亚洲综合激情另类小说区| 欧美一级高清片| 国产电影一区在线| 亚洲最色的网站| 精品国内二区三区| 91亚洲精华国产精华精华液| 日韩精品久久理论片| 国产亚洲午夜高清国产拍精品| 色婷婷久久久久swag精品 | 国产亚洲自拍一区| 日本道在线观看一区二区| 奇米影视在线99精品| 中文字幕中文字幕在线一区 | 亚洲成人动漫精品| 久久久精品日韩欧美| 一本色道久久综合精品竹菊| 黄色精品一二区| 有码一区二区三区| 国产亚洲一二三区| 欧美丰满美乳xxx高潮www| 成人免费视频一区二区| 日本色综合中文字幕| 日韩一区在线播放| 久久综合九色综合欧美98| 欧美影片第一页| 成人性生交大片免费看在线播放| 日韩中文字幕av电影| 最新国产成人在线观看| 久久综合精品国产一区二区三区 | 一区二区三区精品视频在线| 久久精品一二三| 欧美一区中文字幕| 色综合激情久久| 盗摄精品av一区二区三区| 免费高清在线视频一区·| 一区二区三区资源| 国产精品传媒视频| 国产婷婷一区二区| 日韩欧美精品在线| 欧美精品一级二级三级| 色婷婷av一区二区三区软件| 国产.欧美.日韩| 韩国视频一区二区| 精一区二区三区| 日韩精品一二三四| 亚洲第一主播视频| 亚洲自拍偷拍av| 亚洲免费观看高清| 日韩美女视频一区| 国产精品美女www爽爽爽| 国产婷婷色一区二区三区四区| 精品久久久久久久久久久院品网| 欧美肥妇bbw| 7777精品伊人久久久大香线蕉完整版 | 欧美v日韩v国产v| 日韩欧美国产一区二区在线播放| 91精品国产综合久久久久久| 欧美日韩在线三区| 欧美日本韩国一区| 91精品国产综合久久小美女| 欧美一区二区三区小说| 欧美变态口味重另类| 欧美不卡视频一区| 久久久久一区二区三区四区| 久久久精品国产免大香伊| 国产视频亚洲色图| 中文字幕av资源一区| 国产精品久久久久久久久久免费看 | 国产又粗又猛又爽又黄91精品| 极品少妇一区二区三区精品视频 | 久久久久久亚洲综合影院红桃| 精品免费99久久| 国产日韩欧美制服另类| 中文字幕一区日韩精品欧美| 亚洲日本在线视频观看| 亚洲自拍偷拍麻豆| 免费在线观看一区二区三区| 国产在线视频一区二区| 成人av片在线观看| 欧美性大战久久| 日韩精品最新网址| 国产精品美女久久久久久久网站| 亚洲欧美区自拍先锋| 日本伊人午夜精品| 国产黄人亚洲片| 在线亚洲+欧美+日本专区| 91精品国产麻豆| 欧美高清在线精品一区| 亚洲一区在线观看网站| 美美哒免费高清在线观看视频一区二区 | 青青青伊人色综合久久| 国产成人精品影院| 色爱区综合激月婷婷| 欧美一卡二卡三卡| 中文字幕五月欧美| 青青草国产精品97视觉盛宴 | 国产精品免费aⅴ片在线观看| 亚洲六月丁香色婷婷综合久久 | 亚洲精品国产a| 久久99精品国产麻豆婷婷洗澡| 成人激情校园春色| 欧美一区午夜视频在线观看| 国产精品视频在线看| 日韩成人精品视频| 99re66热这里只有精品3直播| 日韩一区二区三区在线| 亚洲少妇30p| 国产九色精品成人porny| 91久久国产综合久久| 久久久一区二区三区| 性做久久久久久久免费看| 国产成人av资源| 日韩亚洲欧美一区二区三区| 中文字幕欧美一区| 韩国女主播一区二区三区| 欧美日本一区二区| 最新不卡av在线| 国产传媒一区在线| 欧美一区二区三区播放老司机| 亚洲美女屁股眼交3| 国产精品自拍在线| 日韩一区二区三区视频在线观看| 日韩毛片精品高清免费| 国产福利91精品一区| 欧美xxx久久| 日本女优在线视频一区二区| 日本韩国欧美一区二区三区| 中文字幕国产一区| 韩日精品视频一区| 日韩欧美高清dvd碟片| 天堂在线一区二区| 在线观看视频一区二区欧美日韩| 国产精品美女一区二区三区 | 久久精品一区四区| 久久99精品久久久久久动态图| 欧美另类高清zo欧美| 一级中文字幕一区二区| 91丨porny丨国产入口| 欧美国产日本韩| 国产九色精品成人porny| 精品国产污网站| 久久99精品视频| 久久综合狠狠综合久久综合88 | 欧美吻胸吃奶大尺度电影| 中文字幕日韩一区二区| 99久久精品免费观看| 中文字幕欧美一| av亚洲精华国产精华精华| 中文在线一区二区| jizz一区二区| 亚洲视频狠狠干| 在线看日本不卡| 亚洲成人综合视频| 91麻豆精品国产无毒不卡在线观看| 偷拍日韩校园综合在线| 91麻豆精品国产91久久久使用方法| 亚洲国产日韩一级| 欧美一区二区视频在线观看 | 国产网红主播福利一区二区| 高清久久久久久| 最好看的中文字幕久久| 欧洲av一区二区嗯嗯嗯啊| 亚洲成人中文在线| 欧美一区二区视频观看视频| 国内精品伊人久久久久av一坑| 国产性天天综合网| 99国产精品久久久久久久久久久| 亚洲制服丝袜av| 欧美一级午夜免费电影| 国产在线精品视频| 国产精品久久久久久久久动漫 | 欧美日韩一级视频| 日韩av中文字幕一区二区 | 成人av网站在线| 亚洲国产你懂的| 精品免费一区二区三区| jizz一区二区| 日韩经典中文字幕一区| 久久久久久电影|