2006-03-23 19:05:12 +01:00
|
|
|
//===-- InstrinsicInst.cpp - Intrinsic Instruction Wrappers -----*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-29 21:36:04 +01:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2006-03-23 19:05:12 +01:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2006-03-24 11:00:56 +01:00
|
|
|
//
|
|
|
|
// This file implements methods that make it really easy to deal with intrinsic
|
2010-01-05 02:10:40 +01:00
|
|
|
// functions.
|
2006-03-24 11:00:56 +01:00
|
|
|
//
|
|
|
|
// All intrinsic function calls are instances of the call instruction, so these
|
|
|
|
// are all subclasses of the CallInst class. Note that none of these classes
|
|
|
|
// has state or virtual methods, which is an important part of this gross/neat
|
|
|
|
// hack working.
|
|
|
|
//
|
|
|
|
// In some cases, arguments to intrinsics need to be generic and are defined as
|
|
|
|
// type pointer to empty struct { }*. To access the real item of interest the
|
|
|
|
// cast instruction needs to be stripped away.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2006-03-23 19:05:12 +01:00
|
|
|
|
|
|
|
#include "llvm/IntrinsicInst.h"
|
|
|
|
#include "llvm/Constants.h"
|
|
|
|
#include "llvm/GlobalVariable.h"
|
2010-03-14 02:56:06 +01:00
|
|
|
#include "llvm/Metadata.h"
|
2006-03-23 19:05:12 +01:00
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
/// DbgInfoIntrinsic - This is the common base class for debug info intrinsics
|
|
|
|
///
|
|
|
|
|
|
|
|
static Value *CastOperand(Value *C) {
|
|
|
|
if (ConstantExpr *CE = dyn_cast<ConstantExpr>(C))
|
2006-11-27 02:05:10 +01:00
|
|
|
if (CE->isCast())
|
2006-03-23 19:05:12 +01:00
|
|
|
return CE->getOperand(0);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Value *DbgInfoIntrinsic::StripCast(Value *C) {
|
|
|
|
if (Value *CO = CastOperand(C)) {
|
2006-03-27 00:46:27 +02:00
|
|
|
C = StripCast(CO);
|
2006-03-23 19:05:12 +01:00
|
|
|
} else if (GlobalVariable *GV = dyn_cast<GlobalVariable>(C)) {
|
|
|
|
if (GV->hasInitializer())
|
|
|
|
if (Value *CO = CastOperand(GV->getInitializer()))
|
2006-03-27 00:46:27 +02:00
|
|
|
C = StripCast(CO);
|
2006-03-23 19:05:12 +01:00
|
|
|
}
|
2006-03-27 00:46:27 +02:00
|
|
|
return dyn_cast<GlobalVariable>(C);
|
2006-03-23 19:05:12 +01:00
|
|
|
}
|
|
|
|
|
2010-01-15 20:04:09 +01:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
/// DbgDeclareInst - This represents the llvm.dbg.declare instruction.
|
|
|
|
///
|
|
|
|
|
|
|
|
Value *DbgDeclareInst::getAddress() const {
|
2010-06-22 21:46:37 +02:00
|
|
|
if (MDNode* MD = cast_or_null<MDNode>(getArgOperand(0)))
|
2010-01-15 20:04:09 +01:00
|
|
|
return MD->getOperand(0);
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2009-12-31 02:32:41 +01:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
/// DbgValueInst - This represents the llvm.dbg.value instruction.
|
|
|
|
///
|
|
|
|
|
2010-01-11 08:45:19 +01:00
|
|
|
const Value *DbgValueInst::getValue() const {
|
2010-06-22 21:46:37 +02:00
|
|
|
return cast<MDNode>(getArgOperand(0))->getOperand(0);
|
2010-01-11 08:45:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Value *DbgValueInst::getValue() {
|
2010-06-22 21:46:37 +02:00
|
|
|
return cast<MDNode>(getArgOperand(0))->getOperand(0);
|
2009-12-31 02:32:41 +01:00
|
|
|
}
|