aboutsummaryrefslogtreecommitdiff
path: root/lldb/test/Shell/Commands/command-disassemble-riscv32-bytes.s
blob: 78be614e3af156c225971c7b84ff04f765401861 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# REQUIRES: riscv
# REQUIRES: python

# This test verifies that disassemble -b prints out the correct bytes and
# format for standard and unknown riscv instructions of various sizes,
# and that unknown instructions show opcodes and disassemble as "<unknown>".
# It also tests that the fdis command from examples/python/filter_disasm.py
# pipes the disassembly output through a simple filter program correctly.


# RUN: llvm-mc -filetype=obj -mattr=+c --triple=riscv32-unknown-unknown %s -o %t
# RUN: %lldb -b %t "-o" "disassemble -b -n main" | FileCheck %s
# RUN: %lldb -b %t -o "command script import %S/../../../examples/python/filter_disasm.py" -o "fdis set %python %S/Inputs/dis_filt.py" -o "fdis -n main" | FileCheck --check-prefix=FILTER %s

main:
    addi   sp, sp, -0x20               # 16 bit standard instruction
    sw     a0, -0xc(s0)                # 32 bit standard instruction
    .insn 8, 0x2000200940003F;         # 64 bit custom instruction
    .insn 6, 0x021F | 0x00001000 << 32 # 48 bit xqci.e.li rd=8 imm=0x1000
    .insn 4, 0x84F940B                 # 32 bit xqci.insbi  
    .insn 2, 0xB8F2                    # 16 bit cm.push

# CHECK:      [0x0] <+0>:   1101                     addi   sp, sp, -0x20 
# CHECK-NEXT: [0x2] <+2>:   fea42a23                 sw     a0, -0xc(s0)
# CHECK-NEXT: [0x6] <+6>:   0940003f 00200020        <unknown>
# CHECK-NEXT: [0xe] <+14>:  021f 0000 1000           <unknown>
# CHECK-NEXT: [0x14] <+20>: 084f940b                 <unknown>
# CHECK-NEXT: [0x18] <+24>: b8f2                     <unknown>

# FILTER: Disassembly filter command (fdis) loaded
# FILTER:      [0x0] <+0>:   1101                     addi   sp, sp, -0x20 
# FILTER-NEXT: [0x2] <+2>:   fea42a23                 sw     a0, -0xc(s0)
# FILTER-NEXT: [0x6] <+6>:   0940003f 00200020        Fake64
# FILTER-NEXT: [0xe] <+14>:  021f 0000 1000           <unknown>
# FILTER-NEXT: [0x14] <+20>: 084f940b                 <unknown>
# FILTER-NEXT: [0x18] <+24>: b8f2                     <unknown>