llvm-diff: Perform structural comparison on GlobalVariables, if possible
authorDominic Chen <d.c.ddcc@gmail.com>
Tue, 17 Dec 2019 00:01:26 +0000 (19:01 -0500)
committerDominic Chen <d.c.ddcc@gmail.com>
Tue, 17 Dec 2019 19:21:48 +0000 (14:21 -0500)
Summary: Names of GlobalVariables may not be preserved depending on compilation options, so prefer a structural diff

Subscribers: llvm-commits

Tags: #llvm

Differential Revision: https://reviews.llvm.org/D71582

llvm/tools/llvm-diff/DifferenceEngine.cpp

index bc93ece..564ce78 100644 (file)
@@ -732,5 +732,14 @@ void DifferenceEngine::diff(Module *L, Module *R) {
 
 bool DifferenceEngine::equivalentAsOperands(GlobalValue *L, GlobalValue *R) {
   if (globalValueOracle) return (*globalValueOracle)(L, R);
+
+  if (isa<GlobalVariable>(L) && isa<GlobalVariable>(R)) {
+    GlobalVariable *GVL = cast<GlobalVariable>(L);
+    GlobalVariable *GVR = cast<GlobalVariable>(R);
+    if (GVL->hasLocalLinkage() && GVL->hasUniqueInitializer() &&
+        GVR->hasLocalLinkage() && GVR->hasUniqueInitializer())
+      return GVL->getInitializer() == GVR->getInitializer();
+  }
+
   return L->getName() == R->getName();
 }