reference, declarationdefinition
definition → references, declarations, derived classes, virtual overrides
reference to multiple definitions → definitions
unreferenced
    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
   38
   39
   40
   41
   42
   43
   44
   45
   46
   47
   48
   49
   50
   51
   52
   53
   54
   55
   56
   57
   58
   59
   60
   61
   62
   63
   64
   65
   66
   67
   68
   69
   70
   71
   72
   73
   74
   75
   76
   77
   78
   79
   80
   81
   82
   83
   84
   85
   86
   87
   88
   89
   90
   91
   92
   93
   94
   95
   96
   97
   98
   99
  100
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu --position-independent \
# RUN:            -show-encoding | FileCheck %s

# RUN: llvm-mc %s -triple mips-unknown-linux-gnu --position-independent \
# RUN:            -filetype=obj -o - \
# RUN:   | llvm-objdump -d -r - | FileCheck %s -check-prefix=CHECK-FOR-STORE

# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -mattr=+micromips \
# RUN:            --position-independent -show-encoding \
# RUN:   | FileCheck %s -check-prefix=MICROMIPS

# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -show-encoding \
# RUN:   | FileCheck %s -check-prefix=NO-PIC

# RUN: llvm-mc %s -triple mips64-unknown-linux-gnuabin32 \
# RUN:            --position-independent -show-encoding \
# RUN:   | FileCheck %s -check-prefixes=BAD-ABI,BAD-ABI-N32

# RUN: llvm-mc %s -triple mips64-unknown-linux-gnu --position-independent \
# RUN:            -show-encoding \
# RUN:   | FileCheck %s -check-prefixes=BAD-ABI,BAD-ABI-N64

  .text
  .ent foo
foo:
  .frame  $sp, 0, $ra
  .set noreorder

  .cpload $25
  .cprestore 8

  jal $25
  jal $4, $25
  jal foo

  .end foo

# CHECK-FOR-STORE: sw  $gp, 8($sp)

# CHECK: .cprestore 8
# CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]

# CHECK: jalr  $4,  $25            # encoding: [0x03,0x20,0x20,0x09]
# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]

# CHECK: lw    $25, %got(foo)($gp) # encoding: [0x8f,0x99,A,A]
# CHECK:                           #   fixup A - offset: 0, value: %got(foo), kind: fixup_Mips_GOT
# CHECK: addiu $25, $25, %lo(foo)  # encoding: [0x27,0x39,A,A]
# CHECK:                           #   fixup A - offset: 0, value: %lo(foo), kind: fixup_Mips_LO16
# CHECK: jalr  $25                 # encoding: [0x03,0x20,0xf8,0x09]
# CHECK: nop                       # encoding: [0x00,0x00,0x00,0x00]
# CHECK: lw    $gp, 8($sp)         # encoding: [0x8f,0xbc,0x00,0x08]
# CHECK: .end  foo

# MICROMIPS: .cprestore 8
# MICROMIPS: jalrs16 $25                 # encoding: [0x45,0xf9]
# MICROMIPS: nop                         # encoding: [0x00,0x00,0x00,0x00]
# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]

# MICROMIPS: jalrs   $4,  $25            # encoding: [0x00,0x99,0x4f,0x3c]
# MICROMIPS: nop                         # encoding: [0x00,0x00,0x00,0x00]
# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]

# MICROMIPS: lw      $25, %got(foo)($gp) # encoding: [0xff,0x3c,A,A]
# MICROMIPS:                             #   fixup A - offset: 0, value: %got(foo), kind: fixup_MICROMIPS_GOT16
# MICROMIPS: addiu   $25, $25, %lo(foo)  # encoding: [0x33,0x39,A,A]
# MICROMIPS:                             #   fixup A - offset: 0, value: %lo(foo), kind: fixup_MICROMIPS_LO16
# MICROMIPS: jalrs   $ra, $25            # encoding: [0x03,0xf9,0x4f,0x3c]
# MICROMIPS: nop                         # encoding: [0x0c,0x00]
# MICROMIPS: lw      $gp, 8($sp)         # encoding: [0xff,0x9d,0x00,0x08]
# MICROMIPS: .end  foo

# NO-PIC:     .cprestore  8
# NO-PIC:     jalr  $25         # encoding: [0x03,0x20,0xf8,0x09]
# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]

# NO-PIC:     jalr  $4,  $25    # encoding: [0x03,0x20,0x20,0x09]
# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]

# NO-PIC:     jal   foo         # encoding: [0b000011AA,A,A,A]
# NO-PIC:                       #   fixup A - offset: 0, value: foo, kind: fixup_Mips_26
# NO-PIC-NOT: lw    $gp, 8($sp) # encoding: [0x8f,0xbc,0x00,0x08]
# NO-PIC:     .end  foo

# BAD-ABI:     .cprestore  8
# BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]

# BAD-ABI:     jalr  $4,  $25                 # encoding: [0x03,0x20,0x20,0x09]
# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]

# BAD-ABI-N32: lw    $25, %got_disp(foo)($gp) # encoding: [0x8f,0x99,A,A]
# BAD-ABI-N64: ld    $25, %got_disp(foo)($gp) # encoding: [0xdf,0x99,A,A]
# BAD-ABI:                                    #   fixup A - offset: 0, value: %got_disp(foo), kind: fixup_Mips_GOT_DISP
# BAD-ABI:     jalr  $25                      # encoding: [0x03,0x20,0xf8,0x09]
# BAD-ABI-NOT: lw    $gp, 8($sp)              # encoding: [0x8f,0xbc,0x00,0x08]
# BAD-ABI:  .end  foo