File:  [Research Unix] / researchv10no / cmd / sml / src / runtime / M68.dep.c
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs
Tue Apr 24 17:21:34 2018 UTC (8 years, 1 month ago) by root
Branches: belllabs, MAIN
CVS tags: researchv10, HEAD
researchv10 Norman

/* Copyright 1989 by AT&T Bell Laboratories */
/* M68.dep.c
 *
 *    M68 dependent code for the SML/NJ runtime kernel.
 */

#include <signal.h>
#include "tags.h"

#if defined(NeXT) && (! defined(FPE_TRAPV_TRAP))
/* This is required because NeXT 1.0 nuked this definition */
#define     FPE_TRAPV_TRAP      0x1c    /* TRAPV [cpTRAPcc TRAPcc] instr */
#endif

extern int cause, fault_code;
extern int saved_pc;
extern int saveregs[];


/* ghandle:
 */
ghandle (sig, code, scp, addr)
    int			sig, code, addr;
    struct sigcontext	*scp;
{
    saved_pc = scp->sc_pc;
    scp->sc_pc = (int)saveregs; 

/* Note: versions of sony_news before Sept 1989 had pc pointer BEFORE
   trap instruction, not after. */
    if (sig==SIGFPE && code==FPE_TRAPV_TRAP && ((short*)saved_pc)[-1] == 23548)
    {   saved_pc-=4;
	cause=CAUSE_GC;
    }
    else {
	fault_code=exnCode(sig,code);
	cause=CAUSE_FAULT;
    }
}


extern int handleprof();

void setupsignals()
{
  struct sigvec a;
  extern fpenable();

  a.sv_handler	= (void (*)()) ghandle;
  a.sv_onstack	= 0;
  a.sv_mask	= 0;
  sigvec(SIGINT,&a,0);
  sigvec(SIGFPE,&a,0);
  sigvec(SIGEMT,&a,0);  /* in case 68881 is not present */
  a.sv_handler = SIG_IGN;
  sigvec(SIGPIPE,&a,0);
  a.sv_handler = (void (*)()) handleprof;
  sigvec(SIGVTALRM,&a,0);
  fpenable();
}

unix.superglobalmegacorp.com

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