diff --git a/lib/Target/X86/X86ATTAsmPrinter.cpp b/lib/Target/X86/X86ATTAsmPrinter.cpp index 4571e7cd8f0..3e690aa398d 100755 --- a/lib/Target/X86/X86ATTAsmPrinter.cpp +++ b/lib/Target/X86/X86ATTAsmPrinter.cpp @@ -118,8 +118,8 @@ void X86ATTAsmPrinter::printOperand(const MachineInstr *MI, unsigned OpNo, "Virtual registers should not make it this far!"); O << '%'; unsigned Reg = MO.getReg(); - if (Modifier && strncmp(Modifier, "trunc", strlen("trunc")) == 0) { - MVT::ValueType VT = (strcmp(Modifier,"trunc16") == 0) + if (Modifier && strncmp(Modifier, "subreg", strlen("subreg")) == 0) { + MVT::ValueType VT = (strcmp(Modifier,"subreg16") == 0) ? MVT::i16 : MVT::i8; Reg = getX86SubSuperRegister(Reg, VT); } diff --git a/lib/Target/X86/X86InstrInfo.td b/lib/Target/X86/X86InstrInfo.td index cd023cc74f5..bc2fc70500e 100644 --- a/lib/Target/X86/X86InstrInfo.td +++ b/lib/Target/X86/X86InstrInfo.td @@ -360,11 +360,11 @@ def NOOP : I<0x90, RawFrm, (ops), "nop", []>; // Truncate def TRUNC_GR32_GR8 : I<0x88, MRMDestReg, (ops GR8:$dst, GR32_:$src), - "mov{b} {${src:trunc8}, $dst|$dst, ${src:trunc8}", []>; + "mov{b} {${src:subreg8}, $dst|$dst, ${src:subreg8}", []>; def TRUNC_GR16_GR8 : I<0x88, MRMDestReg, (ops GR8:$dst, GR16_:$src), - "mov{b} {${src:trunc8}, $dst|$dst, ${src:trunc8}}", []>; + "mov{b} {${src:subreg8}, $dst|$dst, ${src:subreg8}}", []>; def TRUNC_GR32_GR16 : I<0x89, MRMDestReg, (ops GR16:$dst, GR32:$src), - "mov{w} {${src:trunc16}, $dst|$dst, ${src:trunc16}}", + "mov{w} {${src:subreg16}, $dst|$dst, ${src:subreg16}}", [(set GR16:$dst, (trunc GR32:$src))]>; //===----------------------------------------------------------------------===// diff --git a/lib/Target/X86/X86IntelAsmPrinter.cpp b/lib/Target/X86/X86IntelAsmPrinter.cpp index d8e97420a69..c8bcc59b628 100755 --- a/lib/Target/X86/X86IntelAsmPrinter.cpp +++ b/lib/Target/X86/X86IntelAsmPrinter.cpp @@ -87,8 +87,8 @@ void X86IntelAsmPrinter::printOp(const MachineOperand &MO, case MachineOperand::MO_Register: if (MRegisterInfo::isPhysicalRegister(MO.getReg())) { unsigned Reg = MO.getReg(); - if (Modifier && strncmp(Modifier, "trunc", strlen("trunc")) == 0) { - MVT::ValueType VT = (strcmp(Modifier,"trunc16") == 0) + if (Modifier && strncmp(Modifier, "subreg", strlen("subreg")) == 0) { + MVT::ValueType VT = (strcmp(Modifier,"subreg16") == 0) ? MVT::i16 : MVT::i8; Reg = getX86SubSuperRegister(Reg, VT); }