mirror of
https://github.com/cc65/cc65.git
synced 2024-12-21 20:29:24 +00:00
removed redundant code; memset == FillRam, bzero == ClearRam with proper return values
git-svn-id: svn://svn.cc65.org/cc65/trunk@2376 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
0ce4187e0e
commit
78908d8421
@ -1116,17 +1116,17 @@ compatible with standard CRC routines.
|
||||
|
||||
<sect2>FillRam and ClearRam
|
||||
<p>
|
||||
<tt/void FillRam (char *dest, char value, unsigned length)/
|
||||
<tt/void *FillRam (char *dest, char value, unsigned length)/
|
||||
<p>
|
||||
<tt/void ClearRam (char *dest, unsigned length)/
|
||||
<tt/void *ClearRam (char *dest, unsigned length)/
|
||||
<p>
|
||||
Both functions are filling given memory range. <tt/ClearRam/ fills with <tt/NULLs/, while
|
||||
Both functions are filling given memory range. <tt/ClearRam/ fills with <tt/0s/, while
|
||||
<tt/FillRam/ uses given <tt/value/. Be warned that these functions destroy <tt/r0, r1 and
|
||||
r2L/ registers. <tt/FillRam/ is an alias for <tt/memset/.
|
||||
r2L/ registers. These are aliases for <tt/memset/ and <tt/bzero/, respectively.
|
||||
|
||||
<sect2>MoveData
|
||||
<p>
|
||||
<tt/void MoveData (char *dest, char *src, unsigned length)/
|
||||
<tt/void *MoveData (char *dest, char *src, unsigned length)/
|
||||
<p>
|
||||
This functions copies one memory region to another. There are checks for overlap and the
|
||||
non-destructive method is chosen. Be warned that this function destroys contents of
|
||||
|
@ -19,10 +19,10 @@ void __fastcall__ CopyFString(char len, char *dest, const char *source);
|
||||
char __fastcall__ CmpFString(char len, char *dest, const char *source);
|
||||
|
||||
unsigned __fastcall__ CRC(const char *buffer, unsigned len);
|
||||
void __fastcall__ ClearRam(char *dest, unsigned len);
|
||||
void __fastcall__ FillRam(char *dest, char what, unsigned len);
|
||||
void* __fastcall__ ClearRam(char *dest, unsigned len);
|
||||
void* __fastcall__ FillRam(char *dest, char what, unsigned len);
|
||||
|
||||
void __fastcall__ MoveData(char *dest, const char *source, unsigned len);
|
||||
void* __fastcall__ MoveData(char *dest, const char *source, unsigned len);
|
||||
|
||||
void __fastcall__ InitRam(char *myInitTab);
|
||||
|
||||
|
@ -3,43 +3,12 @@
|
||||
; void* _bzero (void* ptr, size_t n);
|
||||
; void bzero (void* ptr, size_t n);
|
||||
;
|
||||
; Maciej 'YTM/Elysium' Witkowiak, 15.07.2001
|
||||
; Maciej 'YTM/Elysium' Witkowiak, 20.08.2003
|
||||
;
|
||||
; NOTE: bzero will return it's first argument as memset does. It is no problem
|
||||
; to declare the return value as void, since it may be ignored. _bzero
|
||||
; (note the leading underscore) is declared with the proper return type,
|
||||
; because the compiler will replace memset by _bzero if the fill value
|
||||
; is zero, and the optimizer looks at the return type to see if the value
|
||||
; in a/x is of any use.
|
||||
|
||||
|
||||
.export _memset, _bzero, __bzero
|
||||
.import popa, popax
|
||||
.import _ClearRam, _FillRam
|
||||
|
||||
.include "../inc/jumptab.inc"
|
||||
.include "../inc/geossym.inc"
|
||||
|
||||
_bzero:
|
||||
__bzero:
|
||||
sta r0L
|
||||
stx r0H
|
||||
lda #0
|
||||
sta r2L ; fill with zeros
|
||||
beq common
|
||||
|
||||
_memset:
|
||||
sta r0L
|
||||
stx r0H
|
||||
jsr popax
|
||||
sta r2L
|
||||
common: jsr popax
|
||||
sta r1L
|
||||
pha
|
||||
stx r1H
|
||||
txa
|
||||
pha
|
||||
jsr FillRam
|
||||
pla ; restore ptr and return it
|
||||
tax
|
||||
pla
|
||||
rts
|
||||
_bzero = _ClearRam
|
||||
__bzero = _ClearRam
|
||||
_memset = _FillRam
|
||||
|
@ -1,10 +1,10 @@
|
||||
|
||||
;
|
||||
; Maciej 'YTM/Alliance' Witkowiak
|
||||
; Maciej 'YTM/Elysium' Witkowiak
|
||||
;
|
||||
; 30.10.99
|
||||
; 30.10.99, 20.08.2003
|
||||
|
||||
; void ClearRam (char *dest, int length);
|
||||
; void * ClearRam (char *dest, int length);
|
||||
|
||||
.import DoublePop
|
||||
.export _ClearRam
|
||||
@ -14,4 +14,12 @@
|
||||
|
||||
_ClearRam:
|
||||
jsr DoublePop
|
||||
jmp ClearRam
|
||||
pha
|
||||
txa
|
||||
pha
|
||||
jsr ClearRam
|
||||
pla
|
||||
tax
|
||||
pla
|
||||
rts
|
||||
|
||||
|
@ -4,7 +4,7 @@
|
||||
;
|
||||
; 30.10.99, 15.07.2001
|
||||
|
||||
; void FillRam (char *dest, char what, int length);
|
||||
; void * FillRam (char *dest, char what, int length);
|
||||
|
||||
.import popa, popax
|
||||
.export _FillRam
|
||||
@ -20,4 +20,11 @@ _FillRam:
|
||||
jsr popax
|
||||
sta r1L
|
||||
stx r1H
|
||||
jmp FillRam
|
||||
pha
|
||||
txa
|
||||
pha
|
||||
jsr FillRam
|
||||
pla
|
||||
tax
|
||||
pla
|
||||
rts
|
||||
|
Loading…
Reference in New Issue
Block a user