mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-06-21 07:18:18 +02:00
88 lines
2.4 KiB
PHP
88 lines
2.4 KiB
PHP
{
|
|
$Id$
|
|
This file is part of the Free Pascal run time library.
|
|
|
|
Copyright (c) 2001 by Jonas Maebe,
|
|
member of the Free Pascal development team
|
|
|
|
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.
|
|
|
|
**********************************************************************}
|
|
|
|
{ ---------------------------------------------------------------------
|
|
This include contains cpu-specific routines
|
|
---------------------------------------------------------------------}
|
|
|
|
function InterLockedDecrement (var Target: integer) : Integer; assembler;
|
|
{ input: address of target in r3 }
|
|
{ output: target-1 in r3 }
|
|
{ side-effect: target := target-1 }
|
|
asm
|
|
InterLockedDecLoop:
|
|
lwarx r10,r10,r3
|
|
subi r10,r10,1
|
|
stwcx. r10,r10,r3
|
|
bne InterLockedDecLoop
|
|
mr r3,r10
|
|
end;
|
|
|
|
|
|
function InterLockedIncrement (var Target: integer) : Integer; assembler;
|
|
{ input: address of target in r3 }
|
|
{ output: target+1 in r3 }
|
|
{ side-effect: target := target+1 }
|
|
asm
|
|
InterLockedIncLoop:
|
|
lwarx r10,r10,r3
|
|
addi r10,r10,1
|
|
stwcx. r10,r10,r3
|
|
bne InterLockedIncLoop
|
|
mr r3,r10
|
|
end;
|
|
|
|
|
|
function InterLockedExchange (var Target: integer;Source : integer) : Integer; assembler;
|
|
{ input: address of target in r3, source in r4 }
|
|
{ output: target in r3 }
|
|
{ side-effect: target := source }
|
|
asm
|
|
InterLockedXchgLoop:
|
|
lwarx r10,r10,r3
|
|
stwcx. r4,r10,r3
|
|
bne InterLockedXchgLoop
|
|
mr r3,r10
|
|
end;
|
|
|
|
|
|
function InterLockedExchangeAdd (var Target: integer;Source : integer) : Integer; assembler;
|
|
{ input: address of target in r3, source in r4 }
|
|
{ output: target in r3 }
|
|
{ side-effect: target := target+source }
|
|
asm
|
|
InterLockedXchgAddLoop:
|
|
lwarx r10,r10,r3
|
|
add r10,r10,r4
|
|
stwcx. r10,r10,r3
|
|
bne InterLockedXchgAddLoop
|
|
sub r3,r10,r4
|
|
end;
|
|
|
|
|
|
{
|
|
$Log$
|
|
Revision 1.4 2003-08-24 20:50:11 olle
|
|
* changed used scratchreg from r0 to r10
|
|
|
|
Revision 1.3 2003/04/24 12:13:23 florian
|
|
* fixed assembler errors
|
|
|
|
Revision 1.2 2002/09/07 16:01:26 peter
|
|
* old logs removed and tabs fixed
|
|
|
|
}
|