|
|
Initial revision
/*
* Copyright (c) 1980 Regents of the University of California.
* All rights reserved. The Berkeley software License Agreement
* specifies the terms and conditions for redistribution.
*/
#ifndef lint
static char sccsid[] = "@(#)resume.c 5.3 (Berkeley) 1/9/89";
#endif not lint
/*
* Resume execution, first setting appropriate registers.
*/
#include "defs.h"
#include <signal.h>
#include "process.h"
#include "machine.h"
#include "main.h"
#include "process.rep"
#include "runtime/frame.rep"
#include "machine/pxerrors.h"
#include "pxinfo.h"
/*
* Resume execution, set (get) pcode location counter before (after) resuming.
*/
resume()
{
register PROCESS *p;
p = process;
do {
if (option('e')) {
printf("execution resumes at pc 0x%x, lc %d\n", process->pc, pc);
fflush(stdout);
}
pcont(p);
dread(&pc, PCADDR, sizeof(pc)); /* Get pcode pc */
if (option('e')) {
printf("execution stops at pc 0x%x, lc %d on sig %d\n",
process->pc, pc, p->signo);
fflush(stdout);
}
} while (p->signo == SIGCONT);
if (option('r') && p->signo != 0) {
choose();
}
/*
* If px implements a breakpoint by executing a halt instruction
* the real pc must be incremented to skip over it.
*
* Currently, px sends itself a signal so no incrementing is needed.
*
if (isbperr()) {
p->pc++;
}
*/
}
/*
* Under the -r option, we offer the opportunity to just get
* the px traceback and not actually enter the debugger.
*
* If the standard input is not a tty but standard error is,
* change standard input to be /dev/tty.
*/
LOCAL choose()
{
register int c;
if (!isterm(stdin)) {
if (!isterm(stderr) || freopen("/dev/tty", "r", stdin) == NIL) {
unsetsigtraces(process);
pcont(process);
quit(process->exitval);
/* NOTREACHED */
}
}
fprintf(stderr, "\nProgram error");
fprintf(stderr, "\nDo you wish to enter the debugger? ");
c = getchar();
if (c == 'n') {
unsetsigtraces(process);
pcont(process);
quit(process->exitval);
}
while (c != '\n' && c != EOF) {
c = getchar();
}
fprintf(stderr, "\nEntering debugger ...");
init();
option('r') = FALSE;
fprintf(stderr, " type 'help' for help.\n");
}
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.