From 69d621387cc84ed91619f2fd81eb1ffa030f0ecc Mon Sep 17 00:00:00 2001 From: Robert Bocchino Date: Fri, 20 Jan 2006 18:18:40 +0000 Subject: Fixed InitializeMemory to handle ConstantPacked. llvm-svn: 25481 --- llvm/lib/ExecutionEngine/ExecutionEngine.cpp | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'llvm/lib/ExecutionEngine/ExecutionEngine.cpp') diff --git a/llvm/lib/ExecutionEngine/ExecutionEngine.cpp b/llvm/lib/ExecutionEngine/ExecutionEngine.cpp index d8bd8f44aa3..53587bff5a0 100644 --- a/llvm/lib/ExecutionEngine/ExecutionEngine.cpp +++ b/llvm/lib/ExecutionEngine/ExecutionEngine.cpp @@ -457,6 +457,12 @@ GenericValue ExecutionEngine::LoadValueFromMemory(GenericValue *Ptr, void ExecutionEngine::InitializeMemory(const Constant *Init, void *Addr) { if (isa(Init)) { return; + } else if (const ConstantPacked *CP = dyn_cast(Init)) { + unsigned ElementSize = + getTargetData().getTypeSize(CP->getType()->getElementType()); + for (unsigned i = 0, e = CP->getNumOperands(); i != e; ++i) + InitializeMemory(CP->getOperand(i), (char*)Addr+i*ElementSize); + return; } else if (Init->getType()->isFirstClassType()) { GenericValue Val = getConstantValue(Init); StoreValueToMemory(Val, (GenericValue*)Addr, Init->getType()); -- cgit v1.2.3