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

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

?? outas386.c

?? 本程序集是Allen I. Holub所寫的《Compiler Design in C》一書的附隨軟件
?? C
?? 第 1 頁 / 共 3 頁
字號:
{
			if (prm_asmfile)
        if( gentype == srrefgen && outcol < 56) {
                fprintf(outputFile,",%s,%d",sp->name,val);
                outcol += strlen(sp->name)+1;
                }
        else    {
                nl();
                fprintf(outputFile,"\tDD\t%s,%d",sp->name,val);
                gentype = srrefgen;
                outcol = 25;
                }
}
void genref(SYM *sp,int offset)
/*
 * Output a reference to the data area (also gens fixups )
 */
{       char    sign;
			char buf[40];
        if( offset < 0) {
                sign = '-';
                offset = -offset;
                }
        else
                sign = '+';
			sprintf(buf,"%s%c%d",sp->name,sign,offset);
			if (prm_asmfile) {
        if( gentype == longgen && outcol < 55 - strlen(sp->name)) {
                fprintf(outputFile,",%s",buf);
                outcol += (11 + strlen(sp->name));
                }
        else    {
								if (!newlabel)
									nl();
								else newlabel = FALSE;
                fprintf(outputFile,"\tDD\t%s",buf);
                outcol = 26 + strlen(sp->name);
                gentype = longgen;
                }
			}
}
void genpcref(SYM *sp,int offset)
/*
 * Output a reference to the code area (also gens fixups )
 */
{
	genref(sp,offset);
}
void genstorage(int nbytes)
/*
 * Output bytes of storage
 */
{			if (prm_asmfile) {
								if (!newlabel)
									nl();
								else newlabel = FALSE;
				if (prm_nasm)
        	fprintf(outputFile,"\tRESB\t0%XH",nbytes);
				else
        	fprintf(outputFile,"\tDB\t0%XH DUP (?)",nbytes);
				outcol = 28;
				gentype = storagegen;
			}
}

void gen_labref(int n)
/*
 * Generate a reference to a label
 */
{			if (prm_asmfile)
        if( gentype == longgen && outcol < 58) {
                fprintf(outputFile,",L_%d",n);
                outcol += 6;
                }
        else    {
								if (!newlabel)
									nl();
								else newlabel = FALSE;
                fprintf(outputFile,"\tDD\tL_%d",n);
                outcol = 22;
                gentype = longgen;
                }
}

int     stringlit(char *s, int uselong)
/*
 *      make s a string literal and return it's label number.
 */
{       struct slit     *lp;
        ++global_flag;          /* always allocate from global space. */
        lp = xalloc(sizeof(struct slit));
        lp->label = nextlabel++;
				if (uselong) 
					lp->str = plitlate(s);
				else
        	lp->str = litlate(s);
        lp->next = strtab;
				lp->type = uselong;
        strtab = lp;
        --global_flag;
        return lp->label;
}

void dumplits(void)
/*
 *      dump the string literal pool.
 */
{
        while( strtab != 0) {
                cseg();
                nl();
                put_label(strtab->label);
								genstring(strtab->str,strtab->type);
								if (strtab->type)
									genword(0);
								else
									genbyte(0);
                strtab = strtab->next;
                }
        nl();
}

/*
 * Exit if from a special segment
 */
void exitseg(void)
{
	if (!prm_nasm) {
		if (curseg == startupxseg) {
			curseg = noseg;
			fprintf(outputFile,"cstartup\tENDS\n");
		}
		else if (curseg == rundownxseg) {
			curseg = noseg;
			fprintf(outputFile,"crundown\tENDS\n");
		}
		else if (curseg == cppxseg) {
			curseg = noseg;
			fprintf(outputFile,"cppinit\tENDS\n");
		}
	}
}
/*
 * Switch to cseg 
 */
void cseg(void)
{			if (prm_asmfile)
       	if( curseg != codeseg) {
                nl();
								exitseg();
								if (prm_nasm)
                	fprintf(outputFile,"[SECTION .text]\n");
								else
                	fprintf(outputFile,"\t.CODE\n");
                curseg = codeseg;
                }
}
/*
 * Switch to deseg
 */
void dseg(void)
{     if (prm_asmfile)  
				if( curseg != dataseg) {
                nl();
								exitseg();
								if (prm_nasm)
                	fprintf(outputFile,"[SECTION .data]\n");
								else
                	fprintf(outputFile,"\t.DATA\n");
                curseg = dataseg;
                }
}
/*
 * Switch to bssseg
 */
void bssseg(void)
{     if (prm_asmfile)  
				if( curseg != bssxseg) {
                nl();
								exitseg();
								if (prm_nasm)
                	fprintf(outputFile,"[SECTION .bss]\n");
								else
                	fprintf(outputFile,"\t.DATA?\n");
                curseg = bssxseg;
                }
}
/*
 * Switch to startupseg
 */
void startupseg(void)
{     if (prm_asmfile)  
				if( curseg != startupxseg) {
                nl();
								exitseg();	
								if (prm_nasm)
                	fprintf(outputFile,"[SECTION cstartup]\n");
								else
                	fprintf(outputFile,"cstartup\tSEGMENT USE32 PUBLIC DWORD \042INITDATA\042\n");
                curseg = startupxseg;
                }
}
/*
 * Switch to rundownseg
 */
void rundownseg(void)
{     if (prm_asmfile)  
				if( curseg != rundownxseg) {
                nl();
								exitseg();
								if (prm_nasm)
	                fprintf(outputFile,"[SECTION crundown]\n");
								else
  	              fprintf(outputFile,"crundown\tSEGMENT USE32 PUBLIC DWORD \042EXITDATA\042\n");
                curseg = rundownxseg;
                }
}
void cppseg(void)
{     if (prm_asmfile)  
				if( curseg != cppxseg) {
                nl();
								exitseg();
								if (prm_nasm)
                	fprintf(outputFile,"[SECTION cppinit]\n");
								else
                	fprintf(outputFile,"cppinit\tSEGMENT USE32 PUBLIC DWORD \042CPPDATA\042\n");
                curseg = cppxseg;
                }
}
void gen_virtual(char *name)
{
	if (prm_asmfile) {
		nl();
		fprintf(outputFile,"@%s\tSEGMENT VIRTUAL",name);
	}
}
void gen_endvirtual(char *name)
{
	if (prm_asmfile) {
		nl();
		fprintf(outputFile,"@%s\tENDS",name);
	}
}
/*
 * Align
 */
void align(int size)
{
			if (prm_asmfile) {
				nl();
				if (prm_nasm)
/* NASM 0.91 wouldn't let me use parenthesis but this should work
 * according to the documented precedence levels
 */
					fprintf(outputFile,"\tTIMES $$-$ & %d NOP\n",3);
				else
					fprintf(outputFile,"\tALIGN\t%d\n",4);
			}
}
/* muldiv val init
 */
void init_muldivval(void)
{
	muldivlink = 0;
}
/*
 * queue muldiv val
 */
void queue_muldivval(int label, long number)
{
	MULDIV *p = xalloc(sizeof(MULDIV));
	p->link = muldivlink;
	p->value = number;
	p->label = label;
	p->size = 0;
	muldivlink = p;
}
void queue_floatval(int label, double number, int size)
{
	MULDIV *p = xalloc(sizeof(MULDIV));
	p->link = muldivlink;
	p->floatvalue = number;
	p->label = label;
	p->size = size;
	muldivlink = p;
}
void dump_muldivval(void)
{
	int tag = FALSE;
	if (prm_asmfile) {
		fprintf(outputFile,"\n");
		if (muldivlink) {
			tag = TRUE;
			align(4);
		}
		while (muldivlink) {
			put_label(muldivlink->label);
			if (muldivlink->size == 0)
				fprintf(outputFile,"\tDD\t0%xH\n",muldivlink->value);
			else if (muldivlink->size == 6)
				fprintf(outputFile,"\tDD\t%f\n",muldivlink->floatvalue);
			else if (muldivlink->size == 8)
				fprintf(outputFile,"\tDQ\t%f\n",muldivlink->floatvalue);
			else
				fprintf(outputFile,"\tDT\t%f\n",muldivlink->floatvalue);
			muldivlink = muldivlink->link;
		}
		if (tag)
			fprintf(outputFile,"\n");
	}
}
void asm_header(void)
{
	nl();
	if (prm_nasm)
				fprintf(outputFile,"[BITS 32]\n\n");
	else {
		fprintf(outputFile,"\tTITLE\t'%s'\n",outfile);
		if (prm_flat)
				fprintf(outputFile,"\t.486p\n\t.MODEL FLAT\n\n");
		else
				fprintf(outputFile,"\t.486p\n\t.MODEL SMALL\n\n");
	}
}
void globaldef(SYM *sp)
{
	char buf[100],*q=buf,*p=sp->name;
	if (curseg == codeseg && currentfunc->pascaldefn) {
		if (prm_cmangle)
			p++;
		while(*p)
			*q++=toupper(*p++);
		*q++ = 0;
	}
	else
		strcpy(buf,p);
	if (prm_nasm)
      fprintf(outputFile,"[GLOBAL\t%s]\n",buf);
	else
      fprintf(outputFile,"\tPUBLIC\t%s\n",buf);
}			
void putexterns(void)
/*
 * Output the fixup tables and the global/external list
 */
{       SYM     *sp;
			int i;
			if (prm_asmfile){
						int notyet = TRUE;
				nl();
				exitseg();
				for (i=0; i < HASHTABLESIZE; i++) {
					if ((sp=(SYM *) globalhash[i]) != 0) {
						while (sp) {
    	    		if( sp->storage_class == sc_externalfunc && sp->extflag) {
								char buf[100],*q=buf,*p=sp->name;
								if (curseg == codeseg && sp->pascaldefn) {
									if (prm_cmangle)
										p++;
									while(*p)
										*q++=toupper(*p++);
									*q++ = 0;
								}
								else
									strcpy(buf,p);
								if (prm_nasm) {
							 		if (notyet) {
										fprintf(outputFile,"\n[SECTION .text]\n");
										notyet = FALSE;
									}
      	          fprintf(outputFile,"[EXTERN\t%s]\n",buf);
								}
								else {
							 		if (notyet) {
										fprintf(outputFile,"\n\t.CODE\n");
										notyet = FALSE;
									}
      	          fprintf(outputFile,"\tEXTRN\t%s:PROC\n",buf);
								}
							}
         			sp = sp->next;
						}
					}
				}
				notyet = TRUE;
				for (i=0; i < HASHTABLESIZE; i++) {
					if ((sp=(SYM *) globalhash[i]) != 0) {
						while (sp) {
	        		if( sp->storage_class == sc_external && sp->extflag) {
								char buf[100],*q=buf,*p=sp->name;
								if (curseg == codeseg && sp->pascaldefn) {
									if (prm_cmangle)
										p++;
									while(*p)
										*q++=toupper(*p++);
									*q++ = 0;
								}
								else
									strcpy(buf,p);
							  if (prm_nasm) {
							 		if (notyet) {
										fprintf(outputFile,"\n[SECTION .data]\n");
										notyet = FALSE;
									}
  	              fprintf(outputFile,"[EXTERN\t%s]\n",buf);
							  }
							  else {
									if (notyet) {
										fprintf(outputFile,"\n\t.DATA\n");
										notyet = FALSE;
									}
  	              fprintf(outputFile,"\tEXTRN\t%s\n",buf);
							  }
							}
         			sp = sp->next;
						}
					}
				}
				if (!prm_nasm)
					fprintf(outputFile,"\tEND\n");
			}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品911| 欧美日韩一区在线观看| 久久国产成人午夜av影院| 日韩欧美国产三级电影视频| 欧美亚洲图片小说| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 欧美日本国产视频| 欧美午夜一区二区三区 | 国产欧美一区二区精品性色超碰| 日韩午夜激情av| 精品少妇一区二区三区免费观看| 日韩免费看的电影| 久久一二三国产| 国产亚洲精品资源在线26u| 国产欧美在线观看一区| 欧美激情一区二区| 亚洲品质自拍视频网站| 亚洲国产精品麻豆| 日韩电影在线观看网站| 老汉av免费一区二区三区| 国产伦理精品不卡| 成人av网站在线观看免费| 色综合久久综合网97色综合| 99在线热播精品免费| 欧美高清精品3d| 94-欧美-setu| 91蝌蚪porny| 欧美日韩综合一区| 日韩午夜中文字幕| 国产日产欧美精品一区二区三区| 亚洲欧洲国产日本综合| 夜夜操天天操亚洲| 狂野欧美性猛交blacked| 国产精品1024| 欧美自拍偷拍一区| 欧美一区二区视频免费观看| 国产日韩欧美一区二区三区综合| 中文字幕综合网| 三级一区在线视频先锋| 国产精品18久久久久久久网站| 色综合天天综合色综合av| 欧美日本在线一区| 国产免费成人在线视频| 亚洲一级二级在线| 国内成人自拍视频| 色综合欧美在线| 精品少妇一区二区| 亚洲日穴在线视频| 理论电影国产精品| 一本久久精品一区二区| 日韩美一区二区三区| 1区2区3区精品视频| 天天亚洲美女在线视频| 国产999精品久久久久久绿帽| 欧美色男人天堂| 日本一区二区三区免费乱视频| 亚洲成人av电影在线| 国产精品99精品久久免费| 欧美高清激情brazzers| 国产精品成人网| 久88久久88久久久| 欧美一a一片一级一片| 欧美国产禁国产网站cc| 精品在线一区二区三区| 欧美性一二三区| 中文字幕精品一区二区三区精品| 日本美女视频一区二区| 91免费观看视频| 久久精品在线观看| 久久国产精品99精品国产| 欧美吻胸吃奶大尺度电影 | 亚洲国产一区视频| 岛国精品在线播放| 日韩欧美二区三区| 亚洲成人av在线电影| 日韩理论片在线| 欧美精品第一页| 日本中文字幕一区| 日韩欧美亚洲一区二区| 天天综合网天天综合色| 日韩一区二区免费电影| 极品少妇一区二区| 国产日韩欧美一区二区三区乱码| www.亚洲免费av| 久久久久高清精品| 欧美一三区三区四区免费在线看 | 国产成a人无v码亚洲福利| 日韩午夜电影av| 天天操天天色综合| 91成人在线观看喷潮| 亚洲女爱视频在线| 99久久99久久综合| 欧美国产日韩一二三区| 激情小说亚洲一区| 91精品视频网| 日韩激情一区二区| 欧美精品乱码久久久久久| 国产日产欧美一区二区视频| 欧美高清在线一区二区| 黑人精品欧美一区二区蜜桃| 日韩精品在线一区二区| 久草精品在线观看| 日韩欧美一区二区在线视频| 秋霞午夜av一区二区三区| 欧美一区二区网站| 日韩av在线播放中文字幕| 精品91自产拍在线观看一区| 日韩高清在线电影| 日韩欧美亚洲一区二区| 精品一区二区三区久久久| 久久色.com| 国产成人免费在线视频| 中文字幕+乱码+中文字幕一区| 国产99久久久国产精品潘金网站| 欧美国产精品中文字幕| 99久久婷婷国产综合精品电影| 自拍偷在线精品自拍偷无码专区| 91老师片黄在线观看| 亚洲一级二级在线| 日韩欧美一级特黄在线播放| 国产一区二区按摩在线观看| 中文字幕欧美国产| 在线欧美日韩国产| 同产精品九九九| 精品国产一区二区三区久久影院| 国产毛片精品国产一区二区三区| 欧美国产精品一区| 日本乱人伦一区| 婷婷国产v国产偷v亚洲高清| 日韩欧美一区在线| 国产99一区视频免费| 亚洲精品视频在线观看免费| 欧美日韩美女一区二区| 久久99精品久久久久久动态图 | 欧美激情在线一区二区三区| 91视频你懂的| 日韩有码一区二区三区| 久久伊人中文字幕| 91影视在线播放| 日日嗨av一区二区三区四区| 久久久久久久久久久久久夜| 91视频你懂的| 蜜桃久久久久久| 综合久久一区二区三区| 777色狠狠一区二区三区| 精品一区在线看| 一区二区三区**美女毛片| 日韩欧美另类在线| 99视频有精品| 五月婷婷欧美视频| 久久精品视频免费| 在线亚洲欧美专区二区| 免费黄网站欧美| 亚洲欧美激情一区二区| 日韩三区在线观看| 97国产一区二区| 另类综合日韩欧美亚洲| 亚洲视频一区在线| 日韩精品一区二区三区中文不卡| 99视频在线观看一区三区| 久久精品国产精品青草| 亚洲日本va在线观看| 日韩亚洲欧美综合| 日本韩国一区二区三区| 国产高清精品久久久久| 香蕉影视欧美成人| 亚洲色欲色欲www在线观看| 精品国产青草久久久久福利| 欧美中文字幕久久| 国产 欧美在线| 激情综合亚洲精品| 亚洲影院免费观看| 中文字幕av一区二区三区高| 日韩精品一区二区三区蜜臀| 日本电影欧美片| 成年人午夜久久久| 国产精品中文字幕欧美| 美女国产一区二区三区| 亚洲成人精品一区二区| 中文字幕一区av| 亚洲国产精品成人综合色在线婷婷 | 亚洲日本一区二区三区| 久久综合99re88久久爱| 这里只有精品视频在线观看| 色播五月激情综合网| 99精品视频在线观看免费| 国产精品一区二区三区乱码| 日韩在线一区二区三区| 亚州成人在线电影| 亚洲在线视频网站| 日韩理论片中文av| 国产精品视频观看| 欧美激情一区二区三区蜜桃视频| 精品久久久久久无| 精品国产麻豆免费人成网站| 7777精品伊人久久久大香线蕉的| 日本电影欧美片| 日本久久一区二区| 欧洲日韩一区二区三区| 欧美综合天天夜夜久久|