From 6f7279bf98e31356306386b2c200820a76b491cf Mon Sep 17 00:00:00 2001 From: Daniel Dunbar Date: Wed, 4 Feb 2009 23:24:38 +0000 Subject: [PATCH] Add ABIArgInfo::dump() git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@63794 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/ABIInfo.h | 2 ++ lib/CodeGen/CGCall.cpp | 31 +++++++++++++++++++++++++++++++ 2 files changed, 33 insertions(+) diff --git a/lib/CodeGen/ABIInfo.h b/lib/CodeGen/ABIInfo.h index a2d80ed78c..651192391a 100644 --- a/lib/CodeGen/ABIInfo.h +++ b/lib/CodeGen/ABIInfo.h @@ -113,6 +113,8 @@ namespace clang { assert(TheKind == ByVal && "Invalid kind!"); return UIntData; } + + void dump() const; }; /// ABIInfo - Target specific hooks for defining how a type should be diff --git a/lib/CodeGen/CGCall.cpp b/lib/CodeGen/CGCall.cpp index a13b232571..a3dd877ce5 100644 --- a/lib/CodeGen/CGCall.cpp +++ b/lib/CodeGen/CGCall.cpp @@ -23,6 +23,7 @@ #include "llvm/ADT/StringExtras.h" #include "llvm/Attributes.h" #include "llvm/Support/CommandLine.h" +#include "llvm/Support/raw_ostream.h" #include "llvm/Target/TargetData.h" #include "ABIInfo.h" @@ -114,6 +115,36 @@ const CGFunctionInfo &CodeGenTypes::getFunctionInfo(QualType ResTy, ABIInfo::~ABIInfo() {} +void ABIArgInfo::dump() const { + fprintf(stderr, "(ABIArgInfo Kind="); + switch (TheKind) { + case Direct: + fprintf(stderr, "Direct"); + break; + case StructRet: + fprintf(stderr, "StructRet"); + break; + case Ignore: + fprintf(stderr, "Ignore"); + break; + case Coerce: + fprintf(stderr, "Coerce Type="); + getCoerceToType()->print(llvm::errs()); + // FIXME: This is ridiculous. + llvm::errs().flush(); + break; + case ByVal: + fprintf(stderr, "ByVal Align=%d", getByValAlignment()); + break; + case Expand: + fprintf(stderr, "Expand"); + break; + } + fprintf(stderr, ")\n"); +} + +/***/ + /// isEmptyStruct - Return true iff a structure has no non-empty /// members. Note that a structure with a flexible array member is not /// considered empty. -- 2.40.0