mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-22 23:24:59 +00:00
Teach LLVM how to scalarize packed types. Currently, this only works on
packed types with an element count of 1, although more generic support is coming. This allows LLVM to turn the following code: void %foo(<1 x float> * %a) { entry: %tmp1 = load <1 x float> * %a; %tmp2 = add <1 x float> %tmp1, %tmp1 store <1 x float> %tmp2, <1 x float> *%a ret void } Into: _foo: lfs f0, 0(r3) fadds f0, f0, f0 stfs f0, 0(r3) blr git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24416 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -257,6 +257,8 @@ public:
|
||||
///
|
||||
SDOperand getLoad(MVT::ValueType VT, SDOperand Chain, SDOperand Ptr,
|
||||
SDOperand SV);
|
||||
SDOperand getVecLoad(unsigned Count, MVT::ValueType VT, SDOperand Chain,
|
||||
SDOperand Ptr, SDOperand SV);
|
||||
SDOperand getExtLoad(unsigned Opcode, MVT::ValueType VT, SDOperand Chain,
|
||||
SDOperand Ptr, SDOperand SV, MVT::ValueType EVT);
|
||||
|
||||
|
@@ -107,12 +107,17 @@ namespace ISD {
|
||||
// big. Like EXTRACT_ELEMENT, this can only be used before legalization.
|
||||
BUILD_PAIR,
|
||||
|
||||
|
||||
// Simple integer binary arithmetic operators.
|
||||
ADD, SUB, MUL, SDIV, UDIV, SREM, UREM,
|
||||
|
||||
// Simple binary floating point operators.
|
||||
FADD, FSUB, FMUL, FDIV, FREM,
|
||||
|
||||
// Simple abstract vector operators. Unlike the integer and floating point
|
||||
// binary operators, these nodes also take two additional operands:
|
||||
// a constant element count, and a value type node indicating the type of
|
||||
// the elements. The order is count, type, op0, op1.
|
||||
VADD, VSUB, VMUL,
|
||||
|
||||
// MULHU/MULHS - Multiply high - Multiply two integers of type iN, producing
|
||||
// an unsigned/signed value of type i[2*n], then return the top part.
|
||||
@@ -209,6 +214,11 @@ namespace ISD {
|
||||
// operand, then the same operands as an LLVM load/store instruction, then a
|
||||
// SRCVALUE node that provides alias analysis information.
|
||||
LOAD, STORE,
|
||||
|
||||
// Abstract vector version of LOAD. VLOAD has a token chain as the first
|
||||
// operand, followed by a pointer operand, a constant element count, a value
|
||||
// type node indicating the type of the elements, and a SRCVALUE node.
|
||||
VLOAD,
|
||||
|
||||
// EXTLOAD, SEXTLOAD, ZEXTLOAD - These three operators all load a value from
|
||||
// memory and extend them to a larger value (e.g. load a byte into a word
|
||||
|
Reference in New Issue
Block a user