03b067e1d5
Inspired by the sparc code (mach/sparc/libem/lar.s). My powerpc code might still have bugs, but it's enough for examples/hilo.mod to work. May need to 'make clean' or touch a build.lua file, so ackbuilder can notice the new lar4.s and sar4.s files and build them.
44 lines
752 B
ArmAsm
44 lines
752 B
ArmAsm
#
|
|
#include "powerpc.h"
|
|
|
|
.sect .text
|
|
|
|
! Load from bounds-checked array.
|
|
!
|
|
! On entry:
|
|
! r3 = ptr to descriptor
|
|
! r4 = index
|
|
! r5 = address of array
|
|
|
|
.define .lar4
|
|
.lar4:
|
|
mfspr r10, lr
|
|
bl .aar4
|
|
mtspr lr, r10
|
|
! r3 = ptr to element
|
|
! r0 = size of element
|
|
|
|
cmpi cr0, 0, r0, 1
|
|
bc IFFALSE, EQ, 1f
|
|
! Load 1 byte.
|
|
lbz r4, 0(r3)
|
|
stwu r4, -4(sp)
|
|
bclr ALWAYS, 0, 0
|
|
1:
|
|
cmpi cr0, 0, r0, 2
|
|
bc IFFALSE, EQ, 2f
|
|
! Load 2 bytes.
|
|
lhz r4, 0(r3)
|
|
stwu r4, -4(sp)
|
|
bclr ALWAYS, 0, 0
|
|
2:
|
|
! Load r0 bytes, where r0 must be a positive multiple of 4.
|
|
subf sp, r0, sp ! move stack pointer down
|
|
or r5, r0, r0 ! index r5 = length r0
|
|
3:
|
|
addic. r5, r5, -4 ! r5 -= 4
|
|
lwzx r4, r5, r3
|
|
stwx r4, r5, sp
|
|
bc IFTRUE, GT, 3b ! loop if r5 > 0
|
|
bclr ALWAYS, 0, 0
|