Don't accept the ctpop, cttz, or ctlz intrinsics with signed arguments. The

interface requires unsigned arguments.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25433 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Reid Spencer 2006-01-19 01:20:03 +00:00
parent 4283ac7857
commit d615bd9013

View File

@ -810,9 +810,8 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UByteTy Assert1(FT->getParamType(0) == Type::UByteTy,
|| FT->getParamType(0) == Type::SByteTy, "Argument is not ubyte!", IF);
"Argument must be a byte type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
@ -821,9 +820,8 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UShortTy Assert1(FT->getParamType(0) == Type::UShortTy,
|| FT->getParamType(0) == Type::ShortTy, "Argument is not ushort!", IF);
"Argument must be a short type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
@ -832,9 +830,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UIntTy Assert1(FT->getParamType(0) == Type::UIntTy, "Argument is not uint!", IF);
|| FT->getParamType(0) == Type::IntTy,
"Argument must be an int type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
@ -843,9 +839,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::ULongTy Assert1(FT->getParamType(0) == Type::ULongTy, "Argument is not ulong!", IF);
|| FT->getParamType(0) == Type::LongTy,
"Argument must be a long type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
@ -854,9 +848,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UByteTy Assert1(FT->getParamType(0) == Type::UByteTy, "Argument is not ubyte!", IF);
|| FT->getParamType(0) == Type::SByteTy,
"Argument must be a byte type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
@ -865,9 +857,8 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UShortTy Assert1(FT->getParamType(0) == Type::UShortTy,
|| FT->getParamType(0) == Type::ShortTy, "Argument is not ushort!", IF);
"Argument must be a short type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::ctlz_i32: case Intrinsic::ctlz_i32:
@ -875,9 +866,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UIntTy Assert1(FT->getParamType(0) == Type::UIntTy, "Argument is not uint!", IF);
|| FT->getParamType(0) == Type::IntTy,
"Argument must be an int type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::ctlz_i64: case Intrinsic::ctlz_i64:
@ -885,9 +874,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::ULongTy Assert1(FT->getParamType(0) == Type::ULongTy, "Argument is not ulong!", IF);
|| FT->getParamType(0) == Type::LongTy,
"Argument must be a long type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::cttz_i8: case Intrinsic::cttz_i8:
@ -895,9 +882,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UByteTy Assert1(FT->getParamType(0) == Type::UByteTy, "Argument is not ubyte!", IF);
|| FT->getParamType(0) == Type::SByteTy,
"Argument must be a byte type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::cttz_i16: case Intrinsic::cttz_i16:
@ -905,9 +890,8 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UShortTy Assert1(FT->getParamType(0) == Type::UShortTy,
|| FT->getParamType(0) == Type::ShortTy, "Argument is not ushort!", IF);
"Argument must be a short type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::cttz_i32: case Intrinsic::cttz_i32:
@ -915,9 +899,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::UIntTy Assert1(FT->getParamType(0) == Type::UIntTy, "Argument is not uint!", IF);
|| FT->getParamType(0) == Type::IntTy,
"Argument must be an int type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;
case Intrinsic::cttz_i64: case Intrinsic::cttz_i64:
@ -925,9 +907,7 @@ void Verifier::visitIntrinsicFunctionCall(Intrinsic::ID ID, CallInst &CI) {
"Illegal # arguments for intrinsic function!", IF); "Illegal # arguments for intrinsic function!", IF);
Assert1(FT->getReturnType() == FT->getParamType(0), Assert1(FT->getReturnType() == FT->getParamType(0),
"Return type does not match source type", IF); "Return type does not match source type", IF);
Assert1(FT->getParamType(0) == Type::ULongTy Assert1(FT->getParamType(0) == Type::ULongTy, "Argument Is not ulong!", IF);
|| FT->getParamType(0) == Type::LongTy,
"Argument must be a long type!", IF);
NumArgs = 1; NumArgs = 1;
break; break;