12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- {
- This file is part of the Free Pascal run time library.
- (c) 2000-2003 by Marco van de Voort
- (c) 2011 by Jonas Maebe
- members of the Free Pascal development team.
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- Signalhandler for FreeBSD/i386
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY;without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- }
- procedure SignalToRunerror(Sig: cint; info : PSigInfo; SigContext:PSigContext); public name '_FPC_DEFAULTSIGHANDLER'; cdecl;
- var
- res : word;
- begin
- res:=0;
- case sig of
- SIGFPE :
- begin
- Case Info^.si_code Of
- FPE_FLTDIV : Res:=208; { floating point divide by zero }
- FPE_INTDIV : Res:=200; { floating point divide by zero }
- FPE_FLTOVF : Res:=205; { floating point overflow }
- FPE_FLTUND : Res:=206; { floating point underflow }
- FPE_FLTRES, { floating point inexact result }
- FPE_FLTINV : Res:=207; { invalid floating point operation }
- Else
- Res:=207; {coprocessor error}
- end;
- { FPU exceptions are completely disabled by the kernel if one occurred, it }
- { seems this is necessary to be able to return to user mode. They can be }
- { enabled by executing a sigreturn, however then the exception is triggered }
- { again immediately if we don't turn off the "exception occurred" flags }
- { in fpscr }
- SigContext^.uc_mcontext.fpscr := SigContext^.uc_mcontext.fpscr and not($fffe0700);
- end;
- SIGILL,
- SIGBUS,
- SIGSEGV :
- res:=216;
- SIGINT:
- res:=217;
- SIGQUIT:
- res:=233;
- end;
- {$ifdef FPC_USE_SIGPROCMASK}
- reenable_signal(sig);
- {$endif }
- { return to trampoline }
- if res <> 0 then
- begin
- SigContext^.uc_mcontext.gpr[3] := res;
- SigContext^.uc_mcontext.gpr[4] := SigContext^.uc_mcontext.iar;
- SigContext^.uc_mcontext.gpr[5] := SigContext^.uc_mcontext.gpr[1];
- { the address of a function is a descriptor, and we need the actual
- address here -> dereference }
- pointer(SigContext^.uc_mcontext.iar) := ppointer(@HandleErrorAddrFrame)^;
- { set corresponding TOC for the routine we are returning to }
- pointer(SigContext^.uc_mcontext.gpr[2]) := (ppointer(@HandleErrorAddrFrame)+1)^;
- end;
- end;
|