Home | History | Annotate | Download | only in Interpreter

Lines Matching refs:Src1

51      Dest.TY##Val = Src1.TY##Val OP Src2.TY##Val; \
54 static void executeFAddInst(GenericValue &Dest, GenericValue Src1,
65 static void executeFSubInst(GenericValue &Dest, GenericValue Src1,
76 static void executeFMulInst(GenericValue &Dest, GenericValue Src1,
87 static void executeFDivInst(GenericValue &Dest, GenericValue Src1,
98 static void executeFRemInst(GenericValue &Dest, GenericValue Src1,
102 Dest.FloatVal = fmod(Src1.FloatVal, Src2.FloatVal);
105 Dest.DoubleVal = fmod(Src1.DoubleVal, Src2.DoubleVal);
115 Dest.IntVal = APInt(1,Src1.IntVal.OP(Src2.IntVal)); \
120 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size()); \
121 Dest.AggregateVal.resize( Src1.AggregateVal.size() ); \
122 for( uint32_t _i=0;_i<Src1.AggregateVal.size();_i++) \
124 Src1.AggregateVal[_i].IntVal.OP(Src2.AggregateVal[_i].IntVal));\
133 Dest.IntVal = APInt(1,(void*)(intptr_t)Src1.PointerVal OP \
137 static GenericValue executeICMP_EQ(GenericValue Src1, GenericValue Src2,
151 static GenericValue executeICMP_NE(GenericValue Src1, GenericValue Src2,
165 static GenericValue executeICMP_ULT(GenericValue Src1, GenericValue Src2,
179 static GenericValue executeICMP_SLT(GenericValue Src1, GenericValue Src2,
193 static GenericValue executeICMP_UGT(GenericValue Src1, GenericValue Src2,
207 static GenericValue executeICMP_SGT(GenericValue Src1, GenericValue Src2,
221 static GenericValue executeICMP_ULE(GenericValue Src1, GenericValue Src2,
235 static GenericValue executeICMP_SLE(GenericValue Src1, GenericValue Src2,
249 static GenericValue executeICMP_UGE(GenericValue Src1, GenericValue Src2,
263 static GenericValue executeICMP_SGE(GenericValue Src1, GenericValue Src2,
280 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
285 case ICmpInst::ICMP_EQ: R = executeICMP_EQ(Src1, Src2, Ty); break;
286 case ICmpInst::ICMP_NE: R = executeICMP_NE(Src1, Src2, Ty); break;
287 case ICmpInst::ICMP_ULT: R = executeICMP_ULT(Src1, Src2, Ty); break;
288 case ICmpInst::ICMP_SLT: R = executeICMP_SLT(Src1, Src2, Ty); break;
289 case ICmpInst::ICMP_UGT: R = executeICMP_UGT(Src1, Src2, Ty); break;
290 case ICmpInst::ICMP_SGT: R = executeICMP_SGT(Src1, Src2, Ty); break;
291 case ICmpInst::ICMP_ULE: R = executeICMP_ULE(Src1, Src2, Ty); break;
292 case ICmpInst::ICMP_SLE: R = executeICMP_SLE(Src1, Src2, Ty); break;
293 case ICmpInst::ICMP_UGE: R = executeICMP_UGE(Src1, Src2, Ty); break;
294 case ICmpInst::ICMP_SGE: R = executeICMP_SGE(Src1, Src2, Ty); break;
305 Dest.IntVal = APInt(1,Src1.TY##Val OP Src2.TY##Val); \
309 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size()); \
310 Dest.AggregateVal.resize( Src1.AggregateVal.size() ); \
311 for( uint32_t _i=0;_i<Src1.AggregateVal.size();_i++) \
313 Src1.AggregateVal[_i].TY##Val OP Src2.AggregateVal[_i].TY##Val);\
324 static GenericValue executeFCMP_OEQ(GenericValue Src1, GenericValue Src2,
374 static GenericValue executeFCMP_ONE(GenericValue Src1, GenericValue Src2,
378 // if input is scalar value and Src1 or Src2 is NaN return false
379 IMPLEMENT_SCALAR_NANS(Ty, Src1, Src2)
381 MASK_VECTOR_NANS(Ty, Src1, Src2, false)
393 for( size_t _i=0; _i<Src1.AggregateVal.size(); _i++)
400 static GenericValue executeFCMP_OLE(GenericValue Src1, GenericValue Src2,
414 static GenericValue executeFCMP_OGE(GenericValue Src1, GenericValue Src2,
428 static GenericValue executeFCMP_OLT(GenericValue Src1, GenericValue Src2,
442 static GenericValue executeFCMP_OGT(GenericValue Src1, GenericValue Src2,
470 Dest = _FUNC(Src1, Src2, Ty); \
471 for( size_t _i=0; _i<Src1.AggregateVal.size(); _i++) \
477 static GenericValue executeFCMP_UEQ(GenericValue Src1, GenericValue Src2,
480 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
481 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
482 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OEQ)
483 return executeFCMP_OEQ(Src1, Src2, Ty);
487 static GenericValue executeFCMP_UNE(GenericValue Src1, GenericValue Src2,
490 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
491 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
492 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_ONE)
493 return executeFCMP_ONE(Src1, Src2, Ty);
496 static GenericValue executeFCMP_ULE(GenericValue Src1, GenericValue Src2,
499 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
500 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
501 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OLE)
502 return executeFCMP_OLE(Src1, Src2, Ty);
505 static GenericValue executeFCMP_UGE(GenericValue Src1, GenericValue Src2,
508 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
509 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
510 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OGE)
511 return executeFCMP_OGE(Src1, Src2, Ty);
514 static GenericValue executeFCMP_ULT(GenericValue Src1, GenericValue Src2,
517 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
518 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
519 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OLT)
520 return executeFCMP_OLT(Src1, Src2, Ty);
523 static GenericValue executeFCMP_UGT(GenericValue Src1, GenericValue Src2,
526 IMPLEMENT_UNORDERED(Ty, Src1, Src2)
527 MASK_VECTOR_NANS(Ty, Src1, Src2, true)
528 IMPLEMENT_VECTOR_UNORDERED(Ty, Src1, Src2, executeFCMP_OGT)
529 return executeFCMP_OGT(Src1, Src2, Ty);
532 static GenericValue executeFCMP_ORD(GenericValue Src1, GenericValue Src2,
536 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
537 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
539 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
541 ( (Src1.AggregateVal[_i].FloatVal ==
542 Src1.AggregateVal[_i].FloatVal) &&
546 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
548 ( (Src1.AggregateVal[_i].DoubleVal ==
549 Src1.AggregateVal[_i].DoubleVal) &&
554 Dest.IntVal = APInt(1,(Src1.FloatVal == Src1.FloatVal &&
557 Dest.IntVal = APInt(1,(Src1.DoubleVal == Src1.DoubleVal &&
563 static GenericValue executeFCMP_UNO(GenericValue Src1, GenericValue Src2,
567 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
568 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
570 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
572 ( (Src1.AggregateVal[_i].FloatVal !=
573 Src1.AggregateVal[_i].FloatVal) ||
577 for( size_t _i=0;_i<Src1.AggregateVal.size();_i++)
579 ( (Src1.AggregateVal[_i].DoubleVal !=
580 Src1.AggregateVal[_i].DoubleVal) ||
585 Dest.IntVal = APInt(1,(Src1.FloatVal != Src1.FloatVal ||
588 Dest.IntVal = APInt(1,(Src1.DoubleVal != Src1.DoubleVal ||
594 static GenericValue executeFCMP_BOOL(GenericValue Src1, GenericValue Src2,
598 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
599 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
600 for( size_t _i=0; _i<Src1.AggregateVal.size(); _i++)
612 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
621 case FCmpInst::FCMP_FALSE: R = executeFCMP_BOOL(Src1, Src2, Ty, false);
623 case FCmpInst::FCMP_TRUE: R = executeFCMP_BOOL(Src1, Src2, Ty, true);
625 case FCmpInst::FCMP_ORD: R = executeFCMP_ORD(Src1, Src2, Ty); break;
626 case FCmpInst::FCMP_UNO: R = executeFCMP_UNO(Src1, Src2, Ty); break;
627 case FCmpInst::FCMP_UEQ: R = executeFCMP_UEQ(Src1, Src2, Ty); break;
628 case FCmpInst::FCMP_OEQ: R = executeFCMP_OEQ(Src1, Src2, Ty); break;
629 case FCmpInst::FCMP_UNE: R = executeFCMP_UNE(Src1, Src2, Ty); break;
630 case FCmpInst::FCMP_ONE: R = executeFCMP_ONE(Src1, Src2, Ty); break;
631 case FCmpInst::FCMP_ULT: R = executeFCMP_ULT(Src1, Src2, Ty); break;
632 case FCmpInst::FCMP_OLT: R = executeFCMP_OLT(Src1, Src2, Ty); break;
633 case FCmpInst::FCMP_UGT: R = executeFCMP_UGT(Src1, Src2, Ty); break;
634 case FCmpInst::FCMP_OGT: R = executeFCMP_OGT(Src1, Src2, Ty); break;
635 case FCmpInst::FCMP_ULE: R = executeFCMP_ULE(Src1, Src2, Ty); break;
636 case FCmpInst::FCMP_OLE: R = executeFCMP_OLE(Src1, Src2, Ty); break;
637 case FCmpInst::FCMP_UGE: R = executeFCMP_UGE(Src1, Src2, Ty); break;
638 case FCmpInst::FCMP_OGE: R = executeFCMP_OGE(Src1, Src2, Ty); break;
644 static GenericValue executeCmpInst(unsigned predicate, GenericValue Src1,
648 case ICmpInst::ICMP_EQ: return executeICMP_EQ(Src1, Src2, Ty);
649 case ICmpInst::ICMP_NE: return executeICMP_NE(Src1, Src2, Ty);
650 case ICmpInst::ICMP_UGT: return executeICMP_UGT(Src1, Src2, Ty);
651 case ICmpInst::ICMP_SGT: return executeICMP_SGT(Src1, Src2, Ty);
652 case ICmpInst::ICMP_ULT: return executeICMP_ULT(Src1, Src2, Ty);
653 case ICmpInst::ICMP_SLT: return executeICMP_SLT(Src1, Src2, Ty);
654 case ICmpInst::ICMP_UGE: return executeICMP_UGE(Src1, Src2, Ty);
655 case ICmpInst::ICMP_SGE: return executeICMP_SGE(Src1, Src2, Ty);
656 case ICmpInst::ICMP_ULE: return executeICMP_ULE(Src1, Src2, Ty);
657 case ICmpInst::ICMP_SLE: return executeICMP_SLE(Src1, Src2, Ty);
658 case FCmpInst::FCMP_ORD: return executeFCMP_ORD(Src1, Src2, Ty);
659 case FCmpInst::FCMP_UNO: return executeFCMP_UNO(Src1, Src2, Ty);
660 case FCmpInst::FCMP_OEQ: return executeFCMP_OEQ(Src1, Src2, Ty);
661 case FCmpInst::FCMP_UEQ: return executeFCMP_UEQ(Src1, Src2, Ty);
662 case FCmpInst::FCMP_ONE: return executeFCMP_ONE(Src1, Src2, Ty);
663 case FCmpInst::FCMP_UNE: return executeFCMP_UNE(Src1, Src2, Ty);
664 case FCmpInst::FCMP_OLT: return executeFCMP_OLT(Src1, Src2, Ty);
665 case FCmpInst::FCMP_ULT: return executeFCMP_ULT(Src1, Src2, Ty);
666 case FCmpInst::FCMP_OGT: return executeFCMP_OGT(Src1, Src2, Ty);
667 case FCmpInst::FCMP_UGT: return executeFCMP_UGT(Src1, Src2, Ty);
668 case FCmpInst::FCMP_OLE: return executeFCMP_OLE(Src1, Src2, Ty);
669 case FCmpInst::FCMP_ULE: return executeFCMP_ULE(Src1, Src2, Ty);
670 case FCmpInst::FCMP_OGE: return executeFCMP_OGE(Src1, Src2, Ty);
671 case FCmpInst::FCMP_UGE: return executeFCMP_UGE(Src1, Src2, Ty);
672 case FCmpInst::FCMP_FALSE: return executeFCMP_BOOL(Src1, Src2, Ty, false);
673 case FCmpInst::FCMP_TRUE: return executeFCMP_BOOL(Src1, Src2, Ty, true);
683 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
689 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
690 R.AggregateVal.resize(Src1.AggregateVal.size());
696 Src1.AggregateVal[i].IntVal OP Src2.AggregateVal[i].IntVal;
703 Src1.AggregateVal[i].IntVal.OP(Src2.AggregateVal[i].IntVal);
710 Src1.AggregateVal[i].TY OP Src2.AggregateVal[i].TY;
750 fmod(Src1.AggregateVal[i].FloatVal, Src2.AggregateVal[i].FloatVal);
755 fmod(Src1.AggregateVal[i].DoubleVal, Src2.AggregateVal[i].DoubleVal);
769 case Instruction::Add: R.IntVal = Src1.IntVal + Src2.IntVal; break;
770 case Instruction::Sub: R.IntVal = Src1.IntVal - Src2.IntVal; break;
771 case Instruction::Mul: R.IntVal = Src1.IntVal * Src2.IntVal; break;
772 case Instruction::FAdd: executeFAddInst(R, Src1, Src2, Ty); break;
773 case Instruction::FSub: executeFSubInst(R, Src1, Src2, Ty); break;
774 case Instruction::FMul: executeFMulInst(R, Src1, Src2, Ty); break;
775 case Instruction::FDiv: executeFDivInst(R, Src1, Src2, Ty); break;
776 case Instruction::FRem: executeFRemInst(R, Src1, Src2, Ty); break;
777 case Instruction::UDiv: R.IntVal = Src1.IntVal.udiv(Src2.IntVal); break;
778 case Instruction::SDiv: R.IntVal = Src1.IntVal.sdiv(Src2.IntVal); break;
779 case Instruction::URem: R.IntVal = Src1.IntVal.urem(Src2.IntVal); break;
780 case Instruction::SRem: R.IntVal = Src1.IntVal.srem(Src2.IntVal); break;
781 case Instruction::And: R.IntVal = Src1.IntVal & Src2.IntVal; break;
782 case Instruction::Or: R.IntVal = Src1.IntVal | Src2.IntVal; break;
783 case Instruction::Xor: R.IntVal = Src1.IntVal ^ Src2.IntVal; break;
789 static GenericValue executeSelectInst(GenericValue Src1, GenericValue Src2,
793 assert(Src1.AggregateVal.size() == Src2.AggregateVal.size());
795 Dest.AggregateVal.resize( Src1.AggregateVal.size() );
796 for (size_t i = 0; i < Src1.AggregateVal.size(); ++i)
797 Dest.AggregateVal[i] = (Src1.AggregateVal[i].IntVal == 0) ?
800 Dest = (Src1.IntVal == 0) ? Src3 : Src2;
808 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
811 GenericValue R = executeSelectInst(Src1, Src2, Src3, Ty);
1138 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1144 uint32_t src1Size = uint32_t(Src1.AggregateVal.size());
1149 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1156 llvm::APInt valueToShift = Src1.IntVal;
1165 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1171 uint32_t src1Size = uint32_t(Src1.AggregateVal.size());
1176 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1183 llvm::APInt valueToShift = Src1.IntVal;
1192 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1198 size_t src1Size = Src1.AggregateVal.size();
1203 llvm::APInt valueToShift = Src1.AggregateVal[i].IntVal;
1210 llvm::APInt valueToShift = Src1.IntVal;
1748 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1755 if(Src1.AggregateVal.size() > indx) {
1763 Dest.IntVal = Src1.AggregateVal[indx].IntVal;
1766 Dest.FloatVal = Src1.AggregateVal[indx].FloatVal;
1769 Dest.DoubleVal = Src1.AggregateVal[indx].DoubleVal;
1786 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1794 Dest.AggregateVal = Src1.AggregateVal;
1796 if(Src1.AggregateVal.size() <= indx)
1821 GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
1826 // There is no need to check types of src1 and src2, because the compiled
1827 // bytecode can't contain different types for src1 and src2 for a
1831 unsigned src1Size = (unsigned)Src1.AggregateVal.size();
1845 Dest.AggregateVal[i].IntVal = Src1.AggregateVal[j].IntVal;
1861 Dest.AggregateVal[i].FloatVal = Src1.AggregateVal[j].FloatVal;
1872 Dest.AggregateVal[i].DoubleVal = Src1.AggregateVal[j].DoubleVal;
1931 GenericValue Src1 = getOperandValue(Agg, SF);
1933 GenericValue Dest = Src1; // Dest is a slightly changed Src1