summaryrefslogtreecommitdiff
path: root/ld/emultempl/crxelf.em
diff options
context:
space:
mode:
authorTomer Levi <Tomer.Levi@nsc.com>2004-10-05 14:35:50 +0000
committerTomer Levi <Tomer.Levi@nsc.com>2004-10-05 14:35:50 +0000
commit21fcc7f109c7f4940944702ab89184dac2ca8278 (patch)
treedae4fc5e57df5cb7b3f3ccc4e6e3cb43edf6f378 /ld/emultempl/crxelf.em
parentbcc4ca95d16234a3b3fc278cd57df1b3830273fd (diff)
downloadbinutils-redhat-21fcc7f109c7f4940944702ab89184dac2ca8278.tar.gz
Enable --relax option by default
Diffstat (limited to 'ld/emultempl/crxelf.em')
-rw-r--r--ld/emultempl/crxelf.em46
1 files changed, 45 insertions, 1 deletions
diff --git a/ld/emultempl/crxelf.em b/ld/emultempl/crxelf.em
index 0694bb9716..3b94559d46 100644
--- a/ld/emultempl/crxelf.em
+++ b/ld/emultempl/crxelf.em
@@ -26,6 +26,9 @@ cat >>e${EMULATION_NAME}.c <<EOF
#include "ldctor.h"
+/* Flag for the emulation-specific "--no-relax" option. */
+static bfd_boolean disable_relaxation = FALSE;
+
static void crxelf_after_parse (void);
static void
@@ -38,13 +41,54 @@ crxelf_after_parse (void)
config.sort_common = TRUE;
/* Don't create a demand-paged executable, since this feature isn't
- meaninful in CR16C embedded systems. Moreover, when magic_demand_paged
+ meaninful in CRX embedded systems. Moreover, when magic_demand_paged
is true the link sometimes fails. */
config.magic_demand_paged = FALSE;
}
+/* This is called after the sections have been attached to output
+ sections, but before any sizes or addresses have been set. */
+
+static void
+crxelf_before_allocation (void)
+{
+ /* Call the default first. */
+ gld${EMULATION_NAME}_before_allocation ();
+
+ /* Enable relaxation by default if the "--no-relax" option was not
+ specified. This is done here instead of in the before_parse hook
+ because there is a check in main() to prohibit use of --relax and
+ -r together. */
+
+ if (!disable_relaxation)
+ command_line.relax = TRUE;
+}
+
EOF
+# Define some shell vars to insert bits of code into the standard elf
+# parse_args and list_options functions.
+#
+PARSE_AND_LIST_PROLOGUE='
+#define OPTION_NO_RELAX 301
+'
+
+PARSE_AND_LIST_LONGOPTS='
+ { "no-relax", no_argument, NULL, OPTION_NO_RELAX},
+'
+
+PARSE_AND_LIST_OPTIONS='
+ fprintf (file, _(" --no-relax Do not relax branches\n"));
+'
+
+PARSE_AND_LIST_ARGS_CASES='
+ case OPTION_NO_RELAX:
+ disable_relaxation = TRUE;
+ break;
+'
+
# Put these extra crx-elf routines in ld_${EMULATION_NAME}_emulation
#
LDEMUL_AFTER_PARSE=crxelf_after_parse
+LDEMUL_BEFORE_ALLOCATION=crxelf_before_allocation
+