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

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

?? analysis.c

?? 非常好的源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
    case GT:
        Printf2("if (",0);
        if (OptimizeFlag && optype(p->op) == I && CheckBooleanAsgn(p)) {
            break;
        }
        FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);
        Printf2("%s ) goto ",opname(p->op));
        hasConditionals = 1;
        if (p->syms[0]) {
            n = equated(p->syms[0]);
            Printf2("_$%d ",n->u.l.label);
            if (succIdx >= MAXSUCCESORS) {
                printf(StrTab[407]);// <Overflow in number of successors\n>
            }
            else {
                successorsTable[succIdx] = n->u.l.label;
                succIdx++;
            }
        }
        AddJumpNode(p);
        p->x.unsafe = unsafe;
        return result;
    case ASGN:
        if (p->op == ASGNB) {
            unsafe = 1;
            hasDangerousOp = 1;
            p->x.unsafe = 1;
        }
		FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);
        break;
    case AND:
        return 0;
    case CALL:
        if (p->x.intrinsic == 0) {
            hasCalls = 1;
            unsafe = 1;
            p->x.unsafe = 1;
        }
        if (p->kids[0]->syms[0]) {
            Printf2("%s() ",p->kids[0]->syms[0]->name);
            FindSymbols(p->kids[0],level+1);
            FindSymbols(p->kids[1],level+1);
            return 0;
        }
        else {
            FindSymbols(p->kids[0],level+1);
            FindSymbols(p->kids[1],level+1);
        }
        break;
    case ARG:
//        if (p->x.intrinsicArg == 0) {
//            unsafe = 1;
//            p->x.unsafe = 1;
//        }
        FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);
        if (p->op == ARGB) {
            hasDangerousOp = 1;
            unsafe = 1;
            p->x.unsafe = 1;
        }
        return 0;
    case LOAD:
    case INDIR:
        FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);
        p->x.unsafe = unsafe;
        return 0;
    case ADDRG:
    case ADDRF:
    case ADDRL:
        p->x.unsafe = unsafe;
        FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);
        return 0;
    default:
        if (op == DIV ||  op == RSH || op == LSH || op == MOD || p->op == CVDI) {
            if (p->op != DIVD) {
                unsafe = 1;
                if (p->op == DIVI || p->op == MODI)
                    hasDangerousOp = 1;
                p->x.unsafe = 1;
                p->kids[0]->x.unsafe = 1;
                if (p->kids[1])
                    p->kids[1]->x.unsafe = 1;
            }
        }
        FindSymbols(p->kids[0],level+1);
        FindSymbols(p->kids[1],level+1);

    }
    p->x.unsafe = unsafe;
    return result;
}
static int SymbolSortFn(const void *f1, const void *f2)
{
    Symbol s1, s2;
    s1 = *(Symbol *) f1;
    s2 = *(Symbol *) f2;
    if (s1->ref > s2->ref)
        return (-1);
    else if (s1->ref < s2->ref)
        return (1);
    else
        return (0);
}

static Symbol RegisterVars[5];
static int maxRegisterVars;
void SetupRegisterVariables(void)
{
    int nrOfSym,i,k,l,RegistersAllocated;
    Symbol *FunctionLocals,n;

    SetRegistersMasks();
    RegisterVariablesMask = maxRegisterVars = 0;
    if (vmask[0] == 0)
        return;
    nrOfSym = 0;
    if (cfunc->u.f.callee) {
        Printf2(StrTab[415],0);// <Function arguments:\n>
        i = 0;
        while (cfunc->u.f.callee[i]) {
            n = cfunc->u.f.callee[i];
            Printf3("[%2d] %s ",i,n->name);
            if (n->addressed) Printf2(StrTab[416],0);// <addressed >
//			printf("%s Usage %f\n",n->name,n->ref);
            i++;
            nrOfSym++;
        }
    }
    FunctionLocals = FunctionInfo.cp->u.block.locals;
    if (OptimizeFlag == 0 && FunctionLocals) {
        i = 0;
        while (FunctionLocals[i]) {
            n = FunctionLocals[i];
            if (n->sclass == REGISTER)
                n->sclass = AUTO;
            i++;
        }
        return;
    }
    if (FunctionLocals) {
        Printf2(StrTab[417],0);// <Local variables:\n>
        i = 0;
        while (FunctionLocals[i]) {
            n = FunctionLocals[i];
            Printf3("[%2d] %s ",i,n->name);
            if (n->addressed) Printf2(StrTab[418],0);// <addressed >
//			printf("%s Usage %f\n",n->name,n->ref);
            i++;
            nrOfSym++;
        }

    }
    if (nrOfSym) {
//		printf("Function %s:\n",cfunc->name);
        FunctionLocals = (Symbol *)allocate((1+nrOfSym)*sizeof(Symbol),FUNC);
        memset(FunctionLocals,0,(1+nrOfSym)*sizeof(Symbol));
        k = 0;
        if (cfunc->u.f.callee) {
            i = 0;
            while (cfunc->u.f.callee[i]) {
                n = cfunc->u.f.callee[i];
                if (n->addressed == 0 &&
                    n->type->size == 4 &&
                    isscalar(n->type) &&
                    unqual(n->type)->op > DOUBLE) {
                    FunctionLocals[k++] = n;
                }
                i++;
            }
        }
        if (FunctionInfo.cp->u.block.locals) {
            i = 0;
            while (FunctionInfo.cp->u.block.locals[i]) {
                n = FunctionInfo.cp->u.block.locals[i];
                if (n->addressed == 0 &&
                    isscalar(n->type) &&
                    n->type->size == 4 &&
                    unqual(n->type)->op > DOUBLE) {
                    FunctionLocals[k++] = n;
                }
                i++;
            }
        }
        if (k) {
            if (k > 1)
                qsort(FunctionLocals,k,sizeof(Symbol),SymbolSortFn);
            Printf2(StrTab[419],0);// <Best three symbols to register: >
#if 0
            for (i=0; i<k;i++) {
                int j,last,first;

                last = FunctionLocals[i]->lastuse;
                first = FunctionLocals[i]->firstuse;
                for (j=i; j<k; j++) {
                    if (FunctionLocals[j]->firstuse > last ||
                        FunctionLocals[j]->lastuse < first) {
                        printf(StrTab[420],// <Disjoint variables %s [%4d] (%d %d) %s [%4d] (%d %d)\n>

                            FunctionLocals[j]->name,
                            FunctionLocals[j]->src.y,
                            FunctionLocals[j]->firstuse,
                            FunctionLocals[j]->lastuse,
                            FunctionLocals[i]->name,
                            FunctionLocals[i]->src.y,
                            FunctionLocals[i]->firstuse,
                            FunctionLocals[i]->lastuse);
                    }
                }
            }
#endif
            RegistersAllocated = 0;
            for (i=0; RegistersAllocated<3 && i < k; i++) {
                n = FunctionLocals[i];
                if (n->x.aliased)
                    continue;
                if (n->ref < 2.0) break;
				else if (n->ref < 3.0 && i > 0 &&
					(FunctionInfo.NestedCalls || FunctionInfo.hasDiv ||FunctionInfo.hasBlockMove))
					break;
                l = n->sclass;
                n->sclass = REGISTER;
                Printf2("%s ",FunctionLocals[i]->name);
                if (!askregvar(n,rmap[ttob(n->type)])) {
                    n->sclass = l;
                    break;
                }
                else {
                    int z,last,first;
                    FunctionInfo.hasRegisterVars = 1;
                    RegisterVars[maxRegisterVars++] = n;
                    RegistersAllocated++;
                    if (IntermediateLanguageFile) {
                        fprintf(ilFile,"; %s --> %s\n",n->name,n->x.name);
                    }
                    last = n->lastuse;
                    first = n->firstuse;
                    if (last && first
                        && first != last
                        && !FunctionInfo.hasgotos)
                    for (z=i+1; z<k;z++) {
                        Symbol s = FunctionLocals[z];
                        if (s->firstuse > last ||
                            s->lastuse < first) {
                            if (s->firstuse != s->lastuse &&
                                s->x.isArgument == 0  &&
                                n->x.isArgument == 0  &&
                                s->sclass != REGISTER) {
#if 0
                                printf("[%4d] aliasing %s to %s [%d]",
                                    s->src.y,
                                    s->name,n->name,z);
                                printf(" reg %s\n",n->x.name);
#endif
                                s->x.regnode = n->x.regnode;
                                s->x.regnode->vbl = s;
                                s->x.name = n->x.name;
                                s->x.aliased = 1;
                                s->sclass = REGISTER;
                                RegisterVars[maxRegisterVars++] = s;
                                if (IntermediateLanguageFile) {
                                    fprintf(ilFile,"; %s aliased to %s --> %s\n",s->name,n->name,n->x.name);
                                }
                                break;
                            }
                        }
                    }
                }
            }
        }
        Printf2("\n",0);
    }
	RegisterVariablesMask = usedmask[0];
}

void SaturateUnsafe(Node p)
{
    if (p == NULL) return;
    p->x.unsafe = 1;
    p->x.dangerousChildren = 1;
    SaturateUnsafe(p->kids[0]);
    SaturateUnsafe(p->kids[1]);
}

void ReplaceReg(Node p,Symbol oldreg,Symbol newreg)
{
    Symbol s;
    int opt;
    if (p == NULL) return;
    s = p->syms[RX];
    if (s) {
        if (s->x.name == oldreg->x.name)
            p->syms[RX] = newreg;
        else if (s->x.regnode) {
            int oldnum = oldreg->x.regnode->number;
            int nodenum = s->x.regnode->number;

            if (oldnum == nodenum) {
                if (s->x.name[2] == 'i' || s->x.name[2] == 'x')
                    p->syms[RX] = shortreg[newreg->x.regnode->number];
                else if (s->x.name[2] == 'l')
                    p->syms[RX] = charreg[newreg->x.regnode->number];
                else {
                    opt = optype(p->op);
                    if (opt != F && opt != D && opt != L)
                        fatal("ReplaceReg",StrTab[421],0);// <Invalid register number>
                }
            }
        }
    }
    ReplaceReg(p->kids[0],oldreg,newreg);
    ReplaceReg(p->kids[1],oldreg,newreg);
}

typedef struct {
    Node conditional;
    Node Jump;
    Code cpJump;
}jmpInfo;

#define relink(a, b) ((b)->x.prev = (a), (a)->x.next = (b))

int BuildBasicBlocks(void)
{
    int i,l,showline;
    Code cp,previous;
    Node p,last,watchout,forest,root;
    Symbol n;
    jmpInfo jInfo;
    struct node sentinel;
    int result = 1;

    endswithjump = hasCalls = currentLabel = succIdx = 0;
    i = 1;
    showline = 0;
    memset(&StartBlock,0,sizeof(basicCodeBlock));
    memset(&jInfo,0,sizeof(jmpInfo));
    ClearAliasTable();
    BlockNodes = NULL;
    aliasIndex = 0;
    JumpNodeIndex = 0;
    memset(JumpNodeTable,0,sizeof(JumpNodeTable));
    previous = NULL;
    watchout = last = NULL;
    AssignmentsList = NULL;
    SymbolsHead = NULL;
    unsafe = 0;
    for (cp = codehead.next; cp; cp = cp->next) {
        switch (cp->kind) {
        case Defpoint:
            src = cp->u.point.src;
            showline = 1;
            break;
        case Gen:
        case Jump:
            watchout = NULL;
        case Label:
            if (cp->kind == Label)
                unsafe = 0;
            if (showline) {
                Printf2("\nLine %d\n",src.y);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
97se亚洲国产综合自在线| 色av成人天堂桃色av| 精品国产麻豆免费人成网站| 首页亚洲欧美制服丝腿| 欧洲一区二区三区免费视频| 亚洲欧美一区二区三区极速播放| 国产成人精品aa毛片| 精品久久人人做人人爱| 久久99久久久欧美国产| 欧美不卡123| 丝袜亚洲另类欧美综合| 4hu四虎永久在线影院成人| 日韩精品一二三区| 这里只有精品免费| 麻豆成人综合网| 欧美精品一区二区三区蜜桃 | 久久精品亚洲精品国产欧美| 精品一区二区国语对白| 精品免费国产二区三区| 国产在线精品免费| 久久久国产一区二区三区四区小说 | 欧日韩精品视频| 亚洲成av人综合在线观看| 在线观看精品一区| 午夜精品爽啪视频| 日韩一本二本av| 国产永久精品大片wwwapp| 久久蜜桃一区二区| 成人午夜视频在线| 国产精品国产馆在线真实露脸| 97se亚洲国产综合在线| 亚洲成a人v欧美综合天堂下载| 91精品国产全国免费观看| 国内精品免费**视频| 中文字幕av一区二区三区| 色狠狠色狠狠综合| 日韩成人av影视| 欧美精品一区男女天堂| 成人sese在线| 亚洲国产精品天堂| 日韩精品在线一区| 成人永久免费视频| 亚洲午夜久久久久久久久久久| 7777精品伊人久久久大香线蕉完整版| 蜜臀a∨国产成人精品| 久久久久久亚洲综合| 99re成人在线| 性做久久久久久久免费看| 制服丝袜一区二区三区| 麻豆精品一区二区综合av| 国产精品视频yy9299一区| www.激情成人| 亚洲最新视频在线观看| 3d动漫精品啪啪一区二区竹菊 | 欧美岛国在线观看| 国产成人精品亚洲午夜麻豆| 亚洲欧洲一区二区三区| 欧美撒尿777hd撒尿| 美腿丝袜亚洲综合| 国产亚洲一区二区三区| 精久久久久久久久久久| 亚洲欧洲日本在线| 欧美日韩成人在线| 国产最新精品免费| 亚洲美女视频一区| 欧美一区二区三区小说| 丁香激情综合国产| 亚洲一区二区黄色| 欧美一区二区三区白人| 成人一区二区三区中文字幕| 亚洲综合久久av| 日韩亚洲欧美高清| 成人av网址在线| 午夜影院在线观看欧美| 久久久久国产精品麻豆ai换脸| 日本福利一区二区| 毛片不卡一区二区| 亚洲婷婷在线视频| 日韩欧美国产系列| av在线免费不卡| 久久电影国产免费久久电影| 国产精品久久久久久久久晋中| 欧美亚洲一区二区在线观看| 国内欧美视频一区二区| 亚洲影院久久精品| 久久久久久久久久久久久久久99| 在线观看日韩毛片| 国产大片一区二区| 日韩和欧美一区二区三区| 国产精品九色蝌蚪自拍| 91精品福利在线一区二区三区| 国产成人av一区二区三区在线| 亚洲成人精品一区二区| 国产精品女主播av| 日韩欧美中文字幕精品| 91美女在线看| 国产一区日韩二区欧美三区| 亚洲成人tv网| 亚洲色大成网站www久久九九| 日韩亚洲电影在线| 91在线高清观看| 国内精品伊人久久久久av影院| 一区二区三区 在线观看视频| 精品国产乱码久久久久久牛牛| 8v天堂国产在线一区二区| 99国产精品久久久久久久久久 | 亚洲综合免费观看高清完整版在线| 精品国产乱子伦一区| 色狠狠综合天天综合综合| 成人av片在线观看| 久久99国产精品久久99 | 玉米视频成人免费看| 国产欧美精品一区| 精品剧情v国产在线观看在线| 欧美二区在线观看| 欧洲精品中文字幕| 一本久久a久久免费精品不卡| 久久久久久久久岛国免费| 免费人成精品欧美精品| 国产黄人亚洲片| 免费成人av在线| 亚洲sss视频在线视频| 国产精品欧美综合在线| 日韩久久精品一区| 9191成人精品久久| 欧美在线一区二区三区| 北条麻妃国产九九精品视频| 国产在线一区二区| 久久精品免费看| 奇米一区二区三区av| 午夜视频一区二区三区| 久久精品72免费观看| 亚洲成av人片| 亚洲成a人v欧美综合天堂| 伊人开心综合网| 亚洲色图欧美在线| 国产精品国产三级国产专播品爱网| 精品国免费一区二区三区| 欧美一级理论性理论a| 欧美二区三区的天堂| 欧美一区二区女人| 91精品国产色综合久久ai换脸| 欧美日韩国产欧美日美国产精品| 在线观看亚洲a| 欧美日韩一区二区不卡| 在线欧美小视频| 欧洲精品中文字幕| 欧美日韩一区在线观看| 欧美视频在线观看一区二区| 成人国产电影网| 91影院在线免费观看| 99久久精品国产毛片| 91激情五月电影| 欧美综合一区二区| 欧美日韩国产免费| 337p亚洲精品色噜噜狠狠| 91精品国产入口| 日韩欧美一区二区免费| 精品嫩草影院久久| 国产欧美日韩精品一区| 中文字幕一区二区三区乱码在线| 亚洲同性同志一二三专区| 亚洲精品五月天| 亚洲自拍偷拍网站| 三级一区在线视频先锋| 日本欧美韩国一区三区| 秋霞电影网一区二区| 国产成人午夜片在线观看高清观看| 国产99精品国产| 91亚洲男人天堂| 欧美三级视频在线| 精品三级av在线| 中文无字幕一区二区三区| 国产精品福利影院| 偷拍亚洲欧洲综合| 六月丁香综合在线视频| 成人免费观看av| 欧美在线小视频| 精品国产91乱码一区二区三区 | 欧美日精品一区视频| 欧美精品久久99| 国产性做久久久久久| 一区二区三区在线观看视频| 蜜桃视频一区二区三区在线观看| 国产一区二区剧情av在线| 色8久久人人97超碰香蕉987| 欧美剧情片在线观看| 国产女人18水真多18精品一级做| 亚洲九九爱视频| 麻豆精品视频在线| 成人黄色软件下载| 欧美一级二级三级乱码| 国产精品视频一二三区| 免费看日韩a级影片| 成人一区二区在线观看| 69久久夜色精品国产69蝌蚪网| 久久无码av三级| 亚洲一二三级电影| 国产一区二区三区综合| 日本韩国精品在线|