mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-08-12 16:09:25 +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/termiosproc.inc svneol=native#text/plain
|
||||||
rtl/haiku/unxconst.inc svneol=native#text/plain
|
rtl/haiku/unxconst.inc svneol=native#text/plain
|
||||||
rtl/haiku/unxfunc.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/cpu.pp svneol=native#text/plain
|
||||||
rtl/i386/cpuh.inc svneol=native#text/plain
|
rtl/i386/cpuh.inc svneol=native#text/plain
|
||||||
rtl/i386/cpuinnr.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