123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- {
- This file is part of the Free Pascal run time library.
- Copyright (c) 2008 by the Free Pascal development team.
- Processor dependent implementation for the system unit for
- AVR
- 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.
- **********************************************************************}
- {$asmmode gas}
- procedure fpc_cpuinit;{$ifdef SYSTEMINLINE}inline;{$endif}
- begin
- end;
- {$define FPC_SYSTEM_HAS_MOVE}
- procedure Move(const source;var dest;count:SizeInt);[public, alias: 'FPC_MOVE'];
- var
- pdest,psrc,pend : pbyte;
- begin
- if (@dest=@source) or (count<=0) then
- exit;
- if (@dest<@source) or (@source+count<@dest) then
- begin
- { Forward Move }
- psrc:=@source;
- pdest:=@dest;
- pend:=psrc+count;
- while psrc<pend do
- begin
- pdest^:=psrc^;
- inc(pdest);
- inc(psrc);
- end;
- end
- else
- begin
- { Backward Move }
- psrc:=@source+count;
- pdest:=@dest+count;
- while psrc>@source do
- begin
- dec(pdest);
- dec(psrc);
- pdest^:=psrc^;
- end;
- end;
- end;
- {$define FPC_SYSTEM_HAS_FILLCHAR}
- Procedure FillChar(var x;count:SizeInt;value:byte);
- var
- pdest,pend : pbyte;
- v : ptruint;
- begin
- if count <= 0 then
- exit;
- pdest:=@x;
- pend:=pdest+count;
- while pdest<pend do
- begin
- pdest^:=value;
- inc(pdest);
- end;
- end;
- {$IFNDEF INTERNAL_BACKTRACE}
- {$define FPC_SYSTEM_HAS_GET_FRAME}
- function get_frame:pointer;assembler;nostackframe;
- asm
- end;
- {$ENDIF not INTERNAL_BACKTRACE}
- {$define FPC_SYSTEM_HAS_GET_CALLER_ADDR}
- function get_caller_addr(framebp:pointer;addr:pointer=nil):pointer;assembler;
- asm
- end;
- {$define FPC_SYSTEM_HAS_GET_CALLER_FRAME}
- function get_caller_frame(framebp:pointer;addr:pointer=nil):pointer;assembler;
- asm
- end;
- {$define FPC_SYSTEM_HAS_SPTR}
- Function Sptr : pointer;assembler;
- asm
- end;
- function InterLockedDecrement (var Target: longint) : longint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- dec(Target);
- Result:=Target;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedIncrement (var Target: longint) : longint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- inc(Target);
- Result:=Target;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedExchange (var Target: longint;Source : longint) : longint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- Target:=Source;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterlockedCompareExchange(var Target: longint; NewValue: longint; Comperand: longint): longint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- if Target=Comperand then
- Target:=NewValue;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedExchangeAdd (var Target: longint;Source : longint) : longint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- inc(Target,Source);
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedDecrement (var Target: smallint) : smallint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- dec(Target);
- Result:=Target;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedIncrement (var Target: smallint) : smallint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- inc(Target);
- Result:=Target;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedExchange (var Target: smallint;Source : smallint) : smallint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- Target:=Source;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterlockedCompareExchange(var Target: smallint; NewValue: smallint; Comperand: smallint): smallint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- if Target=Comperand then
- Target:=NewValue;
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
- function InterLockedExchangeAdd (var Target: smallint;Source : smallint) : smallint;
- var
- temp_sreg : byte;
- begin
- { block interrupts }
- asm
- in r0,0x3f
- std temp_sreg,r0
- cli
- end;
- Result:=Target;
- inc(Target,Source);
- { release interrupts }
- asm
- ldd r0,temp_sreg
- out 0x3f,r0
- end;
- end;
|