mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	IR: Properly canonicalize PointerType in ConstantExpr GEPs
No additional test was needed, Other/constant-fold-gep.ll detects this just fine. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@194221 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1966,11 +1966,12 @@ static Constant *ConstantFoldGetElementPtrImpl(Constant *C, | ||||
|         else if (VectorType *VTy = dyn_cast<VectorType>(LastTy)) | ||||
|           NumElements = VTy->getNumElements(); | ||||
|  | ||||
|         if (ConstantInt *CI = dyn_cast<ConstantInt>(Idx0)) { | ||||
|           int64_t Idx0Val = CI->getSExtValue(); | ||||
|           if (NumElements > 0 && Idx0Val >= 0 && | ||||
|               (uint64_t)Idx0Val < NumElements) | ||||
|             IsSequentialAccessInRange = true; | ||||
|         if (NumElements > 0) { | ||||
|           if (ConstantInt *CI = dyn_cast<ConstantInt>(Idx0)) { | ||||
|             int64_t Idx0Val = CI->getSExtValue(); | ||||
|             if (Idx0Val >= 0 && (uint64_t)Idx0Val < NumElements) | ||||
|               IsSequentialAccessInRange = true; | ||||
|           } | ||||
|         } else if (PointerType *PTy = dyn_cast<PointerType>(LastTy)) | ||||
|           // Only handle pointers to sized types, not pointers to functions. | ||||
|           if (PTy->getElementType()->isSized()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user