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

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

?? dag.c

?? 基于4個mips核的noc設計
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "c.h"static char rcsid[] = "$Id: dag.nw,v 2.30 1998/09/21 21:24:47 drh Exp $";#define iscall(op) (generic(op) == CALL || IR->mulops_calls && IR->mulops_calls(op))static Node forest;static struct dag {	struct node node;	struct dag *hlink;} *buckets[16];int nodecount;static Tree firstarg;int assignargs = 1;int prunetemps = -1;static Node *tail;#ifdef __hpux#define	kill(s)		 _kill(s)#endifstatic int depth = 0;static Node replace(Node);static Node prune(Node);static Node asgnnode(Symbol, Node);static struct dag *dagnode(int, Node, Node, Symbol);static Symbol equated(Symbol);static void fixup(Node);static void labelnode(int);static void list(Node);static void kill(Symbol);static Node node(int, Node, Node, Symbol);static void printdag1(Node, int, int);static void printnode(Node, int, int);static void reset(void);static Node tmpnode(Node);static void typestab(Symbol, void *);static Node undag(Node);static Node visit(Node, int);static void unlist(void);void walk(Tree tp, int tlab, int flab) {	listnodes(tp, tlab, flab);	if (forest) {		Node list = forest->link;		forest->link = NULL;		if (!IR->wants_dag)			list = undag(list);		code(Gen)->u.forest = list;		forest = NULL;	}	reset();	deallocate(STMT);}static Node node(int op, Node l, Node r, Symbol sym) {	int i;	struct dag *p;	i = (opindex(op)^((unsigned long)sym>>2))&(NELEMS(buckets)-1);	for (p = buckets[i]; p; p = p->hlink)		if (p->node.op      == op && p->node.syms[0] == sym		&&  p->node.kids[0] == l  && p->node.kids[1] == r)			return &p->node;	p = dagnode(op, l, r, sym);	p->hlink = buckets[i];	buckets[i] = p;	++nodecount;	return &p->node;}static struct dag *dagnode(int op, Node l, Node r, Symbol sym) {	struct dag *p;	NEW0(p, FUNC);	p->node.op = op;	if ((p->node.kids[0] = l) != NULL)		++l->count;	if ((p->node.kids[1] = r) != NULL)		++r->count;	p->node.syms[0] = sym;	return p;}Node newnode(int op, Node l, Node r, Symbol sym) {	return &dagnode(op, l, r, sym)->node;}static void kill(Symbol p) {	int i;	struct dag **q;	for (i = 0; i < NELEMS(buckets); i++)		for (q = &buckets[i]; *q; )			if (generic((*q)->node.op) == INDIR &&			    (!isaddrop((*q)->node.kids[0]->op)			     || (*q)->node.kids[0]->syms[0] == p)) {				*q = (*q)->hlink;				--nodecount;			} else				q = &(*q)->hlink;}static void reset(void) {	if (nodecount > 0)		memset(buckets, 0, sizeof buckets);	nodecount = 0;}Node listnodes(Tree tp, int tlab, int flab) {	Node p = NULL, l, r;	int op;	assert(tlab || flab || tlab == 0 && flab == 0);	if (tp == NULL)		return NULL;	if (tp->node)		return tp->node;	op = tp->op + sizeop(tp->type->size);#define	XXX 	if (IR->mulops_calls && IR->mulops_calls(p->op)) { \                        list(p); \                        cfunc->u.f.ncalls++; \                }	switch (generic(tp->op)) {	case AND:   { if (depth++ == 0) reset();		      if (flab) {		      	listnodes(tp->kids[0], 0, flab);		      	listnodes(tp->kids[1], 0, flab);		      } else {		      	listnodes(tp->kids[0], 0, flab = genlabel(1));		      	listnodes(tp->kids[1], tlab, 0);		      	labelnode(flab);		      }		      depth--; } break;	case OR:    { if (depth++ == 0)		      	reset();		      if (tlab) {		      	listnodes(tp->kids[0], tlab, 0);		      	listnodes(tp->kids[1], tlab, 0);		      } else {		      	tlab = genlabel(1);		      	listnodes(tp->kids[0], tlab, 0);		      	listnodes(tp->kids[1], 0, flab);		      	labelnode(tlab);		      }		      depth--; } break;	case NOT:   { return listnodes(tp->kids[0], flab, tlab); }	case COND:  { Tree q = tp->kids[1];		      assert(tlab == 0 && flab == 0);		      if (tp->u.sym)		      	addlocal(tp->u.sym);		      flab = genlabel(2);		      listnodes(tp->kids[0], 0, flab);		      assert(q && q->op == RIGHT);		      reset();		      listnodes(q->kids[0], 0, 0);		      if (forest->op == LABEL+V) {		      	equatelab(forest->syms[0], findlabel(flab + 1));		      	unlist();		      }		      list(jump(flab + 1));		      labelnode(flab);		      listnodes(q->kids[1], 0, 0);		      if (forest->op == LABEL+V) {		      	equatelab(forest->syms[0], findlabel(flab + 1));		      	unlist();		      }		      labelnode(flab + 1);		      if (tp->u.sym)		      	p = listnodes(idtree(tp->u.sym), 0, 0); } break;	case CNST:  { Type ty = unqual(tp->type);		      assert(ty->u.sym);		      if (tlab || flab) {		      	assert(ty == inttype);		      	if (tlab && tp->u.v.i != 0)		      		list(jump(tlab));		      	else if (flab && tp->u.v.i == 0)		      		list(jump(flab));		      }		      else if (ty->u.sym->addressed)		      	p = listnodes(cvtconst(tp), 0, 0);		      else		      	p = node(op, NULL, NULL, constant(ty, tp->u.v)); } break;	case RIGHT: { if (   tp->kids[0] && tp->kids[1]			  &&  generic(tp->kids[1]->op) == ASGN			  && (generic(tp->kids[0]->op) == INDIR			  && tp->kids[0]->kids[0] == tp->kids[1]->kids[0]			  || (tp->kids[0]->op == FIELD			  &&  tp->kids[0] == tp->kids[1]->kids[0]))) {		      	assert(tlab == 0 && flab == 0);			if (generic(tp->kids[0]->op) == INDIR) {				p = listnodes(tp->kids[0], 0, 0);				list(p);				listnodes(tp->kids[1], 0, 0);			}			else {				assert(generic(tp->kids[0]->kids[0]->op) == INDIR);				list(listnodes(tp->kids[0]->kids[0], 0, 0));				p = listnodes(tp->kids[0], 0, 0);				listnodes(tp->kids[1], 0, 0);			}		      } else if (tp->kids[1]) {		      	listnodes(tp->kids[0], 0, 0);		      	p = listnodes(tp->kids[1], tlab, flab);		      } else		      	p = listnodes(tp->kids[0], tlab, flab); } break;	case JUMP:  { assert(tlab == 0 && flab == 0);		      assert(tp->u.sym == 0);		      assert(tp->kids[0]);		      l = listnodes(tp->kids[0], 0, 0);		      list(newnode(JUMP+V, l, NULL, NULL));		      reset(); } break;	case CALL:  { Tree save = firstarg;		      firstarg = NULL;		      assert(tlab == 0 && flab == 0);		      if (tp->op == CALL+B && !IR->wants_callb) {		      	Tree arg0 = tree(ARG+P, tp->kids[1]->type,				tp->kids[1], NULL);			if (IR->left_to_right)				firstarg = arg0;			l = listnodes(tp->kids[0], 0, 0);			if (!IR->left_to_right || firstarg) {				firstarg = NULL;				listnodes(arg0, 0, 0);			}		      	p = newnode(CALL+V, l, NULL, NULL);		      } else {		      	l = listnodes(tp->kids[0], 0, 0);		      	r = listnodes(tp->kids[1], 0, 0);		      	p = newnode(tp->op == CALL+B ? tp->op : op, l, r, NULL);		      }		      NEW0(p->syms[0], FUNC);		      assert(isptr(tp->kids[0]->type));		      assert(isfunc(tp->kids[0]->type->type));		      p->syms[0]->type = tp->kids[0]->type->type;		      list(p);		      reset();		      cfunc->u.f.ncalls++;		      firstarg = save; } break;	case ARG:   { assert(tlab == 0 && flab == 0);		      if (IR->left_to_right)		      	listnodes(tp->kids[1], 0, 0);		      if (firstarg) {		      	Tree arg = firstarg;		      	firstarg = NULL;		      	listnodes(arg, 0, 0);		      }		      l = listnodes(tp->kids[0], 0, 0);		      list(newnode(tp->op == ARG+B ? tp->op : op, l, NULL, NULL));		      forest->syms[0] = intconst(tp->type->size);		      forest->syms[1] = intconst(tp->type->align);		      if (!IR->left_to_right)		      	listnodes(tp->kids[1], 0, 0); } break;	case EQ:  case NE: case GT: case GE: case LE:	case LT:    { assert(tp->u.sym == 0);		      assert(errcnt || tlab || flab);		      l = listnodes(tp->kids[0], 0, 0);		      r = listnodes(tp->kids[1], 0, 0);		      assert(errcnt || opkind(l->op) == opkind(r->op));		      assert(errcnt || optype(op) == optype(l->op));		      if (tlab)		      	assert(flab == 0),		      	list(newnode(generic(tp->op) + opkind(l->op), l, r, findlabel(tlab)));		      else if (flab) {		      	switch (generic(tp->op)) {		      	case EQ: op = NE; break;		      	case NE: op = EQ; break;		      	case GT: op = LE; break;		      	case LT: op = GE; break;		      	case GE: op = LT; break;		      	case LE: op = GT; break;		      	default: assert(0);		      	}		      	list(newnode(op + opkind(l->op), l, r, findlabel(flab)));		      }		      if (forest && forest->syms[0])		      	forest->syms[0]->ref++; } break;	case ASGN:  { assert(tlab == 0 && flab == 0);		      if (tp->kids[0]->op == FIELD) {		      	Tree  x = tp->kids[0]->kids[0];			Field f = tp->kids[0]->u.field;			assert(generic(x->op) == INDIR);			reset();			l = listnodes(lvalue(x), 0, 0);			if (fieldsize(f) < 8*f->type->size) {				unsigned int fmask = fieldmask(f);				unsigned int  mask = fmask<<fieldright(f);				Tree q = tp->kids[1];				if (q->op == CNST+I && q->u.v.i == 0				||  q->op == CNST+U && q->u.v.u == 0)					q = bittree(BAND, x, cnsttree(unsignedtype, (unsigned long)~mask));				else if (q->op == CNST+I && (q->u.v.i&fmask) == fmask				||       q->op == CNST+U && (q->u.v.u&fmask) == fmask)					q = bittree(BOR, x, cnsttree(unsignedtype, (unsigned long)mask));				else {					listnodes(q, 0, 0);					q = bittree(BOR,						bittree(BAND, rvalue(lvalue(x)),							cnsttree(unsignedtype, (unsigned long)~mask)),						bittree(BAND, shtree(LSH, cast(q, unsignedtype),							cnsttree(unsignedtype, (unsigned long)fieldright(f))),							cnsttree(unsignedtype, (unsigned long)mask)));				}				r = listnodes(q, 0, 0);				op = ASGN + ttob(q->type);			} else {				r = listnodes(tp->kids[1], 0, 0);				op = ASGN + ttob(tp->kids[1]->type);			}		      } else {		      	l = listnodes(tp->kids[0], 0, 0);		      	r = listnodes(tp->kids[1], 0, 0);		      }		      list(newnode(tp->op == ASGN+B ? tp->op : op, l, r, NULL));		      forest->syms[0] = intconst(tp->kids[1]->type->size);		      forest->syms[1] = intconst(tp->kids[1]->type->align);		      if (isaddrop(tp->kids[0]->op)		      && !tp->kids[0]->u.sym->computed)		      	kill(tp->kids[0]->u.sym);		      else		      	reset();		      p = listnodes(tp->kids[1], 0, 0); } break;	case BOR: case BAND: case BXOR:	case ADD: case SUB:  case RSH:	case LSH:   { assert(tlab == 0 && flab == 0);		      l = listnodes(tp->kids[0], 0, 0);		      r = listnodes(tp->kids[1], 0, 0);		      p = node(op, l, r, NULL); XXX } break;	case DIV: case MUL:	case MOD:   { assert(tlab == 0 && flab == 0);		      l = listnodes(tp->kids[0], 0, 0);		      r = listnodes(tp->kids[1], 0, 0);		      p = node(op, l, r, NULL); XXX } break;	case RET:   { assert(tlab == 0 && flab == 0);		      l = listnodes(tp->kids[0], 0, 0);		      list(newnode(op, l, NULL, NULL)); } break;	case CVF: case CVI: case CVP:	case CVU:   { assert(tlab == 0 && flab == 0);		      assert(optype(tp->kids[0]->op) != optype(tp->op) || tp->kids[0]->type->size != tp->type->size);		      l = listnodes(tp->kids[0], 0, 0);		      p = node(op, l, NULL, intconst(tp->kids[0]->type->size)); XXX } break;	case BCOM:	case NEG:   { assert(tlab == 0 && flab == 0);		      l = listnodes(tp->kids[0], 0, 0);		      p = node(op, l, NULL, NULL); XXX } break;	case INDIR: { Type ty = tp->kids[0]->type;		      assert(tlab == 0 && flab == 0);		      l = listnodes(tp->kids[0], 0, 0);		      if (isptr(ty))		      	ty = unqual(ty)->type;		      if (isvolatile(ty)		      || (isstruct(ty) && unqual(ty)->u.sym->u.s.vfields))		      	p = newnode(tp->op == INDIR+B ? tp->op : op, l, NULL, NULL);		      else		      	p = node(tp->op == INDIR+B ? tp->op : op, l, NULL, NULL); } break;	case FIELD: { Tree q = tp->kids[0];		      if (tp->type == inttype) {		      	long n = fieldleft(tp->u.field);		      	q = shtree(RSH,		      		shtree(LSH, q, cnsttree(inttype, n)),		      		cnsttree(inttype, n + fieldright(tp->u.field)));		      } else if (fieldsize(tp->u.field) < 8*tp->u.field->type->size)		      	q = bittree(BAND,		      		shtree(RSH, q, cnsttree(inttype, (long)fieldright(tp->u.field))),		      		cnsttree(unsignedtype, (unsigned long)fieldmask(tp->u.field)));		      assert(tlab == 0 && flab == 0);		      p = listnodes(q, 0, 0); } break;	case ADDRG:	case ADDRF: { assert(tlab == 0 && flab == 0);		      p = node(tp->op + sizeop(voidptype->size), NULL, NULL, tp->u.sym); } break;	case ADDRL: { assert(tlab == 0 && flab == 0);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日高清视频| 亚洲国产精品综合小说图片区| 中文字幕一区二区三区av| 亚洲欧美国产77777| 黄色小说综合网站| 欧美日韩一区高清| 国产精品福利一区二区三区| 美女被吸乳得到大胸91| 色综合网色综合| 26uuu久久天堂性欧美| 天天av天天翘天天综合网色鬼国产 | 亚洲第一二三四区| 成人午夜视频网站| 久久综合av免费| 麻豆国产91在线播放| 欧美色图第一页| 亚洲视频一二区| 成人一区二区三区| 久久女同精品一区二区| 久久爱另类一区二区小说| 欧美高清视频www夜色资源网| 综合av第一页| 成人国产一区二区三区精品| 精品国产免费久久 | 亚洲欧洲国产日本综合| 国产一区二区在线免费观看| 欧美一区日本一区韩国一区| 亚洲gay无套男同| 欧美体内she精高潮| 亚洲综合激情网| 欧美少妇性性性| 五月天中文字幕一区二区| 欧美无砖专区一中文字| 五月婷婷欧美视频| 日韩欧美在线1卡| 久久99在线观看| 国产欧美一区二区精品久导航| 国产成人精品一区二| 久久精品人人做| jvid福利写真一区二区三区| 中文字幕中文字幕在线一区| 99在线精品观看| 亚洲最大的成人av| 欧美久久久久久久久久| 婷婷久久综合九色国产成人 | 亚洲电影欧美电影有声小说| 欧美午夜精品电影| 日本成人在线电影网| 日韩精品中文字幕在线不卡尤物| 蜜桃视频第一区免费观看| 久久综合九色综合97_久久久| 国产精品亚洲专一区二区三区| 久久久www成人免费毛片麻豆| 国产成人在线电影| 一区二区三区高清| 91精品国产综合久久精品app| 激情久久五月天| 中文字幕在线一区二区三区| 91久久一区二区| 青青草国产精品97视觉盛宴 | 亚洲青青青在线视频| 欧美日韩欧美一区二区| 久久99精品久久久久久久久久久久 | 国产黄色成人av| 一区二区三区日韩精品视频| 欧美午夜精品一区| 国产揄拍国内精品对白| 亚洲色图第一区| 91精品国产综合久久精品图片| 国产91在线观看| 五月激情六月综合| 国产精品久久久久影院色老大| 欧美视频完全免费看| 国产精品18久久久久久久网站| 亚洲精品一卡二卡| 久久蜜桃av一区二区天堂| 在线中文字幕不卡| 国产在线播放一区| 亚洲不卡一区二区三区| 国产亚洲欧美日韩日本| 欧美日韩视频在线一区二区| 国产麻豆一精品一av一免费| 亚洲一卡二卡三卡四卡五卡| 久久久久高清精品| 欧美丰满一区二区免费视频| 成人永久aaa| 蜜桃久久久久久| 亚洲国产欧美在线人成| 日本一区二区三区视频视频| 6080亚洲精品一区二区| 91视频你懂的| 国产一区二区导航在线播放| 日韩成人免费电影| 亚洲精品视频在线观看网站| 久久婷婷国产综合国色天香| 在线观看91av| 欧美午夜一区二区三区免费大片| 国产.欧美.日韩| 久久国产人妖系列| 秋霞av亚洲一区二区三| 亚洲地区一二三色| 综合亚洲深深色噜噜狠狠网站| 精品久久国产字幕高潮| 91麻豆精品国产| 精品污污网站免费看| 欧美中文字幕久久| 99re成人在线| 91视频免费看| 色婷婷av久久久久久久| 色欧美乱欧美15图片| 9色porny自拍视频一区二区| 国产·精品毛片| 成人激情综合网站| 成人污视频在线观看| 国产精品亚洲一区二区三区在线 | aaa国产一区| 91亚洲精品久久久蜜桃| 91丨九色丨国产丨porny| 色综合色综合色综合色综合色综合| 成人性视频免费网站| 成人丝袜18视频在线观看| 成人黄色国产精品网站大全在线免费观看 | 99久久综合狠狠综合久久| 成人动漫一区二区三区| 成+人+亚洲+综合天堂| 91免费看片在线观看| 色欧美片视频在线观看在线视频| 欧美专区在线观看一区| 7777精品伊人久久久大香线蕉超级流畅| 欧美三级视频在线观看| 日韩一级欧美一级| 久久亚洲二区三区| 亚洲欧美在线视频观看| 一区二区免费在线播放| 日韩一区精品视频| 国产一区二区导航在线播放| 国产91在线看| 欧美性大战久久久久久久蜜臀| 欧美日韩一区二区三区视频| 日韩欧美电影在线| 欧美国产在线观看| 亚洲精品日产精品乱码不卡| 亚洲一区精品在线| 精品一区二区三区在线视频| 国产99一区视频免费| 色婷婷精品大在线视频| 日韩一级黄色大片| 国产亚洲欧美色| 亚洲国产欧美另类丝袜| 激情伊人五月天久久综合| av在线免费不卡| 欧美一区二区三区日韩视频| 国产亚洲综合在线| 偷拍一区二区三区| 成人美女视频在线观看18| 欧美三级三级三级| 国产婷婷一区二区| 亚洲亚洲人成综合网络| 国产精品一区二区久久精品爱涩| 欧美曰成人黄网| 久久亚洲精品小早川怜子| 亚洲一区二区成人在线观看| 国产乱人伦偷精品视频免下载| 在线视频亚洲一区| 久久久噜噜噜久久中文字幕色伊伊 | 欧美国产日韩在线观看| 亚洲午夜久久久久久久久久久| 国产又黄又大久久| 欧美绝品在线观看成人午夜影视| 国产日韩欧美精品一区| 日韩av中文在线观看| 91免费版在线| 国产日韩欧美在线一区| 无吗不卡中文字幕| 日本伦理一区二区| 国产色综合一区| 乱一区二区av| 欧美日韩精品一区二区| 亚洲图片另类小说| 国产91高潮流白浆在线麻豆| 欧美一二三区在线观看| 亚洲线精品一区二区三区八戒| 豆国产96在线|亚洲| 日韩精品一区二区三区三区免费 | 亚洲欧美日韩国产综合| 国产精品主播直播| 欧美精品一区视频| 久久精品理论片| 91精品国产一区二区三区蜜臀| 伊人夜夜躁av伊人久久| 91在线精品一区二区| 国产欧美日韩卡一| 国产成人综合亚洲网站| 久久亚洲二区三区| 老司机精品视频一区二区三区| 在线播放亚洲一区| 日韩 欧美一区二区三区| 欧美精品亚洲二区| 视频一区免费在线观看| 欧美色成人综合|