Annotation of researchv9/cmd/adb/sun/setup.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * adb - routines to read a.out+core at startup
        !             3:  * stuff in here is pretty vax dependent
        !             4:  */
        !             5: #include <a.out.h>
        !             6: #include <sys/types.h>
        !             7: #include <sys/dir.h>
        !             8: #include <sys/user.h>
        !             9: #include <sys/param.h>
        !            10: #include "defs.h"
        !            11: #include "space.h"
        !            12: #include "map.h"
        !            13: #include "machine.h"
        !            14: #include "base.h"
        !            15: 
        !            16: char   *symfil = "a.out";
        !            17: char   *corfil = "core";
        !            18: 
        !            19: MAP    symmap[NMAP];
        !            20: MAP    cormap[NMAP];
        !            21: 
        !            22: int fsym, fcor;
        !            23: 
        !            24: static ADDR datbase;
        !            25: ADDR txtsize, datsize, stksize;
        !            26: static ADDR entry;
        !            27: static int magic;
        !            28: 
        !            29: setsym()
        !            30: {
        !            31:        ADDR loc;
        !            32:        struct exec hdr;
        !            33:        register MAP *mp;
        !            34:        char *malloc();
        !            35: 
        !            36:        fsym = getfile(symfil, 1);
        !            37:        mp = symmap;
        !            38:        if (read(fsym, (char *)&hdr, sizeof hdr) != sizeof hdr ||
        !            39:            badmagic((int)hdr.a_magic)) {
        !            40:                mp->f = mp->b = 0;
        !            41:                mp->e = MAXFILE;
        !            42:                mp->sp = DATASP;
        !            43:                mp->flag = MPINUSE;
        !            44:                mp++;
        !            45:                mp->flag = 0;
        !            46:                return;
        !            47:        }
        !            48:        magic = hdr.a_magic;
        !            49:        entry = hdr.a_entry;
        !            50:        loc = hdr.a_text+hdr.a_data;
        !            51:        switch (magic) {
        !            52: 
        !            53:        case OMAGIC:
        !            54:                txtsize = 0;
        !            55:                datbase = 0;
        !            56:                datsize = loc;
        !            57:                mp->b = entry;
        !            58:                mp->e = mp->b + loc;
        !            59:                mp->f = N_TXTOFF(hdr);
        !            60:                mp->sp = DATASP;
        !            61:                mp->flag = MPINUSE;
        !            62:                break;
        !            63: 
        !            64:        case ZMAGIC:
        !            65:        case NMAGIC:
        !            66:                txtsize = hdr.a_text;
        !            67:                mp->b = N_PAGSIZ(hdr);
        !            68:                mp->e = hdr.a_text + mp->b;
        !            69:                mp->f = N_TXTOFF(hdr);
        !            70:                mp->sp = INSTSP;
        !            71:                mp->flag = MPINUSE;
        !            72:                mp++;
        !            73:                mp->b = datbase = round((WORD)(hdr.a_text + N_PAGSIZ(hdr)),
        !            74:                        (WORD)N_SEGSIZ(hdr));
        !            75:                mp->e = datsize = datbase + hdr.a_data;
        !            76:                mp->f = N_TXTOFF(hdr) + hdr.a_text;
        !            77:                mp->sp = DATASP;
        !            78:                mp->flag = MPINUSE;
        !            79:                break;
        !            80:        }
        !            81:        mp++;
        !            82:        mp->flag = 0;
        !            83:        syminit(&hdr);
        !            84: }
        !            85: 
        !            86: setcor()
        !            87: {
        !            88:        register MAP *mp;
        !            89: 
        !            90:        fcor = getfile(corfil,2);
        !            91:        if (fcor < 0
        !            92:        ||  (mapimage() == 0 && mapcore() == 0)) {
        !            93:                /* not a core image */
        !            94:                mp = cormap;
        !            95:                mp->b = 0;
        !            96:                mp->e = MAXFILE;
        !            97:                mp->f = 0;
        !            98:                mp->sp = DATASP;
        !            99:                mp->flag = MPINUSE;
        !           100:                mp++;
        !           101:                mp->flag = 0;
        !           102:                return;
        !           103:        }
        !           104: }
        !           105: 
        !           106: /*
        !           107:  * set up maps for a direct process image (/proc)
        !           108:  */
        !           109: 
        !           110: #define        UOFF(x) (ADDR)(&((struct user *)0)->x)
        !           111: 
        !           112: int
        !           113: mapimage()
        !           114: {
        !           115:        register MAP *mp;
        !           116: 
        !           117:        if (trcimage() == 0)
        !           118:                return (0);
        !           119:        sigcode = trcunab(UOFF(u_code));
        !           120:        txtsize = ctob(trcunab(UOFF(u_tsize)));
        !           121:        datsize = ctob(trcunab(UOFF(u_dsize)));
        !           122:        stksize = ctob(trcunab(UOFF(u_ssize)));
        !           123: #if NOTDEF             /* no ID separation on VAX */
        !           124:        if (magic == IMAGIC)
        !           125:                datbase = 0;
        !           126:        else
        !           127: #endif
        !           128:                datbase = txtsize;
        !           129:        mp = cormap;
        !           130:        if (txtsize) {
        !           131:                mp->b = ctob(1);
        !           132:                mp->e = mp->b + txtsize;
        !           133:                mp->f = TXTBASE + mp->b;
        !           134:                mp->flag = MPINUSE;
        !           135: #if NOTDEF             /* no ID separation on VAX */
        !           136:                if (magic == IMAGIC)
        !           137:                        mp->sp = INSTSP;
        !           138:                else
        !           139: #endif
        !           140:                        mp->sp = DATASP;
        !           141:                mp++;
        !           142:        }
        !           143:        mp->b = ctob(stoc(ctos(btoc(txtsize) + 1)));
        !           144:        mp->e = mp->b + datsize;
        !           145:        mp->f = DATBASE + mp->b;
        !           146:        mp->sp = DATASP;
        !           147:        mp->flag = MPINUSE;
        !           148:        mp++;
        !           149:        mp->b = MAXSTOR - stksize;
        !           150:        mp->e = MAXSTOR;
        !           151:        mp->f = DATBASE + mp->b;
        !           152:        mp->sp = DATASP;
        !           153:        mp->flag = MPINUSE;
        !           154:        mp++;
        !           155:        mp->b = 0;
        !           156:        mp->e = ctob(UPAGES);
        !           157:        mp->f = UBASE;
        !           158:        mp->sp = UBLKSP;
        !           159:        mp->flag = MPINUSE;
        !           160:        mp++;
        !           161:        mp->flag = 0;
        !           162:        rsnarf();
        !           163:        return (1);
        !           164: }
        !           165: 
        !           166: mapcore()
        !           167: {
        !           168:        struct user u;
        !           169:        register MAP *mp;
        !           170: 
        !           171:        lseek(fcor, (off_t)0, 0);
        !           172:        if (read(fcor, (char *)&u, sizeof(u)) != sizeof(u)
        !           173:        ||  badmagic(u.u_exdata.ux_mag))
        !           174:                return (0);
        !           175:        if (magic && magic != u.u_exdata.ux_mag)
        !           176:                printf("%s: not from %s\n", corfil, symfil);
        !           177:        magic = u.u_exdata.ux_mag;
        !           178:        signo = u.u_arg[0];
        !           179:        sigcode = u.u_code;
        !           180:        txtsize = ctob(u.u_tsize);
        !           181:        datsize = ctob(u.u_dsize);
        !           182:        stksize = ctob(u.u_ssize);
        !           183:        mp = cormap;
        !           184:        switch (magic) {
        !           185: 
        !           186:        case OMAGIC:
        !           187:                mp->b = ctob(1);
        !           188:                mp->e = mp->b + txtsize + datsize;
        !           189:                mp->f = ctob(UPAGES);
        !           190:                mp->sp = DATASP;
        !           191:                mp->flag = MPINUSE;
        !           192:                mp++;
        !           193:                mp->b = MAXSTOR - stksize;
        !           194:                mp->e = MAXSTOR;
        !           195:                mp->f = txtsize + datsize + ctob(UPAGES);
        !           196:                mp->sp = DATASP;
        !           197:                mp->flag = MPINUSE;
        !           198:                break;
        !           199: 
        !           200:        case NMAGIC:
        !           201:        case ZMAGIC:
        !           202:                mp->b = ctob(stoc(ctos(u.u_tsize + 1)));
        !           203:                mp->e = mp->b + datsize;
        !           204:                mp->f = ctob(UPAGES);
        !           205:                mp->sp = DATASP;
        !           206:                mp->flag = MPINUSE;
        !           207:                mp++;
        !           208:                mp->b = MAXSTOR - stksize;
        !           209:                mp->e = MAXSTOR;
        !           210:                mp->f = datsize + ctob(UPAGES);
        !           211:                mp->sp = DATASP;
        !           212:                mp->flag = MPINUSE;
        !           213:                break;
        !           214:        }
        !           215:        mp++;
        !           216:        mp->b = 0;
        !           217:        mp->e = ctob(UPAGES);
        !           218:        mp->f = 0;
        !           219:        mp->sp = UBLKSP;
        !           220:        mp->flag = MPINUSE;
        !           221:        mp++;
        !           222:        mp->flag = 0;
        !           223:        rsnarf();
        !           224:        return (1);
        !           225: }
        !           226: 
        !           227: badmagic(num)
        !           228: int num;
        !           229: {
        !           230: 
        !           231:        switch (num) {
        !           232:        case OMAGIC:
        !           233:        case NMAGIC:
        !           234:        case ZMAGIC:
        !           235:                return (0);
        !           236: 
        !           237:        default:
        !           238:                return (1);
        !           239:        }
        !           240: }
        !           241: 
        !           242: cmdmap(itype, star)
        !           243: register int star, itype;
        !           244: {
        !           245:        register MAP *mp;
        !           246:        extern char lastc;
        !           247: 
        !           248:        if (itype & SYMF)
        !           249:                mp = symmap;
        !           250:        else
        !           251:                mp = cormap;
        !           252:        if (star)       /* UGH */
        !           253:                mp++;
        !           254:        if (expr(0))
        !           255:                mp->b = expv; 
        !           256:        if (expr(0))
        !           257:                mp->e = expv; 
        !           258:        if (expr(0))
        !           259:                mp->f = expv; 
        !           260:        mp->flag |= MPINUSE;
        !           261:        if (rdc()=='?' && (itype&SYMF) == 0) {
        !           262:                if (fcor)
        !           263:                        close(fcor);
        !           264:                fcor=fsym;
        !           265:                corfil=symfil;
        !           266:        } else if (lastc == '/' && itype&SYMF) {
        !           267:                if (fsym)
        !           268:                        close(fsym);
        !           269:                fsym=fcor;
        !           270:                symfil=corfil;
        !           271:        } else
        !           272:                reread();
        !           273: }
        !           274: 
        !           275: create(f)
        !           276:        char *f;
        !           277: {
        !           278:        register int fd;
        !           279: 
        !           280:        fd = creat(f, 0666);
        !           281:        if (fd < 0)
        !           282:                return (-1);
        !           283:        close(fd);
        !           284:        return (open(f, wtflag));
        !           285: }
        !           286: 
        !           287: getfile(filnam, cnt)
        !           288:        char *filnam;
        !           289: {
        !           290:        register int fsym;
        !           291: 
        !           292:        if (strcmp(filnam, "-") == 0)
        !           293:                return (-1);
        !           294:        fsym = open(filnam, wtflag);
        !           295:        if (fsym < 0 && xargc > cnt) {
        !           296:                if (wtflag)
        !           297:                        fsym = create(filnam);
        !           298:                if (fsym < 0)
        !           299:                        printf("cannot open `%s'\n", filnam);
        !           300:        }
        !           301:        return (fsym);
        !           302: }
        !           303: 
        !           304: setvar()
        !           305: {
        !           306: 
        !           307:        var[varchk('b')] = datbase;
        !           308:        var[varchk('d')] = datsize;
        !           309:        var[varchk('e')] = entry;
        !           310:        var[varchk('m')] = magic;
        !           311:        var[varchk('s')] = stksize;
        !           312:        var[varchk('t')] = txtsize;
        !           313: }

unix.superglobalmegacorp.com

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