mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-22 12:16:31 +00:00
Tighten up prototype verification of strchr and strrchr to avoid a crash in the very unlikely case that someone passes an integer > i64 to strchr.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@115144 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5c0d472b6e
commit
4c75679b1c
@ -223,7 +223,8 @@ struct StrChrOpt : public LibCallOptimization {
|
||||
const FunctionType *FT = Callee->getFunctionType();
|
||||
if (FT->getNumParams() != 2 ||
|
||||
FT->getReturnType() != Type::getInt8PtrTy(*Context) ||
|
||||
FT->getParamType(0) != FT->getReturnType())
|
||||
FT->getParamType(0) != FT->getReturnType() ||
|
||||
!FT->getParamType(1)->isIntegerTy(32))
|
||||
return 0;
|
||||
|
||||
Value *SrcStr = CI->getArgOperand(0);
|
||||
@ -273,7 +274,8 @@ struct StrRChrOpt : public LibCallOptimization {
|
||||
const FunctionType *FT = Callee->getFunctionType();
|
||||
if (FT->getNumParams() != 2 ||
|
||||
FT->getReturnType() != Type::getInt8PtrTy(*Context) ||
|
||||
FT->getParamType(0) != FT->getReturnType())
|
||||
FT->getParamType(0) != FT->getReturnType() ||
|
||||
!FT->getParamType(1)->isIntegerTy(32))
|
||||
return 0;
|
||||
|
||||
Value *SrcStr = CI->getArgOperand(0);
|
||||
|
Loading…
x
Reference in New Issue
Block a user