1 /****************************************************************************
2 * Copyright (C) 2014-2015 Intel Corporation. All Rights Reserved.
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
25 * @brief Includes all the builder related functionality
29 ******************************************************************************/
32 #include "JitManager.h"
33 #include "common/formats.h"
37 ///@todo Move this to better place
38 enum SHADER_STATS_COUNTER_TYPE
40 STATS_INST_EXECUTED
= 0,
41 STATS_SAMPLE_EXECUTED
= 1,
42 STATS_SAMPLE_L_EXECUTED
= 2,
43 STATS_SAMPLE_B_EXECUTED
= 3,
44 STATS_SAMPLE_C_EXECUTED
= 4,
45 STATS_SAMPLE_C_LZ_EXECUTED
= 5,
46 STATS_SAMPLE_C_D_EXECUTED
= 6,
47 STATS_LOD_EXECUTED
= 7,
48 STATS_GATHER4_EXECUTED
= 8,
49 STATS_GATHER4_C_EXECUTED
= 9,
50 STATS_GATHER4_C_PO_EXECUTED
= 10,
51 STATS_GATHER4_C_PO_C_EXECUTED
= 11,
52 STATS_LOAD_RAW_UAV
= 12,
53 STATS_LOAD_RAW_RESOURCE
= 13,
54 STATS_STORE_RAW_UAV
= 14,
55 STATS_STORE_TGSM
= 15,
63 Builder(JitManager
*pJitMgr
);
66 IRBuilder
<> *IRB() { return mpIRBuilder
; };
67 JitManager
*JM() { return mpJitMgr
; }
70 IRBuilder
<> *mpIRBuilder
;
72 uint32_t mVWidth
; // vector width target simd
73 uint32_t mVWidth16
; // vector width simd16
75 // Built in types: scalar
94 // Built in types: target SIMD
104 Type
* mSimdVectorTRTy
;
105 Type
* mSimdVectorIntTy
;
107 // Built in types: simd16
112 Type
* mSimd16Int16Ty
;
113 Type
* mSimd16Int32Ty
;
114 Type
* mSimd16Int64Ty
;
115 Type
* mSimd16IntPtrTy
;
116 Type
* mSimd16VectorTy
;
117 Type
* mSimd16VectorTRTy
;
121 void SetTargetWidth(uint32_t width
);
122 void SetTempAlloca(Value
* inst
);
123 bool IsTempAlloca(Value
* inst
);
124 bool SetTexelMaskEvaluate(Instruction
* inst
);
125 bool IsTexelMaskEvaluate(Instruction
* inst
);
126 Type
* GetVectorType(Type
* pType
);
127 void SetMetadata(StringRef s
, uint32_t val
)
129 llvm::NamedMDNode
*metaData
= mpJitMgr
->mpCurrentModule
->getOrInsertNamedMetadata(s
);
130 Constant
* cval
= mpIRBuilder
->getInt32(val
);
131 llvm::MDNode
*mdNode
= llvm::MDNode::get(mpJitMgr
->mpCurrentModule
->getContext(), llvm::ConstantAsMetadata::get(cval
));
132 if (metaData
->getNumOperands())
134 metaData
->setOperand(0, mdNode
);
138 metaData
->addOperand(mdNode
);
141 uint32_t GetMetadata(StringRef s
)
143 NamedMDNode
* metaData
= mpJitMgr
->mpCurrentModule
->getNamedMetadata(s
);
146 MDNode
* mdNode
= metaData
->getOperand(0);
147 Metadata
* val
= mdNode
->getOperand(0);
148 return mdconst::dyn_extract
<ConstantInt
>(val
)->getZExtValue();
156 #include "gen_builder.hpp"
157 #include "gen_builder_meta.hpp"
158 #include "gen_builder_intrin.hpp"
159 #include "builder_misc.h"
160 #include "builder_math.h"
161 #include "builder_mem.h"
165 void SetPrivateContext(Value
* pPrivateContext
)
167 mpPrivateContext
= pPrivateContext
;
168 NotifyPrivateContextSet();
170 virtual void NotifyPrivateContextSet() {}
171 inline Value
* GetPrivateContext() { return mpPrivateContext
; }
174 Value
* mpPrivateContext
;