[llvm-commits] [llvm] r138725 - /llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp

Nicolas Geoffray nicolas.geoffray at lip6.fr
Sun Aug 28 07:52:52 PDT 2011


Author: geoffray
Date: Sun Aug 28 09:52:51 2011
New Revision: 138725

URL: http://llvm.org/viewvc/llvm-project?rev=138725&view=rev
Log:
Remove premature previous commit.


Modified:
    llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp

Modified: llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp?rev=138725&r1=138724&r2=138725&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp (original)
+++ llvm/trunk/lib/Target/X86/X86CodeEmitter.cpp Sun Aug 28 09:52:51 2011
@@ -618,32 +618,14 @@
 
   // Emit segment override opcode prefix as needed.
   switch (Desc->TSFlags & X86II::SegOvrMask) {
-    case 0: {
-      // Determine where the memory operand starts, if present.
-      int MemOperand = X86II::getMemoryOperandNo(Desc->TSFlags);
-      // No segment override, check for explicit one on memory operand.
-      if (MemOperand != -1) {   // If the instruction has a memory operand.
-        switch (MI.getOperand(MemOperand+X86::AddrSegmentReg).getReg()) {
-        default: assert(0 && "Unknown segment register!");
-        case 0: break;
-        case X86::CS: MCE.emitByte(0x2E); break;
-        case X86::SS: MCE.emitByte(0x36); break;
-        case X86::DS: MCE.emitByte(0x3E); break;
-        case X86::ES: MCE.emitByte(0x26); break;
-        case X86::FS: MCE.emitByte(0x64); break;
-        case X86::GS: MCE.emitByte(0x65); break;
-        }
-      }
-    }
+  case X86II::FS:
+    MCE.emitByte(0x64);
     break;
-
-    case X86II::FS:
-      MCE.emitByte(0x64);
-      break;
-    case X86II::GS:
-      MCE.emitByte(0x65);
-      break;
-    default: llvm_unreachable("Invalid segment!");
+  case X86II::GS:
+    MCE.emitByte(0x65);
+    break;
+  default: llvm_unreachable("Invalid segment!");
+  case 0: break;  // No segment override!
   }
 
   // Emit the repeat opcode prefix as needed.





More information about the llvm-commits mailing list