Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(46)

Unified Diff: src/IceTranslator.cpp

Issue 587893003: Test generation of global initializers in Subzero bitcode reader. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fix nit Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/IceTranslator.h ('k') | src/PNaClTranslator.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/IceTranslator.cpp
diff --git a/src/IceTranslator.cpp b/src/IceTranslator.cpp
index 0636b505fc76ba2a91f63b75bc05b720802b1295..e0c7e2dbf849397ba5d4e20de9fd27aec770e618 100644
--- a/src/IceTranslator.cpp
+++ b/src/IceTranslator.cpp
@@ -19,6 +19,8 @@
#include "IceDefs.h"
#include "IceTargetLowering.h"
#include "llvm/IR/Module.h"
+#include "llvm/IR/Constant.h"
+#include "llvm/IR/Constants.h"
#include <iostream>
@@ -104,3 +106,49 @@ void Translator::emitConstants() {
if (!Ctx->getFlags().DisableTranslation && Func)
Func->getTarget()->emitConstants();
}
+
+void Translator::convertGlobals(llvm::Module *Mod) {
+ llvm::OwningPtr<TargetGlobalInitLowering> GlobalLowering(
+ TargetGlobalInitLowering::createLowering(Ctx->getTargetArch(), Ctx));
+ for (llvm::Module::const_global_iterator I = Mod->global_begin(),
+ E = Mod->global_end();
+ I != E; ++I) {
+ if (!I->hasInitializer())
+ continue;
+ const llvm::Constant *Initializer = I->getInitializer();
+ IceString Name = I->getName();
+ unsigned Align = I->getAlignment();
+ uint64_t NumElements = 0;
+ const char *Data = NULL;
+ bool IsInternal = I->hasInternalLinkage();
+ bool IsConst = I->isConstant();
+ bool IsZeroInitializer = false;
+
+ if (const llvm::ConstantDataArray *CDA =
+ llvm::dyn_cast<llvm::ConstantDataArray>(Initializer)) {
+ NumElements = CDA->getNumElements();
+ assert(llvm::isa<llvm::IntegerType>(CDA->getElementType()) &&
+ (llvm::cast<llvm::IntegerType>(CDA->getElementType())
+ ->getBitWidth() == 8));
+ Data = CDA->getRawDataValues().data();
+ } else if (llvm::isa<llvm::ConstantAggregateZero>(Initializer)) {
+ if (const llvm::ArrayType *AT =
+ llvm::dyn_cast<llvm::ArrayType>(Initializer->getType())) {
+ assert(llvm::isa<llvm::IntegerType>(AT->getElementType()) &&
+ (llvm::cast<llvm::IntegerType>(AT->getElementType())
+ ->getBitWidth() == 8));
+ NumElements = AT->getNumElements();
+ IsZeroInitializer = true;
+ } else {
+ llvm_unreachable("Unhandled constant aggregate zero type");
+ }
+ } else {
+ llvm_unreachable("Unhandled global initializer");
+ }
+
+ GlobalLowering->lower(Name, Align, IsInternal, IsConst, IsZeroInitializer,
+ NumElements, Data,
+ Ctx->getFlags().DisableTranslation);
+ }
+ GlobalLowering.reset();
+}
« no previous file with comments | « src/IceTranslator.h ('k') | src/PNaClTranslator.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698