[1/2] x86/COFF: support RVA (image-relative) relocations in insn operands
Checks
Context |
Check |
Description |
linaro-tcwg-bot/tcwg_binutils_build--master-arm |
success
|
Build passed
|
linaro-tcwg-bot/tcwg_binutils_build--master-aarch64 |
success
|
Build passed
|
linaro-tcwg-bot/tcwg_binutils_check--master-aarch64 |
success
|
Test passed
|
linaro-tcwg-bot/tcwg_binutils_check--master-arm |
success
|
Test passed
|
Commit Message
As was pointed out in [1] compilers produce code using such constructs,
and hence we'd better support this. In analogy to the .rva directive
permit @rva to be used for this, and in analogy with other architectures
(plus to not diverge from e.g. Clang's integrated assembler, albeit I
haven't been able myself to confirm it knows this form) also permit
@imgrel.
While there also adjust the operand type specifier for the adjacent
@secrel32 - 64-bit fields cannot be used with a 32-bit relocation.
Further while there also deal with *-*-pe* in x86-64.exp, even if (right
now) perhaps only for completeness.
[1] https://sourceware.org/pipermail/binutils/2024-November/137548.html
---
I question the usefulness (to users) of the relocation names chosen for
64-bit: IMAGE_REL_AMD64_* is quite a bit too verbose (and yet uglier to
write when one already needs to resort to using .reloc) than the names
used for 32-bit. Question though is whether this can reasonably be
changed.
@@ -1409,7 +1409,13 @@ gotrel[] =
#else /* TE_PE */
{ STRING_COMMA_LEN ("SECREL32"), { BFD_RELOC_32_SECREL,
BFD_RELOC_32_SECREL },
- OPERAND_TYPE_IMM32_32S_64_DISP32_64, false },
+ OPERAND_TYPE_IMM32_32S_DISP32, false },
+ { STRING_COMMA_LEN ("RVA"), { BFD_RELOC_RVA,
+ BFD_RELOC_RVA },
+ OPERAND_TYPE_IMM32_32S_DISP32, false },
+ { STRING_COMMA_LEN ("IMGREL"), { BFD_RELOC_RVA,
+ BFD_RELOC_RVA },
+ OPERAND_TYPE_IMM32_32S_DISP32, false },
#endif
#undef OPERAND_TYPE_IMM32_32S_DISP32
@@ -805,6 +805,7 @@ if [gas_32_check] then {
} then {
run_dump_test "secrel"
run_dump_test "secidx"
+ run_dump_test "imgrel"
}
# Miscellaneous tests.
@@ -0,0 +1,40 @@
+#objdump: -rs
+#name: i386 imgrel (RVA) reloc
+
+.*: +file format pe-i386
+
+RELOCATION RECORDS FOR \[\.text\]:
+OFFSET[ ]+TYPE[ ]+VALUE
+0+01 rva32 \.text
+0+06 rva32 \.text
+0+0c rva32 \.data
+0+12 rva32 \.data
+0+17 rva32 \.text
+0+1d rva32 \.text
+0+23 rva32 Xtrn
+0+29 rva32 Xtrn
+
+RELOCATION RECORDS FOR \[\.data\]:
+OFFSET[ ]+TYPE[ ]+VALUE
+0+00 rva32 \.text
+0+04 rva32 \.text
+0+08 rva32 \.text
+0+0c rva32 \.data
+0+10 rva32 \.data
+0+14 rva32 \.data
+0+18 rva32 \.data
+0+1c rva32 \.data
+0+20 rva32 \.data
+0+24 rva32 Xtrn
+0+28 rva32 Xtrn
+0+2c rva32 Xtrn
+
+Contents of section \.text:
+ 0000 b8000000 00b90000 00000305 00000000 .*
+ 0010 030d0000 00002d16 00000081 e91b0000 .*
+ 0020 00338300 00000033 8b000000 00.*
+
+Contents of section \.data:
+ 0000 00000000 00000000 00000000 00000000 .*
+ 0010 00000000 00000000 18000000 1c000000 .*
+ 0020 20000000 00000000 00000000 00000000 .*
@@ -0,0 +1,31 @@
+ .text
+Text:
+ mov $Text@rva, %eax
+ mov $Text@imgrel, %ecx
+
+ add Data@rva, %eax
+ add Data@imgrel, %ecx
+
+ sub $.@rva, %eax
+ sub $.@imgrel, %ecx
+
+ xor Xtrn@rva(%ebx), %eax
+ xor Xtrn@imgrel(%ebx), %ecx
+
+ .data
+Data:
+ .rva Text
+ .long Text@rva
+ .long Text@imgrel
+
+ .rva Data
+ .long Data@rva
+ .long Data@imgrel
+
+ .rva .
+ .long .@rva
+ .long .@imgrel
+
+ .rva Xtrn
+ .long Xtrn@rva
+ .long Xtrn@imgrel
@@ -52,11 +52,14 @@ run_dump_test "x86-64-addr32-intel"
run_list_test "x86-64-addr32-bad" "-al"
run_dump_test "x86-64-opcode"
run_dump_test "x86-64-intel64"
-if { ! [istarget "*-*-*cygwin*"] && ![istarget "*-*-mingw*"] } then {
+if { ![istarget "*-*-*cygwin*"]
+ && ![istarget "*-*-mingw*"]
+ && ![istarget "*-*-pe*"] } then {
run_dump_test "x86-64-pcrel"
run_dump_test "x86-64-disassem"
} else {
run_dump_test "x86-64-w64-pcrel"
+ run_dump_test "x86-64-imgrel"
}
run_list_test "pcrel64" "-al"
run_dump_test "x86-64-rip"
@@ -0,0 +1,40 @@
+#objdump: -rs
+#name: x86-64 imgrel (RVA) reloc
+
+.*: +file format pe-x86-64
+
+RELOCATION RECORDS FOR \[\.text\]:
+OFFSET[ ]+TYPE[ ]+VALUE
+0+01 IMAGE_REL_AMD64_ADDR32NB \.text
+0+06 IMAGE_REL_AMD64_ADDR32NB \.text
+0+0d IMAGE_REL_AMD64_ADDR32NB \.data
+0+14 IMAGE_REL_AMD64_ADDR32NB \.data
+0+19 IMAGE_REL_AMD64_ADDR32NB \.text
+0+1f IMAGE_REL_AMD64_ADDR32NB \.text
+0+25 IMAGE_REL_AMD64_ADDR32NB Xtrn
+0+2b IMAGE_REL_AMD64_ADDR32NB Xtrn
+
+RELOCATION RECORDS FOR \[\.data\]:
+OFFSET[ ]+TYPE[ ]+VALUE
+0+00 IMAGE_REL_AMD64_ADDR32NB \.text
+0+04 IMAGE_REL_AMD64_ADDR32NB \.text
+0+08 IMAGE_REL_AMD64_ADDR32NB \.text
+0+0c IMAGE_REL_AMD64_ADDR32NB \.data
+0+10 IMAGE_REL_AMD64_ADDR32NB \.data
+0+14 IMAGE_REL_AMD64_ADDR32NB \.data
+0+18 IMAGE_REL_AMD64_ADDR32NB \.data
+0+1c IMAGE_REL_AMD64_ADDR32NB \.data
+0+20 IMAGE_REL_AMD64_ADDR32NB \.data
+0+24 IMAGE_REL_AMD64_ADDR32NB Xtrn
+0+28 IMAGE_REL_AMD64_ADDR32NB Xtrn
+0+2c IMAGE_REL_AMD64_ADDR32NB Xtrn
+
+Contents of section \.text:
+ 0000 b8000000 00b90000 00000304 25000000 .*
+ 0010 00030c25 00000000 2d180000 0081e91d .*
+ 0020 00000033 83000000 00338b00 000000.*
+
+Contents of section \.data:
+ 0000 00000000 00000000 00000000 00000000 .*
+ 0010 00000000 00000000 18000000 1c000000 .*
+ 0020 20000000 00000000 00000000 00000000 .*
@@ -0,0 +1,31 @@
+ .text
+Text:
+ mov $Text@rva, %eax
+ mov $Text@imgrel, %ecx
+
+ add Data@rva, %eax
+ add Data@imgrel, %ecx
+
+ sub $.@rva, %eax
+ sub $.@imgrel, %ecx
+
+ xor Xtrn@rva(%rbx), %eax
+ xor Xtrn@imgrel(%rbx), %ecx
+
+ .data
+Data:
+ .rva Text
+ .long Text@rva
+ .long Text@imgrel
+
+ .rva Data
+ .long Data@rva
+ .long Data@imgrel
+
+ .rva .
+ .long .@rva
+ .long .@imgrel
+
+ .rva Xtrn
+ .long Xtrn@rva
+ .long Xtrn@imgrel