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

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

?? reg68.c

?? C語(yǔ)言編譯器的源代碼
?? C
字號(hào):
/*
 * 68K/386 32-bit C compiler.
 *
 * copyright (c) 1997, David Lindauer
 * 
 * This compiler is intended for educational use.  It may not be used
 * for profit without the express written consent of the author.
 *
 * It may be freely redistributed, as long as this notice remains intact
 * and either the original sources or derived sources 
 * are distributed along with any executables derived from the originals.
 *
 * The author is not responsible for any damages that may arise from use
 * of this software, either idirect or consequential.
 *
 * v1.35 March 1997
 * David Lindauer, gclind01@starbase.spd.louisville.edu
 *
 * Credits to Mathew Brandt for original K&R C compiler
 *
 */
#include        <stdio.h>
#include        "expr.h"
#include        "c.h"
#include        "gen68.h"

/*
 *      this module handles the allocation and de-allocation of
 *      temporary registers. when a temporary register is allocated
 *      the stack depth is saved in the field deep of the address
 *      mode structure. when validate is called on an address mode
 *      structure the stack is popped until the register is restored
 *      to it's pre-push value.
 */
extern int cf_freedata,cf_freeaddress,cf_freefloat,maxdata,maxaddress;

AMODE    push[] = { {am_adec,7} },
                pop[] = { {am_ainc,7} };
int             next_data,		/* Next available */
                next_addr;
int             max_data,			/* Max available */
                max_addr;
int							next_float, max_float;
long stackdepth,framedepth;

char regstack[20],rsold[30],rsdepth = 0,rsodepth=0;
char aregs[8],dregs[8],fregs[8];

void regini(void)
{
	int i;
	for (i=0; i < 8; i++) {
		aregs[0] = dregs[0] = fregs[0] = 0;
	}
	rsdepth = rsodepth = 0;
}
void gen_push(int reg, int rmode, int flag)
/*
 *      this routine generates code to push a register onto the stack
 */
{       AMODE    *ap1;
        ap1 = xalloc(sizeof(AMODE));
        ap1->preg = reg;
        ap1->mode = rmode;
				if (rmode == am_freg) {
          gen_code(op_fmove,10,ap1,push);
					stackdepth +=8;
				}
				else {
          gen_code(op_move,4,ap1,push);
					stackdepth +=4;
				}
}

void gen_pop(int reg, int rmode, int flag)
/*
 *      generate code to pop the primary register in ap from the
 *      stack.
 */
{       AMODE    *ap1;
        ap1 = xalloc(sizeof(AMODE));
        ap1->preg = reg;
        ap1->mode = rmode;
				if (rmode == am_freg) {
        	gen_code(op_fmove,10,pop,ap1);
					stackdepth -=8;
				}
				else {
        	gen_code(op_move,4,pop,ap1);
					stackdepth -=4;
				}
}
void initstack(void)
/*
 *      this routine should be called before each expression is
 *      evaluated to make sure the stack is balanced and all of
 *      the registers are marked free.
 */
{
	int i;
	for (i=0; i < 8; i++) 
		aregs[0] = dregs[0] = fregs[0] = 0;
			rsdepth = rsodepth = 0;
       next_data = 0;
        next_addr = 0;
        max_data = cf_freedata-1;
        max_addr = cf_freeaddress-1;
			next_float = 0;
			max_float = cf_freefloat-1;
}

void mark(void)
{
	rsold[rsodepth++] = rsdepth;
}
void release(void)
{
	if (!rsodepth)
		return;
	rsodepth--;
	while (rsdepth > rsold[rsodepth]) {
		int data = regstack[--rsdepth];
		if (data <8) {
			gen_pop(data,am_dreg,0);
			dregs[data] = 1;
		}
		else
			if (data < 16) {
				gen_pop(data & 7,am_areg,0);
				aregs[data-8] = 1;
			}
			else {
				gen_pop(data & 7,am_freg,0);
				fregs[data-16] = 1;
			}
	}
 	max_addr = next_addr < cf_freeaddress ? cf_freeaddress-1 : next_addr-1;
	max_data = next_data < cf_freedata ? cf_freedata-1 : next_data-1;
	max_float = next_float < cf_freefloat ? cf_freefloat-1 : next_float-1;
}
AMODE    *temp_data(void)
/*
 *      allocate a temporary data register and return it's
 *      addressing mode.
 */
{       AMODE    *ap;
        ap = xalloc(sizeof(AMODE));
        ap->mode = am_dreg;
        ap->preg = next_data % cf_freedata;
        if( next_data > max_data )
                {
                gen_push(ap->preg,am_dreg,0);
								dregs[ap->preg] = 1;
								regstack[rsdepth++] = ap->preg;
                max_data = next_data;
                }
        ++next_data;
        return ap;
}

AMODE    *temp_addr(void)
/*
 *      allocate a temporary address register and return it's
 *      addressing mode.
 */
{       AMODE    *ap;
        ap = xalloc(sizeof(AMODE));
        ap->mode = am_areg;
        ap->preg = next_addr % cf_freeaddress;
        if( next_addr > max_addr )
                {
                gen_push(ap->preg,am_areg,0);
								aregs[ap->preg] = 1;
								regstack[rsdepth++] = ap->preg+8;
                max_addr = next_addr;
                }
        ++next_addr;
        return ap;
}
AMODE    *temp_float(void)
/*
 *      allocate a temporary address register and return it's
 *      addressing mode.
 */
{       AMODE    *ap;
        ap = xalloc(sizeof(AMODE));
        ap->mode = am_freg;
        ap->preg = next_float % cf_freefloat;
        if( next_float > max_float )
                {
                gen_push(ap->preg,am_freg,0);
								fregs[ap->preg] = 1;
								regstack[rsdepth++] = ap->preg+16;
                max_addr = next_float;
                }
        ++next_float;
        return ap;
}
void freedata(int dreg)
{
	if (dreg < cf_freedata && next_data > 0) {
		dregs[dreg] = 0;
		--next_data;
	}
}
void freeaddr(int areg)
{
	if (areg < cf_freeaddress && next_addr > 0) {
		aregs[areg] = 0;
		--next_addr;
	}
}
		
void freeop(AMODE *ap)
/*
 *      release any temporary registers used in an addressing mode.
 */
{       if( ap->mode == am_immed || ap->mode == am_direct )
                return;         /* no registers used */
        if( ap->mode == am_dreg)
					freedata(ap->preg);
        else if( ap->mode == am_areg || ap->mode == am_ind || ap->mode == am_indx || ap->mode == am_adec || ap->mode == am_ainc)
					freeaddr(ap->preg);
        else if( ap->mode == am_freg && ap->preg < cf_freefloat && next_float>0) {
									fregs[ap->preg] = 0;
                	--next_float;
				}
				else if (ap->mode == am_baseindxdata) {
					freeaddr(ap->preg);
					freedata(ap->sreg);
				}
				else if (ap->mode == am_baseindxaddr) {
					freeaddr(ap->preg);
					freeaddr(ap->sreg);
				}
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级视频精品观看| 欧美最新大片在线看| 日韩精品一区二区三区swag | 欧美国产日韩在线观看| 国产不卡在线一区| 亚洲天天做日日做天天谢日日欢| 91美女视频网站| 五月激情综合网| 欧美精品一区二区三区久久久| 国产成人av电影在线观看| 国产精品女主播在线观看| 日本韩国一区二区三区视频| 天堂成人免费av电影一区| 精品国产乱码久久久久久蜜臀| 国产高清不卡一区| 亚洲午夜影视影院在线观看| 日韩欧美精品在线视频| 成人午夜看片网址| 亚洲一区二区精品3399| 日韩精品一区二区三区视频 | 国产精品理论在线观看| 欧美亚洲国产一卡| 激情综合亚洲精品| 亚洲免费观看视频| 欧美变态凌虐bdsm| 在线观看中文字幕不卡| 精品系列免费在线观看| 亚洲猫色日本管| 日韩三级.com| 99riav久久精品riav| 久久99精品久久久久婷婷| 中文字幕在线不卡一区二区三区| 91精品啪在线观看国产60岁| 成人福利电影精品一区二区在线观看| 亚洲永久免费av| 国产女人18毛片水真多成人如厕| 欧美午夜精品一区二区蜜桃| 国产suv精品一区二区883| 天堂在线一区二区| 中文字幕视频一区| 久久婷婷国产综合国色天香| 欧美色倩网站大全免费| 国产福利一区二区三区视频 | 久久精品av麻豆的观看方式| 亚洲欧美日韩电影| 久久久久亚洲综合| 日韩精品在线看片z| 欧美午夜电影网| a亚洲天堂av| 日本韩国一区二区三区视频| 日韩一区二区三区电影在线观看| 精品一区二区影视| 亚洲美女在线国产| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩国产首页| 91在线视频网址| 狠狠色综合播放一区二区| 性做久久久久久免费观看| 日韩美女啊v在线免费观看| 久久综合一区二区| 欧美电视剧在线看免费| 欧美日产在线观看| 欧美伊人久久大香线蕉综合69| 欧美日本不卡视频| 色94色欧美sute亚洲线路二| 成人动漫视频在线| 国产精品1区二区.| 国产在线精品免费av| 美女久久久精品| 爽好久久久欧美精品| 视频在线观看国产精品| 亚洲电影你懂得| 亚洲夂夂婷婷色拍ww47 | 欧美高清在线一区| 国产喷白浆一区二区三区| 欧美不卡一区二区| 亚洲国产综合色| 亚洲综合图片区| 亚洲国产乱码最新视频| 亚洲综合色网站| 亚洲国产成人tv| 亚洲大片精品永久免费| 五月激情综合网| 蜜桃久久精品一区二区| 精品制服美女久久| 理论电影国产精品| 韩国欧美一区二区| 国产成人精品一区二区三区四区 | 风间由美性色一区二区三区| 国产91综合一区在线观看| 成人国产精品免费网站| 99re热这里只有精品免费视频| 91麻豆国产自产在线观看| 在线免费一区三区| 6080日韩午夜伦伦午夜伦| 精品久久久久久亚洲综合网| 国产清纯白嫩初高生在线观看91| 国产精品美女久久久久久| 亚洲乱码精品一二三四区日韩在线| 亚洲狼人国产精品| 天堂精品中文字幕在线| 国产精品综合二区| 亚洲精品一区二区三区蜜桃下载 | 91精品久久久久久久91蜜桃| 日韩免费观看2025年上映的电影| 国产亚洲综合av| 夜夜精品视频一区二区| 蜜臂av日日欢夜夜爽一区| 国产酒店精品激情| 91豆麻精品91久久久久久| 91麻豆精品91久久久久久清纯| 亚洲精品一区二区精华| 亚洲人成精品久久久久久| 日欧美一区二区| 国产成人鲁色资源国产91色综| 色综合天天综合网国产成人综合天| 91久久奴性调教| 精品欧美久久久| 亚洲伦在线观看| 精品无码三级在线观看视频 | 欧美色老头old∨ideo| 精品不卡在线视频| 一区二区三区四区av| 精品在线你懂的| 色婷婷精品久久二区二区蜜臂av | 成人自拍视频在线| 欧美电影在线免费观看| 国产精品欧美一区喷水| 男女激情视频一区| 日本久久精品电影| 国产欧美一区二区三区沐欲| 五月天中文字幕一区二区| 高清成人免费视频| 正在播放一区二区| 亚洲欧洲日韩av| 国产一区 二区 三区一级| 欧美制服丝袜第一页| 中文字幕二三区不卡| 裸体一区二区三区| 欧美日韩你懂得| 亚洲美腿欧美偷拍| 成人亚洲精品久久久久软件| 日韩一区二区在线看| 一区二区高清视频在线观看| 国产高清亚洲一区| 亚洲精品一区二区在线观看| 日韩和欧美的一区| 91精品福利在线| 亚洲欧洲99久久| 国产91丝袜在线18| 久久综合九色欧美综合狠狠| 亚洲18影院在线观看| 色一情一伦一子一伦一区| 国产欧美1区2区3区| 国产在线精品视频| 久久一区二区视频| 久久精品72免费观看| 欧美一区二区三区在线观看 | 91在线一区二区| 国产精品三级视频| 国产成人夜色高潮福利影视| 2021中文字幕一区亚洲| 喷水一区二区三区| 3d成人动漫网站| 日韩和欧美一区二区三区| 欧美精品1区2区3区| 亚洲va欧美va天堂v国产综合| 色婷婷久久久亚洲一区二区三区| 中文字幕中文在线不卡住| 成人激情动漫在线观看| 国产精品女同一区二区三区| 国产99久久精品| 国产精品对白交换视频| 99国产麻豆精品| 亚洲综合成人在线视频| 欧美日韩免费高清一区色橹橹| 夜夜亚洲天天久久| 欧美日韩你懂得| 免费不卡在线观看| 久久精品一区二区| 成人妖精视频yjsp地址| 亚洲女与黑人做爰| 欧美日韩一区久久| 毛片不卡一区二区| 久久久综合网站| www.欧美日韩| 亚洲一区在线电影| 91精品国产入口| 国产精品一级二级三级| 中文字幕一区二区三区四区| 91福利在线导航| 免费观看在线综合| 亚洲国产精品高清| 在线视频你懂得一区二区三区| 午夜激情一区二区三区| 精品国产百合女同互慰| 国产·精品毛片| 亚洲综合在线视频| 欧美tickling挠脚心丨vk| yourporn久久国产精品|