2004-06-08 01:53:43 +08:00
|
|
|
//===-- BytecodeHandler.cpp - Parsing Handler -------------------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by Reid Spencer and is distributed under the
|
|
|
|
// University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This header file defines the BytecodeHandler class that gets called by the
|
|
|
|
// AbstractBytecodeParser when parsing events occur.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "AnalyzerInternals.h"
|
2004-06-09 14:16:43 +08:00
|
|
|
#include <iostream>
|
2004-06-08 01:53:43 +08:00
|
|
|
|
|
|
|
using namespace llvm;
|
|
|
|
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
class AnalyzerHandler : public BytecodeHandler {
|
2004-06-09 14:16:43 +08:00
|
|
|
BytecodeAnalysis& bca;
|
2004-06-08 01:53:43 +08:00
|
|
|
public:
|
2004-06-09 14:16:43 +08:00
|
|
|
AnalyzerHandler(BytecodeAnalysis& TheBca)
|
|
|
|
: bca(TheBca)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2004-06-08 01:53:43 +08:00
|
|
|
bool handleError(const std::string& str )
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
std::cerr << "Analysis Error: " << str;
|
2004-06-08 01:53:43 +08:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleStart()
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.ModuleId.clear();
|
|
|
|
bca.numTypes = 0;
|
|
|
|
bca.numValues = 0;
|
|
|
|
bca.numFunctions = 0;
|
|
|
|
bca.numConstants = 0;
|
|
|
|
bca.numGlobalVars = 0;
|
|
|
|
bca.numInstructions = 0;
|
|
|
|
bca.numBasicBlocks = 0;
|
|
|
|
bca.numOperands = 0;
|
|
|
|
bca.numCmpctnTables = 0;
|
|
|
|
bca.numSymTab = 0;
|
|
|
|
bca.maxTypeSlot = 0;
|
|
|
|
bca.maxValueSlot = 0;
|
|
|
|
bca.density = 0.0;
|
|
|
|
bca.FunctionInfo.clear();
|
|
|
|
bca.BytecodeDump.clear();
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleFinish()
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.density = bca.numTypes + bca.numFunctions + bca.numConstants +
|
|
|
|
bca.numGlobalVars + bca.numInstructions;
|
|
|
|
bca.density /= bca.byteSize;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleModuleBegin(const std::string& id)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.ModuleId = id;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleModuleEnd(const std::string& id)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleVersionInfo(
|
|
|
|
unsigned char RevisionNum, ///< Byte code revision number
|
|
|
|
Module::Endianness Endianness, ///< Endianness indicator
|
|
|
|
Module::PointerSize PointerSize ///< PointerSize indicator
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleModuleGlobalsBegin()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleGlobalVariable(
|
|
|
|
const Type* ElemType, ///< The type of the global variable
|
|
|
|
bool isConstant, ///< Whether the GV is constant or not
|
|
|
|
GlobalValue::LinkageTypes ///< The linkage type of the GV
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numGlobalVars++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleInitializedGV(
|
|
|
|
const Type* ElemType, ///< The type of the global variable
|
|
|
|
bool isConstant, ///< Whether the GV is constant or not
|
|
|
|
GlobalValue::LinkageTypes,///< The linkage type of the GV
|
|
|
|
unsigned initSlot ///< Slot number of GV's initializer
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numGlobalVars++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
virtual void handleType( const Type* Ty )
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numTypes++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleFunctionDeclaration(
|
|
|
|
const Type* FuncType ///< The type of the function
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numFunctions++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleModuleGlobalsEnd()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleCompactionTableBegin()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleCompactionTablePlane(
|
|
|
|
unsigned Ty,
|
|
|
|
unsigned NumEntries
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numCmpctnTables++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleCompactionTableType(
|
|
|
|
unsigned i,
|
|
|
|
unsigned TypSlot,
|
|
|
|
const Type*
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleCompactionTableValue(
|
|
|
|
unsigned i,
|
|
|
|
unsigned ValSlot,
|
|
|
|
const Type*
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleCompactionTableEnd()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleSymbolTableBegin()
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numSymTab++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleSymbolTablePlane(
|
|
|
|
unsigned Ty,
|
|
|
|
unsigned NumEntries,
|
|
|
|
const Type* Typ
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleSymbolTableType(
|
|
|
|
unsigned i,
|
|
|
|
unsigned slot,
|
|
|
|
const std::string& name
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleSymbolTableValue(
|
|
|
|
unsigned i,
|
|
|
|
unsigned slot,
|
|
|
|
const std::string& name
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleSymbolTableEnd()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleFunctionBegin(
|
|
|
|
const Type* FType,
|
|
|
|
GlobalValue::LinkageTypes linkage
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleFunctionEnd(
|
|
|
|
const Type* FType
|
|
|
|
)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleBasicBlockBegin(
|
|
|
|
unsigned blocknum
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numBasicBlocks++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool handleInstruction(
|
|
|
|
unsigned Opcode,
|
|
|
|
const Type* iType,
|
|
|
|
std::vector<unsigned>& Operands
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numInstructions++;
|
|
|
|
return Instruction::isTerminator(Opcode);
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleBasicBlockEnd(unsigned blocknum)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleGlobalConstantsBegin()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantExpression(
|
|
|
|
unsigned Opcode,
|
|
|
|
const Type* Typ,
|
|
|
|
std::vector<std::pair<const Type*,unsigned> > ArgVec
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantValue( Constant * c )
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantArray(
|
|
|
|
const ArrayType* AT,
|
|
|
|
std::vector<unsigned>& Elements )
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantStruct(
|
|
|
|
const StructType* ST,
|
|
|
|
std::vector<unsigned>& ElementSlots)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantPointer(
|
|
|
|
const PointerType* PT, unsigned Slot)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void handleConstantString( const ConstantArray* CA )
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.numConstants++;
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void handleGlobalConstantsEnd()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void llvm::BytecodeAnalyzer::AnalyzeBytecode(
|
|
|
|
const unsigned char *Buf,
|
|
|
|
unsigned Length,
|
|
|
|
BytecodeAnalysis& bca,
|
|
|
|
const std::string &ModuleID
|
|
|
|
)
|
|
|
|
{
|
2004-06-09 14:16:43 +08:00
|
|
|
bca.byteSize = Length;
|
|
|
|
AnalyzerHandler TheHandler(bca);
|
2004-06-08 01:53:43 +08:00
|
|
|
AbstractBytecodeParser TheParser(&TheHandler);
|
|
|
|
TheParser.ParseBytecode( Buf, Length, ModuleID );
|
2004-06-09 14:16:43 +08:00
|
|
|
if ( bca.detailedResults )
|
|
|
|
TheParser.ParseAllFunctionBodies();
|
2004-06-08 01:53:43 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// vim: sw=2
|