Home | History | Annotate | Download | only in Interpreter

Lines Matching refs:Src1

52      Dest.TY##Val = Src1.TY##Val OP Src2.TY##Val; \
55 static void executeFAddInst(GenericValue &Dest, GenericValue Src1,
66 static void executeFSubInst(GenericValue &Dest, GenericValue Src1,
77 static void executeFMulInst(GenericValue &Dest, GenericValue Src1,
88 static void executeFDivInst(GenericValue &Dest, GenericValue Src1,
99 static void executeFRemInst(GenericValue &Dest, GenericValue Src1,
103 Dest.FloatVal = fmod(Src1.FloatVal, Src2.FloatVal);
106 Dest.DoubleVal = fmod(Src1.DoubleVal, Src2.DoubleVal);
116 Dest.IntVal = APInt(1,Src1.IntVal.OP(Src2.IntVal)); \
121 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size()); \
122 Dest.AggregateVal.resize( Src1.AggregateVal.size() ); \
123 for( uint32_t _i=0;_i<Src1.AggregateVal.size();_i++) \
125 Src1.AggregateVal[_i].IntVal.OP(Src2.AggregateVal[_i].IntVal));\
134 Dest.IntVal = APInt(1,(void*)(intptr_t)Src1.PointerVal OP \
138 static GenericValue executeICMP_EQ(GenericValue Src1, GenericValue Src2,
152 static GenericValue executeICMP_NE(GenericValue Src1, GenericValue Src2,
166 static GenericValue executeICMP_ULT(GenericValue Src1, GenericValue Src2,
180 static GenericValue executeICMP_SLT(GenericValue Src1, GenericValue Src2,
194 static GenericValue executeICMP_UGT(GenericValue Src1, GenericValue Src2,
208 static GenericValue executeICMP_SGT(GenericValue Src1, GenericValue Src2,
222 static GenericValue executeICMP_ULE(GenericValue Src1, GenericValue Src2,
236 static GenericValue executeICMP_SLE(GenericValue Src1, GenericValue Src2,
250 static GenericValue executeICMP_UGE(GenericValue Src1, GenericValue Src2,
264 static GenericValue executeICMP_SGE(GenericValue Src1, GenericValue Src2,
281 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
286 case ICmpInst::ICMP_EQ: R = executeICMP_EQ(Src1, Src2, Ty); break;
287 case ICmpInst::ICMP_NE: R = executeICMP_NE(Src1, Src2, Ty); break;
288 case ICmpInst::ICMP_ULT: R = executeICMP_ULT(Src1, Src2, Ty); break;
289 case ICmpInst::ICMP_SLT: R = executeICMP_SLT(Src1, Src2, Ty); break;
290 case ICmpInst::ICMP_UGT: R = executeICMP_UGT(Src1, Src2, Ty); break;
291 case ICmpInst::ICMP_SGT: R = executeICMP_SGT(Src1, Src2, Ty); break;
292 case ICmpInst::ICMP_ULE: R = executeICMP_ULE(Src1, Src2, Ty); break;
293 case ICmpInst::ICMP_SLE: R = executeICMP_SLE(Src1, Src2, Ty); break;
294 case ICmpInst::ICMP_UGE: R = executeICMP_UGE(Src1, Src2, Ty); break;
295 case ICmpInst::ICMP_SGE: R = executeICMP_SGE(Src1, Src2, Ty); break;
306 Dest.IntVal = APInt(1,Src1.TY##Val OP Src2.TY##Val); \
310 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size()); \
311 Dest.AggregateVal.resize( Src1.AggregateVal.size() ); \
312 for( uint32_t _i=0;_i<Src1.AggregateVal.size();_i++) \
314 Src1.AggregateVal[_i].TY##Val OP Src2.AggregateVal[_i].TY##Val);\
325 static GenericValue executeFCMP_OEQ(GenericValue Src1, GenericValue Src2,
375 static GenericValue executeFCMP_ONE(GenericValue Src1, GenericValue Src2,
379 // if input is scalar value and Src1 or Src2 is NaN return false
380 IMPLEMENT_SCALAR_NANS(Ty, Src1, Src2)
382 MASK_VECTOR_NANS(Ty, Src1, Src2, false)
394 for( size_t _i=0; _i<Src1.AggregateVal.size(); _i++)
401 static GenericValue executeFCMP_OLE(GenericValue Src1, GenericValue Src2,
415 static GenericValue executeFCMP_OGE(GenericValue Src1, GenericValue Src2,
429 static GenericValue executeFCMP_OLT(GenericValue Src1, GenericValue Src2,
443 static GenericValue executeFCMP_OGT(GenericValue Src1, GenericValue Src2,
471 Dest = FUNC(Src1, Src2, Ty); \
472 for (size_t _i = 0; _i < Src1.AggregateVal.size(); _i++) \
478 static GenericValue executeFCMP_UEQ(GenericValue Src1, GenericValue Src2,
481 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
482 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
483 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OEQ)
484 return executeFCMP_OEQ(Src1, Src2, Ty);
488 static GenericValue executeFCMP_UNE(GenericValue Src1, GenericValue Src2,
491 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
492 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
493 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_ONE)
494 return executeFCMP_ONE(Src1, Src2, Ty);
497 static GenericValue executeFCMP_ULE(GenericValue Src1, GenericValue Src2,
500 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
501 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
502 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OLE)
503 return executeFCMP_OLE(Src1, Src2, Ty);
506 static GenericValue executeFCMP_UGE(GenericValue Src1, GenericValue Src2,
509 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
510 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
511 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OGE)
512 return executeFCMP_OGE(Src1, Src2, Ty);
515 static GenericValue executeFCMP_ULT(GenericValue Src1, GenericValue Src2,
518 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
519 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
520 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OLT)
521 return executeFCMP_OLT(Src1, Src2, Ty);
524 static GenericValue executeFCMP_UGT(GenericValue Src1, GenericValue Src2,
527 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
528 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
529 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OGT)
530 return executeFCMP_OGT(Src1, Src2, Ty);
533 static GenericValue executeFCMP_ORD(GenericValue Src1, GenericValue Src2,
537 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
538 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
540 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
542 ( (Src1.AggregateVal[_i].FloatVal ==
543 Src1.AggregateVal[_i].FloatVal) &&
547 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
549 ( (Src1.AggregateVal[_i].DoubleVal ==
550 Src1.AggregateVal[_i].DoubleVal) &&
555 Dest.IntVal = APInt(1,(Src1.FloatVal == Src1.FloatVal &&
558 Dest.IntVal = APInt(1,(Src1.DoubleVal == Src1.DoubleVal &&
564 static GenericValue executeFCMP_UNO(GenericValue Src1, GenericValue Src2,
568 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
569 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
571 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
573 ( (Src1.AggregateVal[_i].FloatVal !=
574 Src1.AggregateVal[_i].FloatVal) ||
578 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
580 ( (Src1.AggregateVal[_i].DoubleVal !=
581 Src1.AggregateVal[_i].DoubleVal) ||
586 Dest.IntVal = APInt(1,(Src1.FloatVal != Src1.FloatVal ||
589 Dest.IntVal = APInt(1,(Src1.DoubleVal != Src1.DoubleVal ||
595 static GenericValue executeFCMP_BOOL(GenericValue Src1, GenericValue Src2,
599 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
600 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
601 for( size_t _i=0; _i<Src1.AggregateVal.size(); _i++)
613 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
622 case FCmpInst::FCMP_FALSE: R = executeFCMP_BOOL(Src1, Src2, Ty, false);
624 case FCmpInst::FCMP_TRUE: R = executeFCMP_BOOL(Src1, Src2, Ty, true);
626 case FCmpInst::FCMP_ORD: R = executeFCMP_ORD(Src1, Src2, Ty); break;
627 case FCmpInst::FCMP_UNO: R = executeFCMP_UNO(Src1, Src2, Ty); break;
628 case FCmpInst::FCMP_UEQ: R = executeFCMP_UEQ(Src1, Src2, Ty); break;
629 case FCmpInst::FCMP_OEQ: R = executeFCMP_OEQ(Src1, Src2, Ty); break;
630 case FCmpInst::FCMP_UNE: R = executeFCMP_UNE(Src1, Src2, Ty); break;
631 case FCmpInst::FCMP_ONE: R = executeFCMP_ONE(Src1, Src2, Ty); break;
632 case FCmpInst::FCMP_ULT: R = executeFCMP_ULT(Src1, Src2, Ty); break;
633 case FCmpInst::FCMP_OLT: R = executeFCMP_OLT(Src1, Src2, Ty); break;
634 case FCmpInst::FCMP_UGT: R = executeFCMP_UGT(Src1, Src2, Ty); break;
635 case FCmpInst::FCMP_OGT: R = executeFCMP_OGT(Src1, Src2, Ty); break;
636 case FCmpInst::FCMP_ULE: R = executeFCMP_ULE(Src1, Src2, Ty); break;
637 case FCmpInst::FCMP_OLE: R = executeFCMP_OLE(Src1, Src2, Ty); break;
638 case FCmpInst::FCMP_UGE: R = executeFCMP_UGE(Src1, Src2, Ty); break;
639 case FCmpInst::FCMP_OGE: R = executeFCMP_OGE(Src1, Src2, Ty); break;
645 static GenericValue executeCmpInst(unsigned predicate, GenericValue Src1,
649 case ICmpInst::ICMP_EQ: return executeICMP_EQ(Src1, Src2, Ty);
650 case ICmpInst::ICMP_NE: return executeICMP_NE(Src1, Src2, Ty);
651 case ICmpInst::ICMP_UGT: return executeICMP_UGT(Src1, Src2, Ty);
652 case ICmpInst::ICMP_SGT: return executeICMP_SGT(Src1, Src2, Ty);
653 case ICmpInst::ICMP_ULT: return executeICMP_ULT(Src1, Src2, Ty);
654 case ICmpInst::ICMP_SLT: return executeICMP_SLT(Src1, Src2, Ty);
655 case ICmpInst::ICMP_UGE: return executeICMP_UGE(Src1, Src2, Ty);
656 case ICmpInst::ICMP_SGE: return executeICMP_SGE(Src1, Src2, Ty);
657 case ICmpInst::ICMP_ULE: return executeICMP_ULE(Src1, Src2, Ty);
658 case ICmpInst::ICMP_SLE: return executeICMP_SLE(Src1, Src2, Ty);
659 case FCmpInst::FCMP_ORD: return executeFCMP_ORD(Src1, Src2, Ty);
660 case FCmpInst::FCMP_UNO: return executeFCMP_UNO(Src1, Src2, Ty);
661 case FCmpInst::FCMP_OEQ: return executeFCMP_OEQ(Src1, Src2, Ty);
662 case FCmpInst::FCMP_UEQ: return executeFCMP_UEQ(Src1, Src2, Ty);
663 case FCmpInst::FCMP_ONE: return executeFCMP_ONE(Src1, Src2, Ty);
664 case FCmpInst::FCMP_UNE: return executeFCMP_UNE(Src1, Src2, Ty);
665 case FCmpInst::FCMP_OLT: return executeFCMP_OLT(Src1, Src2, Ty);
666 case FCmpInst::FCMP_ULT: return executeFCMP_ULT(Src1, Src2, Ty);
667 case FCmpInst::FCMP_OGT: return executeFCMP_OGT(Src1, Src2, Ty);
668 case FCmpInst::FCMP_UGT: return executeFCMP_UGT(Src1, Src2, Ty);
669 case FCmpInst::FCMP_OLE: return executeFCMP_OLE(Src1, Src2, Ty);
670 case FCmpInst::FCMP_ULE: return executeFCMP_ULE(Src1, Src2, Ty);
671 case FCmpInst::FCMP_OGE: return executeFCMP_OGE(Src1, Src2, Ty);
672 case FCmpInst::FCMP_UGE: return executeFCMP_UGE(Src1, Src2, Ty);
673 case FCmpInst::FCMP_FALSE: return executeFCMP_BOOL(Src1, Src2, Ty, false);
674 case FCmpInst::FCMP_TRUE: return executeFCMP_BOOL(Src1, Src2, Ty, true);
684 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
690 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
691 R.AggregateVal.resize(Src1.AggregateVal.size());
697 Src1.AggregateVal[i].IntVal OP Src2.AggregateVal[i].IntVal;
704 Src1.AggregateVal[i].IntVal.OP(Src2.AggregateVal[i].IntVal);
711 Src1.AggregateVal[i].TY OP Src2.AggregateVal[i].TY;
751 fmod(Src1.AggregateVal[i].FloatVal, Src2.AggregateVal[i].FloatVal);
756 fmod(Src1.AggregateVal[i].DoubleVal, Src2.AggregateVal[i].DoubleVal);
770 case Instruction::Add: R.IntVal = Src1.IntVal + Src2.IntVal; break;
771 case Instruction::Sub: R.IntVal = Src1.IntVal - Src2.IntVal; break;
772 case Instruction::Mul: R.IntVal = Src1.IntVal * Src2.IntVal; break;
773 case Instruction::FAdd: executeFAddInst(R, Src1, Src2, Ty); break;
774 case Instruction::FSub: executeFSubInst(R, Src1, Src2, Ty); break;
775 case Instruction::FMul: executeFMulInst(R, Src1, Src2, Ty); break;
776 case Instruction::FDiv: executeFDivInst(R, Src1, Src2, Ty); break;
777 case Instruction::FRem: executeFRemInst(R, Src1, Src2, Ty); break;
778 case Instruction::UDiv: R.IntVal = Src1.IntVal.udiv(Src2.IntVal); break;
779 case Instruction::SDiv: R.IntVal = Src1.IntVal.sdiv(Src2.IntVal); break;
780 case Instruction::URem: R.IntVal = Src1.IntVal.urem(Src2.IntVal); break;
781 case Instruction::SRem: R.IntVal = Src1.IntVal.srem(Src2.IntVal); break;
782 case Instruction::And: R.IntVal = Src1.IntVal & Src2.IntVal; break;
783 case Instruction::Or: R.IntVal = Src1.IntVal | Src2.IntVal; break;
784 case Instruction::Xor: R.IntVal = Src1.IntVal ^ Src2.IntVal; break;
790 static GenericValue executeSelectInst(GenericValue Src1, GenericValue Src2,
794 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
796 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
797 for (size_t i = 0; i < Src1.AggregateVal.size(); ++i)
798 Dest.AggregateVal[i] = (Src1.AggregateVal[i].IntVal == 0) ?
801 Dest = (Src1.IntVal == 0) ? Src3 : Src2;
809 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
812 GenericValue R = executeSelectInst(Src1, Src2, Src3, Ty);
1139 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1145 uint32_t src1Size = uint32_t(Src1.AggregateVal.size());
1150 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1157 llvm::APInt valueToShift = Src1.IntVal;
1166 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1172 uint32_t src1Size = uint32_t(Src1.AggregateVal.size());
1177 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1184 llvm::APInt valueToShift = Src1.IntVal;
1193 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1199 size_t src1Size = Src1.AggregateVal.size();
1204 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1211 llvm::APInt valueToShift = Src1.IntVal;
1749 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1756 if(Src1.AggregateVal.size() > indx) {
1764 Dest.IntVal = Src1.AggregateVal[indx].IntVal;
1767 Dest.FloatVal = Src1.AggregateVal[indx].FloatVal;
1770 Dest.DoubleVal = Src1.AggregateVal[indx].DoubleVal;
1787 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1795 Dest.AggregateVal = Src1.AggregateVal;
1797 if(Src1.AggregateVal.size() <= indx)
1822 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1827 // There is no need to check types of src1 and src2, because the compiled
1828 // bytecode can't contain different types for src1 and src2 for a
1832 unsigned src1Size = (unsigned)Src1.AggregateVal.size();
1846 Dest.AggregateVal[i].IntVal = Src1.AggregateVal[j].IntVal;
1862 Dest.AggregateVal[i].FloatVal = Src1.AggregateVal[j].FloatVal;
1873 Dest.AggregateVal[i].DoubleVal = Src1.AggregateVal[j].DoubleVal;
1932 GenericValue Src1 = getOperandValue(Agg, SF);
1934 GenericValue Dest = Src1; // Dest is a slightly changed Src1