binutils/binutils-ld-rosegment.patch
2024-06-13 17:14:07 +01:00

1817 lines
70 KiB
Diff

diff -rupN binutils.orig/bfd/elf.c binutils-2.41/bfd/elf.c
--- binutils.orig/bfd/elf.c 2024-06-13 15:12:09.941469205 +0100
+++ binutils-2.41/bfd/elf.c 2024-06-13 15:15:52.653310471 +0100
@@ -5344,7 +5344,9 @@ _bfd_elf_map_sections_to_segments (bfd *
thus not executable, and the first section is
executable then put the file and program headers in
their own PT_LOAD. */
- separate_phdr = true;
+ if (!info->one_rosegment)
+ separate_phdr = true;
+
if ((((phdr_lma + phdr_size - 1) & addr_mask & -maxpagesize)
== (sections[0]->lma & addr_mask & -maxpagesize)))
{
diff -rupN binutils.orig/include/bfdlink.h binutils-2.41/include/bfdlink.h
--- binutils.orig/include/bfdlink.h 2024-06-13 15:12:12.208465462 +0100
+++ binutils-2.41/include/bfdlink.h 2024-06-13 15:15:52.653310471 +0100
@@ -423,6 +423,9 @@ struct bfd_link_info
/* TRUE if separate code segment should be created. */
unsigned int separate_code: 1;
+ /* TRUE if only one read-only, non-code segment should be created. */
+ unsigned int one_rosegment: 1;
+
/* Nonzero if .eh_frame_hdr section and PT_GNU_EH_FRAME ELF segment
should be created. 1 for DWARF2 tables, 2 for compact tables. */
unsigned int eh_frame_hdr_type: 2;
diff -rupN binutils.orig/ld/NEWS binutils-2.41/ld/NEWS
--- binutils.orig/ld/NEWS 2024-06-13 15:12:13.177463862 +0100
+++ binutils-2.41/ld/NEWS 2024-06-13 15:15:52.653310471 +0100
@@ -1,5 +1,9 @@
-*- text -*-
+* Add --rosegment option which changes the -z separate-code option so that
+ only one read-only segment is created (instead of two). (The option name
+ is misleading, but it matches the name used by LLD and GOLD).
+
* Add --section-ordering-file <FILE> option to add extra mapping of input
sections to output sections.
diff -rupN binutils.orig/ld/config.in binutils-2.41/ld/config.in
--- binutils.orig/ld/config.in 2024-06-13 15:12:13.182463854 +0100
+++ binutils-2.41/ld/config.in 2024-06-13 15:15:52.653310471 +0100
@@ -45,6 +45,10 @@
default. */
#undef DEFAULT_LD_WARN_RWX_SEGMENTS
+/* Define to 1 if you want to enable --rosegment in the ELF linker by
+ default. */
+#undef DEFAULT_LD_ROSEGMENT
+
/* Define to 1 if you want to enable -z relro in ELF linker by default. */
#undef DEFAULT_LD_Z_RELRO
diff -rupN binutils.orig/ld/configure binutils-2.41/ld/configure
--- binutils.orig/ld/configure 2024-06-13 15:12:13.182463854 +0100
+++ binutils-2.41/ld/configure 2024-06-13 15:18:15.402877779 +0100
@@ -847,6 +847,7 @@ enable_new_dtags
enable_relro
enable_textrel_check
enable_separate_code
+enable_rosegment
enable_warn_execstack
enable_error_execstack
enable_warn_rwx_segments
@@ -1536,6 +1537,7 @@ Optional Features:
--enable-textrel-check=[yes|no|warning|error]
enable DT_TEXTREL check in ELF linker
--enable-separate-code enable -z separate-code in ELF linker by default
+ --enable-rosegment enable --rosegment in the ELF linker by default
--enable-warn-execstack enable warnings when creating an executable stack
--enable-warn-rwx-segments
enable warnings when creating segements with RWX
@@ -15627,6 +15629,16 @@ esac
fi
+# Decide if --rosegment should be enabled in the ELF linker by default.
+ac_default_ld_rosegment=unset
+# Check whether --enable-rosegment was given.
+if test "${enable_rosegment+set}" = set; then :
+ enableval=$enable_rosegment; case "${enableval}" in
+ yes) ac_default_ld_rosegment=1 ;;
+ no) ac_default_ld_rosegment=0 ;;
+esac
+fi
+
# By default warn when an executable stack is created due to object files
# requesting such, not when the user specifies -z execstack.
@@ -17457,6 +17469,13 @@ cat >>confdefs.h <<_ACEOF
_ACEOF
+if test "${ac_default_ld_rosegment}" = unset; then
+ ac_default_ld_rosegment=0
+fi
+
+cat >>confdefs.h <<_ACEOF
+#define DEFAULT_LD_ROSEGMENT $ac_default_ld_rosegment
+_ACEOF
cat >>confdefs.h <<_ACEOF
diff -rupN binutils.orig/ld/configure.ac binutils-2.41/ld/configure.ac
--- binutils.orig/ld/configure.ac 2024-06-13 15:12:13.182463854 +0100
+++ binutils-2.41/ld/configure.ac 2024-06-13 15:17:02.889589604 +0100
@@ -213,6 +213,15 @@ AC_ARG_ENABLE(separate-code,
no) ac_default_ld_z_separate_code=0 ;;
esac])
+# Decide if --rosegment should be enabled in the ELF linker by default.
+ac_default_ld_rosegment=unset
+AC_ARG_ENABLE(rosegment,
+ AS_HELP_STRING([--enable-rosegment],
+ [enable --rosegment in the ELF linker by default]),
+[case "${enableval}" in
+ yes) ac_default_ld_rosegment=1 ;;
+ no) ac_default_ld_rosegment=0 ;;
+esac])
# By default warn when an executable stack is created due to object files
# requesting such, not when the user specifies -z execstack.
@@ -581,6 +590,12 @@ AC_DEFINE_UNQUOTED(DEFAULT_LD_Z_SEPARATE
$ac_default_ld_z_separate_code,
[Define to 1 if you want to enable -z separate-code in ELF linker by default.])
+if test "${ac_default_ld_rosegment}" = unset; then
+ ac_default_ld_rosegment=0
+fi
+AC_DEFINE_UNQUOTED(DEFAULT_LD_ROSEGMENT,
+ $ac_default_ld_rosegment,
+ [Define to 1 if you want to enable --rosegment in the ELF linker by default.])
AC_DEFINE_UNQUOTED(DEFAULT_LD_WARN_EXECSTACK,
$ac_default_ld_warn_execstack,
diff -rupN binutils.orig/ld/emultempl/elf.em binutils-2.41/ld/emultempl/elf.em
--- binutils.orig/ld/emultempl/elf.em 2024-06-13 15:12:12.354465221 +0100
+++ binutils-2.41/ld/emultempl/elf.em 2024-06-13 15:15:52.661310503 +0100
@@ -92,6 +92,7 @@ EOF
fi
fragment <<EOF
link_info.separate_code = DEFAULT_LD_Z_SEPARATE_CODE;
+ link_info.one_rosegment = DEFAULT_LD_ROSEGMENT;
link_info.warn_execstack = DEFAULT_LD_WARN_EXECSTACK;
link_info.no_warn_rwx_segments = ! DEFAULT_LD_WARN_RWX_SEGMENTS;
link_info.default_execstack = DEFAULT_LD_EXECSTACK;
@@ -211,151 +212,303 @@ fragment <<EOF
return
EOF
sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c
+
echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c
+
if cmp -s ldscripts/${EMULATION_NAME}.x ldscripts/${EMULATION_NAME}.xn; then : ; else
-echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
-sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
+ echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c
+ sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c
fi
+
if test -n "$GENERATE_PIE_SCRIPT" ; then
if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xdwer >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdwe >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdw >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xdceor >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdceo >> e${EMULATION_NAME}.c
+
fi
+
+echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xdcer >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdce >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdco >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdc >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xdeor >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdeo >> e${EMULATION_NAME}.c
+
fi
+
fi
+
+echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xder >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xde >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (bfd_link_pie (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xdo >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else if (bfd_link_pie (&link_info)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xd >> e${EMULATION_NAME}.c
fi
+
if test -n "$GENERATE_SHLIB_SCRIPT" ; then
if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xswer >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xswe >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xsw >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xsceor >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xsceo >> e${EMULATION_NAME}.c
+
fi
+
+echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xscer >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xsce >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xsco >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.combreloc) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xsc >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xseor >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xseo >> e${EMULATION_NAME}.c
+
fi
+
fi
+
+echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xser >> e${EMULATION_NAME}.c
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xse >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (bfd_link_dll (&link_info)' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xso >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else if (bfd_link_dll (&link_info)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xs >> e${EMULATION_NAME}.c
+
fi
+
if test -n "$GENERATE_COMBRELOC_SCRIPT" ; then
+
echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xwe >> e${EMULATION_NAME}.c
+
+echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xwer >> e${EMULATION_NAME}.c
+
echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro' >> e${EMULATION_NAME}.c
echo ' && (link_info.flags & DF_BIND_NOW)) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xw >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xceor >> e${EMULATION_NAME}.c
+
echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xceo >> e${EMULATION_NAME}.c
+
fi
+
+echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xcer >> e${EMULATION_NAME}.c
+
echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.separate_code) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xce >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (link_info.combreloc' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xco >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else if (link_info.combreloc) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xc >> e${EMULATION_NAME}.c
+
fi
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
+echo ' ; else if (link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment' >> e${EMULATION_NAME}.c
+echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xeor >> e${EMULATION_NAME}.c
+
echo ' ; else if (link_info.separate_code' >> e${EMULATION_NAME}.c
echo ' && link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xeo >> e${EMULATION_NAME}.c
+
fi
+
+echo ' ; else if (link_info.separate_code' >> e${EMULATION_NAME}.c
+echo ' && link_info.one_rosegment) return' >> e${EMULATION_NAME}.c
+sed $sc ldscripts/${EMULATION_NAME}.xer >> e${EMULATION_NAME}.c
+
echo ' ; else if (link_info.separate_code) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xe >> e${EMULATION_NAME}.c
+
if test -n "$GENERATE_RELRO_SCRIPT" ; then
+
echo ' ; else if (link_info.relro) return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.xo >> e${EMULATION_NAME}.c
+
fi
+
echo ' ; else return' >> e${EMULATION_NAME}.c
sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c
echo '; }' >> e${EMULATION_NAME}.c
@@ -390,7 +543,12 @@ fragment <<EOF
&& (link_info.flags & DF_BIND_NOW))
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xdwe";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xdwer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xdwe";
+ }
else
return "ldscripts/${EMULATION_NAME}.xdw";
}
@@ -402,7 +560,12 @@ fragment <<EOF
&& link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xdceo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xdceor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xdceo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xdco";
}
@@ -413,7 +576,12 @@ fragment <<EOF
&& link_info.combreloc)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xdce";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xdcer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xdce";
+ }
else
return "ldscripts/${EMULATION_NAME}.xdc";
}
@@ -425,7 +593,12 @@ fragment <<EOF
&& link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xdeo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xdeor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xdeo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xdo";
}
@@ -435,7 +608,12 @@ fragment <<EOF
else if (bfd_link_pie (&link_info))
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xde";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xder";
+ else
+ return "ldscripts/${EMULATION_NAME}.xde";
+ }
else
return "ldscripts/${EMULATION_NAME}.xd";
}
@@ -448,7 +626,12 @@ fragment <<EOF
&& link_info.relro && (link_info.flags & DF_BIND_NOW))
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xswe";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xswer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xswe";
+ }
else
return "ldscripts/${EMULATION_NAME}.xsw";
}
@@ -460,7 +643,12 @@ fragment <<EOF
&& link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xsceo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xsceor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xsceo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xsco";
}
@@ -470,7 +658,12 @@ fragment <<EOF
else if (bfd_link_dll (&link_info) && link_info.combreloc)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xsce";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xscer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xsce";
+ }
else
return "ldscripts/${EMULATION_NAME}.xsc";
}
@@ -482,7 +675,12 @@ fragment <<EOF
&& link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xseo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xseor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xseo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xso";
}
@@ -492,7 +690,12 @@ fragment <<EOF
else if (bfd_link_dll (&link_info))
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xse";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xser";
+ else
+ return "ldscripts/${EMULATION_NAME}.xse";
+ }
else
return "ldscripts/${EMULATION_NAME}.xs";
}
@@ -504,7 +707,12 @@ fragment <<EOF
&& (link_info.flags & DF_BIND_NOW))
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xwe";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xwer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xwe";
+ }
else
return "ldscripts/${EMULATION_NAME}.xw";
}
@@ -515,7 +723,12 @@ fragment <<EOF
&& link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xceo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xceor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xceo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xco";
}
@@ -525,7 +738,12 @@ fragment <<EOF
else if (link_info.combreloc)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xce";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xcer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xce";
+ }
else
return "ldscripts/${EMULATION_NAME}.xc";
}
@@ -536,7 +754,12 @@ fragment <<EOF
else if (link_info.relro)
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xeo";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xeor";
+ else
+ return "ldscripts/${EMULATION_NAME}.xeo";
+ }
else
return "ldscripts/${EMULATION_NAME}.xo";
}
@@ -546,7 +769,12 @@ fragment <<EOF
else
{
if (link_info.separate_code)
- return "ldscripts/${EMULATION_NAME}.xe";
+ {
+ if (link_info.one_rosegment)
+ return "ldscripts/${EMULATION_NAME}.xer";
+ else
+ return "ldscripts/${EMULATION_NAME}.xe";
+ }
else
return "ldscripts/${EMULATION_NAME}.x";
}
@@ -607,6 +835,8 @@ fragment <<EOF
{"build-id", optional_argument, NULL, OPTION_BUILD_ID},
{"package-metadata", optional_argument, NULL, OPTION_PACKAGE_METADATA},
{"compress-debug-sections", required_argument, NULL, OPTION_COMPRESS_DEBUG},
+ {"rosegment", no_argument, NULL, OPTION_ROSEGMENT},
+ {"no-rosegment", no_argument, NULL, OPTION_NO_ROSEGMENT},
EOF
if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
fragment <<EOF
@@ -675,6 +905,13 @@ gld${EMULATION_NAME}_handle_option (int
einfo (_("%F%P: invalid --compress-debug-sections option: \`%s'\n"),
optarg);
break;
+
+ case OPTION_ROSEGMENT:
+ link_info.one_rosegment = true;
+ break;
+ case OPTION_NO_ROSEGMENT:
+ link_info.one_rosegment = false;
+ break;
EOF
if test x"$GENERATE_SHLIB_SCRIPT" = xyes; then
diff -rupN binutils.orig/ld/genscripts.sh binutils-2.41/ld/genscripts.sh
--- binutils.orig/ld/genscripts.sh 2024-06-13 15:12:12.356465217 +0100
+++ binutils-2.41/ld/genscripts.sh 2024-06-13 15:15:52.661310503 +0100
@@ -64,35 +64,50 @@
# following suffixes might be generated as well:
#
# xdwe: -pie -z combreloc -z separate-code -z relro -z now
+# xdwer: -pie -z combreloc -z separate-code -z relro -z now -z one-rosegment
# xdw: -pie -z combreloc -z relro -z now
# xdceo: -pie -z combreloc -z separate-code -z relro
+# xdceor: -pie -z combreloc -z separate-code -z relro -z one-rosegment
# xdce: -pie -z combreloc -z separate-code
+# xdcer: -pie -z combreloc -z separate-code -z one-rosegment
# xdco: -pie -z combreloc -z relro
# xdc: -pie -z combreloc
# xdeo: -pie -z separate-code -z relro
+# xdeor: -pie -z separate-code -z relro -z one-rosegment
# xde: -pie -z separate-code
+# xder: -pie -z separate-code -z one-rosegment
# xdo: -pie -z relro
# xd: -pie
#
# xswe: -shared -z combreloc -z separate-code -z relro -z now
+# xswer: -shared -z combreloc -z separate-code -z relro -z now -z one-rosegment
# xsw: -shared -z combreloc -z relro -z now
# xsceo: -shared -z combreloc -z separate-code -z relro
+# xsceor: -shared -z combreloc -z separate-code -z relro -z one-rosegment
# xsce: -shared -z combreloc -z separate-code
+# xscer: -shared -z combreloc -z separate-code -z one-rosegment
# xsco: -shared -z combreloc -z relro
# xsc: -shared -z combreloc
# xseo: -shared -z separate-code -z relro
+# xseor: -shared -z separate-code -z relro -z one-rosegment
# xse: -shared -z separate-code
+# xser: -shared -z separate-code -z one-rosegment
# xso: -shared -z relro
# xs: -shared
#
-# xwe: -z combreloc -z separate-code -z relro -z now
+# xwe: -z combreloc -z separate-code -z relro -z now -z one-rosegment
+# xwer: -z combreloc -z separate-code -z relro -z now
# xw: -z combreloc -z relro -z now
# xceo: -z combreloc -z separate-code -z relro
+# xceor: -z combreloc -z separate-code -z relro -z one-rosegment
# xce: -z combreloc -z separate-code
+# xcer: -z combreloc -z separate-code -z one-rosegment
# xco: -z combreloc -z relro
# xc: -z combreloc
# xeo: -z separate-code -z relro
+# xeor: -z separate-code -z relro -z one-rosegment
# xe: -z separate-code
+# xer: -z separate-code -z one-rosegment
# xo: -z relro
#
#
@@ -301,6 +316,8 @@ DATA_ALIGNMENT_N="${DATA_ALIGNMENT_N-${D
DATA_ALIGNMENT_r="${DATA_ALIGNMENT_r-${DATA_ALIGNMENT-}}"
DATA_ALIGNMENT_u="${DATA_ALIGNMENT_u-${DATA_ALIGNMENT_r}}"
+# Create scripts using different settings of the LD_FLAG variable
+
LD_FLAG=r
DATA_ALIGNMENT=${DATA_ALIGNMENT_r}
DEFAULT_DATA_ALIGNMENT="ALIGN(${SEGMENT_SIZE})"
@@ -331,20 +348,36 @@ LD_FLAG=textonly
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xe
+LD_FLAG=rotextonly
+( echo "/* Script for -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xer
+
if test -n "$GENERATE_RELRO_SCRIPT"; then
- LD_FLAG=
RELRO=" "
+
+ LD_FLAG=
( echo "/* Script for -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xo
+
LD_FLAG=textonly
( echo "/* Script for -z separate-code -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xeo
+
+ LD_FLAG=rotextonly
+ ( echo "/* Script for -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xeor
+
unset RELRO
fi
+
LD_FLAG=n
DATA_ALIGNMENT=${DATA_ALIGNMENT_n}
( echo "/* Script for -n */"
@@ -368,6 +401,7 @@ if test -n "$GENERATE_COMBRELOC_SCRIPT";
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xc
rm -f ${COMBRELOC}
+
LD_FLAG=ctextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xce.tmp
( echo "/* Script for -z combreloc -z separate-code */"
@@ -375,7 +409,17 @@ if test -n "$GENERATE_COMBRELOC_SCRIPT";
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xce
rm -f ${COMBRELOC}
+
+ LD_FLAG=roctextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xcer.tmp
+ ( echo "/* Script for -z combreloc -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xcer
+ rm -f ${COMBRELOC}
+
RELRO_NOW=" "
+
LD_FLAG=w
COMBRELOC=ldscripts/${EMULATION_NAME}.xw.tmp
( echo "/* Script for -z combreloc -z relro -z now */"
@@ -383,6 +427,7 @@ if test -n "$GENERATE_COMBRELOC_SCRIPT";
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xw
rm -f ${COMBRELOC}
+
LD_FLAG=wtextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xwe.tmp
( echo "/* Script for -z combreloc -z separate-code -z relro -z now */"
@@ -391,16 +436,29 @@ if test -n "$GENERATE_COMBRELOC_SCRIPT";
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xwe
rm -f ${COMBRELOC}
COMBRELOC=
+
+ LD_FLAG=rowtextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xwer.tmp
+ ( echo "/* Script for -z combreloc -z separate-code -z relro -z now -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xwer
+ rm -f ${COMBRELOC}
+ COMBRELOC=
+
unset RELRO_NOW
+
if test -n "$GENERATE_RELRO_SCRIPT"; then
- LD_FLAG=c
RELRO=" "
+
+ LD_FLAG=c
COMBRELOC=ldscripts/${EMULATION_NAME}.xco.tmp
( echo "/* Script for -z combreloc -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xco
rm -f ${COMBRELOC}
+
LD_FLAG=ctextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xceo.tmp
( echo "/* Script for -z combreloc -z separate-code -z relro */"
@@ -409,38 +467,66 @@ if test -n "$GENERATE_COMBRELOC_SCRIPT";
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xceo
rm -f ${COMBRELOC}
COMBRELOC=
+
+ LD_FLAG=roctextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xceor.tmp
+ ( echo "/* Script for -z combreloc -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xceor
+ rm -f ${COMBRELOC}
+ COMBRELOC=
+
unset RELRO
fi
fi
if test -n "$GENERATE_SHLIB_SCRIPT"; then
- DATA_ALIGNMENT=${DATA_ALIGNMENT_s-${DATA_ALIGNMENT_}}
CREATE_SHLIB=" "
+ DATA_ALIGNMENT=${DATA_ALIGNMENT_s-${DATA_ALIGNMENT_}}
+
LD_FLAG=shared
( echo "/* Script for -shared */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xs
+
LD_FLAG=sharedtextonly
( echo "/* Script for -shared -z separate-code */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xse
+ LD_FLAG=rosharedtextonly
+ ( echo "/* Script for -shared -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xser
+
if test -n "$GENERATE_RELRO_SCRIPT"; then
RELRO=" "
+
LD_FLAG=shared
( echo "/* Script for -shared -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xso
+
LD_FLAG=sharedtextonly
( echo "/* Script for -shared -z separate-code -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xseo
+
+ LD_FLAG=rosharedtextonly
+ ( echo "/* Script for -shared -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xseor
+
unset RELRO
fi
+
if test -n "$GENERATE_COMBRELOC_SCRIPT"; then
DATA_ALIGNMENT=${DATA_ALIGNMENT_sc-${DATA_ALIGNMENT}}
LD_FLAG=cshared
@@ -450,6 +536,7 @@ if test -n "$GENERATE_SHLIB_SCRIPT"; the
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsc
rm -f ${COMBRELOC}
+
LD_FLAG=csharedtextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xsce.tmp
( echo "/* Script for -shared -z combreloc -z separate-code */"
@@ -457,7 +544,17 @@ if test -n "$GENERATE_SHLIB_SCRIPT"; the
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsce
rm -f ${COMBRELOC}
+
+ LD_FLAG=rocsharedtextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xscer.tmp
+ ( echo "/* Script for -shared -z combreloc -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xscer
+ rm -f ${COMBRELOC}
+
RELRO_NOW=" "
+
LD_FLAG=wshared
COMBRELOC=ldscripts/${EMULATION_NAME}.xsw.tmp
( echo "/* Script for -shared -z combreloc -z relro -z now */"
@@ -465,6 +562,7 @@ if test -n "$GENERATE_SHLIB_SCRIPT"; the
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsw
rm -f ${COMBRELOC}
+
LD_FLAG=wsharedtextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xswe.tmp
( echo "/* Script for -shared -z combreloc -z separate-code -z relro -z now */"
@@ -472,17 +570,28 @@ if test -n "$GENERATE_SHLIB_SCRIPT"; the
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xswe
rm -f ${COMBRELOC}
+
+ LD_FLAG=rowsharedtextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xswe.tmp
+ ( echo "/* Script for -shared -z combreloc -z separate-code -z relro -z now -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xswer
+ rm -f ${COMBRELOC}
+
unset RELRO_NOW
if test -n "$GENERATE_RELRO_SCRIPT"; then
- LD_FLAG=wshared
RELRO=" "
+
+ LD_FLAG=wshared
COMBRELOC=ldscripts/${EMULATION_NAME}.xsco.tmp
( echo "/* Script for -shared -z combreloc -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsco
rm -f ${COMBRELOC}
+
LD_FLAG=wsharedtextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xsceo.tmp
( echo "/* Script for -shared -z combreloc -z separate-code -z relro */"
@@ -490,40 +599,70 @@ if test -n "$GENERATE_SHLIB_SCRIPT"; the
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsceo
rm -f ${COMBRELOC}
+
+ LD_FLAG=rowsharedtextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xsceor.tmp
+ ( echo "/* Script for -shared -z combreloc -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xsceor
+ rm -f ${COMBRELOC}
+
unset RELRO
fi
+
COMBRELOC=
fi
+
unset CREATE_SHLIB
fi
if test -n "$GENERATE_PIE_SCRIPT"; then
- DATA_ALIGNMENT=${DATA_ALIGNMENT_s-${DATA_ALIGNMENT_}}
CREATE_PIE=" "
+
+ DATA_ALIGNMENT=${DATA_ALIGNMENT_s-${DATA_ALIGNMENT_}}
LD_FLAG=pie
( echo "/* Script for -pie */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xd
+
LD_FLAG=pietextonly
( echo "/* Script for -pie -z separate-code */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xde
+
+ LD_FLAG=ropietextonly
+ ( echo "/* Script for -pie -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xder
+
if test -n "$GENERATE_RELRO_SCRIPT"; then
RELRO=" "
+
LD_FLAG=pie
( echo "/* Script for -pie -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdo
+
LD_FLAG=pietextonly
( echo "/* Script for -pie -z separate-code -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdeo
+
+ LD_FLAG=ropietextonly
+ ( echo "/* Script for -pie -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdeor
+
unset RELRO
fi
+
if test -n "$GENERATE_COMBRELOC_SCRIPT"; then
DATA_ALIGNMENT=${DATA_ALIGNMENT_sc-${DATA_ALIGNMENT}}
COMBRELOC=ldscripts/${EMULATION_NAME}.xdc.tmp
@@ -533,6 +672,7 @@ if test -n "$GENERATE_PIE_SCRIPT"; then
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdc
rm -f ${COMBRELOC}
+
LD_FLAG=cpietextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xdce.tmp
( echo "/* Script for -pie -z combreloc -z separate-code */"
@@ -540,7 +680,17 @@ if test -n "$GENERATE_PIE_SCRIPT"; then
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdce
rm -f ${COMBRELOC}
+
+ LD_FLAG=rocpietextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xdcer.tmp
+ ( echo "/* Script for -pie -z combreloc -z separate-code -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdcer
+ rm -f ${COMBRELOC}
+
RELRO_NOW=" "
+
LD_FLAG=wpie
COMBRELOC=ldscripts/${EMULATION_NAME}.xdw.tmp
( echo "/* Script for -pie -z combreloc -z relro -z now */"
@@ -548,6 +698,7 @@ if test -n "$GENERATE_PIE_SCRIPT"; then
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdw
rm -f ${COMBRELOC}
+
LD_FLAG=wpietextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xdwe.tmp
( echo "/* Script for -pie -z combreloc -z separate-code -z relro -z now */"
@@ -555,17 +706,28 @@ if test -n "$GENERATE_PIE_SCRIPT"; then
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdwe
rm -f ${COMBRELOC}
+
+ LD_FLAG=rowpietextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xdwer.tmp
+ ( echo "/* Script for -pie -z combreloc -z separate-code -z relro -z now -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdwer
+ rm -f ${COMBRELOC}
+
unset RELRO_NOW
if test -n "$GENERATE_RELRO_SCRIPT"; then
- LD_FLAG=wpie
RELRO=" "
+
+ LD_FLAG=wpie
COMBRELOC=ldscripts/${EMULATION_NAME}.xdco.tmp
( echo "/* Script for -pie -z combreloc -z relro */"
source_sh ${CUSTOMIZER_SCRIPT}
source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdco
rm -f ${COMBRELOC}
+
LD_FLAG=wpietextonly
COMBRELOC=ldscripts/${EMULATION_NAME}.xdceo.tmp
( echo "/* Script for -pie -z combreloc -z separate-code -z relro */"
@@ -574,10 +736,20 @@ if test -n "$GENERATE_PIE_SCRIPT"; then
) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdceo
rm -f ${COMBRELOC}
+ LD_FLAG=rowpietextonly
+ COMBRELOC=ldscripts/${EMULATION_NAME}.xdceor.tmp
+ ( echo "/* Script for -pie -z combreloc -z separate-code -z relro -z one-rosegment */"
+ source_sh ${CUSTOMIZER_SCRIPT}
+ source_sh ${srcdir}/scripttempl/${SCRIPT_NAME}.sc
+ ) | sed -e '/^ *$/d;s/[ ]*$//' > ldscripts/${EMULATION_NAME}.xdceor
+ rm -f ${COMBRELOC}
+
unset RELRO
fi
+
COMBRELOC=
fi
+
unset CREATE_PIE
fi
diff -rupN binutils.orig/ld/ld.texi binutils-2.41/ld/ld.texi
--- binutils.orig/ld/ld.texi 2024-06-13 15:12:13.178463860 +0100
+++ binutils-2.41/ld/ld.texi 2024-06-13 15:15:52.662310507 +0100
@@ -1108,6 +1108,21 @@ For compatibility with other ELF linkers
followed by a directory name, rather than a file name, it is treated as
the @option{-rpath} option.
+@item --rosegment
+@itemx --no-rosegment
+Attempt to ensure that only a single read-only, non-code segment is
+created. Only useful when used in conjunction with the @option{-z
+separate-code} option. The resulting binaries should be smaller than
+if @option{-z separate-code} is used on its own. Without this option,
+or if @option{--no-rosegment} is specified, the @option{-z separate-code}
+option will create two read-only segments, one before the code segment
+and one after it.
+
+The name of the options are misleading, but they have been chosen in
+order for the linker to be compatible with the LLD and GOLD linkers.
+
+Thse options are only supported by ELF targets.
+
@kindex -s
@kindex --strip-all
@cindex strip all symbols
diff -rupN binutils.orig/ld/ldint.texi binutils-2.41/ld/ldint.texi
--- binutils.orig/ld/ldint.texi 2024-06-13 15:12:12.364465204 +0100
+++ binutils-2.41/ld/ldint.texi 2024-06-13 15:15:52.662310507 +0100
@@ -252,18 +252,23 @@ Here is the list of values assigned to @
@item (empty)
The script generated is used by default (when none of the following
cases apply). The output has an extension of @file{.x}.
+
@item n
The script generated is used when the linker is invoked with the
@code{-n} option. The output has an extension of @file{.xn}.
+
@item N
The script generated is used when the linker is invoked with the
@code{-N} option. The output has an extension of @file{.xbn}.
+
@item r
The script generated is used when the linker is invoked with the
@code{-r} option. The output has an extension of @file{.xr}.
+
@item u
The script generated is used when the linker is invoked with the
@code{-Ur} option. The output has an extension of @file{.xu}.
+
@item shared
The @file{scripttempl} script is only invoked with @code{LD_FLAG} set to
this value if @code{GENERATE_SHLIB_SCRIPT} is defined in the
@@ -271,14 +276,15 @@ this value if @code{GENERATE_SHLIB_SCRIP
this script at the appropriate time, normally when the linker is invoked
with the @code{-shared} option. The output has an extension of
@file{.xs}.
+
@item c
The @file{scripttempl} script is only invoked with @code{LD_FLAG} set to
this value if @code{GENERATE_COMBRELOC_SCRIPT} is defined in the
@file{emulparams} file or if @code{SCRIPT_NAME} is @code{elf}. The
@file{emultempl} script must arrange to use this script at the appropriate
time, normally when the linker is invoked with the @code{-z combreloc}
-option. The output has an extension of
-@file{.xc}.
+option. The output has an extension of @file{.xc}.
+
@item cshared
The @file{scripttempl} script is only invoked with @code{LD_FLAG} set to
this value if @code{GENERATE_COMBRELOC_SCRIPT} is defined in the
@@ -287,6 +293,62 @@ this value if @code{GENERATE_COMBRELOC_S
The @file{emultempl} script must arrange to use this script at the
appropriate time, normally when the linker is invoked with the @code{-shared
-z combreloc} option. The output has an extension of @file{.xsc}.
+
+@item wshared
+Like @emph{cshared} but in addition to needing the @option{-shared}
+and @option {-z combreloc} options, it also needs the
+@option{-z relro} option. If the @option{-z now} option is also used
+then the output has an extension of @file{.xsw}, otherwise it is
+@file{.xsco}.
+
+@item pie
+The @file{scripttempl} script is only invoked with @code{LD_FLAG} set to
+this value if @code{GENERATE_PIE_SCRIPT} is defined in the
+@file{emulparams} file. The @file{emultempl} script must arrange to use
+this script at the appropriate time, normally when the linker is invoked
+with the @code{-pie} option. The output has an extension of
+@file{.xd}.
+
+In addition if the @file{scripttempl} script is also invoked with
+@code{GENERATE_RELRO_SCRIPT} defined then a second script is created
+with an extension of @file{.xdo} to match the @option{-pie} and
+@option{-z relro} options.
+
+@item cpie
+Like @code{pie} but this version is used when the @file{scripttempl}
+script is invoked with both @code{GENERATE_PIE_SCRIPT} and
+@code{GENERATE_COMBRELOC_SCRIPT} defined. The @file{emultempl} script
+must arrange to use this script at the appropriate time, normally when
+the linker is invoked with the @code{-pie} and @option{-z combreloc}
+options. The output has an extension of @file{.xdc}.
+
+@item wpie
+Like @code{cpie}, but in addition the @option{-z relro} and
+@option{-z now} options need to be defined. The output has an
+extension of @file{.xdw}.
+
+@item textonly
+@item pietextonly
+@item cpietextonly
+@item wpietextonly
+
+@item ctextonly
+@item wtextonly
+@item sharedtextonly
+@item csharedtextonly
+@item wsharedtextonly
+
+@item rotextonly
+@item roctextonly
+@item rowtextonly
+@item rosharedtextonly
+@item rocsharedtextonly
+@item rowsharedtextonly
+@item ropietextonly
+@item rocpietextonly
+@item rowpietextonly
+
+
@item auto_import
The @file{scripttempl} script is only invoked with @code{LD_FLAG} set to
this value if @code{GENERATE_AUTO_IMPORT_SCRIPT} is defined in the
@@ -294,8 +356,10 @@ this value if @code{GENERATE_AUTO_IMPORT
use this script at the appropriate time, normally when the linker is
invoked with the @code{--enable-auto-import} option. The output has
an extension of @file{.xa}.
+
@end table
+
Besides the shell variables set by the @file{emulparams} script, and the
@code{LD_FLAG} variable, the @file{genscripts.sh} script will set
certain variables for each run of the @file{scripttempl} script.
diff -rupN binutils.orig/ld/ldlex.h binutils-2.41/ld/ldlex.h
--- binutils.orig/ld/ldlex.h 2024-06-13 15:12:13.182463854 +0100
+++ binutils-2.41/ld/ldlex.h 2024-06-13 15:19:07.065081570 +0100
@@ -182,6 +182,8 @@ enum option_values
OPTION_DISABLE_LINKER_VERSION,
OPTION_REMAP_INPUTS,
OPTION_REMAP_INPUTS_FILE,
+ OPTION_ROSEGMENT,
+ OPTION_NO_ROSEGMENT,
};
/* The initial parser states. */
diff -rupN binutils.orig/ld/lexsup.c binutils-2.41/ld/lexsup.c
--- binutils.orig/ld/lexsup.c 2024-06-13 15:12:13.182463854 +0100
+++ binutils-2.41/ld/lexsup.c 2024-06-13 15:15:52.662310507 +0100
@@ -2228,6 +2228,17 @@ elf_shlib_list_options (FILE *file)
fprintf (file, _("\
-z noseparate-code Don't create separate code program header (default)\n"));
#endif
+#if DEFAULT_LD_ROSEGMENT
+ fprintf (file, _("\
+ --rosegment With -z separate-code, create a single read-only segment (default)\n"));
+ fprintf (file, _("\
+ --no-rosegment With -z separate-code, creste two read-only segments\n"));
+#else
+ fprintf (file, _("\
+ --rosegment With -z separate-code, create a single read-only segment\n"));
+ fprintf (file, _("\
+ --no-rosegment With -z separate-code, creste two read-only segments (default)\n"));
+#endif
fprintf (file, _("\
-z common Generate common symbols with STT_COMMON type\n"));
fprintf (file, _("\
diff -rupN binutils.orig/ld/scripttempl/elf.sc binutils-2.41/ld/scripttempl/elf.sc
--- binutils.orig/ld/scripttempl/elf.sc 2024-06-13 15:12:12.541464912 +0100
+++ binutils-2.41/ld/scripttempl/elf.sc 2024-06-13 15:19:59.546231450 +0100
@@ -78,6 +78,8 @@
# USER_LABEL_PREFIX - prefix to add to user-visible symbols.
# RODATA_NAME, SDATA_NAME, SBSS_NAME, BSS_NAME - base parts of names
# for standard sections, without initial "." or suffixes.
+# ALL_TEXT_BEFORE_RO - put all code sections before read-only
+# sections
#
# When adding sections, do note that the names of some sections are used
# when specifying the start address of the next.
@@ -357,6 +359,11 @@ SHLIB_TEXT_START_ADDR="SEGMENT_START(\"t
# between .plt and .text.
if test -z "$TINY_READONLY_SECTION"; then
case "$LD_FLAG" in
+ *ro*textonly*)
+ ALL_TEXT_BEFORE_RO=" "
+ SEPARATE_TEXT=" "
+ TEXT_SEGMENT_ALIGN=
+ ;;
*textonly*)
SEPARATE_TEXT=" "
TEXT_SEGMENT_ALIGN=". = ALIGN(${MAXPAGESIZE});"
@@ -377,6 +384,11 @@ else
test -z "${TEXT_BASE_ADDRESS}" && TEXT_BASE_ADDRESS="${TEXT_START_ADDR}"
fi
+# ===========================================================================
+# Functions for generating parts of the linker script
+
+emit_header()
+{
cat <<EOF
/* Copyright (C) 2014-2023 Free Software Foundation, Inc.
@@ -396,14 +408,8 @@ ${RELOCATING- /* For some reason, the So
if gld -r is used and the intermediate file has sections starting
at non-zero addresses. Could be a Solaris ld bug, could be a GNU ld
bug. But for now assigning the zero vmas works. */}
-
-SECTIONS
-{
- ${RELOCATING+${SEPARATE_TEXT-/* Read-only sections, merged into text segment: */}}
- ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+PROVIDE (__executable_start = ${TEXT_START_ADDR}); . = ${TEXT_BASE_ADDRESS};}}}
- ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}}
- ${CREATE_PIE+${RELOCATING+PROVIDE (__executable_start = ${SHLIB_TEXT_START_ADDR}); . = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}}
EOF
+}
emit_early_ro()
{
@@ -413,10 +419,21 @@ emit_early_ro()
EOF
}
-test -n "${SEPARATE_CODE}" || emit_early_ro
+emit_executable_start()
+{
+cat <<EOF
+ ${RELOCATING+${SEPARATE_TEXT-/* Read-only sections, merged into text segment: */}}
+ ${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+PROVIDE (__executable_start = ${TEXT_START_ADDR}); . = ${TEXT_BASE_ADDRESS};}}}
+ ${CREATE_SHLIB+${RELOCATING+. = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}}
+ ${CREATE_PIE+${RELOCATING+PROVIDE (__executable_start = ${SHLIB_TEXT_START_ADDR}); . = ${SHLIB_TEXT_START_ADDR}${SIZEOF_HEADERS_CODE};}}
+EOF
+}
+emit_dyn()
+{
test -n "${RELOCATING+0}" || unset NON_ALLOC_DYN
test -z "${NON_ALLOC_DYN}" || TEXT_DYNAMIC=
+
cat > ldscripts/dyntmp.$$ <<EOF
${TEXT_DYNAMIC+${DYNAMIC}}
.hash ${RELOCATING-0} : { *(.hash) }
@@ -433,6 +450,7 @@ if [ "x$COMBRELOC" = x ]; then
else
COMBRELOCCAT="cat > $COMBRELOC"
fi
+
eval $COMBRELOCCAT <<EOF
${INITIAL_RELOC_SECTIONS}
.rel.init ${RELOCATING-0} : { *(.rel.init) }
@@ -508,8 +526,6 @@ cat >> ldscripts/dyntmp.$$ <<EOF
${OTHER_PLT_RELOC_SECTIONS}
EOF
-emit_dyn()
-{
if test -z "${NO_REL_RELOCS}${NO_RELA_RELOCS}"; then
cat ldscripts/dyntmp.$$
else
@@ -520,17 +536,24 @@ emit_dyn()
sed -e '/^[ ]*\.rel\.[^}]*$/,/}/d;/^[ ]*\.rel\./d;/__rel_iplt_/d' ldscripts/dyntmp.$$
fi
fi
+
rm -f ldscripts/dyntmp.$$
+
if test -n "${HAVE_DT_RELR}"; then
echo " .relr.dyn : { *(.relr.dyn) }"
fi
}
-test -n "${NON_ALLOC_DYN}${SEPARATE_CODE}" || emit_dyn
-
+align_text()
+{
cat <<EOF
${RELOCATING+${TEXT_SEGMENT_ALIGN}}
+EOF
+}
+emit_text()
+{
+cat <<EOF
.init ${RELOCATING-0}${RELOCATING+${INIT_ADDR}} :
{
${RELOCATING+${INIT_START}}
@@ -539,7 +562,9 @@ cat <<EOF
} ${FILL}
${TEXT_PLT+${PLT_NEXT_DATA-${PLT} ${OTHER_PLT_SECTIONS}}}
+
${TINY_READONLY_SECTION}
+
.text ${RELOCATING-0} :
{
${RELOCATING+${TEXT_START_SYMBOLS}}
@@ -553,19 +578,25 @@ cat <<EOF
*(.gnu.warning)
${RELOCATING+${OTHER_TEXT_SECTIONS}}
} ${FILL}
+
.fini ${RELOCATING-0}${RELOCATING+${FINI_ADDR}} :
{
${RELOCATING+${FINI_START}}
KEEP (*(SORT_NONE(.fini)))
${RELOCATING+${FINI_END}}
} ${FILL}
+
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT-PROVIDE (__${ETEXT_NAME} = .);}}
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT-PROVIDE (_${ETEXT_NAME} = .);}}
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT-PROVIDE (${ETEXT_NAME} = .);}}
${RELOCATING+${TEXT_SEGMENT_ALIGN}}
EOF
+}
+align_rodata()
+{
if test -n "${SEPARATE_CODE}${SEPARATE_TEXT}"; then
+
if test -n "${RODATA_ADDR}"; then
RODATA_ADDR="\
SEGMENT_START(\"rodata-segment\", ${RODATA_ADDR}) + SIZEOF_HEADERS"
@@ -573,6 +604,7 @@ SEGMENT_START(\"rodata-segment\", ${RODA
RODATA_ADDR="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))"
RODATA_ADDR="SEGMENT_START(\"rodata-segment\", ${RODATA_ADDR})"
fi
+
if test -n "${SHLIB_RODATA_ADDR}"; then
SHLIB_RODATA_ADDR="\
SEGMENT_START(\"rodata-segment\", ${SHLIB_RODATA_ADDR}) + SIZEOF_HEADERS"
@@ -580,6 +612,7 @@ SEGMENT_START(\"rodata-segment\", ${SHLI
SHLIB_RODATA_ADDR="ALIGN(${SEGMENT_SIZE}) + (. & (${MAXPAGESIZE} - 1))"
SHLIB_RODATA_ADDR="SEGMENT_START(\"rodata-segment\", ${SHLIB_RODATA_ADDR})"
fi
+
cat <<EOF
${RELOCATING+/* Adjust the address for the rodata segment. We want to adjust up to
the same address within the page on the next page up. */
@@ -587,12 +620,11 @@ SEGMENT_START(\"rodata-segment\", ${SHLI
${CREATE_SHLIB+. = ${SHLIB_RODATA_ADDR};}
${CREATE_PIE+. = ${SHLIB_RODATA_ADDR};}}
EOF
- if test -n "${SEPARATE_CODE}"; then
- emit_early_ro
- emit_dyn
- fi
fi
+}
+emit_rodata()
+{
cat <<EOF
${WRITABLE_RODATA-${RODATA}}
.${RODATA_NAME}1 ${RELOCATING-0} : { *(.${RODATA_NAME}1) }
@@ -611,7 +643,12 @@ cat <<EOF
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT+PROVIDE (__${ETEXT_NAME} = .);}}
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT+PROVIDE (_${ETEXT_NAME} = .);}}
${RELOCATING+${ETEXT_LAST_IN_RODATA_SEGMENT+PROVIDE (${ETEXT_NAME} = .);}}
+EOF
+}
+emit_data()
+{
+cat <<EOF
${RELOCATING+/* Adjust the address for the data segment. We want to adjust up to
the same address within the page on the next page up. */}
${CREATE_SHLIB-${CREATE_PIE-${RELOCATING+. = ${DATA_ADDR-${DATA_SEGMENT_ALIGN}};}}}
@@ -701,7 +738,10 @@ cat <<EOF
${NOINIT}
${RELOCATING+. = ALIGN(${ALIGNMENT});}
EOF
+}
+emit_large_data()
+{
LARGE_DATA_ADDR=". = SEGMENT_START(\"ldata-segment\", ${LARGE_DATA_ADDR-.});"
SHLIB_LARGE_DATA_ADDR=". = SEGMENT_START(\"ldata-segment\", ${SHLIB_LARGE_DATA_ADDR-.});"
@@ -719,9 +759,10 @@ cat <<EOF
${TINY_BSS_SECTION}
${STACK_ADDR+${STACK}}
EOF
+}
-test -z "${NON_ALLOC_DYN}" || emit_dyn
-
+emit_misc()
+{
source_sh $srcdir/scripttempl/misc-sections.sc
source_sh $srcdir/scripttempl/DWARF.sc
@@ -730,5 +771,46 @@ cat <<EOF
${OTHER_SECTIONS}
${RELOCATING+${OTHER_SYMBOLS}}
${RELOCATING+${DISCARDED}}
+EOF
+}
+
+# ===========================================================================
+# The script:
+
+emit_header
+
+cat <<EOF
+SECTIONS
+{
+EOF
+
+ emit_executable_start
+
+ if test -z "${ALL_TEXT_BEFORE_RO}"; then
+ test -n "${SEPARATE_CODE}" || emit_early_ro
+ test -n "${NON_ALLOC_DYN}${SEPARATE_CODE}" || emit_dyn
+ fi
+
+ align_text
+ emit_text
+
+ align_rodata
+
+ if test -n "${ALL_TEXT_BEFORE_RO}"; then
+ test -n "${SEPARATE_CODE}" || emit_early_ro
+ test -n "${NON_ALLOC_DYN}${SEPARATE_CODE}" || emit_dyn
+ fi
+
+ test -z "${SEPARATE_CODE}" || emit_early_ro
+ test -z "${SEPARATE_CODE}" || emit_dyn
+ emit_rodata
+
+ emit_data
+ emit_large_data
+
+ test -z "${NON_ALLOC_DYN}" || emit_dyn
+ emit_misc
+
+cat <<EOF
}
EOF
*** /dev/null Thu Jun 13 07:51:57 2024
--- binutils-2.41/ld/testsuite/ld-elf/pr30907-1.d Thu Jun 13 15:24:45 2024
***************
*** 0 ****
--- 1,14 ----
+ #name: --rosegment (pr30907-1) (does not have two read-only segments)
+ #source: pr22393-1.s
+ #ld: -shared -z separate-code -z relro --rosegment
+ #readelf: -l --wide
+ #target: *-*-linux-gnu *-*-gnu* *-*-nacl* arm*-*-uclinuxfdpiceabi
+ #xfail: ![check_shared_lib_support]
+ #xfail: ![check_relro_support]
+
+ #failif
+ #...
+ [ ]+LOAD[ ]+0x[0-9a-f x]+R[ ]+0x.*
+ #...
+ [ ]+LOAD[ ]+0x[0-9a-f x]+R[ ]+0x.*
+ #...
*** /dev/null Thu Jun 13 07:51:57 2024
--- binutils-2.41/ld/testsuite/ld-elf/pr30907-2.d Thu Jun 13 15:25:38 2024
***************
*** 0 ****
--- 1,15 ----
+ #name: --rosegment (pr30907-2) (has at least one RX, one R and one RW segments)
+ #source: pr22393-1.s
+ #ld: -shared -z separate-code -z relro --rosegment
+ #readelf: -l --wide
+ #target: *-*-linux-gnu *-*-gnu* *-*-nacl* arm*-*-uclinuxfdpiceabi
+ #xfail: ![check_shared_lib_support]
+ #xfail: ![check_relro_support]
+
+ #...
+ [ ]+LOAD[ ]+0x[0-9a-f x]+R E[ ]+0x.*
+ #...
+ [ ]+LOAD[ ]+0x[0-9a-f x]+R[ ]+0x.*
+ #...
+ [ ]+LOAD[ ]+0x[0-9a-f x]+RW[ ]+0x.*
+ #...
diff -rup binutils.orig/ld/testsuite/ld-elf/mbind1b.d binutils-2.41/ld/testsuite/ld-elf/mbind1b.d
--- binutils.orig/ld/testsuite/ld-elf/mbind1b.d 2024-06-13 16:41:56.979676236 +0100
+++ binutils-2.41/ld/testsuite/ld-elf/mbind1b.d 2024-06-13 16:42:06.645695186 +0100
@@ -1,5 +1,5 @@
#source: mbind1.s
-#ld: -shared -z common-page-size=0x1000 -z max-page-size=0x200000
+#ld: -shared -z common-page-size=0x1000 -z max-page-size=0x200000 --no-rosegment
#readelf: -S -l --wide
#target: *-*-linux* *-*-gnu* arm*-*-uclinuxfdpiceabi
#xfail: ![check_shared_lib_support]
diff -rup binutils.orig/ld/testsuite/ld-elf/mbind1c.d binutils-2.41/ld/testsuite/ld-elf/mbind1c.d
--- binutils.orig/ld/testsuite/ld-elf/mbind1c.d 2024-06-13 16:41:56.979676236 +0100
+++ binutils-2.41/ld/testsuite/ld-elf/mbind1c.d 2024-06-13 16:42:06.646695187 +0100
@@ -1,5 +1,5 @@
#source: mbind1.s
-#ld: -pie -z common-page-size=0x1000 -z max-page-size=0x200000
+#ld: -pie -z common-page-size=0x1000 -z max-page-size=0x200000 --no-rosegment
#readelf: -S -l --wide
#target: *-*-linux* *-*-gnu* arm*-*-uclinuxfdpiceabi
#xfail: ![check_pie_support]
diff -rup binutils.orig/ld/testsuite/ld-elf/pr30508.d binutils-2.41/ld/testsuite/ld-elf/pr30508.d
--- binutils.orig/ld/testsuite/ld-elf/pr30508.d 2024-06-13 16:41:56.998676273 +0100
+++ binutils-2.41/ld/testsuite/ld-elf/pr30508.d 2024-06-13 16:42:06.646695187 +0100
@@ -1,4 +1,4 @@
-#ld: -z separate-code
+#ld: -z separate-code --no-rosegment
#objcopy_linked_file: -R .foo
#readelf: -lW
#target: *-*-linux-gnu *-*-gnu* *-*-nacl* arm*-*-uclinuxfdpiceabi
diff -rup binutils.orig/ld/testsuite/ld-i386/i386.exp binutils-2.41/ld/testsuite/ld-i386/i386.exp
--- binutils.orig/ld/testsuite/ld-i386/i386.exp 2024-06-13 16:41:57.052676379 +0100
+++ binutils-2.41/ld/testsuite/ld-i386/i386.exp 2024-06-13 16:42:06.646695187 +0100
@@ -191,7 +191,7 @@ set i386tests {
{"Reloc section order"
"-shared -melf_i386 -z nocombreloc -z notext" "" "--32"
{reloc.s} {{objdump -hw reloc.d}} "reloc.so"}
- {"Basic --emit-relocs support" "-shared -melf_i386 --emit-relocs" "" "--32"
+ {"Basic --emit-relocs support" "-shared -melf_i386 --emit-relocs --no-rosegment" "" "--32"
{emit-relocs.s} {{readelf --relocs emit-relocs.rd}} "emit-relocs.so"}
{"-z combreloc relocation sections" "-shared -melf_i386 -z combreloc" ""
"--32" {combreloc.s} {{readelf -r combreloc.d}} "combreloc.so"}
diff -rup binutils.orig/ld/testsuite/ld-x86-64/ilp32-4.d binutils-2.41/ld/testsuite/ld-x86-64/ilp32-4.d
--- binutils.orig/ld/testsuite/ld-x86-64/ilp32-4.d 2024-06-13 16:41:57.261676789 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/ilp32-4.d 2024-06-13 16:42:06.646695187 +0100
@@ -1,5 +1,5 @@
#as: --x32
-#ld: -m elf32_x86_64 -shared --no-ld-generated-unwind-info --hash-style=sysv $NO_DT_RELR_LDFLAGS
+#ld: -m elf32_x86_64 -shared --no-ld-generated-unwind-info --hash-style=sysv $NO_DT_RELR_LDFLAGS --no-rosegment
#readelf: -d -S --wide
#target: x86_64-*-linux*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pe-x86-64.exp binutils-2.41/ld/testsuite/ld-x86-64/pe-x86-64.exp
--- binutils.orig/ld/testsuite/ld-x86-64/pe-x86-64.exp 2024-06-13 16:41:57.266676798 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pe-x86-64.exp 2024-06-13 16:42:29.180739367 +0100
@@ -27,7 +27,7 @@ if {![istarget "x86_64-*-linux*"] } {
run_ld_link_tests [list \
[list \
"Build pe-x86-64-1" \
- "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-1a.obj.bz2 pe-x86-64-1b.obj.bz2 pe-x86-64-1c.obj.bz2} \
@@ -36,7 +36,7 @@ run_ld_link_tests [list \
] \
[list \
"Build pe-x86-64-2" \
- "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-2a.obj.bz2 pe-x86-64-2b.obj.bz2 pe-x86-64-2c.obj.bz2} \
@@ -45,7 +45,7 @@ run_ld_link_tests [list \
] \
[list \
"Build pe-x86-64-3" \
- "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-3a.obj.bz2 pe-x86-64-3b.obj.bz2 pe-x86-64-3c.obj.bz2 \
@@ -55,7 +55,7 @@ run_ld_link_tests [list \
] \
[list \
"Build pe-x86-64-4" \
- "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-4a.obj.bz2 pe-x86-64-4b.obj.bz2 pe-x86-64-4c.obj.bz2 \
@@ -65,7 +65,7 @@ run_ld_link_tests [list \
] \
[list \
"Build pe-x86-64-5" \
- "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=begin -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-5.obj.bz2 } \
@@ -75,7 +75,7 @@ run_ld_link_tests [list \
] \
[list \
"Build pe-x86-64-6" \
- "-m elf_x86_64 --entry=main -z max-page-size=0x1000 -z separate-code" \
+ "-m elf_x86_64 --entry=main -z max-page-size=0x1000 -z separate-code --no-rosegment" \
"" \
"" \
{pe-x86-64-6.obj.bz2 } \
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr19609-4e.d binutils-2.41/ld/testsuite/ld-x86-64/pr19609-4e.d
--- binutils.orig/ld/testsuite/ld-x86-64/pr19609-4e.d 2024-06-13 16:41:57.271676808 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pr19609-4e.d 2024-06-13 16:42:29.180739367 +0100
@@ -1,6 +1,6 @@
#source: pr19609-4.s
#as: --64 -mrelax-relocations=yes
-#ld: -melf_x86_64 -Ttext=0x70000000 -Tdata=0xa0000000 --no-relax -z max-page-size=0x1000 -z separate-code
+#ld: -melf_x86_64 -Ttext=0x70000000 -Tdata=0xa0000000 --no-relax -z max-page-size=0x1000 -z separate-code --no-rosegment
#objdump: -dw
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr19609-6a.d binutils-2.41/ld/testsuite/ld-x86-64/pr19609-6a.d
--- binutils.orig/ld/testsuite/ld-x86-64/pr19609-6a.d 2024-06-13 16:41:57.271676808 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pr19609-6a.d 2024-06-13 16:42:29.180739367 +0100
@@ -1,6 +1,6 @@
#source: pr19609-6.s
#as: --64 -mrelax-relocations=yes
-#ld: -melf_x86_64 --defsym foobar=0x80000000 -z max-page-size=0x1000 -z separate-code
+#ld: -melf_x86_64 --defsym foobar=0x80000000 -z max-page-size=0x1000 -z separate-code --no-rosegment
#objdump: -dw
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr19609-6b.d binutils-2.41/ld/testsuite/ld-x86-64/pr19609-6b.d
--- binutils.orig/ld/testsuite/ld-x86-64/pr19609-6b.d 2024-06-13 16:41:57.271676808 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pr19609-6b.d 2024-06-13 16:42:29.180739367 +0100
@@ -1,6 +1,6 @@
#source: pr19609-6.s
#as: --64 -mrelax-relocations=yes
-#ld: -melf_x86_64 --defsym foobar=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code
+#ld: -melf_x86_64 --defsym foobar=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code --no-rosegment
#objdump: -dw
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr19609-7b.d binutils-2.41/ld/testsuite/ld-x86-64/pr19609-7b.d
--- binutils.orig/ld/testsuite/ld-x86-64/pr19609-7b.d 2024-06-13 16:41:57.271676808 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pr19609-7b.d 2024-06-13 16:42:29.180739367 +0100
@@ -1,6 +1,6 @@
#source: pr19609-7.s
#as: --64 -mrelax-relocations=yes
-#ld: -melf_x86_64 -Ttext=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code
+#ld: -melf_x86_64 -Ttext=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code --no-rosegment
#objdump: -dw
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/pr19609-7d.d binutils-2.41/ld/testsuite/ld-x86-64/pr19609-7d.d
--- binutils.orig/ld/testsuite/ld-x86-64/pr19609-7d.d 2024-06-13 16:41:57.271676808 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/pr19609-7d.d 2024-06-13 16:42:29.181739369 +0100
@@ -1,6 +1,6 @@
#source: pr19609-7.s
#as: --x32 -mrelax-relocations=yes
-#ld: -melf32_x86_64 -Ttext=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code
+#ld: -melf32_x86_64 -Ttext=0x80000000 --no-relax -z max-page-size=0x1000 -z separate-code --no-rosegment
#objdump: -dw
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/sframe-plt-1.d binutils-2.41/ld/testsuite/ld-x86-64/sframe-plt-1.d
--- binutils.orig/ld/testsuite/ld-x86-64/sframe-plt-1.d 2024-06-13 16:41:57.288676842 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/sframe-plt-1.d 2024-06-13 16:42:29.181739369 +0100
@@ -2,7 +2,7 @@
#source: sframe-foo.s
#source: sframe-bar.s
#objdump: --sframe=.sframe
-#ld: -shared
+#ld: -shared --no-rosegment
#name: SFrame for plt0 and pltN
.*: +file format .*
diff -rup binutils.orig/ld/testsuite/ld-x86-64/sframe-simple-1.d binutils-2.41/ld/testsuite/ld-x86-64/sframe-simple-1.d
--- binutils.orig/ld/testsuite/ld-x86-64/sframe-simple-1.d 2024-06-13 16:41:57.288676842 +0100
+++ binutils-2.41/ld/testsuite/ld-x86-64/sframe-simple-1.d 2024-06-13 16:42:29.181739369 +0100
@@ -2,7 +2,7 @@
#source: sframe-foo.s
#source: sframe-bar.s
#objdump: --sframe=.sframe
-#ld: -shared
+#ld: -shared --no-rosegment
#name: SFrame simple link
.*: +file format .*