public inbox for binutils-cvs@sourceware.org
 help / color / mirror / Atom feed
* [binutils-gdb] gas: make S_IS_LOCAL() and S_IS_EXTERNAL() exclusive of one another
@ 2023-08-18  6:58 Jan Beulich
  0 siblings, 0 replies; only message in thread
From: Jan Beulich @ 2023-08-18  6:58 UTC (permalink / raw)
  To: bfd-cvs

https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=b41ef0baac449de58c84d1a0261af0d91443b540

commit b41ef0baac449de58c84d1a0261af0d91443b540
Author: Jan Beulich <jbeulich@suse.com>
Date:   Fri Aug 18 08:57:34 2023 +0200

    gas: make S_IS_LOCAL() and S_IS_EXTERNAL() exclusive of one another
    
    While they aren't opposites of each other, there also shouldn't be any
    symbol for which both return true; both may return false. Therefore
    use S_IS_EXTERNAL() in S_IS_LOCAL(), thus subsuming the sanity check
    which so far both did alike.

Diff:
---
 gas/symbols.c | 9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)

diff --git a/gas/symbols.c b/gas/symbols.c
index ea05801e356..45e46ed39b7 100644
--- a/gas/symbols.c
+++ b/gas/symbols.c
@@ -2420,15 +2420,14 @@ S_IS_LOCAL (symbolS *s)
   if (s->flags.local_symbol)
     return 1;
 
-  flags = s->bsym->flags;
-
-  /* Sanity check.  */
-  if ((flags & BSF_LOCAL) && (flags & BSF_GLOBAL))
-    abort ();
+  if (S_IS_EXTERNAL (s))
+    return 0;
 
   if (bfd_asymbol_section (s->bsym) == reg_section)
     return 1;
 
+  flags = s->bsym->flags;
+
   if (flag_strip_local_absolute
       /* Keep BSF_FILE symbols in order to allow debuggers to identify
 	 the source file even when the object file is stripped.  */

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-08-18  6:58 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-08-18  6:58 [binutils-gdb] gas: make S_IS_LOCAL() and S_IS_EXTERNAL() exclusive of one another Jan Beulich

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).