Annotation of researchv9/jtools/src/pi/ed8symtab.c, revision 1.1

1.1     ! root        1: #include "ed8.h"
        !             2: #include "symtab.pri"
        !             3: #include "dtype.pri"
        !             4: #include "symbol.h"
        !             5: SRCFILE("ed8symtab.c")
        !             6: 
        !             7: char *N_Name(int n_type)
        !             8: {
        !             9:        char *type;
        !            10:        static char name[64];
        !            11: 
        !            12:        switch( n_type&~N_EXT ){
        !            13:                default:        type = Name("N_0x%X", n_type );
        !            14:                case N_ABS:     type = "ABS";           break;
        !            15:                case N_BCOMM:   type = "BCOMM";         break;
        !            16:                case N_BSS:     type = "BSS";           break;
        !            17:                case N_BSTR:    type = "BSTR";          break;
        !            18:                case N_COMM:    type = "COMM";          break;
        !            19:                case N_DATA:    type = "DATA";          break;
        !            20:                case N_DIM:     type = "DIM";           break;
        !            21:                case N_ECOML:   type = "ECOML";         break;
        !            22:                case N_ECOMM:   type = "ECOMM";         break;
        !            23:                case N_BFUN:    type = "BFUN";          break;
        !            24:                case N_EFUN:    type = "EFUN";          break;
        !            25:                case N_ENTRY:   type = "ENTRY";         break;
        !            26:                case N_ESO:     type = "ESO";           break;
        !            27:                case N_ESTR:    type = "ESTR";          break;
        !            28:                case N_FN:      type = "FN";            break;
        !            29:                case N_FNAME:   type = "FNAME";         break;
        !            30:                case N_GSYM:    type = "GSYM";          break;
        !            31:                case N_LBRAC:   type = "LBRAC";         break;
        !            32:                case N_LCSYM:   type = "LCSYM";         break;
        !            33:                case N_LENG:    type = "LENG";          break;
        !            34:                case N_LSYM:    type = "LSYM";          break;
        !            35:                case N_PSYM:    type = "PSYM";          break;
        !            36:                case N_RBRAC:   type = "RBRAC";         break;
        !            37:                case N_RFUN:    type = "RFUN";          break;
        !            38:                case N_RSYM:    type = "RSYM";          break;
        !            39:                case N_SFLD:    type = "SFLD";          break;
        !            40:                case N_SLINE:   type = "SLINE";         break;
        !            41:                case N_SO:      type = "SO";            break;
        !            42:                case N_SOL:     type = "SOL";           break;
        !            43:                case N_SSYM:    type = "SSYM";          break;
        !            44:                case N_STSYM:   type = "STSYM";         break;
        !            45:                case N_TEXT:    type = "TEXT";          break;
        !            46:                case N_TYID:    type = "TYID";          break;
        !            47:                case N_UNDF:    type = "UNDF";          break;
        !            48:                case N_VER:     type = "VER";           break;
        !            49:        }
        !            50:        sprintf( name, "%s%s", type, n_type&N_EXT ? "'" : "" );
        !            51:        return name;
        !            52: }
        !            53: 
        !            54: DType Ed8SymTab::chain(int t, nlist *n)
        !            55: {
        !            56:        DType d;
        !            57: 
        !            58:        trace( "%d.chain(0%o,%d) %s", this, t, n, PccName(t) );
        !            59:        if( t&TMASK ){
        !            60:                d.pcc = t&TMASK;
        !            61:                d.univ = new DType;
        !            62:                *(d.ref()) = chain(DECREF(t), n);
        !            63:        } else {
        !            64:                d.pcc = t;
        !            65:                if((t==STRTY || t==ENUMTY || t==UNIONTY) && (++n)->n_type==N_TYID) 
        !            66:                        d.univ = idtosym(U_UTYPE,n->n_un.n_name,0);
        !            67:        }
        !            68:        return d;
        !            69: }
        !            70: 
        !            71: DType Ed8SymTab::gatherdtype(nlist *n)
        !            72: {
        !            73:        DType d, *dp;
        !            74: 
        !            75:        trace( "%d.gatherdtype(%d)", this, n);
        !            76:        d = chain(n->n_desc,n);
        !            77:        if( (++n)->n_type==N_TYID ) ++n;
        !            78:        for( dp = &d; dp; dp = dp->ref() )
        !            79:                if( dp->isary() && n->n_type==N_DIM )
        !            80:                        dp->dim = n++->n_value;
        !            81:        trace( "%s", d.text() );
        !            82:        return d;
        !            83: }
        !            84: 
        !            85: Ed8SymTab::Ed8SymTab(Core* c, int fd, SymTab *i):(c, fd, i)
        !            86: {
        !            87:        hdr = new exec;
        !            88: }
        !            89: 
        !            90: Ed8SymTab::~Ed8SymTab() { delete hdr; }
        !            91: 
        !            92: char *Ed8SymTab::gethdr()
        !            93: {
        !            94:        trace( "%d.gethdr()", this );   OK( "Ed8SymTab::gethdr" );
        !            95:        if( lseek( fd, 0L, 0 ) == -1 || !ReadOK(fd, (char*)hdr, sizeof *hdr) )
        !            96:                return SysErr( "symbol table: " );
        !            97:        _magic = hdr->a_magic;
        !            98:        if( N_BADMAG(*hdr) || hdr->a_trsize || hdr->a_drsize )
        !            99:                return "symbol table: not executable text";
        !           100:        entries = hdr->a_syms/sizeof(nlist);
        !           101:        return 0;
        !           102: }
        !           103: 
        !           104: Block *Ed8SymTab::gatherfunc(Func *func)
        !           105: {
        !           106:        register struct nlist *f, *n;
        !           107:        register Block *ablk, *lblk;
        !           108:        Var *arg = 0, *lcl = 0;
        !           109:        register Stmt *stmt = 0;
        !           110:        long bfun = func->begin, size = func->size, i, inasrc = 1;
        !           111:        char *so = func->source()->_text;
        !           112: 
        !           113:        ++FunctionGathered;
        !           114:        SymbolStats();
        !           115:        trace( "%d.gatherfunc(%d,%d,%s)", this, bfun, size, so );       OK(0);
        !           116:        IF_LIVE( bfun < 0 || bfun+size > entries ) return 0;
        !           117:        if (size == 0)
        !           118:                return fakeblk();
        !           119:        if( !(n = f = nlistvector(bfun,size)) ) return 0;
        !           120:        IF_LIVE( n->n_type != N_BFUN ) return 0;
        !           121:        ablk = new Block( this, 0, 0, sf("%s().arg_blk",n->n_un.n_name) );
        !           122:        lblk = new Block( this, ablk, 0, sf("%s().lcl_blk",n->n_un.n_name) );
        !           123:        ablk->child = lblk;
        !           124:        for( i = 0; i < size; ++i, ++n ){
        !           125:                if( n->n_type == N_SOL ){
        !           126:                        inasrc = eqstr( n->n_un.n_name, so );
        !           127:                        n->n_type = N_SLINE;
        !           128:                }
        !           129:                if( !inasrc ) continue;
        !           130:                switch( n->n_type ){
        !           131:                case N_PSYM:
        !           132:                        gathervar( n, &arg, ablk, U_ARG );
        !           133:                        break;
        !           134:                case N_LSYM:
        !           135:                        gathervar( n, &lcl, lblk, U_AUT );
        !           136:                        lcl->range.lo = - lcl->range.lo;        /* VAX */
        !           137:                        break;
        !           138:                case N_STSYM:
        !           139:                case N_LCSYM:
        !           140:                        gathervar( n, &lcl, lblk, U_STA );
        !           141:                        break;
        !           142:                case N_RSYM:
        !           143:                        gathervar( n, &lcl, lblk, U_REG );
        !           144:                        break;
        !           145:                case N_BFUN:
        !           146:                case N_RFUN:
        !           147:                case N_SLINE:                                   // cfront screws up
        !           148:                        if( stmt && n->n_desc > stmt->lineno )
        !           149:                                func->lines.hi = n->n_desc;
        !           150:                        if( stmt ) stmt->range.hi = n->n_value;
        !           151:                        stmt = new Stmt(this,lblk,stmt);
        !           152:                        if( !ablk->stmt ) ablk->stmt = stmt;
        !           153:                        stmt->lineno = n->n_desc;
        !           154:                        stmt->range.lo = n->n_value;
        !           155:                        if( !ablk->range.lo )
        !           156:                                ablk->range.lo = n->n_value;
        !           157:                        ablk->range.hi = n->n_value;
        !           158:                        break;
        !           159:                case N_EFUN:
        !           160:                        if( stmt ) stmt->range.hi = n->n_value;
        !           161:                        goto BreakOut;
        !           162:                }
        !           163:        }
        !           164: BreakOut:
        !           165:        delete f;
        !           166:        uncfront( ablk->var, (char *)0 );
        !           167:        uncfront( lblk->var, (char *)0 );
        !           168:        return ablk;
        !           169: }
        !           170: 
        !           171: void Ed8SymTab::gathervar( nlist *n, Var **v, Block *b, UDisc d )
        !           172: {
        !           173:        trace( "%d.gathervar(%d,%d,%d,%d)", n, v, b, d ); VOK;
        !           174:        IF_LIVE( !v ) return;
        !           175:        *v = new Var( this, b, *v, d, n->n_un.n_name );
        !           176:        if( b && !b->var ) b->var = *v;
        !           177:        (*v)->range.lo = n->n_value;
        !           178:        (*v)->type = gatherdtype(n);
        !           179: }
        !           180: 
        !           181: char *Ed8SymTab::gettbl()
        !           182: {
        !           183:        trace( "%d.gettbl()" ); OK("SymTab.gettbl");
        !           184:        base = new nlist[entries];
        !           185:        symoff = (nlist*)N_SYMOFF(*hdr);
        !           186:        if( lseek(fd, (long)symoff, 0) == 1
        !           187:         || !ReadOK(fd, (char*)base, hdr->a_syms)
        !           188:         || !ReadOK(fd, (char*)&strsize, 4) ){
        !           189:                delete base; base = 0;
        !           190:                return SysErr( "symbol table: " );
        !           191:        }
        !           192:        strings = new char[strsize];
        !           193:        if( lseek( fd, -4, 1 ) == -1 || !ReadOK(fd, strings, strsize) ){
        !           194:                delete strings; strings = 0;
        !           195:                delete base; base = 0;
        !           196:                return SysErr( "strings table: " );
        !           197:        }
        !           198:        strcpy( strings, "???" );       /* zero string index */
        !           199:        return 0;
        !           200: }
        !           201: 
        !           202: Source *Ed8SymTab::tree()
        !           203: {
        !           204:        register nlist  *n, *base_entries, *r;
        !           205:        Source          *src = 0;
        !           206:        Func            *func = 0;
        !           207:        Block           *fake = fakeblk();
        !           208:        Var             *glb = 0, *fst = 0, *resolve;
        !           209:        UType           *u;
        !           210:        register long   regstrings, inafunc = 0, inasrc = 0;
        !           211:        
        !           212:        trace( "%d.tree()", this ); OK(0);
        !           213:        if( _warn = gettbl() ) return 0;
        !           214:        base_entries = base+entries;
        !           215:        regstrings = (long) strings;
        !           216:        glb = globregs(_blk, 18 );
        !           217:        for( n = base; n < base_entries; ++n ){
        !           218:                n->n_un.n_strx += (long) regstrings;
        !           219:                switch( n->n_type ){
        !           220:                case N_BSTR:
        !           221:                        for( r = n+1; r->n_type != N_ESTR; ++r ) {}
        !           222:                        if( u = (UType*) idtosym(U_UTYPE,n->n_un.n_name,0) ){
        !           223:                                if( u->size<r+1-n ){    /* use the biggest */
        !           224:                                        u->size = r+1-n;
        !           225:                                        u->begin = n-base;
        !           226:                                        u->range.lo = r->n_value;
        !           227:                                        u->type.pcc = n->n_desc;
        !           228:                                }
        !           229:                                break;
        !           230:                        }
        !           231:                        ++UTypeStubs;
        !           232:                        u = new UType(this, n-base, r+1-n, n->n_un.n_name );
        !           233:                        u->range.lo = r->n_value;
        !           234:                        u->type.pcc = n->n_desc;
        !           235:                        u->type.univ = u;
        !           236:                        u->rsib = utype;
        !           237:                        utype = u;
        !           238:                }
        !           239:        }
        !           240:        for( n = base; n < base_entries; ++n ){
        !           241:                switch( n->n_type ){
        !           242:                case N_ABS|N_EXT:
        !           243:                        if( n->n_un.n_name[0] != '_' ) break;   /* ? */
        !           244:                case N_BSS|N_EXT:
        !           245:                case N_DATA|N_EXT:
        !           246:                        if( *n->n_un.n_name == '_' ) ++n->n_un.n_name;
        !           247:                        resolve = (Var*)idtosym(U_GLB, n->n_un.n_name, 0);
        !           248:                        if( resolve ){
        !           249:                                if( !resolve->range.lo )
        !           250:                                        resolve->range.lo = n->n_value;
        !           251:                        } else {
        !           252:                                n->n_desc = LONG;
        !           253:                                gathervar( n, &glb, _blk, U_GLB );
        !           254:                                break;
        !           255:                        }
        !           256:                        break;
        !           257:                case N_GSYM:
        !           258:                        if( !inasrc || inafunc ) break;
        !           259:                        if( !idtosym(U_GLB, n->n_un.n_name, 0) )
        !           260:                                gathervar( n, &glb, _blk, U_GLB );
        !           261:                        break;
        !           262:                case N_LCSYM:
        !           263:                case N_STSYM:
        !           264:                        if( !inasrc || inafunc || !src || !src->blk ) break;
        !           265:                        gathervar( n, &fst, src->blk, U_FST );
        !           266:                        break;
        !           267: 
        !           268:                case N_SO:
        !           269:                        inasrc = 1;
        !           270:                        src = new Source(this,src,n->n_un.n_name,0);
        !           271:                        func = 0;
        !           272:                        inafunc = 0;
        !           273:                        fst = 0;
        !           274:                        break;
        !           275:                case N_SOL:
        !           276:                        inasrc = src && eqstr(src->_text,n->n_un.n_name);
        !           277:                        break;
        !           278:                case N_TEXT|N_EXT:
        !           279:                        if( *n->n_un.n_name == '_' ) ++n->n_un.n_name;
        !           280:                        if( idtosym(U_FUNC, n->n_un.n_name, 0) ) break;
        !           281:                        func = new Func(this,0,0,0,n->n_un.n_name);
        !           282:                        func->range.lo = n->n_value;
        !           283:                        func->_blk = fake;
        !           284:                        DType *t = new DType;
        !           285:                        t->pcc = LONG;
        !           286:                        func->type = t->incref();
        !           287:                        func->type.pcc = FTN;
        !           288:                        break;
        !           289:                case N_BFUN:
        !           290:                        if( !inasrc || !src ) break;
        !           291:                        inafunc = 1;
        !           292:                        ++FunctionStubs;
        !           293:                        func = new Func(this,src,func,n-base,n->n_un.n_name);
        !           294:                        if( !src->child ) src->child = src->linefunc = func;
        !           295:                        func->range.lo = n->n_value;
        !           296:                        func->lines.lo = n->n_desc;
        !           297:                        if( !strcmp(n->n_un.n_name,(n+1)->n_un.n_name) )
        !           298:                                func->type = gatherdtype(++n);
        !           299:                        break;
        !           300:                case N_ESO:
        !           301:                        inasrc = inafunc = 0;
        !           302:                        break;
        !           303:                case N_EFUN:
        !           304:                        /* if( !inasrc ) break; screws yyparse() */
        !           305:                        if( !inafunc || !func ) break;
        !           306:                        inafunc = 0;
        !           307:                        func->lines.hi = n->n_desc;
        !           308:                        func->size = n-base - func->begin + 1;
        !           309:                }
        !           310:        }
        !           311:        while( src && src->lsib ) src = (Source*) src->lsib;
        !           312:        if( base ) { delete base; base = 0; }
        !           313:        return src;
        !           314: }
        !           315: 
        !           316: Var *Ed8SymTab::gatherutype(UType *u)
        !           317: {
        !           318:        nlist *f, *n;
        !           319:        Var *first = 0, *v = 0;
        !           320:        long bstr = u->begin, size = u->size;
        !           321: 
        !           322:        ++UTypeGathered;
        !           323:        SymbolStats();
        !           324:        trace( "%d.gatherutype(%d %d)", this, bstr, size );
        !           325:        if( !(f = n = nlistvector(bstr,size)) ) return 0;
        !           326:        for( ++n; n->n_type != N_ESTR; ++n ){
        !           327:                switch( n->n_type ){
        !           328:                case N_SFLD:
        !           329:                        int length = n->n_desc>>BTSHIFT;
        !           330:                        n->n_value = (32 - (n->n_value & 0x1f) - length) +
        !           331:                                (n->n_value & ~0x1f);
        !           332:                        switch( n->n_desc & BTMASK ){
        !           333:                        case INT:       n->n_desc = BITS; break;
        !           334:                        case UNSIGNED:  n->n_desc = UBITS;
        !           335:                        }
        !           336:                        gathervar(n, &v, 0, U_MOT);
        !           337:                        v->type.dim = length;
        !           338:                        break;
        !           339:                case N_SSYM:
        !           340:                        gathervar(n, &v, 0, U_MOT);
        !           341:                }
        !           342:                if( !first ) first = v;
        !           343:        }
        !           344:        delete f;
        !           345:        uncfront(first, u->_text);
        !           346:        return first;
        !           347: }
        !           348: 
        !           349: nlist *Ed8SymTab::nlistvector(long start, long size )
        !           350: {
        !           351:        struct nlist *n;
        !           352:        int i;
        !           353: 
        !           354:        trace( "%d.nlistvector(%d,%d) %d", this, start, size, symoff );
        !           355:        lseek(fd, (long) (symoff + start), 0);
        !           356:        n = new nlist[size];
        !           357:        IF_LIVE( !ReadOK(fd, (char*) n, size * sizeof *n) ){
        !           358:                delete n;
        !           359:                return 0;
        !           360:        }
        !           361:        for( i = 0; i < size; ++i )
        !           362:                n[i].n_un.n_strx += (long) strings;
        !           363:        return n;
        !           364: }
        !           365: 

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.