Nick Clifton 47e37c
*** ../binutils-2.23.52.0.1.orig/bfd/opncls.c	2013-03-14 11:25:30.338306122 +0000
Nick Clifton 47e37c
--- bfd/opncls.c	2013-03-14 12:20:21.686397360 +0000
Nick Clifton 47e37c
*************** find_separate_debug_file (bfd *abfd, con
Nick Clifton 47e37c
*** 1297,1302 ****
Nick Clifton 47e37c
--- 1297,1304 ----
Nick Clifton 47e37c
        bfd_malloc (strlen (debug_file_directory) + 1
Nick Clifton 47e37c
                    + (canon_dirlen > dirlen ? canon_dirlen : dirlen)
Nick Clifton 47e37c
                    + strlen (".debug/")
Nick Clifton 47e37c
+ #define FEDORA_LIB_DEBUG_DIR "/usr/lib/debug/"
Nick Clifton 47e37c
+ 		  + strlen (FEDORA_LIB_DEBUG_DIR) + strlen ("usr/")
Nick Clifton 47e37c
                    + strlen (base)
Nick Clifton 47e37c
                    + 1);
Nick Clifton 47e37c
    if (debugfile == NULL)
Nick Clifton 47e37c
*************** find_separate_debug_file (bfd *abfd, con
Nick Clifton 47e37c
*** 1332,1337 ****
Nick Clifton 47e37c
--- 1334,1359 ----
Nick Clifton 5b79e0
    if (check_func (debugfile, crc32))
Nick Clifton 5b79e0
      goto found;
Nick Clifton 47e37c
  
Nick Clifton 47e37c
+   /* Then try in the global debug dir for Fedora libraries.  */
Nick Clifton 47e37c
+   sprintf (debugfile, "%s%s%s", FEDORA_LIB_DEBUG_DIR, dir, base);
Nick Clifton 47e37c
+   if (separate_debug_file_exists (debugfile, crc32))
Nick Clifton 47e37c
+     {
Nick Clifton 47e37c
+       free (base);
Nick Clifton 47e37c
+       free (dir);
Nick Clifton 47e37c
+       free (canon_dir);
Nick Clifton 47e37c
+       return debugfile;
Nick Clifton 47e37c
+     }
Nick Clifton 47e37c
+ 
Nick Clifton 47e37c
+   /* Then try in the usr subdirectory of the global debug dir for Fedora libraries.  */
Nick Clifton 47e37c
+   sprintf (debugfile, "%s/usr%s%s", FEDORA_LIB_DEBUG_DIR, dir, base);
Nick Clifton 47e37c
+   if (separate_debug_file_exists (debugfile, crc32))
Nick Clifton 47e37c
+     {
Nick Clifton 47e37c
+       free (base);
Nick Clifton 47e37c
+       free (dir);
Nick Clifton 47e37c
+       free (canon_dir);
Nick Clifton 47e37c
+       return debugfile;
Nick Clifton 47e37c
+     }
Nick Clifton 47e37c
+   
Nick Clifton 47e37c
    /* Then try in the global debugfile directory.  */
Nick Clifton 47e37c
    strcpy (debugfile, debug_file_directory);
Nick Clifton 47e37c
    dirlen = strlen (debug_file_directory) - 1;
Nick Clifton 47e37c
*** ../binutils-2.23.52.0.1.orig/bfd/dwarf2.c	2013-03-14 11:25:30.608306129 +0000
Nick Clifton 47e37c
--- bfd/dwarf2.c	2013-03-14 13:14:18.102487075 +0000
Nick Clifton 47e37c
*************** find_line (bfd *abfd,
Nick Clifton 47e37c
*** 3339,3346 ****
Nick Clifton 47e37c
--- 3339,3349 ----
Nick Clifton 47e37c
    struct dwarf2_debug *stash;
Nick Clifton 47e37c
    /* What address are we looking for?  */
Nick Clifton 47e37c
    bfd_vma addr;
Nick Clifton 47e37c
+   /* What is the address without relocation ?  */
Nick Clifton 47e37c
+   bfd_vma unrelocated_addr;
Nick Clifton 47e37c
    struct comp_unit* each;
Nick Clifton 47e37c
    bfd_vma found = FALSE;
Nick Clifton 47e37c
+   bfd_vma possible_find = FALSE;
Nick Clifton 47e37c
    bfd_boolean do_line;
Nick Clifton 47e37c
  
Nick Clifton 47e37c
    *filename_ptr = NULL;
Nick Clifton 47e37c
*************** find_line (bfd *abfd,
Nick Clifton 47e37c
*** 3380,3385 ****
Nick Clifton 47e37c
--- 3383,3394 ----
Nick Clifton 47e37c
    else
Nick Clifton 47e37c
      abort ();
Nick Clifton 47e37c
  
Nick Clifton 47e37c
+   /* If we are dealing with PIC code then the debug information
Nick Clifton 47e37c
+      will be based on unrelocated addresses.  Since we cannot be
Nick Clifton 47e37c
+      sure if this is a PIC address we test both with and without
Nick Clifton 47e37c
+      relocation.  */
Nick Clifton 47e37c
+   unrelocated_addr = addr;
Nick Clifton 47e37c
+ 
Nick Clifton 47e37c
    if (section->output_section)
Nick Clifton 47e37c
      addr += section->output_section->vma + section->output_offset;
Nick Clifton 47e37c
    else
Nick Clifton 47e37c
*************** find_line (bfd *abfd,
Nick Clifton 47e37c
*** 3442,3447 ****
Nick Clifton 47e37c
--- 3451,3466 ----
Nick Clifton 47e37c
  						   stash));
Nick Clifton 47e37c
  	  if (found)
Nick Clifton 47e37c
  	    goto done;
Nick Clifton 47e37c
+ 
Nick Clifton 47e37c
+ 	  if (! possible_find)
Nick Clifton 47e37c
+ 	    possible_find = ((each->arange.high == 0
Nick Clifton 47e37c
+ 			      || comp_unit_contains_address (each, unrelocated_addr))
Nick Clifton 47e37c
+ 			     && comp_unit_find_nearest_line (each, unrelocated_addr,
Nick Clifton 47e37c
+ 							     filename_ptr,
Nick Clifton 47e37c
+ 							     functionname_ptr,
Nick Clifton 47e37c
+ 							     linenumber_ptr,
Nick Clifton 47e37c
+ 							     discriminator_ptr,
Nick Clifton 47e37c
+ 							     stash));
Nick Clifton 47e37c
  	}
Nick Clifton 47e37c
      }
Nick Clifton 47e37c
  
Nick Clifton 47e37c
*************** find_line (bfd *abfd,
Nick Clifton 47e37c
*** 3535,3540 ****
Nick Clifton 47e37c
--- 3554,3569 ----
Nick Clifton 47e37c
  						     discriminator_ptr,
Nick Clifton 47e37c
  						     stash));
Nick Clifton 47e37c
  
Nick Clifton 47e37c
+ 	  if (! found && ! do_line && ! possible_find)
Nick Clifton 47e37c
+ 	    possible_find = ((each->arange.high == 0
Nick Clifton 47e37c
+ 			      || comp_unit_contains_address (each, unrelocated_addr))
Nick Clifton 47e37c
+ 			     && comp_unit_find_nearest_line (each, unrelocated_addr,
Nick Clifton 47e37c
+ 							     filename_ptr,
Nick Clifton 47e37c
+ 							     functionname_ptr,
Nick Clifton 47e37c
+ 							     linenumber_ptr,
Nick Clifton 47e37c
+ 							     discriminator_ptr,
Nick Clifton 47e37c
+ 							     stash));
Nick Clifton 47e37c
+ 
Nick Clifton 47e37c
  	  if ((bfd_vma) (stash->info_ptr - stash->sec_info_ptr)
Nick Clifton 47e37c
  	      == stash->sec->size)
Nick Clifton 47e37c
  	    {
Nick Clifton 47e37c
*************** find_line (bfd *abfd,
Nick Clifton 47e37c
*** 3552,3557 ****
Nick Clifton 47e37c
--- 3581,3588 ----
Nick Clifton 47e37c
    if ((abfd->flags & (EXEC_P | DYNAMIC)) == 0)
Nick Clifton 47e37c
      unset_sections (stash);
Nick Clifton 47e37c
  
Nick Clifton 47e37c
+   if (! found)
Nick Clifton 47e37c
+     return possible_find;
Nick Clifton 47e37c
    return found;
Nick Clifton 47e37c
  }
Nick Clifton 47e37c