1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
/****************************************************************************
* Copyright (C) 2014-2015 Intel Corporation. All Rights Reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice (including the next
* paragraph) shall be included in all copies or substantial portions of the
* Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
* IN THE SOFTWARE.
*
* @file builder.h
*
* @brief Includes all the builder related functionality
*
* Notes:
*
******************************************************************************/
#pragma once
#include "JitManager.h"
#include "common/formats.h"
namespace SwrJit
{
using namespace llvm;
struct Builder
{
Builder(JitManager *pJitMgr);
virtual ~Builder() {}
IRBuilder<> *IRB() { return mpIRBuilder; };
JitManager *JM() { return mpJitMgr; }
JitManager *mpJitMgr;
IRBuilder<> *mpIRBuilder;
uint32_t mVWidth; // vector width target simd
uint32_t mVWidth16; // vector width simd16
// Built in types: scalar
Type* mVoidTy;
Type* mInt1Ty;
Type* mInt8Ty;
Type* mInt16Ty;
Type* mInt32Ty;
Type* mInt64Ty;
Type* mIntPtrTy;
Type* mFP16Ty;
Type* mFP32Ty;
Type* mFP32PtrTy;
Type* mDoubleTy;
Type* mInt8PtrTy;
Type* mInt16PtrTy;
Type* mInt32PtrTy;
Type* mSimd4FP64Ty;
// Built in types: target SIMD
Type* mSimdFP16Ty;
Type* mSimdFP32Ty;
Type* mSimdInt1Ty;
Type* mSimdInt16Ty;
Type* mSimdInt32Ty;
Type* mSimdInt64Ty;
Type* mSimdIntPtrTy;
Type* mSimdVectorTy;
Type* mSimdVectorTRTy;
Type* mSimdVectorIntTy;
// Built in types: simd16
Type* mSimd16FP16Ty;
Type* mSimd16FP32Ty;
Type* mSimd16Int1Ty;
Type* mSimd16Int16Ty;
Type* mSimd16Int32Ty;
Type* mSimd16Int64Ty;
Type* mSimd16IntPtrTy;
Type* mSimd16VectorTy;
Type* mSimd16VectorTRTy;
Type* mSimd32Int8Ty;
void SetTargetWidth(uint32_t width);
void SetTempAlloca(Value* inst);
bool IsTempAlloca(Value* inst);
#include "gen_builder.hpp"
#include "gen_builder_meta.hpp"
#include "gen_builder_intrin.hpp"
#include "builder_misc.h"
#include "builder_math.h"
#include "builder_mem.h"
protected:
void SetPrivateContext(Value* pPrivateContext)
{
mpPrivateContext = pPrivateContext;
NotifyPrivateContextSet();
}
virtual void NotifyPrivateContextSet() {}
inline Value* GetPrivateContext() { return mpPrivateContext; }
private:
Value* mpPrivateContext;
};
}
|