mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-05-02 02:13:42 +02:00
82 lines
2.2 KiB
PHP
82 lines
2.2 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 r0,0(r3)
|
|
subi r0,r0,1
|
|
stwcx. r0,0(r3)
|
|
bne InterLockedDecLoop
|
|
mr r3,r0
|
|
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 r0,0(r3)
|
|
addi r0,r0,1
|
|
stwcx. r0,0(r3)
|
|
bne InterLockedIncLoop
|
|
mr r3,r0
|
|
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 r0,0(r3)
|
|
stwcx. r4,0(r3)
|
|
bne InterLockedXchgLoop
|
|
mr r3,r0
|
|
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
|
|
InterLockedXchgLoop:
|
|
lwarx r0,0(r3)
|
|
add r0,r0,r4
|
|
stwcx. r0,0(r3)
|
|
bne InterLockedXchgLoop
|
|
sub r3,r0,r4
|
|
end;
|
|
|
|
|
|
{
|
|
$Log$
|
|
Revision 1.2 2002-09-07 16:01:26 peter
|
|
* old logs removed and tabs fixed
|
|
|
|
}
|