mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-27 20:53:48 +02:00

unit's initialization code in case we're in a library + implemented InquireSignal(), AbandonSignalHandler(), HookSignal() and UnhookSignal() in the sysutils unit * for Kylix compatibility, these routines support operating on SIGINT and SIGQUIT as well, although they are not hooked by default by FPC. The run time errors/exception codes for these signals are resp. 217 and 233 (same as in Kylix; I changed ENoWideStringSupport to 234). * changed the BSD syscall version of fpsigaction to use pointer rather than "var" arguments (compatible with other targets, and required to be able to pass nil arguments inside the system unit) -> together fixes mantis #12704 git-svn-id: trunk@13077 -
91 lines
2.0 KiB
PHP
91 lines
2.0 KiB
PHP
{
|
|
This file is part of the Free Pascal run time library.
|
|
Copyright (c) 1999-2006 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
|
|
REG_PC = 1;
|
|
REG_nPC = 2;
|
|
REG_O6 = 17;
|
|
REG_SP = REG_O6;
|
|
|
|
const
|
|
FPE_INTDIV = 1;
|
|
FPE_INTOVF = 2;
|
|
FPE_FLTDIV = 3;
|
|
FPE_FLTOVF = 4;
|
|
FPE_FLTUND = 5;
|
|
FPE_FLTRES = 6;
|
|
FPE_FLTINV = 7;
|
|
FPE_FLTSUB = 8;
|
|
|
|
|
|
procedure SignalToRunerror(sig : longint; SigInfo: PSigInfo; SigContext: PSigContext);public name '_FPC_DEFAULTSIGHANDLER';cdecl;
|
|
var
|
|
res : word;
|
|
addr : pointer;
|
|
frame : pointer;
|
|
begin
|
|
res:=0;
|
|
if assigned(sigcontext) then
|
|
begin
|
|
addr := pointer(sigcontext^.uc_mcontext.gregs[REG_PC]);
|
|
frame := pointer(sigcontext^.uc_mcontext.gregs[REG_SP])
|
|
end
|
|
else
|
|
begin
|
|
addr := nil;
|
|
frame := nil;
|
|
end;
|
|
case sig of
|
|
SIGFPE :
|
|
begin
|
|
case siginfo^.si_code of
|
|
FPE_INTDIV:
|
|
res:=200;
|
|
FPE_INTOVF:
|
|
res:=205;
|
|
FPE_FLTDIV:
|
|
res:=200;
|
|
FPE_FLTOVF:
|
|
res:=205;
|
|
FPE_FLTUND:
|
|
res:=206;
|
|
else
|
|
res:=207;
|
|
end;
|
|
end;
|
|
SIGILL,
|
|
SIGSEGV :
|
|
begin
|
|
res:=216;
|
|
end;
|
|
SIGBUS :
|
|
begin
|
|
res:=214;
|
|
end;
|
|
SIGINT:
|
|
res:=217;
|
|
SIGQUIT:
|
|
res:=233;
|
|
end;
|
|
reenable_signal(sig);
|
|
{ give runtime error at the position where the signal was raised }
|
|
if res<>0 then
|
|
HandleErrorAddrFrame(res,addr,frame);
|
|
end;
|
|
|
|
|