mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-04-05 15:47:54 +02:00
* fix VFPv4 support
git-svn-id: trunk@33182 -
This commit is contained in:
parent
43746685a5
commit
1c067e96bf
@ -290,7 +290,7 @@ unit cgcpu;
|
||||
non-overlapping subregs per register, so we can only use
|
||||
half the single precision registers for now (as sub registers of the
|
||||
double precision ones). }
|
||||
if current_settings.fputype=fpu_vfpv3 then
|
||||
if current_settings.fputype in [fpu_vfpv3,fpu_vfpv4] then
|
||||
rg[R_MMREGISTER]:=trgcpu.create(R_MMREGISTER,R_SUBFD,
|
||||
[RS_D0,RS_D1,RS_D2,RS_D3,RS_D4,RS_D5,RS_D6,RS_D7,
|
||||
RS_D16,RS_D17,RS_D18,RS_D19,RS_D20,RS_D21,RS_D22,RS_D23,RS_D24,RS_D25,RS_D26,RS_D27,RS_D28,RS_D29,RS_D30,RS_D31,
|
||||
@ -1922,6 +1922,7 @@ unit cgcpu;
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin;
|
||||
mmregs:=rg[R_MMREGISTER].used_in_proc-paramanager.get_volatile_registers_mm(pocall_stdcall);
|
||||
@ -2068,7 +2069,7 @@ unit cgcpu;
|
||||
begin
|
||||
reference_reset(ref,4);
|
||||
if (tg.direction*tarmprocinfo(current_procinfo).floatregstart>=1023) or
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16]) then
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16]) then
|
||||
begin
|
||||
if not is_shifter_const(tarmprocinfo(current_procinfo).floatregstart,shift) then
|
||||
begin
|
||||
@ -2097,6 +2098,7 @@ unit cgcpu;
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
ref.index:=ref.base;
|
||||
@ -2157,6 +2159,7 @@ unit cgcpu;
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin;
|
||||
{ restore vfp registers? }
|
||||
@ -2169,7 +2172,7 @@ unit cgcpu;
|
||||
begin
|
||||
reference_reset(ref,4);
|
||||
if (tg.direction*tarmprocinfo(current_procinfo).floatregstart>=1023) or
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16]) then
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16]) then
|
||||
begin
|
||||
if not is_shifter_const(tarmprocinfo(current_procinfo).floatregstart,shift) then
|
||||
begin
|
||||
@ -2197,6 +2200,7 @@ unit cgcpu;
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
ref.index:=ref.base;
|
||||
@ -4219,7 +4223,7 @@ unit cgcpu;
|
||||
rg[R_FPUREGISTER]:=trgcpu.create(R_FPUREGISTER,R_SUBNONE,
|
||||
[RS_F0,RS_F1,RS_F2,RS_F3,RS_F4,RS_F5,RS_F6,RS_F7],first_fpu_imreg,[]);
|
||||
|
||||
if current_settings.fputype=fpu_vfpv3 then
|
||||
if current_settings.fputype in [fpu_vfpv3,fpu_vfpv4] then
|
||||
rg[R_MMREGISTER]:=trgcpu.create(R_MMREGISTER,R_SUBFD,
|
||||
[RS_D0,RS_D1,RS_D2,RS_D3,RS_D4,RS_D5,RS_D6,RS_D7,
|
||||
RS_D16,RS_D17,RS_D18,RS_D19,RS_D20,RS_D21,RS_D22,RS_D23,RS_D24,RS_D25,RS_D26,RS_D27,RS_D28,RS_D29,RS_D30,RS_D31,
|
||||
|
@ -965,7 +965,7 @@ Const
|
||||
(controllertypestr:'THUMB2_BARE'; controllerunitstr:'THUMB2_BARE'; cputype:cpu_armv7m; fputype:fpu_soft; flashbase:$00000000; flashsize:$00002000; srambase:$20000000; sramsize:$00000400)
|
||||
);
|
||||
|
||||
vfp_scalar = [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16,fpu_fpv4_s16];
|
||||
vfp_scalar = [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16,fpu_fpv4_s16];
|
||||
|
||||
{ Supported optimizations, only used for information }
|
||||
supported_optimizerswitches = genericlevel1optimizerswitches+
|
||||
|
@ -134,7 +134,7 @@ unit cpupara;
|
||||
getparaloc:=LOC_MMREGISTER
|
||||
else if (calloption in [pocall_cdecl,pocall_cppdecl,pocall_softfloat]) or
|
||||
(cs_fp_emulation in current_settings.moduleswitches) or
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16,fpu_fpv4_s16]) then
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16,fpu_fpv4_s16]) then
|
||||
{ the ARM eabi also allows passing VFP values via VFP registers,
|
||||
but Mac OS X doesn't seem to do that and linux only does it if
|
||||
built with the "-mfloat-abi=hard" option }
|
||||
@ -648,7 +648,7 @@ unit cpupara;
|
||||
end
|
||||
else if (p.proccalloption in [pocall_softfloat]) or
|
||||
(cs_fp_emulation in current_settings.moduleswitches) or
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16,fpu_fpv4_s16]) then
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16,fpu_fpv4_s16]) then
|
||||
begin
|
||||
case retcgsize of
|
||||
OS_64,
|
||||
|
@ -174,6 +174,7 @@ unit cpupi;
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
floatsavesize:=0;
|
||||
|
@ -200,6 +200,7 @@ interface
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
{ force mmreg as location, left right doesn't matter
|
||||
@ -299,6 +300,7 @@ interface
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
hlcg.location_force_mmregscalar(current_asmdata.CurrAsmList,left.location,left.resultdef,true);
|
||||
|
@ -47,7 +47,7 @@ implementation
|
||||
if (realresdef.typ=floatdef) and
|
||||
(target_info.abi <> abi_eabihf) and
|
||||
((cs_fp_emulation in current_settings.moduleswitches) or
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16,fpu_fpv4_s16])) then
|
||||
(current_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv4,fpu_vfpv3_d16,fpu_fpv4_s16])) then
|
||||
begin
|
||||
{ keep the fpu values in integer registers for now, the code
|
||||
generator will move them to memory or an mmregister when necessary
|
||||
|
@ -116,6 +116,7 @@ implementation
|
||||
expectloc:=LOC_FPUREGISTER;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16,
|
||||
fpu_fpv4_s16:
|
||||
expectloc:=LOC_MMREGISTER;
|
||||
@ -242,6 +243,7 @@ implementation
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
location_reset(location,LOC_MMREGISTER,def_cgsize(resultdef));
|
||||
|
@ -88,6 +88,7 @@ implementation
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16,
|
||||
fpu_fpv4_s16:
|
||||
begin
|
||||
@ -128,6 +129,7 @@ implementation
|
||||
expectloc:=LOC_FPUREGISTER;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
expectloc:=LOC_MMREGISTER;
|
||||
fpu_fpv4_s16:
|
||||
@ -158,6 +160,7 @@ implementation
|
||||
expectloc:=LOC_FPUREGISTER;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
expectloc:=LOC_MMREGISTER;
|
||||
fpu_fpv4_s16:
|
||||
@ -188,6 +191,7 @@ implementation
|
||||
expectloc:=LOC_FPUREGISTER;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
expectloc:=LOC_MMREGISTER;
|
||||
fpu_fpv4_s16:
|
||||
@ -260,6 +264,7 @@ implementation
|
||||
current_asmdata.CurrAsmList.concat(setoppostfix(taicpu.op_reg_reg(A_ABS,location.register,left.location.register),get_fpu_postfix(resultdef)));
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
if singleprec then
|
||||
@ -296,6 +301,7 @@ implementation
|
||||
current_asmdata.CurrAsmList.concat(setoppostfix(taicpu.op_reg_reg_reg(A_MUF,location.register,left.location.register,left.location.register),get_fpu_postfix(resultdef)));
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
if singleprec then
|
||||
@ -325,6 +331,7 @@ implementation
|
||||
current_asmdata.CurrAsmList.concat(setoppostfix(taicpu.op_reg_reg(A_SQT,location.register,left.location.register),get_fpu_postfix(resultdef)));
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
if singleprec then
|
||||
|
@ -409,6 +409,7 @@ implementation
|
||||
end;
|
||||
fpu_vfpv2,
|
||||
fpu_vfpv3,
|
||||
fpu_vfpv4,
|
||||
fpu_vfpv3_d16:
|
||||
begin
|
||||
hlcg.location_force_mmregscalar(current_asmdata.CurrAsmList,left.location,left.resultdef,true);
|
||||
|
@ -3757,7 +3757,7 @@ begin
|
||||
end
|
||||
else
|
||||
begin
|
||||
if not (init_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16]) then
|
||||
if not (init_settings.fputype in [fpu_vfpv2,fpu_vfpv3,fpu_vfpv3_d16,fpu_vfpv4]) then
|
||||
begin
|
||||
Message(option_illegal_fpu_eabihf);
|
||||
StopOptions(1);
|
||||
|
@ -28,7 +28,7 @@ const
|
||||
{$if not(defined(wince)) and not(defined(gba)) and not(defined(nds)) and not(defined(FPUSOFT)) and not(defined(FPULIBGCC))}
|
||||
|
||||
{$define FPC_SYSTEM_HAS_SYSINITFPU}
|
||||
{$if not defined(darwin) and not defined(FPUVFPV2) and not defined(FPUVFPV3) and not defined(FPUVFPV3_D16)}
|
||||
{$if not defined(darwin) and not defined(FPUVFPV2) and not defined(FPUVFPV3) and not defined(FPUVFPV4) and not defined(FPUVFPV3_D16)}
|
||||
Procedure SysInitFPU;{$ifdef SYSTEMINLINE}inline;{$endif}
|
||||
begin
|
||||
{ Enable FPU exceptions, but disable INEXACT, UNDERFLOW, DENORMAL }
|
||||
|
@ -14,7 +14,7 @@
|
||||
|
||||
**********************************************************************}
|
||||
|
||||
{$if defined(FPUFPA) or defined(FPUFPA10) or defined(FPUFPA11) or defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(FPUFPA) or defined(FPUFPA10) or defined(FPUFPA11) or defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_D16)}
|
||||
{$ifndef FPC_SYSTEM_HAS_ABS}
|
||||
{$define FPC_SYSTEM_HAS_ABS}
|
||||
function fpc_abs_real(d : ValReal) : ValReal;compilerproc;
|
||||
|
@ -132,7 +132,7 @@ procedure ClearExceptions(RaisePending: Boolean =true);
|
||||
begin
|
||||
end;
|
||||
|
||||
{$elseif defined(darwin) or defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_d16) or defined(FPUFPV4_s16)}
|
||||
{$elseif defined(darwin) or defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_d16) or defined(FPUFPV4_s16)}
|
||||
|
||||
const
|
||||
_VFP_ENABLE_IM = 1 shl 8; { invalid operation }
|
||||
|
@ -16,7 +16,7 @@
|
||||
|
||||
function fpc_setjmp(var S : jmp_buf) : longint;assembler;[Public, alias : 'FPC_SETJMP'];nostackframe; compilerproc;
|
||||
asm
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(CPUARMV3) or defined(CPUARMV4) or defined(CPUARMV5)}
|
||||
fstmiax r0!, {d8-d15}
|
||||
// according to the ARM Developer Suite Assembler Guide Version 1.2
|
||||
@ -69,7 +69,7 @@ procedure fpc_longjmp(var S : jmp_buf;value : longint);assembler;[Public, alias
|
||||
movs r0, r1
|
||||
it eq
|
||||
moveq r0, #1
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_D16)}
|
||||
fldmiad ip!, {d8-d15}
|
||||
{$endif}
|
||||
ldmia ip!, {v1-v6, sl, fp}
|
||||
@ -101,7 +101,7 @@ procedure fpc_longjmp(var S : jmp_buf;value : longint);assembler;[Public, alias
|
||||
mov ip, r0
|
||||
movs r0, r1
|
||||
moveq r0, #1
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(CPUARMV3) or defined(CPUARMV4) or defined(CPUARMV5)}
|
||||
fldmiax ip!, {d8-d15}
|
||||
// according to the ARM Developer Suite Assembler Guide Version 1.2
|
||||
|
@ -16,7 +16,7 @@
|
||||
|
||||
type
|
||||
jmp_buf = packed record
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV3_D16)}
|
||||
{$if defined(FPUVFPV2) or defined(FPUVFPV3) or defined(FPUVFPV4) or defined(FPUVFPV3_D16)}
|
||||
d8,d9,d10,d11,d12,d13,d14,d15: double;
|
||||
{$endif}
|
||||
v1,v2,v3,v4,v5,v6,sl,fp,sp,pc : dword;
|
||||
|
Loading…
Reference in New Issue
Block a user