/* * 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 "tbaa_info.h" #include #include #include #include #include namespace art { namespace compiler_llvm { llvm::MDNode* TBAAInfo::GetRootType() { if (root_ == NULL) { root_ = GenTBAANode("Art TBAA Root"); } return root_; } llvm::MDNode* TBAAInfo::GetSpecialType(TBAASpecialType sty_id) { DCHECK_GE(sty_id, 0) << "Unknown TBAA special type: " << sty_id; DCHECK_LT(sty_id, MAX_TBAA_SPECIAL_TYPE) << "Unknown TBAA special type: " << sty_id; llvm::MDNode*& spec_ty = special_type_[sty_id]; if (spec_ty == NULL) { switch (sty_id) { case kTBAARegister: spec_ty = GenTBAANode("Register", GetRootType()); break; case kTBAAStackTemp: spec_ty = GenTBAANode("StackTemp", GetRootType()); break; case kTBAAHeapArray: spec_ty = GenTBAANode("HeapArray", GetRootType()); break; case kTBAAHeapInstance: spec_ty = GenTBAANode("HeapInstance", GetRootType()); break; case kTBAAHeapStatic: spec_ty = GenTBAANode("HeapStatic", GetRootType()); break; case kTBAAJRuntime: spec_ty = GenTBAANode("JRuntime", GetRootType()); break; case kTBAARuntimeInfo: spec_ty = GenTBAANode("RuntimeInfo", GetRootType()); break; case kTBAAShadowFrame: spec_ty = GenTBAANode("ShadowFrame", GetRootType()); break; case kTBAAConstJObject: spec_ty = GenTBAANode("ConstJObject", GetRootType(), true); break; default: LOG(FATAL) << "Unknown TBAA special type: " << sty_id; break; } } return spec_ty; } llvm::MDNode* TBAAInfo::GetMemoryJType(TBAASpecialType sty_id, JType jty_id) { DCHECK(sty_id == kTBAAHeapArray || sty_id == kTBAAHeapInstance || sty_id == kTBAAHeapStatic) << "SpecialType must be array, instance, or static"; DCHECK_GE(jty_id, 0) << "Unknown JType: " << jty_id; DCHECK_LT(jty_id, MAX_JTYPE) << "Unknown JType: " << jty_id; DCHECK_NE(jty_id, kVoid) << "Can't load/store Void type!"; std::string name; size_t sty_mapped_index = 0; switch (sty_id) { case kTBAAHeapArray: sty_mapped_index = 0; name = "HeapArray "; break; case kTBAAHeapInstance: sty_mapped_index = 1; name = "HeapInstance "; break; case kTBAAHeapStatic: sty_mapped_index = 2; name = "HeapStatic "; break; default: LOG(FATAL) << "Unknown TBAA special type: " << sty_id; break; } llvm::MDNode*& spec_ty = memory_jtype_[sty_mapped_index][jty_id]; if (spec_ty != NULL) { return spec_ty; } switch (jty_id) { case kBoolean: name += "Boolean"; break; case kByte: name += "Byte"; break; case kChar: name += "Char"; break; case kShort: name += "Short"; break; case kInt: name += "Int"; break; case kLong: name += "Long"; break; case kFloat: name += "Float"; break; case kDouble: name += "Double"; break; case kObject: name += "Object"; break; default: LOG(FATAL) << "Unknown JType: " << jty_id; break; } spec_ty = GenTBAANode(name, GetSpecialType(sty_id)); return spec_ty; } llvm::MDNode* TBAAInfo::GenTBAANode(llvm::StringRef name, llvm::MDNode* parent, bool read_only) { llvm::SmallVector array_ref; array_ref.push_back(llvm::MDString::get(context_, name)); if (parent != NULL) { array_ref.push_back(parent); } if (read_only != false) { array_ref.push_back(llvm::ConstantInt::get(llvm::Type::getInt1Ty(context_), read_only)); } return llvm::MDNode::get(context_, array_ref); } } // namespace compiler_llvm } // namespace art