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
22foo:
23  .frame  $sp, 0, $ra
24  .set noreorder
25  .cpload $25
26  .set reorder
27
28  .cprestore 8
29
30  jal $25
31  jal $4, $25
32  jal foo
33
34  .end foo
35
36# CHECK-FOR-STORE: sw  $gp, 8($sp)
37
38# CHECK: .cprestore 8
39# CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
40# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
41# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
42
43# CHECK: jalr  $4,  $25            # encoding: [0x03,0x20,0x20,0x09]
44# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
45# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
46
47# CHECK: lw    $25, %got(foo)($gp) # encoding: [0x8f,0x99,A,A]
48# CHECK:                           #   fixup A - offset: 0, value: foo@GOT, kind: fixup_Mips_GOT_Local
49# CHECK: addiu $25, $25, %lo(foo)  # encoding: [0x27,0x39,A,A]
50# CHECK:                           #   fixup A - offset: 0, value: foo@ABS_LO, kind: fixup_Mips_LO16
51# CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
52# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
53# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
54# CHECK: .end  foo
55
56# MICROMIPS: .cprestore 8
57# MICROMIPS: jalrs16 $25                 # encoding: [0x45,0xf9]
58# MICROMIPS: nop                         # encoding: [0x0c,0x00]
59# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
60
61# MICROMIPS: jalrs   $4,  $25            # encoding: [0x00,0x99,0x4f,0x3c]
62# MICROMIPS: nop                         # encoding: [0x0c,0x00]
63# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
64
65# MICROMIPS: lw      $25, %got(foo)($gp) # encoding: [0xff,0x3c,A,A]
66# MICROMIPS:                             #   fixup A - offset: 0, value: foo@GOT, kind: fixup_MICROMIPS_GOT16
67# MICROMIPS: addiu   $25, $25, %lo(foo)  # encoding: [0x33,0x39,A,A]
68# MICROMIPS:                             #   fixup A - offset: 0, value: foo@ABS_LO, kind: fixup_MICROMIPS_LO16
69# MICROMIPS: jalrs   $ra, $25            # encoding: [0x03,0xf9,0x4f,0x3c]
70# MICROMIPS: nop                         # encoding: [0x0c,0x00]
71# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
72# MICROMIPS: .end  foo
73
74# NO-PIC:     .cprestore 8
75# NO-PIC:     jalr  $25         # encoding: [0x03,0x20,0xf8,0x09]
76# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
77
78# NO-PIC:     jalr  $4,  $25    # encoding: [0x03,0x20,0x20,0x09]
79# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
80
81# NO-PIC:     jal   foo         # encoding: [0b000011AA,A,A,A]
82# NO-PIC:                       #   fixup A - offset: 0, value: foo, kind: fixup_Mips_26
83# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
84# NO-PIC:     .end  foo
85
86# BAD-ABI:     .cprestore 8
87# BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
88# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
89
90# BAD-ABI:     jalr  $4,  $25                 # encoding: [0x03,0x20,0x20,0x09]
91# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
92
93# BAD-ABI-N32: lw    $25, %got_disp(foo)($gp) # encoding: [0x8f,0x99,A,A]
94# BAD-ABI-N64: ld    $25, %got_disp(foo)($gp) # encoding: [0xdf,0x99,A,A]
95# BAD-ABI:                                    #   fixup A - offset: 0, value: foo@GOT_DISP, kind: fixup_Mips_GOT_DISP
96# BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
97# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
98# BAD-ABI:     .end  foo
99