Silence warnings and simplify code. Eliminate a 32/64 bit portability issue.
authorBenjamin Kramer <benny.kra@googlemail.com>
Mon, 16 Aug 2010 23:00:12 +0000 (23:00 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Mon, 16 Aug 2010 23:00:12 +0000 (23:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@111201 91177308-0d34-0410-b5e6-96231b3b80d8

lib/MC/ELFObjectWriter.cpp

index 5f7ef1217d71042f60a3570cf7022b8cdba6131b..4d0b374196c4a856d873b0711727fbb59dbdad50 100644 (file)
@@ -545,14 +545,13 @@ void ELFObjectWriterImpl::RecordRelocation(const MCAssembler &Asm,
   if (IsPCRel) {
     Type = ELF::R_X86_64_PC32;
   } else {
-    switch (Fixup.getKind()) {
+    switch ((unsigned)Fixup.getKind()) {
+    default: llvm_unreachable("invalid fixup kind!");
     case FK_Data_8: Type = ELF::R_X86_64_64; break;
     case X86::reloc_pcrel_4byte:
     case FK_Data_4:
-      long Offset;
-      Offset = Target.getConstant();
       // check that the offset fits within a signed long
-      if (!(((long) -1 << 31) & Offset) || (((long) -1 << 31) & Offset) == ((long) -1 << 31))
+      if (isInt<32>(Target.getConstant()))
         Type = ELF::R_X86_64_32S;
       else
         Type = ELF::R_X86_64_32;