12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- {
- $Id$
- This file is part of the Free Pascal run time library.
- Copyright (c) 1999-2000 by Michael Van Canneyt,
- member of the Free Pascal development team.
- Signal handler is arch dependant due to processor to language
- exception conversion.
- See the file COPYING.FPC, included in this distribution,
- for details about the copyright.
- 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.
- **********************************************************************}
- const
- FPU_All = $7f;
- function GetFPUState(const SigContext : TSigContext) : longint;
- begin
- if assigned(SigContext.fpstate) then
- GetfpuState:=SigContext.fpstate^.sw;
- {$ifdef SYSTEM_DEBUG}
- writeln('xx:',sigcontext.en_tw,' ',sigcontext.en_cw);
- {$endif SYSTEM_DEBUG}
- {$ifdef SYSTEM_DEBUG}
- Writeln(stderr,'FpuState = ',GetFpuState);
- {$endif SYSTEM_DEBUG}
- end;
- procedure SignalToRunerror(sig : longint; SigInfo: PSigInfo; SigContext: PSigContext);cdecl;
- var
- res,fpustate : word;
- begin
- res:=0;
- case sig of
- SIGFPE :
- begin
- { this is not allways necessary but I don't know yet
- how to tell if it is or not PM }
- res:=200;
- fpustate:=GetFPUState(SigContext^);
- if (FpuState and FPU_All) <> 0 then
- begin
- { first check the more precise options }
- if (FpuState and FPU_DivisionByZero)<>0 then
- res:=200
- else if (FpuState and FPU_Overflow)<>0 then
- res:=205
- else if (FpuState and FPU_Underflow)<>0 then
- res:=206
- else if (FpuState and FPU_Denormal)<>0 then
- res:=216
- else if (FpuState and (FPU_StackOverflow or FPU_StackUnderflow or FPU_Invalid))<>0 Then
- res:=207
- else
- res:=207; {'Coprocessor Error'}
- end;
- sysResetFPU;
- end;
- SIGILL,
- SIGBUS,
- SIGSEGV :
- res:=216;
- end;
- { give runtime error at the position where the signal was raised }
- if res<>0 then
- HandleErrorAddrFrame(res,pointer(SigContext^.eip),pointer(SigContext^.ebp));
- end;
- {
- $Log$
- Revision 1.5 2005-01-30 18:01:15 peter
- * signal cleanup for linux
- * sigactionhandler instead of tsigaction for bsds
- * sigcontext moved to cpu dir
- Revision 1.4 2004/08/08 09:36:09 florian
- * fixed runerror for invalid operation
- Revision 1.3 2004/02/05 01:16:12 florian
- + completed x86-64/linux system unit
- Revision 1.2 2003/11/01 01:58:11 marco
- * more small fixes.
- Revision 1.1 2003/11/01 01:27:20 marco
- * initial version from 1.0.x branch
- }
|