mirror of
https://github.com/cc65/cc65.git
synced 2024-11-18 15:05:14 +00:00
New used block structure for the heap
git-svn-id: svn://svn.cc65.org/cc65/trunk@3347 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
802f259b37
commit
842ff39d4c
@ -6,7 +6,7 @@
|
|||||||
; Return the size of an allocated block.
|
; Return the size of an allocated block.
|
||||||
;
|
;
|
||||||
|
|
||||||
.importzp ptr1
|
.importzp ptr1, ptr2
|
||||||
.export __heapblocksize
|
.export __heapblocksize
|
||||||
|
|
||||||
.include "_heap.inc"
|
.include "_heap.inc"
|
||||||
@ -19,33 +19,57 @@
|
|||||||
|
|
||||||
__heapblocksize:
|
__heapblocksize:
|
||||||
|
|
||||||
; Decrement the block pointer so it points to the admin data
|
; Below the user data is a pointer that points to the start of the real
|
||||||
|
; (raw) memory block. The first word of this block is the size. To access
|
||||||
|
; the raw block pointer, we will decrement the high byte of the pointer,
|
||||||
|
; the pointer is then at offset 254/255.
|
||||||
|
|
||||||
sub #HEAP_ADMIN_SPACE ; Assume it's less than 256
|
sta ptr1
|
||||||
bcs L1
|
|
||||||
dex
|
dex
|
||||||
L1: sta ptr1
|
|
||||||
stx ptr1+1
|
stx ptr1+1
|
||||||
|
ldy #$FE
|
||||||
; Load the size from the given block
|
|
||||||
|
|
||||||
ldy #1
|
|
||||||
lda (ptr1),y
|
lda (ptr1),y
|
||||||
|
sta ptr2 ; Place the raw block pointer into ptr2
|
||||||
|
iny
|
||||||
|
lda (ptr1),y
|
||||||
|
sta ptr2+2
|
||||||
|
|
||||||
|
; Load the size from the raw block
|
||||||
|
|
||||||
|
ldy #usedblock::size+1
|
||||||
|
lda (ptr2),y
|
||||||
tax
|
tax
|
||||||
.if (.cpu .bitand CPU_ISET_65SC02)
|
.if (.cpu .bitand CPU_ISET_65SC02)
|
||||||
lda (ptr1)
|
lda (ptr2)
|
||||||
.else
|
.else
|
||||||
dey
|
dey
|
||||||
lda (ptr1),y
|
lda (ptr2),y
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
; Adjust it to the user visible size
|
; Correct the raw block size so that is shows the user visible portion. To
|
||||||
|
; do that, we must decrease the size by the amount of unused memory, which is
|
||||||
|
; the difference between the user space pointer and the raw memory block
|
||||||
|
; pointer. Since we have decremented the user space pointer by 256, we will
|
||||||
|
; have to correct the result.
|
||||||
|
;
|
||||||
|
; return size - (ptr1 + 256 - ptr2)
|
||||||
|
; return size - ptr1 - 256 + ptr2
|
||||||
|
|
||||||
sub #HEAP_ADMIN_SPACE
|
dex ; - 256
|
||||||
bcs L9
|
add ptr2
|
||||||
dex
|
pha
|
||||||
|
txa
|
||||||
|
adc ptr2+1
|
||||||
|
tax
|
||||||
|
pla
|
||||||
|
sub ptr1
|
||||||
|
pha
|
||||||
|
txa
|
||||||
|
sbc ptr1+1
|
||||||
|
tax
|
||||||
|
pla
|
||||||
|
|
||||||
; Done
|
; Done
|
||||||
|
|
||||||
L9: rts
|
rts
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user