Home | History | Annotate | Download | only in priv

Lines Matching full:iricb

50 static IRICB iricb;
54 LibVEX_InitIRI(const IRICB *iricb_in)
56 iricb = *iricb_in; // copy in
190 block iricb. */
197 if (iricb.rounding_mode != NO_ROUNDING_MODE) {
198 rounding_mode = mkU32(iricb.rounding_mode);
201 switch (iricb.num_operands) {
203 opnd1 = load(endian, iricb.t_opnd1, iricb.opnd1);
205 data = binop(iricb.op, rounding_mode, opnd1);
207 data = unop(iricb.op, opnd1);
211 opnd1 = load(endian, iricb.t_opnd1, iricb.opnd1);
213 if (iricb.shift_amount_is_immediate) {
215 vassert(iricb.t_opnd2 == Ity_I8);
217 opnd2 = mkU8(*((ULong *)iricb.opnd2));
219 opnd2 = load(endian, iricb.t_opnd2, iricb.opnd2);
223 data = triop(iricb.op, rounding_mode, opnd1, opnd2);
225 data = binop(iricb.op, opnd1, opnd2);
229 opnd1 = load(endian, iricb.t_opnd1, iricb.opnd1);
230 opnd2 = load(endian, iricb.t_opnd2, iricb.opnd2);
231 opnd3 = load(endian, iricb.t_opnd3, iricb.opnd3);
233 data = qop(iricb.op, rounding_mode, opnd1, opnd2, opnd3);
235 data = triop(iricb.op, opnd1, opnd2, opnd3);
240 opnd1 = load(endian, iricb.t_opnd1, iricb.opnd1);
241 opnd2 = load(endian, iricb.t_opnd2, iricb.opnd2);
242 opnd3 = load(endian, iricb.t_opnd3, iricb.opnd3);
243 opnd4 = load(endian, iricb.t_opnd4, iricb.opnd4);
244 data = qop(iricb.op, opnd1, opnd2, opnd3, opnd4);
251 store(irsb, endian, iricb.result, data);
255 if (iricb.t_result == Ity_I1 || sizeofIRType(iricb.t_result) <= 8) {
257 } else if (sizeofIRType(iricb.t_result) == 16) {