mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-27 07:12:06 +00:00
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:
parent
4283ac7857
commit
d615bd9013
@ -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;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user