1 //===- StructuralHash.cpp - Function Hash Printing ------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // This file defines the StructuralHashPrinterPass which is used to show
10 // the structural hash of all functions in a module and the module itself.
12 //===----------------------------------------------------------------------===//
14 #include "llvm/Analysis/StructuralHash.h"
15 #include "llvm/IR/Module.h"
16 #include "llvm/IR/StructuralHash.h"
17 #include "llvm/Support/Format.h"
21 PreservedAnalyses
StructuralHashPrinterPass::run(Module
&M
,
22 ModuleAnalysisManager
&MAM
) {
24 << format("%016" PRIx64
,
25 StructuralHash(M
, Options
!= StructuralHashOptions::None
))
27 for (Function
&F
: M
) {
28 if (F
.isDeclaration())
30 if (Options
== StructuralHashOptions::CallTargetIgnored
) {
31 auto IgnoreOp
= [&](const Instruction
*I
, unsigned OpndIdx
) {
32 return I
->getOpcode() == Instruction::Call
&&
33 isa
<Constant
>(I
->getOperand(OpndIdx
));
35 auto FuncHashInfo
= StructuralHashWithDifferences(F
, IgnoreOp
);
36 OS
<< "Function " << F
.getName()
37 << " Hash: " << format("%016" PRIx64
, FuncHashInfo
.FunctionHash
)
39 for (auto &[IndexPair
, OpndHash
] : *FuncHashInfo
.IndexOperandHashMap
) {
40 auto [InstIndex
, OpndIndex
] = IndexPair
;
41 OS
<< "\tIgnored Operand Hash: " << format("%016" PRIx64
, OpndHash
)
42 << " at (" << InstIndex
<< "," << OpndIndex
<< ")\n";
45 OS
<< "Function " << F
.getName() << " Hash: "
48 StructuralHash(F
, Options
== StructuralHashOptions::Detailed
))
52 return PreservedAnalyses::all();