diff -r 522a865288d9 -r 5778c1daa9b1 src/arch/x86/isa/decoder/two_byte_opcodes.isa --- a/src/arch/x86/isa/decoder/two_byte_opcodes.isa Sat Jan 05 10:14:17 2013 -0600 +++ b/src/arch/x86/isa/decoder/two_byte_opcodes.isa Sat Jan 05 10:16:40 2013 -0600 @@ -601,7 +601,7 @@ 0x4: Inst::PCMPEQB(Pq,Qq); 0x5: Inst::PCMPEQW(Pq,Qq); 0x6: Inst::PCMPEQD(Pq,Qq); - 0x7: WarnUnimpl::emms(); + 0x7: Inst::EMMS(); } // repe (0xF3) 0x4: decode OPCODE_OP_BOTTOM3 { diff -r 522a865288d9 -r 5778c1daa9b1 src/arch/x86/isa/insts/simd64/integer/exit_media_state.py --- a/src/arch/x86/isa/insts/simd64/integer/exit_media_state.py Sat Jan 05 10:14:17 2013 -0600 +++ b/src/arch/x86/isa/insts/simd64/integer/exit_media_state.py Sat Jan 05 10:16:40 2013 -0600 @@ -36,6 +36,9 @@ # Authors: Gabe Black microcode = ''' -# EMMS +def macroop EMMS { + emms +}; + # FEMMS ''' diff -r 522a865288d9 -r 5778c1daa9b1 src/arch/x86/isa/microasm.isa --- a/src/arch/x86/isa/microasm.isa Sat Jan 05 10:14:17 2013 -0600 +++ b/src/arch/x86/isa/microasm.isa Sat Jan 05 10:16:40 2013 -0600 @@ -212,6 +212,7 @@ assembler.symbols["fsw"] = readFpReg("FSW") assembler.symbols["fcw"] = readFpReg("FCW") + assembler.symbols["ftw"] = readFpReg("FTW") macroopDict = assembler.assemble(microcode) diff -r 522a865288d9 -r 5778c1daa9b1 src/arch/x86/isa/microops/mediaop.isa --- a/src/arch/x86/isa/microops/mediaop.isa Sat Jan 05 10:14:17 2013 -0600 +++ b/src/arch/x86/isa/microops/mediaop.isa Sat Jan 05 10:16:40 2013 -0600 @@ -1502,4 +1502,10 @@ else if(arg1 == arg2) ccFlagBits = ccFlagBits | ZFBit; ''' + + class Emms(MediaOp): + def __init__(self): + super(Emms, self).__init__('InstRegIndex(MISCREG_FTW)', + 'InstRegIndex(0)', 'InstRegIndex(0)', 0) + code = 'FTW = 0xFFFF;' }}; diff -r 522a865288d9 -r 5778c1daa9b1 src/arch/x86/isa/operands.isa --- a/src/arch/x86/isa/operands.isa Sat Jan 05 10:14:17 2013 -0600 +++ b/src/arch/x86/isa/operands.isa Sat Jan 05 10:16:40 2013 -0600 @@ -162,6 +162,7 @@ # Registers related to the state of x87 floating point unit. 'TOP': controlReg('MISCREG_X87_TOP', 66, ctype='ub'), 'FSW': controlReg('MISCREG_FSW', 67, ctype='uw'), + 'FTW': controlReg('MISCREG_FTW', 68, ctype='uw'), # The segment base as used by memory instructions. 'SegBase': controlReg('MISCREG_SEG_EFF_BASE(segment)', 70),