From 2798cd077a4a754064755ca82ad14434daea59fe Mon Sep 17 00:00:00 2001 From: Brian Gaeke Date: Fri, 12 Dec 2003 05:13:05 +0000 Subject: [PATCH] Since we are using a gep_type_iterator, we apparently must get the type index by using I.getOperand() here. This was failing an assertion on basically every struct access. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10426 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/ExecutionEngine/Interpreter/Execution.cpp | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/lib/ExecutionEngine/Interpreter/Execution.cpp b/lib/ExecutionEngine/Interpreter/Execution.cpp index 732a485d783..abade5f857a 100644 --- a/lib/ExecutionEngine/Interpreter/Execution.cpp +++ b/lib/ExecutionEngine/Interpreter/Execution.cpp @@ -706,8 +706,7 @@ GenericValue Interpreter::executeGEPOperation(Value *Ptr, gep_type_iterator I, if (const StructType *STy = dyn_cast(*I)) { const StructLayout *SLO = TD.getStructLayout(STy); - // Indices must be ubyte constants... - const ConstantUInt *CPU = cast(*I); + const ConstantUInt *CPU = cast(I.getOperand()); unsigned Index = CPU->getValue(); Total += SLO->MemberOffsets[Index]; -- 2.34.1