summaryrefslogtreecommitdiff
path: root/src/arch/x86
AgeCommit message (Collapse)Author
2009-08-17X86: Implement a media xor microop.Gabe Black
2009-08-17X86: Implement PUNPCKLQDQ.Gabe Black
2009-08-17X86: Implement PUNPCKHQDQ.Gabe Black
2009-08-17X86: Implement PUNPCKHDQ.Gabe Black
2009-08-17X86: Implement PUNPCKHWD.Gabe Black
2009-08-17X86: Implement PUNPCKHBW.Gabe Black
2009-08-17X86: Implement PUNPCKLDQ.Gabe Black
2009-08-17X86: Implement PUNPCKLWD.Gabe Black
2009-08-17X86: Implement the versions of PUNPCKLBW that use XMM registers.Gabe Black
2009-08-17X86: Implement the MOVQ instruction.Gabe Black
2009-08-17X86: Implement the lfpimm microop.Gabe Black
2009-08-17X86: Implement the versions of MOVD that have an MMX source.Gabe Black
2009-08-17X86: Implement the versions of PUNPCKLBW that use MMX registers.Gabe Black
2009-08-17X86: Implement an unpack microop.Gabe Black
2009-08-17X86: Implement the versions of MOVD that have an MMX destination.Gabe Black
2009-08-17X86: Ignore the size part of XMM/MMX operands. The instructions know what ↵Gabe Black
they want.
2009-08-17X86: Use suffixes to differentiate XMM/MMX/GPR operands.Gabe Black
2009-08-17X86: Add microcode assembler symbols for mmx registers.Gabe Black
2009-08-17X86: Set up a media microop framework and create mov2int and mov2fp microops.Gabe Black
2009-08-17X86: Create base classes for use with media/SIMD microops.Gabe Black
2009-08-17X86: Turn the DIV and IDIV microcode into templates and generate all the ↵Gabe Black
variants.
2009-08-17X86: Remove some FIXMEs from IDIV that have been fixed.Gabe Black
2009-08-17X86: Turn the CMPXCHG8B microcode into a template and generate each variant.Gabe Black
2009-08-17X86: Fix a bug introduced to IDIV in a recent attempt to fix another bug.Gabe Black
2009-08-09X86: Implement the CMPXCHG8B/CMPXCHG16B instruction.Gabe Black
2009-08-09X86: Don't clobber the original dividend when doing signed divide.Gabe Black
2009-08-09X86: Decode byte sized singed divide as byte sized.Gabe Black
2009-08-08X86: Make not taken conditional moves leave the destination alone. Adjust ↵Gabe Black
CMOVcc. The manuals from both AMD and Intel say that when writing to a 32 bit destination in 64 bit mode, the upper 32 bits of the register are filled with zeros. They also both say that the CMOV instructions leave their destination alone when their condition fails. Unfortunately, it seems that CMOV will zero extend its destination register whether or not it was supposed to actually do a move on both platforms. This seems to be the only case where this happens, but it would be hard to say for sure.
2009-08-07X86: (Re)Implemented SHRD.Gabe Black
2009-08-07X86: Implement SHLD.Gabe Black
2009-08-07X86: Implement shift right/left double microops.Gabe Black
This is my best guess as far as what these should do. Other existing microops use implicit registers, mul1s and mul1u for instance, so this should be ok. The microop that loads the implicit DoubleBits register would fall into one of the microop slots for moving to/from special registers.
2009-08-07X86: Make the qaud width bswap instruction handle the fact that 32 bit ↵Gabe Black
operations zero extend.
2009-08-07X86: Use the right field when using legacy prefixes to distinguish instructions.Gabe Black
2009-08-07X86: Don't truncate the immediate parameter for the ENTER instruction.Gabe Black
2009-08-06X86: Adjust the various sizes used for the enter and leave instructions.Gabe Black
2009-08-06X86: Make scas compare its operands in the right order.Gabe Black
2009-08-06X86: Fix a copy/paste error for cmovnp.Gabe Black
2009-08-05X86: Make conditional moves zero extend their 32 bit destinations always.Gabe Black
2009-08-05X86: Fix condition code setting for signed multiplies with negative results.Gabe Black
2009-08-05X86: Make the check for negative operands for sign multiply more direct.Gabe Black
2009-08-05X86: Make sure immediate values are truncated properly.Gabe Black
Register values will be "picked" which will assure they don't have junk beyond the part we're using. Immediate values don't go through a similar process, so we should truncate them explicitly.
2009-08-05X86: Use the new forced folding mechanism for the SAHF and LAHF instructions.Gabe Black
2009-08-05X86: Fix the indexing for ah in byte division instructions.Gabe Black
2009-08-05X86: Fix the indexing for ah in byte multiply instructions.Gabe Black
2009-08-05X86: Let microops force folding an index into the high byte of a register.Gabe Black
2009-08-05X86: Handle rotate left with carry instructions that go all the way around ↵Gabe Black
or more.
2009-08-05X86: Set the flags on rotate left with carry instructions.Gabe Black
2009-08-05X86: Handle rotate right with carry instructions that go all the way around ↵Gabe Black
or more.
2009-08-05X86: Fix the overflow bit for rotate right with carry.Gabe Black
2009-08-05X86: Fix the computation of the bottom part of rotate right with carry.Gabe Black