gas: make S_IS_LOCAL() and S_IS_EXTERNAL() exclusive of one another
authorJan Beulich <jbeulich@suse.com>
Fri, 18 Aug 2023 06:57:34 +0000 (08:57 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 18 Aug 2023 06:57:34 +0000 (08:57 +0200)
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.

gas/symbols.c

index ea05801e35620a5a533a3933816f8d086f4dabfb..45e46ed39b7bb351bb199092081122ace3ab18bf 100644 (file)
@@ -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.  */