Ifdef out handling for relocs which never occur during bootstrap.
authorUlrich Drepper <drepper@redhat.com>
Thu, 23 Nov 2000 17:26:27 +0000 (17:26 +0000)
committerUlrich Drepper <drepper@redhat.com>
Thu, 23 Nov 2000 17:26:27 +0000 (17:26 +0000)
sysdeps/sparc/sparc32/dl-machine.h
sysdeps/sparc/sparc64/dl-machine.h

index 84d25cd..feec35e 100644 (file)
@@ -377,6 +377,7 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
 
       switch (ELF32_R_TYPE (reloc->r_info))
        {
+#ifndef RTLD_BOOTSTRAP
        case R_SPARC_COPY:
          if (sym == NULL)
            /* This can happen in trace mode if an object could not be
@@ -397,6 +398,7 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
          memcpy (reloc_addr, (void *) value, MIN (sym->st_size,
                                                   refsym->st_size));
          break;
+#endif
        case R_SPARC_GLOB_DAT:
        case R_SPARC_32:
          *reloc_addr = value;
@@ -404,6 +406,7 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
        case R_SPARC_JMP_SLOT:
          elf_machine_fixup_plt(map, 0, reloc, reloc_addr, value);
          break;
+#ifndef RTLD_BOOTSTRAP
        case R_SPARC_8:
          *(char *) reloc_addr = value;
          break;
@@ -429,11 +432,14 @@ elf_machine_rela (struct link_map *map, const Elf32_Rela *reloc,
        case R_SPARC_HI22:
          *reloc_addr = (*reloc_addr & 0xffc00000) | (value >> 10);
          break;
+#endif
        case R_SPARC_NONE:              /* Alright, Wilbur.  */
          break;
+#if !defined RTLD_BOOTSTRAP || defined _NDEBUG
        default:
          _dl_reloc_bad_type (map, ELFW(R_TYPE) (reloc->r_info), 0);
          break;
+#endif
        }
     }
 }
index b2a0e7a..aee5ba8 100644 (file)
@@ -212,6 +212,7 @@ elf_machine_rela (struct link_map *map, const Elf64_Rela *reloc,
 
       switch (ELF64_R_TYPE_ID (reloc->r_info))
        {
+#ifndef RTLD_BOOTSTRAP
        case R_SPARC_COPY:
          if (sym == NULL)
            /* This can happen in trace mode if an object could not be
@@ -232,11 +233,12 @@ elf_machine_rela (struct link_map *map, const Elf64_Rela *reloc,
          memcpy (reloc_addr, (void *) value, MIN (sym->st_size,
                                                   refsym->st_size));
          break;
-
+#endif
        case R_SPARC_64:
        case R_SPARC_GLOB_DAT:
          *reloc_addr = value;
          break;
+#ifndef RTLD_BOOTSTRAP
        case R_SPARC_8:
          *(char *) reloc_addr = value;
          break;
@@ -311,11 +313,11 @@ elf_machine_rela (struct link_map *map, const Elf64_Rela *reloc,
            ((*(unsigned int *)reloc_addr & 0xffc00000) |
             ((value >> 10) & 0x003fffff));
          break;
-
+#endif
        case R_SPARC_JMP_SLOT:
          elf_machine_fixup_plt(map, 0, reloc, reloc_addr, value);
          break;
-
+#ifndef RTLD_BOOTSTRAP
        case R_SPARC_UA64:
          if (! ((long) reloc_addr & 3))
            {
@@ -333,10 +335,12 @@ elf_machine_rela (struct link_map *map, const Elf64_Rela *reloc,
          ((unsigned char *) reloc_addr) [6] = value >> 8;
          ((unsigned char *) reloc_addr) [7] = value;
          break;
-
+#endif
+#if !defined RTLD_BOOTSTRAP || defined _NDEBUG
        default:
          _dl_reloc_bad_type (map, ELFW(R_TYPE) (reloc->r_info), 0);
          break;
+#endif
        }
     }
 }