|
|
1.1 ! root 1: # ! 2: /* Handle signal trapping from version 6 or version 7 compatability ! 3: * mode programs. ! 4: * Art Wetzel November 1979 ! 5: */ ! 6: #ifdef TRACE ! 7: #include <stdio.h> ! 8: #endif ! 9: #include <signal.h> ! 10: #include "defs.h" ! 11: unsigned int sigvals[NSIG+1]; ! 12: /* actual catch point for all signals */ ! 13: sigcatch(signum) int signum; { ! 14: unsigned short *pcptr; ! 15: extern getregs(); ! 16: if(incompat) { ! 17: /* hurry up and get the registers before they are destroyed */ ! 18: getregs(); ! 19: } else { ! 20: /* we were in native mode simulating a sys call */ ! 21: /* set it up with the old values */ ! 22: dosig(signum, pc); ! 23: /* go back where we were doing the sys call */ ! 24: return(0); ! 25: } ! 26: /* figure out the pc */ ! 27: pcptr = (unsigned short *)((char *)&pcptr + 20); ! 28: pc = (unsigned short *) *pcptr; ! 29: /* get the psl with condition codes */ ! 30: /* requires UNIX-32V patch to not clear out condition codes */ ! 31: psl = 0x83c00000 | (*(pcptr - 6) & 017); ! 32: /* actually do the thing */ ! 33: if(sigvals[signum] != (unsigned int)SIG_DFL && (sigvals[signum] & (unsigned int)SIG_IGN) == 0) ! 34: dosig(signum, pc); ! 35: /* go back to compatability mode and the signal routine there */ ! 36: incompat++; ! 37: compat(); ! 38: } ! 39: /* routine to set up pdp11 space for return from a signal */ ! 40: dosig(signum, from) { ! 41: unsigned short *sp; ! 42: #ifdef TRACE ! 43: fprintf(stderr,"Caught sig %d from 0%o -> 0%o\n",signum,(pc-1),*(pc-1)); ! 44: #endif ! 45: /* where is the stack */ ! 46: sp = (unsigned short *)regs[6]; ! 47: /* stack up psw condition codes so rti works */ ! 48: *(--sp) = psl & 017; ! 49: /* stack pc */ ! 50: *(--sp) = (unsigned short)(int)pc; ! 51: /* reset stack pointer */ ! 52: regs[6] = (unsigned short)(int)sp; ! 53: /* reset pc to signal catching routine */ ! 54: pc = (unsigned short *)sigvals[signum]; ! 55: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.