public inbox for binutils@sourceware.org
 help / color / mirror / Atom feed
* [PATCH] MIPS/Gas: Support .L/$ as the mark of local symbol
@ 2024-02-05 10:14 YunQiang Su
  2024-02-21  8:50 ` YunQiang Su
  2024-02-21 13:32 ` Maciej W. Rozycki
  0 siblings, 2 replies; 5+ messages in thread
From: YunQiang Su @ 2024-02-05 10:14 UTC (permalink / raw)
  To: nickc; +Cc: binutils, macro, xry111

In as.texi, there are lines:
  A local symbol is any symbol beginning with certain local
  label prefixes. By default, the local label prefix is
  @samp{.L} for ELF systems or @samp{L} for traditional a.out
  systems, but each target may have its own set of local
  label prefixes.

Let's support it for MIPS:
1) For OldABI, GCC uses "$" to mark local symbols, and
   for NewABI, ".L" is used. So let's support both for
   OldABI, and ".L" only for NewABI.
2) Emit an fatal error, if a local symbol is used, while
   not defined, just like LLVM does.
---
 gas/config/tc-mips.c | 10 ++++++++++
 1 file changed, 10 insertions(+)

diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c
index 43c12de2c8a..a84b13e1815 100644
--- a/gas/config/tc-mips.c
+++ b/gas/config/tc-mips.c
@@ -17725,6 +17725,16 @@ pic_need_relax (symbolS *sym)
   if (symbol_section_p (sym))
     return true;
 
+  if (strstr (S_GET_NAME (sym), ".L") == S_GET_NAME (sym)
+      || ((mips_abi == O64_ABI || mips_abi == O32_ABI)
+	   && strstr (S_GET_NAME (sym), "$") == S_GET_NAME (sym)))
+    {
+      if (!S_IS_DEFINED (sym))
+	as_fatal (_("undefined temporary symbol: %s"),
+		  S_GET_NAME (sym));
+      return true;
+    }
+
   symsec = S_GET_SEGMENT (sym);
 
   /* This must duplicate the test in adjust_reloc_syms.  */
-- 
2.39.2


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2024-02-21 14:47 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-02-05 10:14 [PATCH] MIPS/Gas: Support .L/$ as the mark of local symbol YunQiang Su
2024-02-21  8:50 ` YunQiang Su
2024-02-21 13:32 ` Maciej W. Rozycki
2024-02-21 14:09   ` YunQiang Su
2024-02-21 14:47     ` Maciej W. Rozycki

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).