Blame SOURCES/binutils-readelf-other-sym-info.patch

38fe89
diff -rup binutils.orig/binutils/readelf.c binutils-2.29/binutils/readelf.c
38fe89
--- binutils.orig/binutils/readelf.c	2017-12-12 16:24:19.571221194 +0000
38fe89
+++ binutils-2.29/binutils/readelf.c	2017-12-12 16:27:26.997979803 +0000
38fe89
@@ -11018,12 +11018,14 @@ print_dynamic_symbol (bfd_vma si, unsign
38fe89
       unsigned int vis = ELF_ST_VISIBILITY (psym->st_other);
38fe89
 
38fe89
       printf (" %-7s",  get_symbol_visibility (vis));
38fe89
+#if 0
38fe89
       /* Check to see if any other bits in the st_other field are set.
38fe89
 	 Note - displaying this information disrupts the layout of the
38fe89
 	 table being generated, but for the moment this case is very
38fe89
 	 rare.  */
38fe89
       if (psym->st_other ^ vis)
38fe89
 	printf (" [%s] ", get_symbol_other (filedata, psym->st_other ^ vis));
38fe89
+#endif
38fe89
     }
38fe89
 
38fe89
   printf (" %3.3s ", get_symbol_index_type (filedata, psym->st_shndx));
38fe89
@@ -11031,6 +11033,15 @@ print_dynamic_symbol (bfd_vma si, unsign
38fe89
     print_symbol (25, GET_DYNAMIC_NAME (psym->st_name));
38fe89
   else
38fe89
     printf (_(" <corrupt: %14ld>"), psym->st_name);
38fe89
+#if 1
38fe89
+    {
38fe89
+      unsigned int vis = ELF_ST_VISIBILITY (psym->st_other);
38fe89
+
38fe89
+      /* Check to see if any other bits in the st_other field are set.  */
38fe89
+      if (psym->st_other ^ vis)
38fe89
+	printf (" \t[%s]", get_symbol_other (filedata, psym->st_other ^ vis));
38fe89
+    }
38fe89
+#endif
38fe89
   putchar ('\n');
38fe89
 }
38fe89
 
38fe89
--- binutils.orig/binutils/readelf.c	2017-12-12 16:36:21.806561149 +0000
38fe89
+++ binutils-2.29.1/binutils/readelf.c	2017-12-12 16:38:17.763168514 +0000
38fe89
@@ -11548,11 +11548,13 @@ process_symbol_table (FILE * file)
38fe89
 		  unsigned int vis = ELF_ST_VISIBILITY (psym->st_other);
38fe89
 
38fe89
 		  printf (" %-7s", get_symbol_visibility (vis));
38fe89
+#if 0
38fe89
 		  /* Check to see if any other bits in the st_other field are set.
38fe89
 		     Note - displaying this information disrupts the layout of the
38fe89
 		     table being generated, but for the moment this case is very rare.  */
38fe89
 		  if (psym->st_other ^ vis)
38fe89
 		    printf (" [%s] ", get_symbol_other (filedata, psym->st_other ^ vis));
38fe89
+#endif
38fe89
 		}
38fe89
 	      printf (" %4s ", get_symbol_index_type (filedata, psym->st_shndx));
38fe89
 	      print_symbol (25, psym->st_name < strtab_size
38fe89
@@ -11571,7 +11573,15 @@ process_symbol_table (FILE * file)
38fe89
 		    printf (sym_info == symbol_hidden ? "@%s" : "@@%s",
38fe89
 			    version_string);
38fe89
 		}
38fe89
+#if 1
38fe89
+		{
38fe89
+		  unsigned int vis = ELF_ST_VISIBILITY (psym->st_other);
38fe89
 
38fe89
+		  /* Check to see if any other bits in the st_other field are set.  */
38fe89
+		  if (psym->st_other ^ vis)
38fe89
+		    printf (" \t[%s] ", get_symbol_other (filedata, psym->st_other ^ vis));
38fe89
+		}
38fe89
+#endif
38fe89
 	      putchar ('\n');
38fe89
 
38fe89
 	      if (ELF_ST_BIND (psym->st_info) == STB_LOCAL