My Project
transform.hh
Go to the documentation of this file.
1 /* ###
2  * IP: GHIDRA
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
18 #ifndef __TRANSFORM__
19 #define __TRANSFORM__
20 
21 #include "varnode.hh"
22 class Funcdata; // Forward declaration
23 class TransformOp;
24 
26 class TransformVar {
27  friend class TransformManager;
28  friend class TransformOp;
29 public:
31  enum {
32  piece = 1,
35  piece_temp = 4,
36  constant = 5,
38  };
40  enum {
43  };
44 private:
45  Varnode *vn;
46  Varnode *replacement;
47  uint4 type;
48  uint4 flags;
49  int4 byteSize;
50  int4 bitSize;
51  uintb val;
52  TransformOp *def;
53  void createReplacement(Funcdata *fd);
54  void initialize(uint4 tp,Varnode *v,int4 bits,int4 bytes,uintb value);
55 public:
56  Varnode *getOriginal(void) const { return vn; }
57  TransformOp *getDef(void) const { return def; }
58 };
59 
61 class TransformOp {
62  friend class TransformManager;
63  friend class TransformVar;
64 public:
66  enum {
67  op_replacement = 1,
68  op_preexisting = 2,
69  indirect_creation = 4,
70  indirect_creation_possible_out = 8
71  };
72 private:
73  PcodeOp *op;
74  PcodeOp *replacement;
75  OpCode opc;
76  uint4 special;
77  TransformVar *output;
78  vector<TransformVar *> input;
79  TransformOp *follow;
80  void createReplacement(Funcdata *fd);
81  bool attemptInsertion(Funcdata *fd);
82 public:
83  TransformVar *getOut(void) const { return output; }
84  TransformVar *getIn(int4 i) const { return input[i]; }
85 };
86 
89  friend class LanedIterator;
90 public:
92  class LanedIterator {
93  int4 size;
94  uint4 mask;
95  void normalize(void);
96  public:
97  LanedIterator(const LanedRegister *lanedR) { size = 0; mask = lanedR->sizeBitMask; normalize(); }
98  LanedIterator(void) { size = -1; mask = 0; }
99  LanedIterator &operator++(void) { size += 1; normalize(); return *this; }
100  int4 operator*(void) const { return size; }
101  LanedIterator &operator=(const LanedIterator &op2) { size = op2.size; mask = op2.mask; return *this; }
102  bool operator==(const LanedIterator &op2) const { return (size == op2.size); }
103  bool operator!=(const LanedIterator &op2) const { return (size != op2.size); }
104  };
106 private:
107  int4 wholeSize;
108  uint4 sizeBitMask;
109 public:
110  LanedRegister(void) { wholeSize = 0; sizeBitMask = 0; }
111  LanedRegister(int4 sz,uint4 mask) { wholeSize = sz; sizeBitMask = mask; }
112  bool restoreXml(const Element *el,const AddrSpaceManager *manage);
113  int4 getWholeSize(void) const { return wholeSize; }
114  uint4 getSizeBitMask(void) const { return sizeBitMask; }
115  void addLaneSize(int4 size) { sizeBitMask |= ((uint4)1 << size); }
116  bool allowedLane(int4 size) const { return (((sizeBitMask >> size) & 1) != 0); }
117  const_iterator begin(void) const { return LanedIterator(this); }
118  const_iterator end(void) const { return LanedIterator(); }
119 };
120 
127  int4 wholeSize;
128  vector<int4> laneSize;
129  vector<int4> lanePosition;
130 public:
131  LaneDescription(const LaneDescription &op2);
132  LaneDescription(int4 origSize,int4 sz);
133  LaneDescription(int4 origSize,int4 lo,int4 hi);
134  bool subset(int4 lsbOffset,int4 size);
135  int4 getNumLanes(void) const { return laneSize.size(); }
136  int4 getWholeSize(void) const { return wholeSize; }
137  int4 getSize(int4 i) const { return laneSize[i]; }
138  int4 getPosition(int4 i) const { return lanePosition[i]; }
139  int4 getBoundary(int4 bytePos) const;
140  bool restriction(int4 numLanes,int4 skipLanes,int4 bytePos,int4 size,int4 &resNumLanes,int4 &resSkipLanes) const;
141  bool extension(int4 numLanes,int4 skipLanes,int4 bytePos,int4 size,int4 &resNumLanes,int4 &resSkipLanes) const;
142 };
143 
151  Funcdata *fd;
152  map<int4,TransformVar *> pieceMap;
153  list<TransformVar> newVarnodes;
154  list<TransformOp> newOps;
155 
156  void specialHandling(TransformOp &rop);
157  void createOps(void);
158  void createVarnodes(vector<TransformVar *> &inputList);
159  void removeOld(void);
160  void transformInputVarnodes(vector<TransformVar *> &inputList);
161  void placeInputs(void);
162 public:
163  TransformManager(Funcdata *f) { fd = f; }
164  virtual ~TransformManager(void);
165  virtual bool preserveAddress(Varnode *vn,int4 bitSize,int4 lsbOffset) const;
166  Funcdata *getFunction(void) const { return fd; }
167  void clearVarnodeMarks(void);
168  TransformVar *newPreexistingVarnode(Varnode *vn);
169  TransformVar *newUnique(int4 size);
170  TransformVar *newConstant(int4 size,int4 lsbOffset,uintb val);
171  TransformVar *newIop(Varnode *vn);
172  TransformVar *newPiece(Varnode *vn,int4 bitSize,int4 lsbOffset);
173  TransformVar *newSplit(Varnode *vn,const LaneDescription &description);
174  TransformVar *newSplit(Varnode *vn,const LaneDescription &description,int4 numLanes,int4 startLane);
175  TransformOp *newOpReplace(int4 numParams,OpCode opc,PcodeOp *replace);
176  TransformOp *newOp(int4 numParams,OpCode opc,TransformOp *follow);
177  TransformOp *newPreexistingOp(int4 numParams,OpCode opc,PcodeOp *originalOp);
178 
179  TransformVar *getPreexistingVarnode(Varnode *vn);
180  TransformVar *getPiece(Varnode *vn,int4 bitSize,int4 lsbOffset);
181  TransformVar *getSplit(Varnode *vn,const LaneDescription &description);
182  TransformVar *getSplit(Varnode *vn,const LaneDescription &description,int4 numLanes,int4 startLane);
183  void opSetInput(TransformOp *rop,TransformVar *rvn,int4 slot);
184  void opSetOutput(TransformOp *rop,TransformVar *rvn);
185  static bool preexistingGuard(int4 slot,TransformVar *rvn);
186 
187  void apply(void);
188 };
189 
197 inline void TransformVar::initialize(uint4 tp,Varnode *v,int4 bits,int4 bytes,uintb value)
198 
199 {
200  type = tp;
201  vn = v;
202  val = value;
203  bitSize = bits;
204  byteSize = bytes;
205  flags = 0;
206  def = (TransformOp *)0;
207  replacement = (Varnode *)0;
208 }
209 
213 inline void TransformManager::opSetInput(TransformOp *rop,TransformVar *rvn,int4 slot)
214 
215 {
216  rop->input[slot] = rvn;
217 }
218 
224 
225 {
226  rop->output = rvn;
227  rvn->def = rop;
228 }
229 
241 
242 {
243  if (slot == 0) return true; // If we came in on the first slot, build the TransformOp
244  if (rvn->type == TransformVar::piece || rvn->type == TransformVar::piece_temp)
245  return false; // The op was/will be visited on slot 0, don't create TransformOp now
246  return true; // The op was not (will not be) visited on slot 0, build now
247 }
248 
249 #endif
LanedRegister(void)
Constructor for use with restoreXml.
Definition: transform.hh:110
LanedIterator & operator=(const LanedIterator &op2)
Assignment.
Definition: transform.hh:101
const_iterator end(void) const
Ending iterator over possible lane sizes.
Definition: transform.hh:118
Funcdata * getFunction(void) const
Get function being transformed.
Definition: transform.hh:166
bool allowedLane(int4 size) const
Is size among the allowed lane sizes.
Definition: transform.hh:116
OpCode
The op-code defining a specific p-code operation (PcodeOp)
Definition: opcodes.hh:35
A manager for different address spaces.
Definition: translate.hh:218
bool operator==(const LanedIterator &op2) const
Equal operator.
Definition: transform.hh:102
Placeholder node for Varnode that will exist after a transform is applied to a function.
Definition: transform.hh:26
New Varnode is a piece of an original Varnode.
Definition: transform.hh:32
Container for data structures associated with a single function.
Definition: funcdata.hh:45
TransformVar * getOut(void) const
Get the output placeholder variable for this operator.
Definition: transform.hh:83
void addLaneSize(int4 size)
Add a new size to the allowed list.
Definition: transform.hh:115
Special iop constant encoding a PcodeOp reference.
Definition: transform.hh:37
Placeholder node for PcodeOp that will exist after a transform is applied to a function.
Definition: transform.hh:61
A new constant Varnode.
Definition: transform.hh:36
bool operator!=(const LanedIterator &op2) const
Not-equal operator.
Definition: transform.hh:103
Varnode preexisted in the original data-flow.
Definition: transform.hh:33
void opSetInput(TransformOp *rop, TransformVar *rvn, int4 slot)
Mark given variable as input to given op.
Definition: transform.hh:213
A new temporary (unique space) Varnode.
Definition: transform.hh:34
Varnode * getOriginal(void) const
Get the original Varnode this placeholder models.
Definition: transform.hh:56
The last (most significant piece) of a split array.
Definition: transform.hh:41
int4 getPosition(int4 i) const
Get the significance offset of the i-th lane.
Definition: transform.hh:138
Lowest level operation of the p-code language.
Definition: op.hh:58
void opSetOutput(TransformOp *rop, TransformVar *rvn)
Mark given variable as output of given op.
Definition: transform.hh:223
LanedRegister(int4 sz, uint4 mask)
Constructor.
Definition: transform.hh:111
const_iterator begin(void) const
Starting iterator over possible lane sizes.
Definition: transform.hh:117
A low-level variable or contiguous set of bytes described by an Address and a size.
Definition: varnode.hh:65
TransformManager(Funcdata *f)
Constructor.
Definition: transform.hh:163
An XML element. A node in the DOM tree.
Definition: xml.hh:150
LanedIterator(const LanedRegister *lanedR)
Constructor.
Definition: transform.hh:97
int4 getNumLanes(void) const
Get the total number of lanes.
Definition: transform.hh:135
int4 getSize(int4 i) const
Get the size of the i-th lane.
Definition: transform.hh:137
int4 getWholeSize(void) const
Get the size in bytes of the whole laned register.
Definition: transform.hh:113
int4 getWholeSize(void) const
Get the size of the region being split.
Definition: transform.hh:136
Class for iterating over possible lane sizes.
Definition: transform.hh:92
TransformVar * getIn(int4 i) const
Get the i-th input placeholder variable for this.
Definition: transform.hh:84
The Varnode and VarnodeBank classes.
TransformOp * getDef(void) const
Get the operator that defines this placeholder variable.
Definition: transform.hh:57
uint4 getSizeBitMask(void) const
Get the bit mask of possible lane sizes.
Definition: transform.hh:114
LanedIterator(void)
Constructor for ending iterator.
Definition: transform.hh:98
This is a piece of an input that has already been visited.
Definition: transform.hh:42
Description of logical lanes within a big Varnode.
Definition: transform.hh:126
static bool preexistingGuard(int4 slot, TransformVar *rvn)
Should newPreexistingOp be called.
Definition: transform.hh:240
int4 operator*(void) const
Dereference operator.
Definition: transform.hh:100
Class for splitting larger registers holding smaller logical lanes.
Definition: transform.hh:150
A temporary representing a piece of an original Varnode.
Definition: transform.hh:35
LanedIterator & operator++(void)
Preincrement operator.
Definition: transform.hh:99
Describes a (register) storage location and the ways it might be split into lanes.
Definition: transform.hh:88
LanedIterator const_iterator
Iterator over possible lane sizes for this register.
Definition: transform.hh:105