mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-15 11:00:15 +02:00
haiku: add sighnd.inc for x86_64, the i386 version with minimal changes, probably needs to be better adapted for 64bit
git-svn-id: trunk@40793 -
This commit is contained in:
parent
1a26c381f9
commit
d6891557d3
1
.gitattributes
vendored
1
.gitattributes
vendored
@ -9434,6 +9434,7 @@ rtl/haiku/termios.inc svneol=native#text/plain
|
||||
rtl/haiku/termiosproc.inc svneol=native#text/plain
|
||||
rtl/haiku/unxconst.inc svneol=native#text/plain
|
||||
rtl/haiku/unxfunc.inc svneol=native#text/plain
|
||||
rtl/haiku/x86_64/sighnd.inc svneol=native#text/plain
|
||||
rtl/i386/cpu.pp svneol=native#text/plain
|
||||
rtl/i386/cpuh.inc svneol=native#text/plain
|
||||
rtl/i386/cpuinnr.inc svneol=native#text/plain
|
||||
|
94
rtl/haiku/x86_64/sighnd.inc
Normal file
94
rtl/haiku/x86_64/sighnd.inc
Normal file
@ -0,0 +1,94 @@
|
||||
{
|
||||
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.
|
||||
|
||||
**********************************************************************}
|
||||
|
||||
|
||||
procedure SignalToRunerror(sig : longint; SigContext: PSigInfo; uContext: PSigContext);public name '_FPC_DEFAULTSIGHANDLER';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;
|
||||
// fp_status always here under BeOS and x86 CPU
|
||||
// (fp_status is not behind a pointer in the BeOS context record)
|
||||
FpuState:=ucontext^.xregs.state.old_format.fp_status;
|
||||
|
||||
if (FpuState and FPU_ExceptionMask) <> 0 then
|
||||
begin
|
||||
{ first check the more precise options }
|
||||
if (FpuState and FPU_DivisionByZero)<>0 then
|
||||
res:=200
|
||||
else if (FpuState and (FPU_StackOverflow or FPU_StackUnderflow or FPU_Invalid))<>0 Then
|
||||
res:=207
|
||||
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
|
||||
res:=207; {'Coprocessor Error'}
|
||||
end;
|
||||
with ucontext^.xregs.state.old_format do
|
||||
begin
|
||||
fp_status := fp_status and not FPU_ExceptionMask;
|
||||
end;
|
||||
SysResetFPU;
|
||||
end;
|
||||
SIGBUS:
|
||||
begin
|
||||
res:=214;
|
||||
end;
|
||||
SIGILL:
|
||||
begin
|
||||
// FIXME
|
||||
{ if sse_check then
|
||||
begin
|
||||
os_supports_sse := false;
|
||||
res := 0;
|
||||
inc(ucontext^.eip, 3);
|
||||
end
|
||||
else}
|
||||
res:=216;
|
||||
end;
|
||||
SIGSEGV :
|
||||
begin
|
||||
res:=216;
|
||||
end;
|
||||
SIGINT:
|
||||
begin
|
||||
res:=217;
|
||||
end;
|
||||
SIGQUIT:
|
||||
begin
|
||||
res:=233;
|
||||
end;
|
||||
end;
|
||||
reenable_signal(sig);
|
||||
{ give runtime error at the position where the signal was raised }
|
||||
if res<>0 then
|
||||
begin
|
||||
HandleErrorAddrFrame(res, pointer(ucontext^.eip),
|
||||
pointer(ucontext^.ebp));
|
||||
end;
|
||||
end;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user