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

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

?? fgen.c

?? m68k系列反匯編的C語言源碼,供學(xué)習(xí)編譯原理的同學(xué)使用。實用!
?? C
字號:
/* *                 Author:  Christopher G. Phillips *              Copyright (C) 1994 All Rights Reserved * *                              NOTICE * * Permission to use, copy, modify, and distribute this software and * its documentation for any purpose and without fee is hereby granted * provided that the above copyright notice appear in all copies and * that both the copyright notice and this permission notice appear in * supporting documentation. * * The author makes no representations about the suitability of this * software for any purpose.  This software is provided ``as is'' * without express or implied warranty. *//* * MC68881/MC68882 FPU support. */#include <stdio.h>#include <stdlib.h>#include <string.h>#include "dis.h"#include "addr.h"static char	*fccs[] = {	"F", "EQ", "OGT", "OGE", "OLT", "OLE", "OGL", "OR",	"UN", "UEQ", "UGT", "UGE", "ULT", "ULE", "NE", "T",	"SF", "SEQ", "GT", "GE", "LT", "LE", "GL", "GLE",	"NGLE", "NGL", "NLE", "NLT", "NGE", "NGT", "SNE", "ST"};#define NFCCS	(sizeof fccs / sizeof fccs[0])/* * Here come most of the math functions. * fmath accounts for those after FSUB. */static char	*names[] = {	"FMOVE", "FINT", "FSINH", "FINTRZ",	"FSQRT", NULL, "FLOGNP1", NULL,	"FETOXM1", "FTANH", "FATAN", NULL,	"FASIN", "FATANH", "FSIN", "FTAN",	"FETOX", "FTWOTOX", "FTENTOX", NULL,	"FLOGN", "FLOG10", "FLOG2", NULL,	"FABS", "FCOSH", "FNEG", NULL,	"FACOS", "FCOS", "FGETEXP", "FGETMAN",	"FDIV", "FMOD", "FADD", "FMUL",	"FSGLDIV", "FREM", "FSCALE", "FSGLMUL",	"FSUB"};#define NNAMES	(sizeof names / sizeof names[0])char *fcc(unsigned condition){	return (condition < NFCCS) ? fccs[condition] : NULL;}intftype2lis(int type){	switch (type) {	case SINGLE:	return L_ISSINGLE;	case DOUBLE:	return L_ISDOUBLE;	case EXTENDED:	return L_ISEXTENDED;	case PACKED:	return L_ISPACKED;	default:	return -1;	}}size_tfsizeof(int type){	switch (type) {	case SINGLE:	return 2 * WORDSIZE;	case DOUBLE:	return 4 * WORDSIZE;	case EXTENDED:	return 6 * WORDSIZE;	case PACKED:	return 6 * WORDSIZE;	default:	return 0;	}}static intsrcreg2size(int srcreg){	switch (srcreg) {	case 0: return LONGWORD;	case 1: return SINGLE;	case 2: return EXTENDED;	case 3: return PACKED;	case 4: return WORD;	case 5: return DOUBLE;	case 6: return BYTE;	default: return -1;	}}static voidfmovefromfp(m68kword inst, unsigned long value){	int	size = (value >> 10) & 7;	int	srcreg = (value >> 7) & 7;	int	k = value & 0x7f;	int	reg = inst & 7;	int	mode = (inst >> 3) & 7;		/*	 * destreg and srcreg are switched so the	 * call to srcreg2size is correct	 * (size is playing the role of destreg)	 */	if ((size = srcreg2size(size)) == -1) {		size = PACKED;		if (k & 0x40)			k |= ~0x7f;	/* sign-extend */		sprintf(buf3, "{#%d}", k);	} else if (size == PACKED) {		if (k & 0xf)			return;		sprintf(buf3, "{D%d}", (int)(k >> 4));	} else if (k)		return;	/* not sure here: manual says k ``should'' be 0 */	sprintf(buf1, "FP%d", srcreg);#define ISSINGLE(s)	((s) == SINGLE)	if (ISDATA(mode) && !ISINTEGRAL(size) && !ISSINGLE(size)	  || !ISADEA(mode, reg))		return;#undef ISSINGLE	if (getea(buf2, reg, mode, size))		return;	if (size == PACKED)		strcat(buf2, buf3);	instprint(ops2f(2) | size2f(size), "FMOVE", buf1, buf2);	valid = 1;}static voidfmovelist(m68kword inst, unsigned long value){	int	to_ea = value & 0x2000;	int	reg = inst & 7;	int	mode = (inst >> 3) & 7;	char	*cp1, *cp2;	int	nregs;	if (value & 0x3ff)		return;	if (to_ea && !ISADEA(mode, reg) && !ISDIRECT(mode))		return;	cp1 = buf1;	*cp1 = '\0';	nregs = 0;	if (value & 0x1000) {		cp1 += sprintf(cp1, "FPCR");		nregs++;	}	if (value & 0x0800) {		if (cp1 != buf1)			*cp1++ = '/';		cp1 += sprintf(cp1, "FPSR");		nregs++;	}	if (value & 0x0400) {		if (cp1 != buf1)			*cp1++ = '/';		cp1 += sprintf(cp1, "FPIAR");		nregs++;	}	if (cp1 == buf1)		strcpy(cp1, "0");		if (ISDATA(mode) && nregs != 1	  || ISDIRECT(mode) && nregs != 1 && (value & 0x0400) == 0)		return;	if (getea(buf2, reg, mode, LONGWORD))		return;	if (to_ea) {		cp1 = buf1;		cp2 = buf2;	} else {		cp1 = buf2;		cp2 = buf1;	}	instprint(ops2f(2) | size2f(LONGWORD), nregs == 1 ? "FMOVE" : "FMOVEM",	  cp1, cp2);	valid = 1;}static voidfmovem(m68kword inst, unsigned long value){	int		to_ea = value & 0x2000;	int		eareg = inst & 7;	int		eamode = (inst >> 3) & 7;	int		mode = (value >> 11) & 3;	unsigned long	reglist = value & 0xff;	char		*cp1, *cp2;	if (value & 0x0700)		return;	if (to_ea) {		if (!ISACEAplusPRE(eamode, eareg))			return;	} else if (!ISCEAplusPOST(eamode, eareg))		return;	/*	 * Note that (mode & 2) implies postincrement or control	 * addressing mode, otherwise predecrement addressing mode	 *	 * Not sure what this means though...	 */	if (mode & 1) {		/*		 * Dynamic list		 */		if (value & 0x8f)			return;		sprintf(buf1, "D%d", (int)((value >> 4) & 7));	} else {		/*		 * Static list		 */		if (mode & 2)			revbits(&reglist, 8);		regbyte(buf1, reglist, "FP", 0);	}	if (getea(buf2, eareg, eamode, EXTENDED))		return;	if (to_ea) {		cp1 = buf1;		cp2 = buf2;	} else {		cp1 = buf2;		cp2 = buf1;	}	instprint(ops2f(2) | size2f(EXTENDED), "FMOVEM", cp1, cp2);	valid = 1;}static voidfmath(m68kword inst, unsigned long value){	int	reg = inst & 7;	int	mode = (inst >> 3) & 7;	int	srcreg = (value >> 10) & 7;	int	destreg = (value >> 7) & 7;	int	cosreg = value & 7;	int	use_ea = value & 0x4000;	int	size;	size_t	name_index = value & 0x7f;	int	nops;	char	*name = NULL;	size = EXTENDED;	nops = 2;	if (name_index == 0x3a) {		name = "FTST";		nops = 1;		sprintf(buf2, "FP%d", destreg);	} else if (name_index >= 0x30 && name_index <= 0x37) {		name = "FSINCOS";		sprintf(buf2, "FP%d:FP%d", cosreg, destreg /* sine reg */);	} else {		sprintf(buf2, "FP%d", destreg);		if (name_index < NNAMES)			name = names[name_index];		else if (name_index == 0x38)			name = "FCMP";	}	if (!name)		return;#define ISSINGLE(s)	((s) == SINGLE)	if (use_ea) {		if ((size = srcreg2size(srcreg)) == -1)			return;		if (ISDIRECT(mode) || ISDATA(mode) && !ISINTEGRAL(size)		  && !ISSINGLE(size))#undef ISSINGLE			return;		if (getea(nops == 1 ? buf2 : buf1, reg, mode, size))			return;	} else {		if (mode || reg)			return;		if (srcreg == destreg && name_index < 0x20)			nops = 1;		else			sprintf(buf1, "FP%d", srcreg);	}	if (nops == 1)		instprint(ops2f(1) | size2f(size), name, buf2);	else		instprint(ops2f(2) | size2f(size), name, buf1, buf2);	valid = 1;}static voidfmovecr(unsigned long value){	int	reg = (value >> 7) & 7;	int	offset = value & 0x7f;	sprintf(buf2, "FP%d", reg);	immsprintf(buf1, offset);	switch (offset) {	case 0x00:	strcat(buf1, "!PI");	break;	case 0x0b:	strcat(buf1, "!Log10(2)");	break;	case 0x0c:	strcat(buf1, "!e");	break;	case 0x0d:	strcat(buf1, "!Log2(e)");	break;	case 0x0e:	strcat(buf1, "!Log10(e)");	break;	case 0x0f:	strcat(buf1, "!0.0");	break;	case 0x30:	strcat(buf1, "!1n(2)");	break;	case 0x31:	strcat(buf1, "!1n(10)");	break;	case 0x32:	strcat(buf1, "!10^0");	break;	case 0x33:	strcat(buf1, "!10^1");	break;	case 0x34:	strcat(buf1, "!10^2");	break;	case 0x35:	strcat(buf1, "!10^4");	break;	case 0x36:	strcat(buf1, "!10^8");	break;	case 0x37:	strcat(buf1, "!10^16");	break;	case 0x38:	strcat(buf1, "!10^32");	break;	case 0x39:	strcat(buf1, "!10^64");	break;	case 0x3a:	strcat(buf1, "!10^128");	break;	case 0x3b:	strcat(buf1, "!10^256");	break;	case 0x3c:	strcat(buf1, "!10^512");	break;	case 0x3d:	strcat(buf1, "!10^1024");	break;	case 0x3e:	strcat(buf1, "!10^2048");	break;	case 0x3f:	strcat(buf1, "!10^4096");	break;	}	instprint(ops2f(2), "FMOVECR", buf1, buf2);	valid = 1;}voidfgen(m68kword inst){	unsigned long	value;	int		failure;	value = getval(WORD, &failure) & 0xffff;	if (failure)		return;	if ((inst & 0x7f) == 0 && (value & 0xfc00) == 0x5c00)		fmovecr(value);	else		switch ((value >> 13) & 7) {		case 0: /* FALLTHROUGH */		case 2:			fmath(inst, value);			break;		case 3:			fmovefromfp(inst, value);			break;		case 4: /* FALLTHROUGH */		case 5:			fmovelist(inst, value);			break;		case 6: /* FALLTHROUGH */		case 7:			fmovem(inst, value);			break;		default:			return;		}}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久99久久综合| 国产一区二区三区黄视频 | 日韩一区二区三区三四区视频在线观看| 综合色中文字幕| 色噜噜久久综合| 亚洲一区在线播放| 欧美精品免费视频| 精品一二线国产| 中文字幕免费一区| 在线中文字幕一区| 石原莉奈一区二区三区在线观看| 欧美一三区三区四区免费在线看| 久久福利资源站| 日本一区二区三区视频视频| 99国产精品久久| 图片区小说区区亚洲影院| 中文幕一区二区三区久久蜜桃| 国产一区二区久久| 亚洲精品福利视频网站| 欧美一区二区三区四区久久| 国产成人啪午夜精品网站男同| 最新久久zyz资源站| 欧美精品 国产精品| 国产精品白丝jk黑袜喷水| 亚洲精品视频自拍| 日韩午夜电影av| 不卡高清视频专区| 青青草原综合久久大伊人精品| 国产日韩三级在线| 欧美三日本三级三级在线播放| 麻豆91小视频| 亚洲在线中文字幕| 国产亚洲综合在线| 欧美高清精品3d| 波多野结衣中文字幕一区| 日本欧美一区二区| 1024精品合集| 久久青草欧美一区二区三区| 欧美三级电影网| gogo大胆日本视频一区| 麻豆一区二区99久久久久| 一区二区三区在线播| 国产人妖乱国产精品人妖| 91精品中文字幕一区二区三区| 成人激情小说网站| 国产在线观看一区二区| 亚洲午夜精品久久久久久久久| 国产三级精品三级在线专区| 日韩区在线观看| 在线观看日韩国产| 99久久夜色精品国产网站| 国产最新精品免费| 青青青伊人色综合久久| 一区二区三区在线观看国产| 国产精品毛片高清在线完整版| 欧美电影精品一区二区| 欧美男女性生活在线直播观看| 97精品久久久久中文字幕| 国产xxx精品视频大全| 久久精品久久精品| 日韩av一级电影| 亚洲一区二区视频在线| 亚洲日本电影在线| 最好看的中文字幕久久| 国产精品第四页| 国产精品久久免费看| 国产无一区二区| 久久久久久日产精品| 精品日韩欧美一区二区| 亚洲美女在线国产| 国产精品欧美一级免费| 国产欧美日韩精品a在线观看| 欧美xxxxx牲另类人与| 欧美一级夜夜爽| 91精品国产综合久久久久久久| 欧美日韩在线播放| 欧美精品久久99| 欧美一卡2卡三卡4卡5免费| 欧美电影一区二区三区| 日韩一区二区三区视频在线| 日韩欧美123| 久久婷婷成人综合色| 久久久久国产精品人| 欧美激情在线一区二区| 国产精品电影一区二区| 亚洲天堂av老司机| 一区二区三区电影在线播| 亚洲综合在线观看视频| 亚洲国产欧美在线| 免费在线观看视频一区| 九九在线精品视频| 国产宾馆实践打屁股91| 91亚洲精品久久久蜜桃网站| 欧美亚洲国产一区在线观看网站| 欧美三级中文字幕| 精品乱人伦小说| 国产精品国产三级国产aⅴ原创| 一区在线观看免费| 亚洲r级在线视频| 另类小说欧美激情| eeuss国产一区二区三区| 日本久久一区二区三区| 91精品国产aⅴ一区二区| 久久蜜桃av一区二区天堂 | 亚洲精品国久久99热| 亚洲高清视频的网址| 精品在线播放免费| 成人a区在线观看| 欧美福利电影网| 日本一区二区综合亚洲| 亚洲国产日日夜夜| 狠狠色丁香婷综合久久| 99久久久久久99| 91精品国产综合久久婷婷香蕉 | 日本成人在线不卡视频| 国产精品18久久久久久久久| 色网站国产精品| 精品乱人伦小说| 亚洲一区二区视频在线观看| 韩国在线一区二区| 欧美视频在线一区| 国产蜜臀av在线一区二区三区| 亚洲成人一区二区在线观看| 国产一区不卡精品| 欧美日韩另类一区| 国产精品嫩草99a| 麻豆精品视频在线观看| 91激情在线视频| 国产精品色眯眯| 久久99精品久久久久久动态图| 日韩欧美一级二级三级久久久| 日韩一区在线免费观看| 国产揄拍国内精品对白| 欧美日韩在线三级| 国产精品久久久久久久久快鸭| 人人狠狠综合久久亚洲| 在线视频你懂得一区二区三区| 久久一留热品黄| 麻豆极品一区二区三区| 欧美日韩在线播放三区四区| 亚洲欧洲一区二区三区| 国产精品2024| 精品久久人人做人人爰| 日韩精品成人一区二区在线| 色偷偷一区二区三区| 国产精品麻豆一区二区| 国产九九视频一区二区三区| 欧美巨大另类极品videosbest | 中文字幕五月欧美| 国产老肥熟一区二区三区| 欧美成人一区二区| 视频一区二区欧美| 欧美在线视频不卡| 日韩理论在线观看| proumb性欧美在线观看| 欧美国产精品一区二区| 久久精品噜噜噜成人av农村| 欧美一区二区视频在线观看2020 | 色综合色狠狠天天综合色| 中文字幕精品三区| 国产成人精品aa毛片| 久久久亚洲精品一区二区三区| 久久精品国产秦先生| 精品国产乱码久久久久久1区2区| 日本中文在线一区| 日韩一区二区在线观看视频播放| 日韩激情av在线| 日韩精品中文字幕一区二区三区 | 粉嫩欧美一区二区三区高清影视| 精品国产伦一区二区三区观看体验| 日本欧洲一区二区| 日韩精品专区在线影院重磅| 国产中文字幕一区| 久久婷婷综合激情| 成人黄页在线观看| 亚洲欧美日韩系列| 91国偷自产一区二区三区成为亚洲经典| 亚洲女厕所小便bbb| 欧美视频在线播放| 日本不卡一区二区| 久久蜜桃一区二区| 99在线热播精品免费| 亚洲黄色性网站| 欧美一区二区福利视频| 国产一区不卡视频| 中文字幕一区二| 欧美区在线观看| 极品瑜伽女神91| 国产精品久久久久久久久免费相片 | 中文字幕中文字幕一区| 成人app在线观看| 亚洲妇女屁股眼交7| 欧美一级xxx| 成人午夜免费电影| 伊人色综合久久天天人手人婷| 91精品福利视频| 激情欧美一区二区| 1区2区3区精品视频| 欧美丰满一区二区免费视频 | 不卡高清视频专区|