Annotation of researchv10no/cmd/adb/v8/trcrun.c, revision 1.1

1.1     ! root        1: /*
        !             2:  * OS-specific functions for running the debugged process
        !             3:  * particular to v8 (assumes /proc)
        !             4:  */
        !             5: 
        !             6: #include "defs.h"
        !             7: #include "regs.h"
        !             8: #include <sys/pioctl.h>
        !             9: #include <sys/user.h>
        !            10: #include <sys/proc.h>
        !            11: #include <signal.h>
        !            12: #include <errno.h>
        !            13: #include "base.h"
        !            14: 
        !            15: char lastc, peekc;
        !            16: ADDR txtsize;
        !            17: 
        !            18: static int child;
        !            19: static long tsigs = -1;
        !            20: 
        !            21: /*
        !            22:  * kill process
        !            23:  */
        !            24: 
        !            25: killpcs()
        !            26: {
        !            27:        long sig = SIGKILL;
        !            28: 
        !            29:        ioctl(fcor, PIOCCSIG, 0);
        !            30:        ioctl(fcor, PIOCKILL, &sig);
        !            31:        ioctl(fcor, PIOCRUN, 0);
        !            32: }
        !            33: 
        !            34: /*
        !            35:  * grab the process already opened (but not traced);
        !            36:  * stop it so we can look at it
        !            37:  */
        !            38: 
        !            39: grab()
        !            40: {
        !            41:        struct proc p;
        !            42:        int f;
        !            43: 
        !            44:        if ((f = open(corfil, 2)) < 0)
        !            45:                error("no write access");
        !            46:        close(fcor);
        !            47:        fcor = f;
        !            48:        if (ioctl(fcor, PIOCGETPR, &p) < 0)
        !            49:                error("not a process");
        !            50:        pid = p.p_pid;
        !            51:        child = 0;
        !            52:        ioctl(fcor, PIOCSMASK, &tsigs);
        !            53:        if (p.p_stat != SSTOP)
        !            54:                ioctl(fcor, PIOCSTOP, 0);
        !            55:        bpwait();
        !            56: }
        !            57: 
        !            58: /*
        !            59:  * turn off tracing & let it go
        !            60:  */
        !            61: 
        !            62: ungrab()
        !            63: {
        !            64:        long zero = 0;
        !            65: 
        !            66:        if (signo == 0)
        !            67:                ioctl(fcor, PIOCCSIG, 0);
        !            68:        ioctl(fcor, PIOCSMASK, &zero);
        !            69:        ioctl(fcor, PIOCRUN, 0);
        !            70:        pid = 0;
        !            71: }
        !            72: 
        !            73: /*
        !            74:  * get the program to be debugged ready to run
        !            75:  * program is left stopped at the beginning (so we can poke in breakpoints)
        !            76:  */
        !            77: 
        !            78: startpcs()
        !            79: {
        !            80:        int fd;
        !            81:        char *procname();
        !            82:        extern int (*sigint)(), (*sigqit)();
        !            83: 
        !            84:        fd = procopen(getpid());
        !            85:        if (ioctl(fd, PIOCSEXEC, 0) < 0) {
        !            86:                close(fd);
        !            87:                error("no process ioctl");
        !            88:        }
        !            89:        if ((pid = fork()) == 0) {
        !            90:                close(fd);
        !            91:                close(fsym);
        !            92:                close(fcor);
        !            93:                signal(SIGINT, sigint);
        !            94:                signal(SIGQUIT, sigqit);
        !            95:                doexec();
        !            96:                exit(0);
        !            97:        }
        !            98:        ioctl(fd, PIOCREXEC, 0);
        !            99:        close(fd);
        !           100:        if (pid == -1)
        !           101:                error("can't fork");
        !           102:        child++;
        !           103:        fcor = procopen(pid);
        !           104:        corfil = procname(pid);
        !           105:        ioctl(fcor, PIOCSMASK, &tsigs);
        !           106:        bpwait();
        !           107:        ioctl(fcor, PIOCREXEC, 0);
        !           108:        if (adrflg)
        !           109:                rput(PC, wtoa(adrval));
        !           110:        while (rdc() != EOR)
        !           111:                ;
        !           112:        reread();
        !           113: }
        !           114: 
        !           115: int
        !           116: procopen(pid)
        !           117: int pid;
        !           118: {
        !           119:        char *pn;
        !           120:        int fd;
        !           121:        char *procname();
        !           122: 
        !           123:        pn = procname(pid);
        !           124:        if ((fd = open(pn, 2)) < 0) {
        !           125:                printf("%s: cannot open\n", pn);
        !           126:                error(0);
        !           127:        }
        !           128:        return (fd);
        !           129: }
        !           130: 
        !           131: char *
        !           132: procname(pid)
        !           133: int pid;
        !           134: {
        !           135:        static char name[20];
        !           136: 
        !           137:        sprintf(name, "/proc/%d", pid);
        !           138:        return (name);
        !           139: }
        !           140: 
        !           141: /*
        !           142:  * set process running, single-stepped
        !           143:  */
        !           144: 
        !           145: runstep(keepsig)
        !           146: int keepsig;
        !           147: {
        !           148: 
        !           149:        delbp();
        !           150:        setstep();
        !           151:        rrest();
        !           152:        if (keepsig == 0)
        !           153:                ioctl(fcor, PIOCCSIG, 0);
        !           154:        ioctl(fcor, PIOCRUN, 0);
        !           155: }
        !           156: 
        !           157: /*
        !           158:  * set process running
        !           159:  */
        !           160: 
        !           161: runrun(keepsig)
        !           162: int keepsig;
        !           163: {
        !           164: 
        !           165:        if (keepsig == 0)
        !           166:                ioctl(fcor, PIOCCSIG, 0);
        !           167:        ioctl(fcor, PIOCRUN, 0);
        !           168: }
        !           169: 
        !           170: /*
        !           171:  * exec the program to be debugged
        !           172:  * opening standard input and output as requested
        !           173:  */
        !           174: 
        !           175: doexec()
        !           176: {
        !           177:        char *argl[MAXARG];
        !           178:        char args[LINSIZ];
        !           179:        register char *p;
        !           180:        register char **ap;
        !           181:        register char *thisarg;
        !           182:        extern char **environ;
        !           183: 
        !           184:        ap = argl;
        !           185:        p = args;
        !           186:        *ap++ = symfil;
        !           187:        for (rdc(); lastc != EOR;) {
        !           188:                thisarg = p;
        !           189:                if (lastc == '<' || lastc == '>') {
        !           190:                        *p++ = lastc;
        !           191:                        rdc();
        !           192:                }
        !           193:                while (lastc != EOR && lastc != SPC && lastc != TB) {
        !           194:                        *p++ = lastc;
        !           195:                        readchar();
        !           196:                }
        !           197:                if (lastc == SPC || lastc == TB)
        !           198:                        rdc();
        !           199:                *p++ = 0;
        !           200:                if (*thisarg == '<') {
        !           201:                        close(0);
        !           202:                        if (open(&thisarg[1], 0) < 0) {
        !           203:                                printf("%s: cannot open\n", &thisarg[1]);
        !           204:                                _exit(0);
        !           205:                        }
        !           206:                }
        !           207:                else if (*thisarg == '>') {
        !           208:                        close(1);
        !           209:                        if (creat(&thisarg[1], 0666) < 0) {
        !           210:                                printf("%s: cannot create\n", &thisarg[1]);
        !           211:                                _exit(0);
        !           212:                        }
        !           213:                }
        !           214:                else
        !           215:                        *ap++ = thisarg;
        !           216:        }
        !           217:        *ap = NULL;
        !           218:        execve(symfil, argl, environ);
        !           219:        perror(symfil);
        !           220: }
        !           221: 
        !           222: /*
        !           223:  * wait for the process to stop;
        !           224:  * pick up status and registers when it does
        !           225:  */
        !           226: 
        !           227: #define        WSLEEP  10
        !           228: 
        !           229: bpwait()
        !           230: {
        !           231:        register int w;
        !           232:        int stat;
        !           233:        int (*isig)();
        !           234:        int nulsig();
        !           235:        extern int errno;
        !           236: 
        !           237:        isig = signal(SIGINT, SIG_IGN);
        !           238:        /*
        !           239:         * alarm stuff is just in case
        !           240:         */
        !           241:        for (;;) {
        !           242:                signal(SIGALRM, nulsig);
        !           243:                alarm(WSLEEP);
        !           244:                if (ioctl(fcor, PIOCWSTOP, 0) >= 0)
        !           245:                        errno = 0;
        !           246:                alarm(0);
        !           247:                if (errno == 0) {
        !           248:                        signal(SIGINT, isig);
        !           249:                        mapimage();
        !           250:                        if (signo == SIGTRAP || signo == SIGSTOP)
        !           251:                                signo = 0;
        !           252:                        else {
        !           253:                                sigprint();
        !           254:                                newline();
        !           255:                        }
        !           256:                        return;         /* should set stuff? */
        !           257:                }
        !           258:                if (errno == ENOENT)
        !           259:                        break;
        !           260:                /* still there, still running.  try again. */
        !           261:        }
        !           262:        if (child == 0) {
        !           263:                close(fcor);
        !           264:                pid = 0;
        !           265:                corfil = NULL;
        !           266:                errflg = "process terminated";
        !           267:                return;
        !           268:        }
        !           269:        /*
        !           270:         * process has died; wait and report status
        !           271:         * should check if it's really our child
        !           272:         */
        !           273:        signal(SIGALRM, nulsig);
        !           274:        alarm(WSLEEP);
        !           275:        while ((w = wait(&stat)) != -1 && w != pid)
        !           276:                ;
        !           277:        alarm(0);
        !           278:        pid = 0;
        !           279:        signal(SIGINT, isig);
        !           280:        close(fcor);
        !           281:        pid = 0;
        !           282:        corfil = NULL;
        !           283:        errflg = "process terminated";
        !           284:        if (w == -1)
        !           285:                errflg = "wait failed";
        !           286:        else {
        !           287:                if ((stat & 0177) == 0177)
        !           288:                        printf("trace status?  0%o\n", stat);
        !           289:                else {
        !           290:                        sigcode = 0;
        !           291:                        if ((signo = stat & 0177) != 0)
        !           292:                                sigprint();
        !           293:                        if (stat & 0200) {
        !           294:                                prints(" - core dumped");
        !           295:                                corfil = "core";
        !           296:                                setcor();
        !           297:                        }
        !           298:                }
        !           299:        }
        !           300: }
        !           301: 
        !           302: static
        !           303: nulsig()
        !           304: {
        !           305: }
        !           306: 
        !           307: /*
        !           308:  * is the right-hand file a process image?
        !           309:  */
        !           310: 
        !           311: static struct proc p;
        !           312: static struct user u;
        !           313: 
        !           314: trcimage()
        !           315: {
        !           316: 
        !           317:        if (ioctl(fcor, PIOCGETPR, &p) < 0)
        !           318:                return (0);
        !           319:        lseek(fcor, (off_t)UBASE, 0);
        !           320:        if (read(fcor, (char *)&u, sizeof(u)) != sizeof(u))
        !           321:                return (0);
        !           322:        if (p.p_stat != SSTOP)
        !           323:                signo = 0;
        !           324:        else
        !           325:                signo = p.p_cursig;
        !           326:        return (1);
        !           327: }
        !           328: 
        !           329: /*
        !           330:  * get bits of u-area before maps are set
        !           331:  */
        !           332: 
        !           333: int
        !           334: trcunab(off)
        !           335: int off;
        !           336: {
        !           337: 
        !           338:        return (*(int *)((char *)&u + off));
        !           339: }

unix.superglobalmegacorp.com

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