Skip to content

Commit

Permalink
LoongArch: Check whether binutils supports the relax function. If sup…
Browse files Browse the repository at this point in the history
…ported, explicit relocs are turned off by default.

gcc/ChangeLog:

	* config.in: Regenerate.
	* config/loongarch/genopts/loongarch.opt.in: Add compilation option
	mrelax. And set the initial value of explicit-relocs according to the
	detection status.
	* config/loongarch/gnu-user.h: When compiling with -mno-relax, pass the
	--no-relax option to the linker.
	* config/loongarch/loongarch-driver.h (ASM_SPEC): When compiling with
	-mno-relax, pass the -mno-relax option to the assembler.
	* config/loongarch/loongarch-opts.h (HAVE_AS_MRELAX_OPTION): Define macro.
	* config/loongarch/loongarch.opt: Regenerate.
	* configure: Regenerate.
	* configure.ac: Add detection of support for binutils relax function.

(cherry picked from commint 9bab65a77049edcc7afc59532173206ee816e726)
  • Loading branch information
chenglulu326 authored and ouuleilei-bot committed Feb 21, 2024
1 parent 10af7fc commit 2e2ab47
Show file tree
Hide file tree
Showing 7 changed files with 59 additions and 3 deletions.
6 changes: 6 additions & 0 deletions gcc/config.in
Original file line number Diff line number Diff line change
Expand Up @@ -636,6 +636,12 @@
#endif


/* Define if your assembler supports -mrelax option. */
#ifndef USED_FOR_TARGET
#undef HAVE_AS_MRELAX_OPTION
#endif


/* Define if your assembler supports .mspabi_attribute. */
#ifndef USED_FOR_TARGET
#undef HAVE_AS_MSPABI_ATTRIBUTE
Expand Down
7 changes: 6 additions & 1 deletion gcc/config/loongarch/genopts/loongarch.opt.in
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ Target Joined RejectNegative UInteger Var(loongarch_max_inline_memcpy_size) Init
-mmax-inline-memcpy-size=SIZE Set the max size of memcpy to inline, default is 1024.

mexplicit-relocs
Target Var(TARGET_EXPLICIT_RELOCS) Init(HAVE_AS_EXPLICIT_RELOCS)
Target Var(TARGET_EXPLICIT_RELOCS) Init(HAVE_AS_EXPLICIT_RELOCS & !HAVE_AS_MRELAX_OPTION)
Use %reloc() assembly operators.

; The code model option names for -mcmodel.
Expand Down Expand Up @@ -188,3 +188,8 @@ Specify the code model.
mdirect-extern-access
Target Var(TARGET_DIRECT_EXTERN_ACCESS) Init(0)
Avoid using the GOT to access external symbols.

mrelax
Target Var(loongarch_mrelax) Init(HAVE_AS_MRELAX_OPTION)
Take advantage of linker relaxations to reduce the number of instructions
required to materialize symbol addresses.
3 changes: 2 additions & 1 deletion gcc/config/loongarch/gnu-user.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,8 @@ along with GCC; see the file COPYING3. If not see
"%{!shared: %{static} " \
"%{!static: %{!static-pie: %{rdynamic:-export-dynamic} " \
"-dynamic-linker " GNU_USER_DYNAMIC_LINKER "}} " \
"%{static-pie: -static -pie --no-dynamic-linker -z text}}"
"%{static-pie: -static -pie --no-dynamic-linker -z text}}" \
"%{mno-relax: --no-relax}"


/* Similar to standard Linux, but adding -ffast-math support. */
Expand Down
4 changes: 4 additions & 0 deletions gcc/config/loongarch/loongarch-opts.h
Original file line number Diff line number Diff line change
Expand Up @@ -92,4 +92,8 @@ loongarch_config_target (struct loongarch_target *target,
#define HAVE_AS_EXPLICIT_RELOCS 0
#endif

#ifndef HAVE_AS_MRELAX_OPTION
#define HAVE_AS_MRELAX_OPTION 0
#endif

#endif /* LOONGARCH_OPTS_H */
7 changes: 6 additions & 1 deletion gcc/config/loongarch/loongarch.opt
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@ Target Joined RejectNegative UInteger Var(loongarch_max_inline_memcpy_size) Init
-mmax-inline-memcpy-size=SIZE Set the max size of memcpy to inline, default is 1024.

mexplicit-relocs
Target Var(TARGET_EXPLICIT_RELOCS) Init(HAVE_AS_EXPLICIT_RELOCS)
Target Var(TARGET_EXPLICIT_RELOCS) Init(HAVE_AS_EXPLICIT_RELOCS & !HAVE_AS_MRELAX_OPTION)
Use %reloc() assembly operators.

; The code model option names for -mcmodel.
Expand Down Expand Up @@ -195,3 +195,8 @@ Specify the code model.
mdirect-extern-access
Target Var(TARGET_DIRECT_EXTERN_ACCESS) Init(0)
Avoid using the GOT to access external symbols.

mrelax
Target Var(loongarch_mrelax) Init(HAVE_AS_MRELAX_OPTION)
Take advantage of linker relaxations to reduce the number of instructions
required to materialize symbol addresses.
31 changes: 31 additions & 0 deletions gcc/configure
Original file line number Diff line number Diff line change
Expand Up @@ -29037,6 +29037,37 @@ if test $gcc_cv_as_loongarch_eh_frame_pcrel_encoding_support = yes; then

$as_echo "#define HAVE_AS_EH_FRAME_PCREL_ENCODING_SUPPORT 1" >>confdefs.h

fi

{ $as_echo "$as_me:${as_lineno-$LINENO}: checking assembler for -mrelax option" >&5
$as_echo_n "checking assembler for -mrelax option... " >&6; }
if ${gcc_cv_as_loongarch_relax+:} false; then :
$as_echo_n "(cached) " >&6
else
gcc_cv_as_loongarch_relax=no
if test x$gcc_cv_as != x; then
$as_echo '.text' > conftest.s
if { ac_try='$gcc_cv_as $gcc_cv_as_flags -mrelax -o conftest.o conftest.s >&5'
{ { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_try\""; } >&5
(eval $ac_try) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }; }
then
gcc_cv_as_loongarch_relax=yes
else
echo "configure: failed program was" >&5
cat conftest.s >&5
fi
rm -f conftest.o conftest.s
fi
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gcc_cv_as_loongarch_relax" >&5
$as_echo "$gcc_cv_as_loongarch_relax" >&6; }
if test $gcc_cv_as_loongarch_relax = yes; then

$as_echo "#define HAVE_AS_MRELAX_OPTION 1" >>confdefs.h

fi

;;
Expand Down
4 changes: 4 additions & 0 deletions gcc/configure.ac
Original file line number Diff line number Diff line change
Expand Up @@ -5350,6 +5350,10 @@ x:
.cfi_endproc],,
[AC_DEFINE(HAVE_AS_EH_FRAME_PCREL_ENCODING_SUPPORT, 1,
[Define if your assembler supports eh_frame pcrel encoding.])])
gcc_GAS_CHECK_FEATURE([-mrelax option], gcc_cv_as_loongarch_relax,
[-mrelax], [.text],,
[AC_DEFINE(HAVE_AS_MRELAX_OPTION, 1,
[Define if your assembler supports -mrelax option.])])
;;
s390*-*-*)
gcc_GAS_CHECK_FEATURE([.gnu_attribute support],
Expand Down

0 comments on commit 2e2ab47

Please sign in to comment.