|
@@ -44,6 +44,12 @@ Function Sptr : pointer;assembler;
|
|
end;
|
|
end;
|
|
|
|
|
|
|
|
|
|
|
|
+{$ifndef VER3_2}
|
|
|
|
+{$define FPC_SYSTEM_INTERLOCKED_USE_INTRIN}
|
|
|
|
+{$endif VER3_2}
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+{$ifdef VER3_2}
|
|
function InterLockedDecrement (var Target: longint) : longint;
|
|
function InterLockedDecrement (var Target: longint) : longint;
|
|
begin
|
|
begin
|
|
dec(Target);
|
|
dec(Target);
|
|
@@ -65,20 +71,27 @@ function InterLockedExchange (var Target: longint;Source : longint) : longint;
|
|
end;
|
|
end;
|
|
|
|
|
|
|
|
|
|
-function InterlockedCompareExchange(var Target: longint; NewValue: longint; Comperand: longint): longint;
|
|
|
|
|
|
+function InterLockedExchangeAdd (var Target: longint;Source : longint) : longint;
|
|
begin
|
|
begin
|
|
Result:=Target;
|
|
Result:=Target;
|
|
- if Target=Comperand then
|
|
|
|
- Target:=NewValue;
|
|
|
|
|
|
+ inc(Target,Source);
|
|
end;
|
|
end;
|
|
|
|
+{$endif}
|
|
|
|
|
|
|
|
|
|
-function InterLockedExchangeAdd (var Target: longint;Source : longint) : longint;
|
|
|
|
|
|
+{$ifdef VER3_2}
|
|
|
|
+function InterlockedCompareExchange(var Target: longint; NewValue: longint; Comperand: longint): longint;
|
|
|
|
+{$else VER3_2}
|
|
|
|
+{$define FPC_SYSTEM_HAS_ATOMIC_CMP_XCHG_32}
|
|
|
|
+function fpc_atomic_cmp_xchg_32 (var Target: longint; NewValue: longint; Comparand: longint) : longint; [public,alias:'FPC_ATOMIC_CMP_XCHG_32'];
|
|
|
|
+{$endif VER3_2}
|
|
begin
|
|
begin
|
|
Result:=Target;
|
|
Result:=Target;
|
|
- inc(Target,Source);
|
|
|
|
|
|
+ if Target={$ifdef VER3_2}Comperand{$else}Comparand{$endif} then
|
|
|
|
+ Target:=NewValue;
|
|
end;
|
|
end;
|
|
|
|
|
|
|
|
+
|
|
{$define FPC_SYSTEM_HAS_SYSRESETFPU}
|
|
{$define FPC_SYSTEM_HAS_SYSRESETFPU}
|
|
procedure SysResetFPU;{$ifdef SYSTEMINLINE}inline;{$endif}
|
|
procedure SysResetFPU;{$ifdef SYSTEMINLINE}inline;{$endif}
|
|
{$ifdef FPUFD}
|
|
{$ifdef FPUFD}
|