123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- {
- $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
- }
|