From 4c1c283a7410784e9cab309f868248690b788a9c Mon Sep 17 00:00:00 2001 From: Ian Rogers Date: Mon, 4 Mar 2013 18:30:13 -0800 Subject: Move compiler_llvm to art::llvm. Also move the invoke stubs (soon to be removed) under compiler. Start moving LLVM code under compiler. Will move GBC expander to dex/portable once it is disentangled from other builds (moving toward solving Bug: 8195425). Change-Id: I8829f9db6ade9ac8e32bd16198b90f83619769f1 --- src/compiler/llvm/ir_builder.cc | 130 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 src/compiler/llvm/ir_builder.cc (limited to 'src/compiler/llvm/ir_builder.cc') diff --git a/src/compiler/llvm/ir_builder.cc b/src/compiler/llvm/ir_builder.cc new file mode 100644 index 0000000000..1fd1c9029e --- /dev/null +++ b/src/compiler/llvm/ir_builder.cc @@ -0,0 +1,130 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include "ir_builder.h" + +#include "base/stringprintf.h" + +#include + +namespace art { +namespace llvm { + + +//---------------------------------------------------------------------------- +// General +//---------------------------------------------------------------------------- + +IRBuilder::IRBuilder(::llvm::LLVMContext& context, ::llvm::Module& module, + IntrinsicHelper& intrinsic_helper) + : LLVMIRBuilder(context), module_(&module), mdb_(context), java_object_type_(NULL), + java_method_type_(NULL), java_thread_type_(NULL), intrinsic_helper_(intrinsic_helper) { + // Get java object type from module + ::llvm::Type* jobject_struct_type = module.getTypeByName("JavaObject"); + CHECK(jobject_struct_type != NULL); + java_object_type_ = jobject_struct_type->getPointerTo(); + + // If type of Method is not explicitly defined in the module, use JavaObject* + ::llvm::Type* type = module.getTypeByName("Method"); + if (type != NULL) { + java_method_type_ = type->getPointerTo(); + } else { + java_method_type_ = java_object_type_; + } + + // If type of Thread is not explicitly defined in the module, use JavaObject* + type = module.getTypeByName("Thread"); + if (type != NULL) { + java_thread_type_ = type->getPointerTo(); + } else { + java_thread_type_ = java_object_type_; + } + + // Create JEnv* type + ::llvm::Type* jenv_struct_type = ::llvm::StructType::create(context, "JEnv"); + jenv_type_ = jenv_struct_type->getPointerTo(); + + // Get Art shadow frame struct type from module + art_frame_type_ = module.getTypeByName("ShadowFrame"); + CHECK(art_frame_type_ != NULL); + + runtime_support_ = NULL; +} + + +//---------------------------------------------------------------------------- +// Type Helper Function +//---------------------------------------------------------------------------- + +::llvm::Type* IRBuilder::getJType(JType jty) { + switch (jty) { + case kVoid: + return getJVoidTy(); + + case kBoolean: + return getJBooleanTy(); + + case kByte: + return getJByteTy(); + + case kChar: + return getJCharTy(); + + case kShort: + return getJShortTy(); + + case kInt: + return getJIntTy(); + + case kLong: + return getJLongTy(); + + case kFloat: + return getJFloatTy(); + + case kDouble: + return getJDoubleTy(); + + case kObject: + return getJObjectTy(); + + default: + LOG(FATAL) << "Unknown java type: " << jty; + return NULL; + } +} + +::llvm::StructType* IRBuilder::getShadowFrameTy(uint32_t vreg_size) { + std::string name(StringPrintf("ShadowFrame%u", vreg_size)); + + // Try to find the existing struct type definition + if (::llvm::Type* type = module_->getTypeByName(name)) { + CHECK(::llvm::isa< ::llvm::StructType>(type)); + return static_cast< ::llvm::StructType*>(type); + } + + // Create new struct type definition + ::llvm::Type* elem_types[] = { + art_frame_type_, + ::llvm::ArrayType::get(getInt32Ty(), vreg_size), + }; + + return ::llvm::StructType::create(elem_types, name); +} + + +} // namespace llvm +} // namespace art -- cgit v1.2.3-59-g8ed1b