NAME=rcall
FILE==
CMDS=<<EOF
e asm.arch=arm
e asm.bits=64
wx e18f1394 # BL XXX
sd +4
wx 00013fd6 # BLR x8
ao~type[1]
ao@ 0~type[1]
/at call
echo --
/at ucall
echo --
/at rcall
EOF
EXPECT=<<EOF
rcall
call
0x00000000 4 bl 0x4e3f84
--
--
0x00000004 4 blr x8
EOF
RUN

NAME=syscall
FILE==
CMDS=<<EOF
e asm.arch=arm
e asm.bits=64
e asm.os=linux
asn fstat
asr 80
EOF
EXPECT=<<EOF
80
fstat
EOF
RUN

NAME=noreturn errno
FILE=bins/mach0/BatteryLife.arm_64.1
CMDS=<<EOF
e emu.str=1
s 0x100011130
pd 2~addChild
EOF
EXPECT=<<EOF
EOF
RUN

NAME=adrp string
FILE=bins/mach0/SwiftUITest
CMDS=<<EOF
e emu.str=1
s. 886c
pds 10
EOF
EXPECT=<<EOF
0x100008870 str.Hello_World
EOF
RUN

NAME=symbol with invalid offset
FILE=bins/elf/libarm64.so
CMDS=<<EOF
ii
iE
EOF
EXPECT=<<EOF
nth vaddr      bind   type   lib name             
--------------------------------------------------
3   0x00020060 GLOBAL NOTYPE     _bss_end__
4   0x000006b0 GLOBAL FUNC       realloc
5   0x000006c0 GLOBAL FUNC       __cxa_finalize
7   0x000006d0 GLOBAL FUNC       __stack_chk_fail
8   0x00020058 GLOBAL NOTYPE     __bss_start
9   0x00020060 GLOBAL NOTYPE     __end__
10  0x00020058 GLOBAL NOTYPE     __bss_start__
11  0x00020058 GLOBAL NOTYPE     _edata
12  0x000006e0 GLOBAL FUNC       malloc
13  0x000006f0 GLOBAL FUNC       memcpy
14  0x00020060 GLOBAL NOTYPE     __bss_end__
15  0x00000700 GLOBAL FUNC       memset
16  0x00020060 GLOBAL NOTYPE     _end
17  0x00000710 GLOBAL FUNC       free
18  0x00000720 GLOBAL FUNC       __cxa_atexit
nth paddr      vaddr      bind   type size lib name            
---------------------------------------------------------------
6   0x0000aa20 0x0000aa20 GLOBAL FUNC 1176     Java_o__003dc_e
EOF
RUN

NAME=ao mte irg addg
FILE=bins/mach0/hello-mte
CMDS=<<EOF
ao@ 0x100007f10
echo --
ao@ 0x100007f14
EOF
EXPECT=<<EOF
address: 0x100007f10
opcode: irg x8, sp, x8
esilcost: 0
disasm: irg x8, sp, x8
pseudo: asm("irg x8, sp, x8")
mnemonic: irg
mask: ffffffff
prefix: 0
id: 0
bytes: e813c89a
refptr: 0
size: 4
sign: false
type: mov
cycles: 0
family: sec
--
address: 0x100007f14
opcode: addg x9, x8, 0x20, 0
esilcost: 0
disasm: addg x9, x8, 0x20, 0
pseudo: asm("addg x9, x8, 0x20, 0")
mnemonic: addg
mask: ffffffff
prefix: 0
id: 0
bytes: 09018291
refptr: 0
size: 4
sign: false
type: add
cycles: 0
family: sec
EOF
RUN

NAME=ao mte big endian
FILE==
ARGS=-a arm -b 64 -e cfg.bigendian=true
CMDS=<<EOF
wx 91a0090c918201099ac813e8
ao@ 0
echo ---
ao@ 4
echo ---
ao@ 8
EOF
EXPECT=<<EOF
address: 0x0
opcode: addg x12, x8, 0x200, 2
esilcost: 0
disasm: addg x12, x8, 0x200, 2
pseudo: asm("addg x12, x8, 0x200, 2")
mnemonic: addg
mask: ffffffff
prefix: 0
id: 0
bytes: 91a0090c
refptr: 0
size: 4
sign: false
type: add
cycles: 0
family: sec
---
address: 0x4
opcode: addg x9, x8, 0x20, 0
esilcost: 0
disasm: addg x9, x8, 0x20, 0
pseudo: asm("addg x9, x8, 0x20, 0")
mnemonic: addg
mask: ffffffff
prefix: 0
id: 0
bytes: 91820109
refptr: 0
size: 4
sign: false
type: add
cycles: 0
family: sec
---
address: 0x8
opcode: irg x8, sp, x8
esilcost: 0
disasm: irg x8, sp, x8
pseudo: asm("irg x8, sp, x8")
mnemonic: irg
mask: ffffffff
prefix: 0
id: 0
bytes: 9ac813e8
refptr: 0
size: 4
sign: false
type: mov
cycles: 0
family: sec
EOF
RUN

NAME=Variable analysis with stp/preindexed str
FILE=malloc://1024
ARGS=-a arm -b 64
CMDS=<<EOF
wx 00000000000000000000000000000000f30f1ef8fd7b01a9fd430091fd7b41a9e00313aaf30742f8c0035fd6
aap
s 0x10
aaef
afvx
e asm.comments=0
e asm.bytes=0
e asm.stackptr=1
pdf
EOF
EXPECT=<<EOF
afvR
   var_10h  0x18,0x1c
   var_20h
    var_8h  0x1c
afvW
   var_10h  0x14
   var_20h  0x10
    var_8h  0x14
/ fcn.00000010();
|           ; var int64_t var_20h @ stack - 0x20
|           ; var int64_t var_10h @ stack - 0x10
|           ; var int64_t var_8h @ stack - 0x8
|           0x00000010     0 -= 32      str   x19, [var_20h]!
|           0x00000014   -32            stp   fp, lr, [var_10h]
|           0x00000018   -32            add   fp, sp, 0x10
|           0x0000001c   -32            ldp   fp, lr, [var_10h]
|           0x00000020   -32            mov   x0, x19
|           0x00000024   -32 += 32      ldr   x19, [sp], 0x20
\           0x00000028     0            ret
EOF
RUN

NAME=pacibsp considered a valid function preamble
FILE=malloc://1024
ARGS=-a arm -b 64
CMDS=<<EOF
wx 7f2303d5fc6fbaa9fa6701a9f85f02a9
af
pd 4
EOF
EXPECT=<<EOF
/ fcn.00000000();
|           0x00000000      pacibsp
|           0x00000004      stp   x28, x27, [sp, -0x60]!
|           0x00000008      stp   x26, x25, [sp, 0x10]
|           0x0000000c      stp   x24, x23, [sp, 0x20]
EOF
RUN

NAME=pacibsp identified as function prologue
FILE=malloc://1024
ARGS=-a arm -b 64
CMDS=<<EOF
wx 7f2303d5fc6fbaa9fa6701a9f85f02a9ff0f5fd6
aap
pd 5
EOF
EXPECT=<<EOF
/ fcn.00000000();
|           0x00000000      pacibsp
|           0x00000004      stp   x28, x27, [sp, -0x60]!
|           0x00000008      stp   x26, x25, [sp, 0x10]
|           0x0000000c      stp   x24, x23, [sp, 0x20]
\           0x00000010      retab
EOF
RUN
