2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -show-encoding |\
|
2016-12-13 01:40:26 +08:00
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,O32
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -mattr=+xgot -show-encoding |\
|
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,XO32
|
|
|
|
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnuabin32 -show-encoding |\
|
2016-12-13 01:40:26 +08:00
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,N32
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnuabin32 -mattr=+xgot -show-encoding |\
|
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,XN32
|
|
|
|
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnu -show-encoding |\
|
2016-12-13 01:40:26 +08:00
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,N64
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnu -mattr=+xgot -show-encoding |\
|
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MIPS,XN64
|
|
|
|
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -mattr=micromips -show-encoding |\
|
2016-12-13 01:40:26 +08:00
|
|
|
# RUN: FileCheck %s -check-prefixes=ALL,MM,O32-MM
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# Repeat the tests but using ELF output. An initial version of this patch did
|
|
|
|
# this as the output different depending on whether it went through
|
|
|
|
# MCAsmStreamer or MCELFStreamer. This ensures that the assembly expansion and
|
|
|
|
# direct objection emission match.
|
|
|
|
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-O32
|
2019-11-10 19:53:36 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips-unknown-linux-gnu -mattr=+xgot -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-XO32
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnuabin32 -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-N32
|
2019-11-10 19:53:36 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnuabin32 -mattr=+xgot -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-XN32
|
2018-12-12 15:03:04 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnu -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-N64
|
2019-11-10 19:53:36 +08:00
|
|
|
# RUN: llvm-mc %s -triple mips64-unknown-linux-gnu -mattr=+xgot -filetype=obj | \
|
2020-03-16 07:17:52 +08:00
|
|
|
# RUN: llvm-objdump -d -r - | FileCheck %s --check-prefixes=ELF-XN64
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2015-08-19 00:18:09 +08:00
|
|
|
.weak weak_label
|
|
|
|
|
|
|
|
.text
|
|
|
|
.option pic2
|
|
|
|
|
|
|
|
.ent local_label
|
|
|
|
local_label:
|
|
|
|
.frame $sp, 0, $ra
|
|
|
|
.set noreorder
|
|
|
|
|
|
|
|
jal local_label
|
|
|
|
nop
|
|
|
|
|
|
|
|
# Expanding "jal local_label":
|
|
|
|
# O32: lw $25, %got(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# O32: # fixup A - offset: 0, value: %got(local_label), kind: fixup_Mips_GOT
|
2015-08-19 00:18:09 +08:00
|
|
|
# O32: addiu $25, $25, %lo(local_label) # encoding: [0x27,0x39,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# O32: # fixup A - offset: 0, value: %lo(local_label), kind: fixup_Mips_LO16
|
2018-12-10 23:07:36 +08:00
|
|
|
# O32-NEXT: .reloc ($tmp0), R_MIPS_JALR, local_label
|
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-O32-NEXT: 27 39 00 00 addiu $25, $25, 0
|
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-O32-NEXT: R_MIPS_JALR local_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XO32: lw $25, %got(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got(local_label), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo(local_label) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo(local_label), kind: fixup_Mips_LO16
|
|
|
|
# XO32-NEXT: .reloc ($tmp0), R_MIPS_JALR, local_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 00 addiu $25, $25, 0
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_JALR local_label
|
|
|
|
|
2015-08-19 00:18:09 +08:00
|
|
|
# N32: lw $25, %got_disp(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# N32: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
2018-12-12 15:03:04 +08:00
|
|
|
# N32-NEXT: .reloc .Ltmp0, R_MIPS_JALR, local_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP local_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR local_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN32: lw $25, %got_disp(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN32-NEXT: .reloc .Ltmp0, R_MIPS_JALR, local_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP local_label
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR local_label
|
|
|
|
|
2015-08-19 00:18:09 +08:00
|
|
|
# N64: ld $25, %got_disp(local_label)($gp) # encoding: [0xdf,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# N64: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
2018-12-10 23:07:36 +08:00
|
|
|
# N64-NEXT: .reloc .Ltmp0, R_MIPS_JALR, local_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE local_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE local_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN64: ld $25, %got_disp(local_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN64-NEXT: .reloc .Ltmp0, R_MIPS_JALR, local_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# O32-MM: lw $25, %got(local_label)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM: # fixup A - offset: 0, value: %got(local_label), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM: addiu $25, $25, %lo(local_label) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM: # fixup A - offset: 0, value: %lo(local_label), kind: fixup_MICROMIPS_LO16
|
2018-12-10 23:07:36 +08:00
|
|
|
# O32-MM-NEXT: .reloc ($tmp0), R_MICROMIPS_JALR, local_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
jal local_label+8
|
|
|
|
nop
|
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32: lw $25, %got(local_label+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(local_label+8), kind: fixup_Mips_GOT
|
|
|
|
# O32-NEXT: addiu $25, $25, %lo(local_label+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %lo(local_label+8), kind: fixup_Mips_LO16
|
|
|
|
# O32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-O32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-O32-NEXT: 00 00 00 00 nop
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# XO32: lw $25, %got(local_label+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got(local_label+8), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo(local_label+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo(local_label+8), kind: fixup_Mips_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-XO32-NEXT: 00 00 00 00 nop
|
2019-11-10 19:53:36 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# N32-NEXT: .reloc .Ltmp1, R_MIPS_JALR, local_label
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP local_label
|
|
|
|
# ELF-N32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR local_label
|
|
|
|
|
|
|
|
# XN32: lw $25, %got_disp(local_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# XN32-NEXT: .reloc .Ltmp1, R_MIPS_JALR, local_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP local_label
|
|
|
|
# ELF-XN32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR local_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(local_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# N64-NEXT: .reloc .Ltmp1, R_MIPS_JALR, local_label
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
# ELF-N64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
|
|
|
|
# XN64: ld $25, %got_disp(local_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(local_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# XN64-NEXT: .reloc .Ltmp1, R_MIPS_JALR, local_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
# ELF-XN64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE local_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32-MM: lw $25, %got(local_label+8)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(local_label+8), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, %lo(local_label+8) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %lo(local_label+8), kind: fixup_MICROMIPS_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
jal weak_label
|
|
|
|
nop
|
2015-08-19 00:18:09 +08:00
|
|
|
|
|
|
|
# Expanding "jal weak_label":
|
|
|
|
# O32: lw $25, %call16(weak_label)($gp) # encoding: [0x8f,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# O32: # fixup A - offset: 0, value: %call16(weak_label), kind: fixup_Mips_CALL16
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-NEXT: .reloc ($tmp1), R_MIPS_JALR, weak_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_CALL16 weak_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-O32-NEXT: R_MIPS_JALR weak_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XO32: lui $25, %call_hi(weak_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %call_hi(weak_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XO32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XO32-NEXT: lw $25, %call_lo(weak_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %call_lo(weak_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NEXT: .reloc ($tmp1), R_MIPS_JALR, weak_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XO32-MEXT: R_MIPS_CALL_HI16 weak_label
|
|
|
|
# ELF-XO32-MEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XO32-MEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XO32-MEXT: R_MIPS_CALL_LO16 weak_label
|
|
|
|
# ELF-XO32-MEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XO32-MEXT: R_MIPS_JALR weak_label
|
|
|
|
|
2015-08-19 00:18:09 +08:00
|
|
|
# N32: lw $25, %call16(weak_label)($gp) # encoding: [0x8f,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# N32: # fixup A - offset: 0, value: %call16(weak_label), kind: fixup_Mips_CALL16
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32-NEXT: .reloc .Ltmp2, R_MIPS_JALR, weak_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_CALL16 weak_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR weak_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN32: lui $25, %call_hi(weak_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %call_hi(weak_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XN32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XN32-NEXT: lw $25, %call_lo(weak_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %call_lo(weak_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN32-NEXT: .reloc .Ltmp2, R_MIPS_JALR, weak_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_CALL_HI16 weak_label
|
|
|
|
# ELF-XN32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XN32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_CALL_LO16 weak_label
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR weak_label
|
|
|
|
|
2015-08-19 00:18:09 +08:00
|
|
|
# N64: ld $25, %call16(weak_label)($gp) # encoding: [0xdf,0x99,A,A]
|
2016-05-03 21:35:44 +08:00
|
|
|
# N64: # fixup A - offset: 0, value: %call16(weak_label), kind: fixup_Mips_CALL16
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64-NEXT: .reloc .Ltmp2, R_MIPS_JALR, weak_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_CALL16/R_MIPS_NONE/R_MIPS_NONE weak_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE weak_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN64: lui $25, %call_hi(weak_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %call_hi(weak_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XN64-NEXT: daddu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x2d]
|
|
|
|
# XN64-NEXT: ld $25, %call_lo(weak_label)($25) # encoding: [0xdf,0x39,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %call_lo(weak_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN64-NEXT: .reloc .Ltmp2, R_MIPS_JALR, weak_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_CALL_HI16/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
# ELF-XN64-NEXT: 03 3c c8 2d daddu $25, $25, $gp
|
|
|
|
# ELF-XN64-NEXT: df 39 00 00 ld $25, 0($25)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_CALL_LO16/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# O32-MM: lw $25, %call16(weak_label)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM: # fixup A - offset: 0, value: %call16(weak_label), kind: fixup_MICROMIPS_CALL16
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM-NEXT: .reloc ($tmp1), R_MICROMIPS_JALR, weak_label
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
jal weak_label+8
|
|
|
|
nop
|
|
|
|
|
|
|
|
# O32: lw $25, %got(weak_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(weak_label), kind: fixup_Mips_GOT
|
|
|
|
# O32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 weak_label
|
|
|
|
# ELF-O32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-O32-NEXT: 00 00 00 00 nop
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# XO32: lui $25, %got_hi(weak_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got_hi(weak_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XO32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XO32-NEXT: lw $25, %got_lo(weak_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got_lo(weak_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XO32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT_HI16 weak_label
|
|
|
|
# ELF-XO32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XO32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT_LO16 weak_label
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-XO32-NEXT: 00 00 00 00 nop
|
2019-11-10 19:53:36 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(weak_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(weak_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# N32-NEXT: .reloc .Ltmp3, R_MIPS_JALR, weak_label
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP weak_label
|
|
|
|
# ELF-N32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR weak_label
|
|
|
|
|
|
|
|
# XN32: lui $25, %got_hi(weak_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_hi(weak_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XN32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XN32-NEXT: lw $25, %got_lo(weak_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_lo(weak_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XN32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# XN32-NEXT: .reloc .Ltmp3, R_MIPS_JALR, weak_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 3c 19 00 00 lui $25, 0
|
2019-11-19 19:58:50 +08:00
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_HI16 weak_label+0x8
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XN32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_LO16 weak_label
|
|
|
|
# ELF-XN32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR weak_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(weak_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64: # fixup A - offset: 0, value: %got_disp(weak_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# N64-NEXT: .reloc .Ltmp3, R_MIPS_JALR, weak_label
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
# ELF-N64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
|
|
|
|
# XN64: lui $25, %got_hi(weak_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_hi(weak_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XN64-NEXT: daddu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x2d]
|
|
|
|
# XN64-NEXT: ld $25, %got_lo(weak_label)($25) # encoding: [0xdf,0x39,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_lo(weak_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XN64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# XN64-NEXT: .reloc .Ltmp3, R_MIPS_JALR, weak_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: 3c 19 00 00 lui $25, 0
|
2019-11-19 19:58:50 +08:00
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_HI16/R_MIPS_NONE/R_MIPS_NONE weak_label+0x8
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64-NEXT: 03 3c c8 2d daddu $25, $25, $gp
|
|
|
|
# ELF-XN64-NEXT: df 39 00 00 ld $25, 0($25)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_LO16/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
# ELF-XN64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE weak_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32-MM: lw $25, %got(weak_label)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(weak_label), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, 8 # encoding: [0x33,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM-NOT: .reloc
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
jal global_label
|
|
|
|
nop
|
2015-08-19 00:18:09 +08:00
|
|
|
|
|
|
|
# Expanding "jal global_label":
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32: lw $25, %call16(global_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %call16(global_label), kind: fixup_Mips_CALL16
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-NEXT: .reloc ($tmp2), R_MIPS_JALR, global_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_CALL16 global_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-O32-NEXT: R_MIPS_JALR global_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XO32: lui $25, %call_hi(global_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %call_hi(global_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XO32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XO32-NEXT: lw $25, %call_lo(global_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %call_lo(global_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NEXT: .reloc ($tmp2), R_MIPS_JALR, global_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_CALL_HI16 global_label
|
|
|
|
# ELF-XO32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XO32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_CALL_LO16 global_label
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_JALR global_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %call16(global_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %call16(global_label), kind: fixup_Mips_CALL16
|
|
|
|
# N32-NEXT: .reloc .Ltmp4, R_MIPS_JALR, global_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_CALL16 global_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR global_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN32: lui $25, %call_hi(global_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %call_hi(global_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XN32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XN32-NEXT: lw $25, %call_lo(global_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %call_lo(global_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN32-NEXT: .reloc .Ltmp4, R_MIPS_JALR, global_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_CALL_HI16 global_label
|
|
|
|
# ELF-XN32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XN32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_CALL_LO16 global_label
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR global_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %call16(global_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %call16(global_label), kind: fixup_Mips_CALL16
|
|
|
|
# N64-NEXT: .reloc .Ltmp4, R_MIPS_JALR, global_label
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_CALL16/R_MIPS_NONE/R_MIPS_NONE global_label
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE global_label
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN64: lui $25, %call_hi(global_label) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %call_hi(global_label), kind: fixup_Mips_CALL_HI16
|
|
|
|
# XN64-NEXT: daddu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x2d]
|
|
|
|
# XN64-NEXT: ld $25, %call_lo(global_label)($25) # encoding: [0xdf,0x39,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %call_lo(global_label), kind: fixup_Mips_CALL_LO16
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN64-NEXT: .reloc .Ltmp4, R_MIPS_JALR, global_label
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_CALL_HI16/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
# ELF-XN64-NEXT: 03 3c c8 2d daddu $25, $25, $gp
|
|
|
|
# ELF-XN64-NEXT: df 39 00 00 ld $25, 0($25)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_CALL_LO16/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# O32-MM: lw $25, %call16(global_label)($gp) # encoding: [0xff,0x3c,A,A]
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %call16(global_label), kind: fixup_MICROMIPS_CALL16
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM-NEXT: .reloc ($tmp2), R_MICROMIPS_JALR, global_label
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
jal global_label+8
|
|
|
|
nop
|
|
|
|
|
|
|
|
# O32: lw $25, %got(global_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(global_label), kind: fixup_Mips_GOT
|
|
|
|
# O32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 global_label
|
|
|
|
# ELF-O32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-O32-NEXT: 00 00 00 00 nop
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# XO32: lui $25, %got_hi(global_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got_hi(global_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XO32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XO32-NEXT: lw $25, %got_lo(global_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got_lo(global_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XO32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 3c 19 00 00 lui $25, 0
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT_HI16 global_label
|
|
|
|
# ELF-XO32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XO32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT_LO16 global_label
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-XO32-NEXT: 00 00 00 00 nop
|
2019-11-10 19:53:36 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(global_label)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(global_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# N32-NEXT: .reloc .Ltmp5, R_MIPS_JALR, global_label
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP global_label
|
|
|
|
# ELF-N32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-N32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N32-NEXT: R_MIPS_JALR global_label
|
|
|
|
|
|
|
|
# XN32: lui $25, %got_hi(global_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_hi(global_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XN32-NEXT: addu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x21]
|
|
|
|
# XN32-NEXT: lw $25, %got_lo(global_label)($25) # encoding: [0x8f,0x39,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_lo(global_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XN32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# XN32-NEXT: .reloc .Ltmp5, R_MIPS_JALR, global_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 3c 19 00 00 lui $25, 0
|
2019-11-19 19:58:50 +08:00
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_HI16 global_label+0x8
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32-NEXT: 03 3c c8 21 addu $25, $25, $gp
|
|
|
|
# ELF-XN32-NEXT: 8f 39 00 00 lw $25, 0($25)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_LO16 global_label
|
|
|
|
# ELF-XN32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR global_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(global_label)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(global_label), kind: fixup_Mips_GOT_DISP
|
|
|
|
# N64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# N64-NEXT: .reloc .Ltmp5, R_MIPS_JALR, global_label
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
# ELF-N64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-N64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-N64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
|
|
|
|
# XN64: lui $25, %got_hi(global_label+8) # encoding: [0x3c,0x19,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_hi(global_label+8), kind: fixup_Mips_GOT_HI16
|
|
|
|
# XN64-NEXT: daddu $25, $25, $gp # encoding: [0x03,0x3c,0xc8,0x2d]
|
|
|
|
# XN64-NEXT: ld $25, %got_lo(global_label)($25) # encoding: [0xdf,0x39,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_lo(global_label), kind: fixup_Mips_GOT_LO16
|
|
|
|
# XN64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# XN64-NEXT: .reloc .Ltmp5, R_MIPS_JALR, global_label
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: 3c 19 00 00 lui $25, 0
|
2019-11-19 19:58:50 +08:00
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_HI16/R_MIPS_NONE/R_MIPS_NONE global_label+0x8
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64-NEXT: 03 3c c8 2d daddu $25, $25, $gp
|
|
|
|
# ELF-XN64-NEXT: df 39 00 00 ld $25, 0($25)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_LO16/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
# ELF-XN64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE global_label
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32-MM: lw $25, %got(global_label)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(global_label), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, 8 # encoding: [0x33,0x39,0x00,0x08]
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM-NOT: .reloc
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
jal .text
|
|
|
|
nop
|
2015-08-19 00:18:09 +08:00
|
|
|
|
|
|
|
# Expanding "jal .text":
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32: lw $25, %got(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(.text), kind: fixup_Mips_GOT
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
2017-02-03 05:26:06 +08:00
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XO32: lw $25, %got(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got(.text), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo(.text) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo(.text), kind: fixup_Mips_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NEXT: .reloc ($tmp3), R_MIPS_JALR, .text
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 00 addiu $25, $25, 0
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_JALR .text
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP .text
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN32: lw $25, %got_disp(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN32-NEXT: .reloc .Ltmp6, R_MIPS_JALR, .text
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP .text
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR .text
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(.text)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
2019-11-09 15:35:21 +08:00
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .text
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2019-10-23 02:20:52 +08:00
|
|
|
# XN64: ld $25, %got_disp(.text)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN64-NEXT: .reloc .Ltmp6, R_MIPS_JALR, .text
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .text
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE .text
|
|
|
|
|
2017-02-03 05:26:06 +08:00
|
|
|
# O32-MM: lw $25, %got(.text)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(.text), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, %lo(.text) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %lo(.text), kind: fixup_MICROMIPS_LO16
|
2019-11-09 15:35:21 +08:00
|
|
|
# O42-MM-NEXT: .reloc ($tmp3), R_MICROMIPS_JALR, .text
|
|
|
|
|
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
jal .text+8
|
|
|
|
nop
|
|
|
|
|
|
|
|
# O32: lw $25, %got(.text+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(.text+8), kind: fixup_Mips_GOT
|
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
|
|
|
|
# XO32: lw $25, %got(.text+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got(.text+8), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo(.text+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo(.text+8), kind: fixup_Mips_LO16
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-XO32-NEXT: 00 00 00 00 nop
|
2019-11-10 19:53:36 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP .text
|
|
|
|
|
|
|
|
# XN32: lw $25, %got_disp(.text)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# XN32-NEXT: .reloc .Ltmp7, R_MIPS_JALR, .text
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP .text
|
|
|
|
# ELF-XN32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR .text
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(.text)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .text
|
|
|
|
|
|
|
|
# XN64: ld $25, %got_disp(.text)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(.text), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# XN64-NEXT: .reloc .Ltmp7, R_MIPS_JALR, .text
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .text
|
|
|
|
# ELF-XN64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE .text
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# O32-MM: lw $25, %got(.text+8)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(.text+8), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, %lo(.text+8) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %lo(.text+8), kind: fixup_MICROMIPS_LO16
|
|
|
|
# O42-MM-NEXT: .reloc ($tmp4), R_MICROMIPS_JALR, .text
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# local labels ($tmp symbols)
|
|
|
|
jal 1f
|
|
|
|
nop
|
2015-08-19 00:18:09 +08:00
|
|
|
|
|
|
|
# Expanding "jal 1f":
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32: lw $25, %got($tmp4)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got($tmp4), kind: fixup_Mips_GOT
|
|
|
|
# O32-NEXT: addiu $25, $25, %lo($tmp4) # encoding: [0x27,0x39,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %lo($tmp4), kind: fixup_Mips_LO16
|
|
|
|
# O32-NEXT: .reloc ($tmp5), R_MIPS_JALR, ($tmp4)
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
2019-11-09 15:35:21 +08:00
|
|
|
# ELF-O32-NEXT: 27 39 00 b8 addiu $25, $25, 184
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-O32-NEXT: R_MIPS_JALR $tmp0
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32: lw $25, %got($tmp4)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got($tmp4), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo($tmp4) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo($tmp4), kind: fixup_Mips_LO16
|
|
|
|
# XO32-NEXT: .reloc ($tmp5), R_MIPS_JALR, ($tmp4)
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 d8 addiu $25, $25, 216
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_JALR $tmp0
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(.Ltmp8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP .Ltmp0
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN32: lw $25, %got_disp(.Ltmp8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN32-NEXT: .reloc .Ltmp9, R_MIPS_JALR, .Ltmp8
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP .Ltmp0
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR .Ltmp0
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(.Ltmp8)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# XN64: ld $25, %got_disp(.Ltmp8)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN64-NEXT: .reloc .Ltmp9, R_MIPS_JALR, .Ltmp8
|
2019-10-23 02:20:52 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM: lw $25, %got($tmp4)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got($tmp4), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, %lo($tmp4) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %lo($tmp4), kind: fixup_MICROMIPS_LO16
|
|
|
|
# O32-MM-NEXT: .reloc ($tmp5), R_MICROMIPS_JALR, ($tmp4)
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
jal 1f+8
|
|
|
|
nop
|
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32: lw $25, %got(($tmp4)+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %got(($tmp4)+8), kind: fixup_Mips_GOT
|
|
|
|
# O32-NEXT: addiu $25, $25, %lo(($tmp4)+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# O32-NEXT: # fixup A - offset: 0, value: %lo(($tmp4)+8), kind: fixup_Mips_LO16
|
|
|
|
# O32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-O32-NEXT: 27 39 00 c0 addiu $25, $25, 192
|
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-O32-NEXT: 00 00 00 00 nop
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# XO32: lw $25, %got(($tmp4)+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %got(($tmp4)+8), kind: fixup_Mips_GOT
|
|
|
|
# XO32-NEXT: addiu $25, $25, %lo(($tmp4)+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# XO32-NEXT: # fixup A - offset: 0, value: %lo(($tmp4)+8), kind: fixup_Mips_LO16
|
|
|
|
# XO32-NOT: .reloc
|
2019-11-09 15:35:21 +08:00
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XO32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-XO32-NEXT: 27 39 00 e0 addiu $25, $25, 224
|
|
|
|
# ELF-XO32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-XO32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-XO32-NEXT: 00 00 00 00 nop
|
2019-11-10 19:53:36 +08:00
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N32: lw $25, %got_disp(.Ltmp8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP .Ltmp0
|
|
|
|
|
|
|
|
# XN32: lw $25, %got_disp(.Ltmp8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# XN32-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN32-NEXT: addiu $25, $25, 8 # encoding: [0x27,0x39,0x00,0x08]
|
|
|
|
# XN32-NEXT: .reloc .Ltmp10, R_MIPS_JALR, .Ltmp8
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_GOT_DISP .Ltmp0
|
|
|
|
# ELF-XN32-NEXT: 27 39 00 08 addiu $25, $25, 8
|
|
|
|
# ELF-XN32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN32-NEXT: R_MIPS_JALR .Ltmp0
|
|
|
|
|
2019-11-09 15:35:21 +08:00
|
|
|
# N64: ld $25, %got_disp(.Ltmp8)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
|
|
|
|
# XN64: ld $25, %got_disp(.Ltmp8)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# XN64-NEXT: # fixup A - offset: 0, value: %got_disp(.Ltmp8), kind: fixup_Mips_GOT_DISP
|
|
|
|
# XN64-NEXT: daddiu $25, $25, 8 # encoding: [0x67,0x39,0x00,0x08]
|
|
|
|
# XN64-NEXT: .reloc .Ltmp10, R_MIPS_JALR, .Ltmp8
|
|
|
|
|
2019-11-10 19:53:36 +08:00
|
|
|
# ELF-XN64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
# ELF-XN64-NEXT: 67 39 00 08 daddiu $25, $25, 8
|
|
|
|
# ELF-XN64-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-XN64-NEXT: R_MIPS_JALR/R_MIPS_NONE/R_MIPS_NONE .Ltmp0
|
|
|
|
|
2019-11-09 14:29:42 +08:00
|
|
|
# O32-MM: lw $25, %got(($tmp4)+8)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %got(($tmp4)+8), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-NEXT: addiu $25, $25, %lo(($tmp4)+8) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-NEXT: # fixup A - offset: 0, value: %lo(($tmp4)+8), kind: fixup_MICROMIPS_LO16
|
|
|
|
# O32-MM-NOT: .reloc
|
2015-08-19 00:18:09 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
.local forward_local
|
|
|
|
jal forward_local
|
|
|
|
nop
|
|
|
|
|
|
|
|
# Expanding "jal forward_local":
|
|
|
|
# O32-FIXME: lw $25, %got(forward_local)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-FIXME: # fixup A - offset: 0, value: %got(forward_local), kind: fixup_Mips_GOT
|
|
|
|
# O32-FIXME: addiu $25, $25, %lo(forward_local) # encoding: [0x27,0x39,A,A]
|
|
|
|
# O32-FIXME:: # fixup A - offset: 0, value: %lo(forward_local), kind: fixup_Mips_LO16
|
2018-12-10 23:07:36 +08:00
|
|
|
# O32-FIXME: .reloc ($tmp6), R_MIPS_JALR, forward_local
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
2019-11-09 15:35:21 +08:00
|
|
|
# ELF-O32-NEXT: 27 39 00 c4 addiu $25, $25, 196
|
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
|
|
|
# ELF-O32-NEXT: R_MIPS_JALR forward_local
|
|
|
|
|
|
|
|
# N32-FIXME: lw $25, %got_disp(forward_local)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-FIXME: # fixup A - offset: 0, value: %got_disp(forward_local), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP forward_local
|
|
|
|
|
|
|
|
# N64-FIXME: ld $25, %got_disp(forward_local)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-FIXME: # fixup A - offset: 0, value: %got_disp(forward_local), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE forward_local
|
|
|
|
|
|
|
|
# O32-MM-FIXME: lw $25, %got(forward_local)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-FIXME: # fixup A - offset: 0, value: %got(forward_local), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-FIXME: addiu $25, $25, %lo(forward_local) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-FIXME: # fixup A - offset: 0, value: %lo(forward_local), kind: fixup_MICROMIPS_LO16
|
|
|
|
# O32-MM-FIXME: .reloc ($tmp6), R_MIPS_JALR, forward_local
|
|
|
|
|
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
|
|
|
|
|
|
|
.local forward_local
|
|
|
|
jal forward_local+8
|
|
|
|
nop
|
|
|
|
|
|
|
|
# O32-FIXME: lw $25, %got(forward_local+8)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# O32-FIXME: # fixup A - offset: 0, value: %got(forward_local+8), kind: fixup_Mips_GOT
|
|
|
|
# O32-FIXME: addiu $25, $25, %lo(forward_local+8) # encoding: [0x27,0x39,A,A]
|
|
|
|
# O32-FIXME:: # fixup A - offset: 0, value: %lo(forward_local+8), kind: fixup_Mips_LO16
|
|
|
|
# O32-FIXME: .reloc ($tmp7), R_MIPS_JALR, forward_local
|
|
|
|
|
|
|
|
# ELF-O32: 8f 99 00 00 lw $25, 0($gp)
|
|
|
|
# ELF-O32-NEXT: R_MIPS_GOT16 .text
|
|
|
|
# ELF-O32-NEXT: 27 39 00 cc addiu $25, $25, 204
|
2016-11-25 19:06:43 +08:00
|
|
|
# ELF-O32-NEXT: R_MIPS_LO16 .text
|
2018-12-10 23:07:36 +08:00
|
|
|
# ELF-O32-NEXT: 03 20 f8 09 jalr $25
|
2019-11-09 14:29:42 +08:00
|
|
|
# ELF-O32-NEXT: 00 00 00 00 nop
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
# N32-FIXME: lw $25, %got_disp(forward_local)($gp) # encoding: [0x8f,0x99,A,A]
|
|
|
|
# N32-FIXME: # fixup A - offset: 0, value: %got_disp(forward_local), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N32: 8f 99 00 00 lw $25, 0($gp)
|
2017-09-21 18:44:26 +08:00
|
|
|
# ELF-N32-NEXT: R_MIPS_GOT_DISP forward_local
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
# N64-FIXME: ld $25, %got_disp(forward_local)($gp) # encoding: [0xdf,0x99,A,A]
|
|
|
|
# N64-FIXME: # fixup A - offset: 0, value: %got_disp(forward_local), kind: fixup_Mips_GOT_DISP
|
|
|
|
|
|
|
|
# ELF-N64: df 99 00 00 ld $25, 0($gp)
|
|
|
|
# ELF-N64-NEXT: R_MIPS_GOT_DISP/R_MIPS_NONE/R_MIPS_NONE forward_local
|
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# O32-MM-FIXME: lw $25, %got(forward_local)($gp) # encoding: [0xff,0x3c,A,A]
|
|
|
|
# O32-MM-FIXME: # fixup A - offset: 0, value: %got(forward_local), kind: fixup_MICROMIPS_GOT16
|
|
|
|
# O32-MM-FIXME: addiu $25, $25, %lo(forward_local) # encoding: [0x33,0x39,A,A]
|
|
|
|
# O32-MM-FIXME: # fixup A - offset: 0, value: %lo(forward_local), kind: fixup_MICROMIPS_LO16
|
2018-12-10 23:07:36 +08:00
|
|
|
# O32-MM-FIXME: .reloc ($tmp6), R_MIPS_JALR, forward_local
|
2016-11-25 19:06:43 +08:00
|
|
|
|
2016-12-13 01:40:26 +08:00
|
|
|
# MIPS: jalr $25 # encoding: [0x03,0x20,0xf8,0x09]
|
|
|
|
# MM: jalr $ra, $25 # encoding: [0x03,0xf9,0x0f,0x3c]
|
|
|
|
# ALL: nop # encoding: [0x00,0x00,0x00,0x00]
|
2016-11-25 19:06:43 +08:00
|
|
|
|
|
|
|
.end local_label
|
|
|
|
|
|
|
|
1:
|
|
|
|
nop
|
|
|
|
add $8, $8, $8
|
|
|
|
nop
|
|
|
|
forward_local:
|