NAME=noreturn errno
FILE=malloc://32
EXPECT=<<EOF
size: 32
EOF
CMDS=<<EOF
s main
af
afi~^size
EOF
RUN

NAME=thumb ldr pc-rel analysis
FILE=malloc://32
EXPECT=<<EOF
            0x00000000      dff80000       ldr.w r0, [0x00000004]      ; [0x4:4]=18 ; 4
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx dff80000 12000000 34000000
pd 1
EOF
RUN

NAME=thumb ldr pc-rel emulation
FILE=malloc://32
EXPECT=<<EOF
0x00000012
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx dff80000 12000000 34000000
aes
dr r0
EOF
RUN

NAME=bx ip eof
FILE=malloc://32
EXPECT=<<EOF
8
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx dff804c0 fc446047 18e0 0200
af
afi~size[1]
EOF
RUN

NAME=thumb ldr pc-rel analysis
FILE=malloc://32
EXPECT=<<EOF
            0x00000000      0149           ldr r1, [0x00000008]        ; [0x8:4]=0x22221111 ; 8
            0x00000002      014a           ldr r2, [0x00000008]        ; [0x8:4]=0x22221111 ; 8
            0x00000004      014b           ldr r3, [0x0000000c]        ; [0xc:4]=0x44443333 ; 12
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx 0149 014a 014b 0000 1111 2222 3333 4444 5555 6666
pd 3
EOF
RUN

NAME=thumb ldr+add pc-rel analysis
FILE=malloc://32
EXPECT=<<EOF
            0x00000000      0249           ldr r1, [0x0000000c]        ; [0xc:4]=0x22221111 ; 12 ; r1=0x22221111
            0x00000002      024a           ldr r2, [0x0000000c]        ; [0xc:4]=0x22221111 ; 12 ; r2=0x22221111
            0x00000004      024b           ldr r3, [0x00000010]        ; [0x10:4]=0x44443333 ; 16 ; r3=0x44443333
            0x00000006      7944           add r1, pc                  ; r1=0x2222111b
            0x00000008      7a44           add r2, pc                  ; r2=0x2222111d
            0x0000000a      7b44           add r3, pc                  ; r3=0x44443341
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
e asm.emu=1
wx 0249 024a 024b 7944 7a44 7b44 1111 2222 3333 4444 5555 6666 7777
pd 6
EOF
RUN

NAME=thumb adr pc-rel analysis
FILE=malloc://32
EXPECT=<<EOF
            0x00000002      01a0           adr r0, 4                   ; "Radare2 test string"
                                                                       ; 0x8 ; 8
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx 10b5 01a0 00bf 00bf 52616461726532207465737420737472696e6700
pd 1 @ 0x2
EOF
RUN

NAME=pd bits override for arm
FILE=malloc://32
EXPECT=<<EOF
mov r0, r0
            0x00000000      0000a0e1       mov r0, r0
            0x00000000      0000a0e1       mov r0, r0
            0x00000000      0000a0e1       mov r0, r0
            0x00000000      0000           movs r0, r0
            0x00000000      0000a0e1       mov r0, r0
            0x00000000      0000           movs r0, r0
            0x00000002                    unaligned
        ,=< 0x00000002      a0e1           b 0x346
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
wa mov r0, r0
pi 1
pd 1
ahb 32
pd 1
pd 1 @a:arm @b:32
pd 1 @a:arm @b:16
ahb 16
pd 1 @a:arm @b:32
pd 1 @a:arm @b:16
pd 1 @a:arm @b:32@2
pd 1 @a:arm @b:16@2
EOF
RUN

NAME=thumb adr pc-rel analysis with newline
FILE=malloc://32
EXPECT=<<EOF
            0x00000002      01a0           adr r0, 4                   ; "Radare2 test\r\n"
                                                                       ; 0x8 ; 8
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx 10b5 01a0 00bf 00bf 5261646172653220746573740d0a00
pd 1 @ 0x2
EOF
RUN

NAME=arm 16 BE 4 bytes instruction
FILE=-
EXPECT=<<EOF
f003e9da
blx 0x33b8
03f0dae9
blx 0x33b8
EOF
ARGS=-a arm -b 16
CMDS=<<EOF
e cfg.bigendian=1
wa blx 0x33b8
p8 4
pi 1
e cfg.bigendian=0
wa blx 0x33b8
p8 4
pi 1
EOF
RUN

NAME=arm-or-thumb visual bug
FILE=../bins/mach0/arm-or-thumb
EXPECT=<<EOF
32
EOF
CMDS=<<EOF
e scr.interactive=1
e scr.null=1
Vprdfq
e scr.null=0
afi~^size[1]
EOF
RUN

NAME=arm-or-thumb visual bug
FILE=../bins/mach0/arm-or-thumb
EXPECT=<<EOF
32
EOF
CMDS=<<EOF
af
afi~^size[1]
EOF
RUN

NAME=ARM32 bb 0 size -- af
FILE=malloc://32
EXPECT=<<EOF
0x00000000 0x0000000c 00:0000 12 j 0x00000010 f 0x0000000c
0x0000000c 0x00000010 00:0000 4 j 0x00000010
0x00000010 0x00000020 00:0000 16
EOF
CMDS=<<EOF
wx ff0000e2010050e30000001affffffea70009de594008de5e4139fe500f09ee5
e asm.arch=arm
e asm.bits=32
af
# .a2f
#pdf
afb
EOF
RUN

NAME=ARM32 bb 0 size -- a2f
FILE=malloc://32
BROKEN=1
EXPECT=<<EOF
0x00000000 0x0000000c 00:0000 12 j 0x00000010 f 0x0000000c
0x0000000c 0x00000010 00:0000 4 j 0x00000010
0x00000010 0x00000020 00:0000 16
EOF
CMDS=<<EOF
wx ff0000e2010050e30000001affffffea70009de594008de5e4139fe500f09ee5
e asm.arch=arm
e asm.bits=32
.a2f
afb
EOF
RUN

NAME=ldr code analysis
FILE=malloc://32
EXPECT=<<EOF
ldr ip, [0x00000028]
ldr ip, [sl, ip]
load
load
EOF
CMDS=<<EOF
wx 20c09fe5 0cc09ae7
e asm.arch=arm
e asm.bits=32
# pd 2 - note different colors
pi 2
ao~type[1]
ao@4~type[1]
EOF
RUN

NAME=endian
FILE=malloc://32
EXPECT=<<EOF
ldr r9, [sl, r5, ror 21]
ldr r9, [sl, 2791]
EOF
CMDS=<<EOF
e asm.arch=arm.gnu
e asm.bits=32
wx e59a9ae7
e cfg.bigendian=false
pi 1@0
e cfg.bigendian=true
pi 1@0
EOF
RUN

NAME=ldr thumb
FILE=malloc://32
EXPECT=<<EOF
ptr: 0x0000008c
ptr: 0x0000008c
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx 2249224a
ao~^ptr
ao@2~^ptr
EOF
RUN

NAME=arm32 bxeq lr
FILE=malloc://512
EXPECT=<<EOF
/ (fcn) fcn.00000000 16
|           0x00000000      021081e0       add r1, r1, r2
|           0x00000004      1eff2f01       bxeq lr
|           0x00000008      0020a0e3       mov r2, 0
\           0x0000000c      1eff2fe1       bx lr
EOF
CMDS=<<EOF
e asm.calls=false
e asm.arch=arm
e asm.bits=32
wx 021081e0 1eff2f01 0020a0e3 1eff2fe1
af
pd 4
EOF
RUN

NAME=arm32 blx switches bits
FILE=malloc://512
EXPECT=<<EOF
movs r1, 4
movs r4, 9
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
wx fffffffa 04210924
af
pi 2 @4
EOF
RUN

NAME=arm32 bx switches bits on odd location
FILE=malloc://512
EXPECT=<<EOF
movs r1, 4
movs r4, 9
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e anal.armthumb=true
wx 0910 a0e3 11ff 2fe1 0421 0924
aae
pi 2 @8
EOF
RUN

NAME=ELF ARM: thumb/arm switch
FILE=../bins/elf/analysis/libstagefright_soft_g711dec.so
EXPECT=<<EOF
size: 28
size: 28
EOF
CMDS=<<EOF
af
afi~size
afi~size
EOF
RUN

NAME=arm: ldr code analysis
FILE=malloc://32
EXPECT=<<EOF
ldr ip, [0x00000028]
ldr ip, [sl, ip]
load
load
EOF
CMDS=<<EOF
wx 20c09fe5
wx 0cc09ae7 @ 4
e asm.arch=arm
e asm.bits=32
# pd 2 - note different colors
pi 2
ao~type[1]
ao@4~type[1]
EOF
RUN

NAME=arm: endian
FILE=malloc://32
EXPECT=<<EOF
ldr sb, [sl, r5, ror 21]
ldr sb, [sl, 0xae7]
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
wx e59a9ae7
e cfg.bigendian=false
pi 1@0
e cfg.bigendian=true
pi 1@0
EOF
RUN

NAME=arm: no afterjmp or nopskip
FILE=malloc://32
EXPECT=<<EOF
12
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=64
wx 1f2003d5d0d8065800021fd61f2003d5
e anal.nopskip=false
e anal.jmp.after=false
af
afl~[2]
EOF
RUN

NAME=arm: afterjmp
FILE=malloc://32
EXPECT=<<EOF
12
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=64
wx 1f2003d5d0d8065800021fd61f2003d5
e anal.nopskip=false
e anal.jmp.after=true
af
afl~[2]
EOF
RUN

NAME=arm: afterjmp nopskip
FILE=malloc://32
EXPECT=<<EOF
8
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=64
wx 1f2003d5d0d8065800021fd61f2003d5
e anal.nopskip=true
e anal.jmp.after=false
af
afl~[2]
EOF
RUN

NAME=ARM64 bl capstone
FILE=malloc://32
EXPECT=<<EOF
bl 0x20
jump: 0x00000020
EOF
CMDS=<<EOF
s 4
wx 07000094
e asm.arch=arm
e asm.bits=64
pi 1
ao~jump
EOF
RUN

NAME=ARM64 bl gnu
FILE=malloc://32
EXPECT=<<EOF
bl 0x00000020
jump: 0x00000020
EOF
CMDS=<<EOF
s 4
wx 07000094
e asm.arch=arm.gnu
e asm.bits=64
pi 1
ao~jump
EOF
RUN

NAME=arm relsub >256
FILE=malloc://800
EXPECT=<<EOF
                 ldr r0, [sym.callback]
EOF
CMDS=<<EOF
wx 0d039fe5
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
f sym.callback=0x315
pd 1
EOF
RUN

NAME=arm relsub <256
FILE=-
EXPECT=<<EOF
                 ldr r0, [0x00000014]
                 ldr r0, [sym.callback]
EOF
CMDS=<<EOF
wx 0c009fe5
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
f sym.callback=0x14
pd 1
e asm.var.submin=0
pd 1
EOF
RUN

NAME=arm relsub
FILE=../bins/elf/arm1.bin
EXPECT=<<EOF
                 ldr r0, main
                 ldr r1, obj.object.6286
                 ldr r3, sym.__libc_csu_init
                 ldr r4, obj.completed.6278
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
pd 1 @ 0x00008168
pd 1 @ 0x00008204
pd 1 @ 0x0000816c
pd 1 @ 0x000081b0
EOF
RUN

NAME=arm relsub
FILE=../bins/elf/analysis/arm-ls
BROKEN=1
EXPECT=<<EOF
                 ldr r0, main
                 ldr r1, obj.object.6286
                 ldr r3, sym.__libc_csu_init
                 ldr r4, obj.completed.6278
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
pd 1 @ 0x00014368
EOF
RUN

NAME=jump sign extend : arm.cs
FILE=malloc://4
EXPECT=<<EOF
jump: 0x80000000
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e io.va=true
wx ffffffea # bl 0x80000000
om 3 0x7ffffffc
ao @ 0x7ffffffc~jump
EOF
RUN

NAME=jump sign extend : arm.gnu
FILE=malloc://4
EXPECT=<<EOF
jump: 0x80000000
EOF
CMDS=<<EOF
e asm.arch=arm.gnu
e asm.bits=32
e io.va=true
wx ffffffea # bl 0x80000000
om 3 0x7ffffffc
ao @ 0x7ffffffc~jump
EOF
RUN

NAME=ELF ARM: function names
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
name: sym.call_weak_fn
EOF
CMDS=<<EOF
s sym.call_weak_fn
af
afi~name
EOF
RUN

NAME=ELF ARM: function names 2
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
0x000102bc    1 12           sym.imp.abort
EOF
CMDS=<<EOF
aa
afl~abort
EOF
RUN

NAME=ELF ARM: function names 3
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
0x00010304    1 28           sym.call_weak_fn
EOF
CMDS=<<EOF
aa
afl~weak
EOF
RUN

NAME=ELF ARM: function names 4
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
0x00010304    1 28           sym.call_weak_fn
EOF
CMDS=<<EOF
af @@ sym*
afl~weak
EOF
RUN

NAME=ELF ARM: aa
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
42
15
EOF
CMDS=<<EOF
aa
f~sym?
afl~?
EOF
RUN

NAME=ELF ARM: aa2
FILE=../bins/elf/analysis/arm_32_flags0
EXPECT=<<EOF
0x000102c8    1 44           entry0
0x000102a4    1 12           sym.imp.__libc_start_main
0x00010304    1 28           sym.call_weak_fn
0x00010328    1 36           sym.deregister_tm_clones
0x00010358    1 44           sym.register_tm_clones
0x00010390    1 36           entry.fini0
0x000103b8    4 44           entry.init0
0x00010494    1 4            sym.__libc_csu_fini
0x00010498    1 8            sym._fini
0x000103ec    1 28           sym.func
0x00010434    3 88           sym.__libc_csu_init
0x00010278    1 12           sym._init
0x00010408    1 40           main
0x00010298    1 12           sym.imp.printf
0x000102bc    1 12           sym.imp.abort
EOF
CMDS=<<EOF
aa
afl
EOF
RUN

NAME=ELF ARM: function arg
FILE=../bins/elf/analysis/armcall
EXPECT=<<EOF
            ; CALL XREF from main @ 0x10468
/ (fcn) sym.call 44
|           ; var int32_t var_8h @ fp-0x8
|           ; arg int32_t arg1 @ r0
|           0x00010420      00482de9       push {fp, lr}
|           0x00010424      04b08de2       add fp, sp, 4
|           0x00010428      08d04de2       sub sp, sp, 8
|           0x0001042c      08000be5       str r0, [var_8h]            ; 8 ; arg1
|           0x00010430      14009fe5       ldr r0, [0x0001044c]        ; [0x1044c:4]=0x104f0
|           0x00010434      08101be5       ldr r1, [var_8h]            ; 8
|           0x00010438      a2ffffeb       bl sym.imp.printf
|           0x0001043c      0030a0e3       mov r3, 0
|           0x00010440      0300a0e1       mov r0, r3
|           0x00010444      04d04be2       sub sp, fp, 4
\           0x00010448      0088bde8       pop {fp, pc}
EOF
CMDS=<<EOF
e asm.calls=false
afr@main
afva@sym.call
pdf@sym.call
EOF
RUN

NAME=ELF ARM: function args
FILE=../bins/elf/analysis/armcall
EXPECT=<<EOF
/ (fcn) main 44
|           ; var int32_t var_ch @ fp-0xc
|           ; var int32_t var_8h @ fp-0x8
|           ; arg int argc @ r0
|           ; arg char **argv @ r1
|           0x00010450      00482de9       push {fp, lr}
|           0x00010454      04b08de2       add fp, sp, 4
|           0x00010458      08d04de2       sub sp, sp, 8
|           0x0001045c      08000be5       str r0, [var_8h]            ; 8 ; argc
|           0x00010460      0c100be5       str r1, [var_ch]            ; 0xc ; 12 ; argv
|           0x00010464      08001be5       ldr r0, [var_8h]            ; 8
|           0x00010468      ecffffeb       bl sym.call
|           0x0001046c      0030a0e1       mov r3, r0
|           0x00010470      0300a0e1       mov r0, r3
|           0x00010474      04d04be2       sub sp, fp, 4
\           0x00010478      0088bde8       pop {fp, pc}
EOF
CMDS=<<EOF
e asm.calls=false
af@main
afva@main
pdf@main
EOF
RUN

NAME=ELF ARM: aav
FILE=../bins/elf/analysis/armcall
EXPECT=<<EOF
            0x00010328      .dword 0x000104e0 ; sym.__libc_csu_fini
            0x0001032c      .dword 0x00010450 ; main ; sym.main
            ; UNKNOWN XREF from section..plt @ +0x10
            ;-- aav.0x00010330:
            0x00010330      .dword 0x0001047c ; sym.__libc_csu_init
EOF
CMDS=<<EOF
e asm.calls=false
aav
pd 3 @ 0x00010328
EOF
RUN

NAME=ELF ARM: af and aav
FILE=../bins/elf/arm1.bin
EXPECT=<<EOF
                 andeq r4, r8, r8, asr r7
                 .dword 0x00008b00 ; sym.__libc_csu_fini
                 .dword 0x00008290 ; main ; sym.main
                 .dword 0x00008b48 ; sym.__libc_csu_init
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
e asm.flags=false
af @ sym.call_gmon_start
af @ entry0
aav
pd 1 @ 0x000081e0
pd 1 @ 0x0000817c
pd 1 @ 0x00008180
pd 1 @ 0x00008184
EOF
RUN

NAME=ELF ARM: aav string
FILE=../bins/elf/arm1.bin
BROKEN=1
EXPECT=<<EOF
            .dword 0x0002061f ; str.:__Raspbian_4.9.2_10__4.9.2
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=32
e asm.comments=false
e asm.bytes=false
e asm.offset=false
e asm.flags=false
af @ sym.deregister_tm_clones
aav
pd 1 @ 0x0001037c
EOF
RUN

NAME=ELF ARM: vars
FILE=../bins/elf/analysis/arm-ls
EXPECT=<<EOF
16
EOF
CMDS=<<EOF
e asm.calls=false
s main
af
pd 1~var?
EOF
RUN

NAME=sp vars arm16
FILE=malloc://1024
EXPECT=<<EOF
var int16_t var_54h @ sp+0x0
var int16_t var_50h @ sp+0x4
var int16_t var_4ch @ sp+0x8
var int16_t var_48h @ sp+0xc
var int16_t var_44h @ sp+0x10
var int16_t var_40h @ sp+0x14
var int16_t var_3ch @ sp+0x18
var int16_t var_38h @ sp+0x1c
var int16_t var_34h @ sp+0x20
var int16_t var_30h @ sp+0x24
var int16_t var_2ch @ sp+0x28
var int16_t var_28h @ sp+0x2c
var int16_t var_24h @ sp+0x30
var int16_t var_20h @ sp+0x34
var int16_t var_1ch @ sp+0x38
var int16_t var_18h @ sp+0x3c
var int16_t var_14h @ sp+0x40
var int16_t var_10h @ sp+0x44
var int16_t var_ch @ sp+0x48
var int16_t var_8h @ sp+0x4c
var int16_t var_4h @ sp+0x50
EOF
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wx f0b503af2de9000d95b0002001210222032340f2040940f2050c40f2060e0724082509261490139112921193cdf80090cdf804c0cdf808e0039404950596ddf85080cdf81880ddf84ca0cdf81ca0ddf848b0cdf820b0ddf84480cdf82480cdf82890cdf82cc0cdf830e00d940e950f96fff740ff00211090084615b0bde8000df0bd
aa
afv~var
EOF
RUN

NAME=arm thumb basic block detection with ITTE
BROKEN=1
FILE=../../bins/elf/analysis/bug-it-bb
CMDS=<<EOF
aaa ; s 0x00010074 ; afb
EOF
EXPECT=<<EOF
0x00010074 0x0001007a 00:0000 6 j 0x0001007a f 0x0001007e 0x0001007a 0x0001007e 00:0000 4 j 0x00010080 0x0001007e 0x00010080 00:0000 2 j 0x00010080 0x00010080 0x00010082 00:0000 2
EOF
RUN

NAME=arm jump table
FILE=../bins/elf/analysis/callback.elf
CMDS=<<EOF
af @ sym.input_handler2
CC. @ 0x000105b8~?(7
EOF
EXPECT=<<EOF
1
EOF
RUN

NAME=arm jump table
FILE=../bins/elf/analysis/mobile_bank.45115ff5f655d94fc26cb5244928b3fc
CMDS=<<EOF
af @ 0x11284
CC. @ 0x000112b0~?(8
EOF
EXPECT=<<EOF
1
EOF
RUN

NAME=arm main analyzed with aaa
FILE=../bins/elf/analysis/ch23.bin
CMDS=<<EOF
aaa
afl~?0x00008470
EOF
EXPECT=<<EOF
1
EOF
RUN

NAME=arm main in disassembly
FILE=../bins/elf/analysis/ch23.bin
BROKEN=1
CMDS=<<EOF
aaa
pd 1 @ 0x000083d8~[5]
EOF
EXPECT=<<EOF
main
EOF
RUN

NAME=tbh jump table
FILE=malloc://2048
CMDS=<<EOF
e asm.arch=arm
e asm.bits=16
wxs 01380793d3b24ff00109024600bf00bf00bf00bf59b2a1f120005a28139200f28d81404d02eb8004082601270122dfe810f09700850185015c0085015b008501850185018501a2
wxs 0097008501ac007b008501af005d005d005d005d005d005d005d005d005d008501850185018501850185018501c300850185018501c3008501c30085018501850185019c008501
wxs 85018501850185018501850185018501850185010d0185018501850185018501850185018501c30085011c01e700c300c300c300b200e700b50085019c00850129016801390185
wxs 0185014c019f006201850185010e0185019f00b1e6d7e6139ca1f13000224612f9013fa3f1300109293ff686afa21c00eb800012f9013b01eb4000a3f130010a29f5d3dbb2013a
wxs c0f1000878e700bf07df0100139a104610f9011fcbb22a2b35d0303900274ff00109079709293ff662af901c002303eb830310f9012b01eb4303a2f130010a29f5d34fe758b20a
wxs 9001200b9096e60cf1010c93e64ff0010c90e609981ef0010f50f8048b099018bfc8f1000886e60122129f85e60120089080e6acf1010c7de64ff0020c7ae6139000e013920998
wxs 4ff0010950f8041b079109906fe6bcf1010f18bfbcf1000f40f0bb800998ddf830a008300990e7e0ddf830a0139d109c0e98012805d195f90000119900f02dfc05e014f0ff0f04
wxs bf28780af8010b0d9801300d9018e60cf10200042800f29980dfe810f00500050005000500a901099a52f8040bc1170a9f0029d14d4ff030090b9eb8bf01260b96b8bf2d2710eb
wxs e1700a9780eae17441ebe17080eae1770a26b3e0c84d129810f0010f52d058b2302141ea00200a90022010260b9001204ae00999bcf1000f01f10400dcbf09688df86b10099001
wxs 9f0121dfe00cf10200042857d8dfe810f078028102050005008a02099951f8040b099185e20998002250f8044b0990002c00f0c48004920220ac4d10220b900820079047f63000
wxs 0a9030e0099819f0010f50f8047b099000f0ac80079a30230021002a00f0b080785c002800f0ac8001319142f8d3a7e09d4d0a2602e00020102612900cf10200042817d8dfe800
wxs f0030308084d00099a52f8044be71748e00998324650f8044b09900020049020463023059014ae029f104662e00696139d2c4614f8010d2528fbd1ddf830a0ac4229d80d980025
wxs 009901eb00080f98b0f1ff3f06d018eb050002bf0af801bb012010900e98012806d1139e119996f9000000f061fb07e01098139e10f0ff0f04bf30780af8010b01356019b042de
wxs d90d9828440d90139d109c
s 0
af
pds 1@0x2e~:1
EOF
EXPECT=<<EOF
0x0000002e switch table (91 cases) at 0x32
EOF
RUN

NAME=ao 16 after ao 32
FILE=../bins/arm/elf/hello_world
CMDS=<<EOF
e asm.bits=16
ao@0x568
?e --
ao@0x50e
EOF
EXPECT=<<EOF
address: 0x568
opcode: push {r3, lr}
disasm: push {r3, lr}
pseudo: push (r3, lr) 
mnemonic: push
mask: ffffffff
prefix: 0
id: 424
bytes: 08402de9
refptr: 0
size: 4
sign: false
type: push
cycles: 1
esil: 8,sp,-=,lr,r3,2,sp,=[*]
family: cpu
--
address: 0x50e
opcode: add r7, sp, 0
disasm: add r7, sp, 0
pseudo: r7 = sp + 0
mnemonic: add
description: add two values
mask: ffff
prefix: 0
id: 2
bytes: 00af
refptr: 0
size: 2
sign: false
type: add
cycles: 1
esil: 0,sp,+,0xffffffff,&,r7,=
family: cpu
EOF
RUN

NAME=arm aae with bit switch
FILE=../bins/arm/elf/hello_world
EXPECT=<<EOF
            ;-- main:
            0x0000050c      80b5           push {r7, lr}
            0x0000050e      00af           add r7, sp, 0
            0x00000510      034b           ldr r3, [0x00000520]        ; [0x520:4]=94 ; 1312
            0x00000512      7b44           add r3, pc                  ; 0x574 ; "Hello world!"
            0x00000514      1846           mov r0, r3
            0x00000516      fff75aef       blx sym.imp.puts
            0x0000051a      0023           movs r3, 0
            0x0000051c      1846           mov r0, r3
            0x0000051e      80bd           pop {r7, pc}
EOF
CMDS=<<EOF
aei
e asm.bits=32
aae 20 @ main
pd 9 @ main
EOF
RUN
