blob: d6831e0a6b98d3fab54829e6856756d247d24a73 [file] [log] [blame]
Zack Rusine7611612008-02-11 09:43:59 -05001/**************************************************************************
2 *
3 * Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas.
4 * All Rights Reserved.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the
8 * "Software"), to deal in the Software without restriction, including
9 * without limitation the rights to use, copy, modify, merge, publish,
10 * distribute, sub license, and/or sell copies of the Software, and to
11 * permit persons to whom the Software is furnished to do so, subject to
12 * the following conditions:
13 *
14 * The above copyright notice and this permission notice (including the
15 * next paragraph) shall be included in all copies or substantial portions
16 * of the Software.
17 *
18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR
22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25 *
26 **************************************************************************/
27
28#ifndef INSTRUCTIONSSOA_H
29#define INSTRUCTIONSSOA_H
30
Zack Rusincac037d2008-03-12 22:51:57 -040031#include <pipe/p_shader_tokens.h>
Zack Rusinfb1c0932008-04-21 15:15:31 -040032#include <llvm/Support/IRBuilder.h>
Zack Rusin53c29632008-02-13 00:36:31 -050033
Zack Rusine884c7e2008-03-01 08:04:21 -050034#include <map>
Zack Rusine7611612008-02-11 09:43:59 -050035#include <vector>
36
37namespace llvm {
38 class Module;
39 class Function;
40 class BasicBlock;
41 class Value;
42}
43class StorageSoa;
44
45class InstructionsSoa
46{
47public:
48 InstructionsSoa(llvm::Module *mod, llvm::Function *func,
49 llvm::BasicBlock *block, StorageSoa *storage);
50
Zack Rusin59766ac2008-05-15 17:46:20 -040051 std::vector<llvm::Value*> abs(const std::vector<llvm::Value*> in1);
Zack Rusinf70cc892008-02-14 22:42:57 -050052 std::vector<llvm::Value*> arl(const std::vector<llvm::Value*> in);
Zack Rusine7611612008-02-11 09:43:59 -050053 std::vector<llvm::Value*> add(const std::vector<llvm::Value*> in1,
54 const std::vector<llvm::Value*> in2);
Zack Rusine884c7e2008-03-01 08:04:21 -050055 std::vector<llvm::Value*> dp3(const std::vector<llvm::Value*> in1,
56 const std::vector<llvm::Value*> in2);
Zack Rusina9c40f82008-03-01 09:50:41 -050057 std::vector<llvm::Value*> dp4(const std::vector<llvm::Value*> in1,
58 const std::vector<llvm::Value*> in2);
Zack Rusin1d1cf8e2008-05-16 16:06:59 -040059 std::vector<llvm::Value*> lit(const std::vector<llvm::Value*> in);
Zack Rusinf70cc892008-02-14 22:42:57 -050060 std::vector<llvm::Value*> madd(const std::vector<llvm::Value*> in1,
61 const std::vector<llvm::Value*> in2,
62 const std::vector<llvm::Value*> in3);
Zack Rusinea1a6072008-05-16 14:54:40 -040063 std::vector<llvm::Value*> max(const std::vector<llvm::Value*> in1,
64 const std::vector<llvm::Value*> in2);
65 std::vector<llvm::Value*> min(const std::vector<llvm::Value*> in1,
66 const std::vector<llvm::Value*> in2);
Zack Rusine7611612008-02-11 09:43:59 -050067 std::vector<llvm::Value*> mul(const std::vector<llvm::Value*> in1,
68 const std::vector<llvm::Value*> in2);
Zack Rusincac037d2008-03-12 22:51:57 -040069 std::vector<llvm::Value*> pow(const std::vector<llvm::Value*> in1,
70 const std::vector<llvm::Value*> in2);
Zack Rusin02e45b22008-05-16 17:10:52 -040071 std::vector<llvm::Value*> rsq(const std::vector<llvm::Value*> in1);
Stephane Marchesin8bdb4d22008-10-01 00:00:58 +020072 std::vector<llvm::Value*> slt(const std::vector<llvm::Value*> in1,
73 const std::vector<llvm::Value*> in2);
Zack Rusin59766ac2008-05-15 17:46:20 -040074 std::vector<llvm::Value*> sub(const std::vector<llvm::Value*> in1,
75 const std::vector<llvm::Value*> in2);
Zack Rusine7611612008-02-11 09:43:59 -050076 void end();
Zack Rusin135d2322008-02-13 03:18:37 -050077
Zack Rusincf51d5c2008-02-14 23:50:39 -050078 std::vector<llvm::Value*> extractVector(llvm::Value *vector);
Stephane Marchesin94ba48b2008-10-07 21:11:01 +020079 llvm::IRBuilder<>* getIRBuilder();
Zack Rusin135d2322008-02-13 03:18:37 -050080private:
81 const char * name(const char *prefix) const;
Zack Rusinf70cc892008-02-14 22:42:57 -050082 llvm::Value *vectorFromVals(llvm::Value *x, llvm::Value *y,
83 llvm::Value *z, llvm::Value *w);
Zack Rusine884c7e2008-03-01 08:04:21 -050084 void createFunctionMap();
85 void createBuiltins();
Zack Rusincac037d2008-03-12 22:51:57 -040086 void createDependencies();
Zack Rusine884c7e2008-03-01 08:04:21 -050087 llvm::Function *function(int);
88 llvm::Module *currentModule() const;
89 llvm::Value *allocaTemp();
Zack Rusina9c40f82008-03-01 09:50:41 -050090 std::vector<llvm::Value*> allocaToResult(llvm::Value *allocaPtr);
91 std::vector<llvm::Value*> callBuiltin(llvm::Function *func,
92 const std::vector<llvm::Value*> in1);
93 std::vector<llvm::Value*> callBuiltin(llvm::Function *func,
94 const std::vector<llvm::Value*> in1,
95 const std::vector<llvm::Value*> in2);
96 std::vector<llvm::Value*> callBuiltin(llvm::Function *func,
97 const std::vector<llvm::Value*> in1,
98 const std::vector<llvm::Value*> in2,
99 const std::vector<llvm::Value*> in3);
Zack Rusincac037d2008-03-12 22:51:57 -0400100 void injectFunction(llvm::Function *originalFunc, int op = TGSI_OPCODE_LAST);
Zack Rusin53c29632008-02-13 00:36:31 -0500101private:
Stephane Marchesin3f4b67f2008-09-30 20:50:49 +0200102 llvm::IRBuilder<> m_builder;
Zack Rusinf70cc892008-02-14 22:42:57 -0500103 StorageSoa *m_storage;
Zack Rusine884c7e2008-03-01 08:04:21 -0500104
105 std::map<int, std::string> m_functionsMap;
106 std::map<int, llvm::Function*> m_functions;
107 llvm::Module *m_builtins;
Zack Rusincac037d2008-03-12 22:51:57 -0400108 std::map<std::string, std::vector<std::string> > m_builtinDependencies;
Zack Rusine884c7e2008-03-01 08:04:21 -0500109
Zack Rusin135d2322008-02-13 03:18:37 -0500110private:
111 mutable int m_idx;
112 mutable char m_name[32];
Zack Rusine7611612008-02-11 09:43:59 -0500113};
114
115
116#endif