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:
Károly Balogh 2019-01-07 13:47:46 +00:00
parent 1a26c381f9
commit d6891557d3
2 changed files with 95 additions and 0 deletions
.gitattributes
rtl/haiku/x86_64

1
.gitattributes vendored
View File

@ -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

View 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;