|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| | Added scalar compare VCMPSS, VCMPSD.
Implemented LowerSELECT for scalar FP operations.
I replaced FSETCCss, FSETCCsd with one node type FSETCCs.
Node extract_vector_elt(v16i1/v8i1, idx) returns an element of type i1.
llvm-svn: 197384 | 
| | 
| 
| 
| 
| 
| | added EVEX_KZ to tablegen
llvm-svn: 193959 | 
| | 
| 
| 
| | llvm-svn: 191874 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Add VEX_LIG to scalar FMA4 instructions.
Use VEX_LIG in some of the inheriting checks in disassembler table generator.
Make use of VEX_L_W, VEX_L_W_XS, VEX_L_W_XD contexts.
Don't let VEX_L_W, VEX_L_W_XS, VEX_L_W_XD, VEX_L_W_OPSIZE inherit from their non-L forms unless VEX_LIG is set.
Let VEX_L_W, VEX_L_W_XS, VEX_L_W_XD, VEX_L_W_OPSIZE inherit from all of their non-L or non-W cases.
Increase ranking on VEX_L_W, VEX_L_W_XS, VEX_L_W_XD, VEX_L_W_OPSIZE so they get chosen over non-L/non-W forms.
llvm-svn: 191649 | 
| | 
| 
| 
| 
| 
| 
| | Added 512-bit operands printing.
Added instruction formats for KNL instructions.
llvm-svn: 187324 | 
| | 
| 
| 
| 
| 
| | byte represent 8 instructions and the reg modRM byte represents up to 64 instructions. Reduces modRM table from 43k entreis to 25k entries. Based on a patch from Manman Ren.
llvm-svn: 163774 | 
| | 
| 
| 
| 
| 
| | used to store the operand types and encodings. Store only the unique combinations in a separate table and store indices in the instruction table. Saves about 32K of static data.
llvm-svn: 161101 | 
| | 
| 
| 
| | llvm-svn: 161026 | 
| | 
| 
| 
| | llvm-svn: 153935 | 
| | 
| 
| 
| 
| 
| | Shaves 150k off the size of X86DisassemblerDecoder.o
llvm-svn: 151995 | 
| | 
| 
| 
| 
| 
| | Kay Tiong Khoo.
llvm-svn: 151510 | 
| | 
| 
| 
| 
| 
| | MSP430, PPC, PTX, Sparc, X86, XCore.
llvm-svn: 150878 | 
| | 
| 
| 
| | llvm-svn: 150167 | 
| | 
| 
| 
| | llvm-svn: 143895 | 
| | 
| 
| 
| 
| 
| | for 64BIT_REXW_XD not existing, but it does exist.
llvm-svn: 141642 | 
| | 
| 
| 
| 
| 
| | instructions. Mark instructions that have this behavior. Fixes PR10676.
llvm-svn: 141065 | 
| | 
| 
| 
| 
| 
| | 0xf2 as an opcode extension and allows the opsize prefix. This necessitated adding IC_XD_OPSIZE and IC_64BIT_XD_OPSIZE contexts. Unfortunately, this increases the size of the disassembler tables. Fixes PR10702.
llvm-svn: 140954 | 
| | 
| 
| 
| | llvm-svn: 128826 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | instruction set.  This code adds support for the VEX prefix
and for the YMM registers accessible on AVX-enabled
architectures.  Instruction table support that enables AVX
instructions for the disassembler is in an upcoming patch.
llvm-svn: 127644 | 
| | 
| 
| 
| | llvm-svn: 120298 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | operands.
With this done, we can remove the _Int suffixes from the round instructions
without the disassembler blowing up.  This allows the assembler to support
them, implementing rdar://8456376 - llvm-mc rejects 'roundss'
llvm-svn: 115019 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | and %rcr_, leaving just %cr_ which is what people expect.
Updated the disassembler to support this unified register set.
Added a testcase to verify that the registers continue to be
decoded correctly.
llvm-svn: 103196 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | argument that had to be between 0 and 7 to have any value,
firing an assert later in the AsmPrinter.  Now, the
disassembler rejects instructions with out-of-range values
for that immediate.
llvm-svn: 100694 | 
| | 
| 
| 
| 
| 
| 
| 
| | Made LEA memory operands emit only 4 MCInst operands.
Made the scale operand equal 1 for instructions that have no
SIB byte.
llvm-svn: 91919 | 
|  | incarnations), integrated into the MC framework.  
The disassembler is table-driven, using a custom TableGen backend to 
generate hierarchical tables optimized for fast decode.  The disassembler 
consumes MemoryObjects and produces arrays of MCInsts, adhering to the 
abstract base class MCDisassembler (llvm/MC/MCDisassembler.h).
The disassembler is documented in detail in
- lib/Target/X86/Disassembler/X86Disassembler.cpp (disassembler runtime)
- utils/TableGen/DisassemblerEmitter.cpp (table emitter)
You can test the disassembler by running llvm-mc -disassemble for i386
or x86_64 targets.  Please let me know if you encounter any problems
with it.
llvm-svn: 91749 |