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