dwarfdump: Added macro support to llvm-dwarfdump tool.
[oota-llvm.git] / test / MC / Mips / cprestore-noreorder.s
1 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 -relocation-model=pic -show-encoding | \
2 # RUN:  FileCheck %s
3
4 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 -relocation-model=pic -filetype=obj -o -| \
5 # RUN:  llvm-objdump -d -r -arch=mips - | \
6 # RUN:   FileCheck %s -check-prefix=CHECK-FOR-STORE
7
8 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 -mattr=+micromips -relocation-model=pic -show-encoding | \
9 # RUN:  FileCheck %s -check-prefix=MICROMIPS
10
11 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 -relocation-model=static -show-encoding | \
12 # RUN:  FileCheck %s -check-prefix=NO-PIC
13
14 # RUN: llvm-mc %s -arch=mips -mcpu=mips64 -target-abi n32 -relocation-model=pic -show-encoding | \
15 # RUN:  FileCheck %s -check-prefix=BAD-ABI -check-prefix=BAD-ABI-N32
16
17 # RUN: llvm-mc %s -arch=mips64 -mcpu=mips64 -target-abi n64 -relocation-model=pic -show-encoding | \
18 # RUN:  FileCheck %s -check-prefix=BAD-ABI -check-prefix=BAD-ABI-N64
19
20   .text
21   .ent foo
22 foo:
23   .frame  $sp, 0, $ra
24   .set noreorder
25
26   .cpload $25
27   .cprestore 8
28
29   jal $25
30   jal $4, $25
31   jal foo
32
33   .end foo
34
35 # CHECK-FOR-STORE: sw  $gp, 8($sp)
36
37 # CHECK: .cprestore 8
38 # CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
39 # CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
40 # CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
41
42 # CHECK: jalr  $4,  $25            # encoding: [0x03,0x20,0x20,0x09]
43 # CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
44 # CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
45
46 # CHECK: lw    $25, %got(foo)($gp) # encoding: [0x8f,0x99,A,A]
47 # CHECK:                           #   fixup A - offset: 0, value: foo@GOT, kind: fixup_Mips_GOT_Local
48 # CHECK: addiu $25, $25, %lo(foo)  # encoding: [0x27,0x39,A,A]
49 # CHECK:                           #   fixup A - offset: 0, value: foo@ABS_LO, kind: fixup_Mips_LO16
50 # CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
51 # CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
52 # CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
53 # CHECK: .end  foo
54
55 # MICROMIPS: .cprestore 8
56 # MICROMIPS: jalrs16 $25                 # encoding: [0x45,0xf9]
57 # MICROMIPS: nop                         # encoding: [0x00,0x00,0x00,0x00]
58 # MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
59
60 # MICROMIPS: jalrs   $4,  $25            # encoding: [0x00,0x99,0x4f,0x3c]
61 # MICROMIPS: nop                         # encoding: [0x00,0x00,0x00,0x00]
62 # MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
63
64 # MICROMIPS: lw      $25, %got(foo)($gp) # encoding: [0xff,0x3c,A,A]
65 # MICROMIPS:                             #   fixup A - offset: 0, value: foo@GOT, kind: fixup_MICROMIPS_GOT16
66 # MICROMIPS: addiu   $25, $25, %lo(foo)  # encoding: [0x33,0x39,A,A]
67 # MICROMIPS:                             #   fixup A - offset: 0, value: foo@ABS_LO, kind: fixup_MICROMIPS_LO16
68 # MICROMIPS: jalrs   $ra, $25            # encoding: [0x03,0xf9,0x4f,0x3c]
69 # MICROMIPS: nop                         # encoding: [0x0c,0x00]
70 # MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
71 # MICROMIPS: .end  foo
72
73 # NO-PIC:     .cprestore  8
74 # NO-PIC:     jalr  $25         # encoding: [0x03,0x20,0xf8,0x09]
75 # NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
76
77 # NO-PIC:     jalr  $4,  $25    # encoding: [0x03,0x20,0x20,0x09]
78 # NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
79
80 # NO-PIC:     jal   foo         # encoding: [0b000011AA,A,A,A]
81 # NO-PIC:                       #   fixup A - offset: 0, value: foo, kind: fixup_Mips_26
82 # NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
83 # NO-PIC:     .end  foo
84
85 # BAD-ABI:     .cprestore  8
86 # BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
87 # BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
88
89 # BAD-ABI:     jalr  $4,  $25                 # encoding: [0x03,0x20,0x20,0x09]
90 # BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
91
92 # BAD-ABI-N32: lw    $25, %got_disp(foo)($gp) # encoding: [0x8f,0x99,A,A]
93 # BAD-ABI-N64: ld    $25, %got_disp(foo)($gp) # encoding: [0xdf,0x99,A,A]
94 # BAD-ABI:                                    #   fixup A - offset: 0, value: foo@GOT_DISP, kind: fixup_Mips_GOT_DISP
95 # BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
96 # BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
97 # BAD-ABI:  .end  foo