Compiler projects using llvm
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt -disable-output -S -passes=print-ir-similarity < %s 2>&1 | FileCheck --allow-empty %s

; Check to make sure that the IRSimilarityIdentifier and IRSimilarityPrinterPass
; return items only within the same function when there are different sets of
; instructions in functions.

; CHECK: 2 candidates of length 3.  Found in:
; CHECK-NEXT:   Function: turtle, Basic Block: (unnamed)
; CHECK-NEXT:     Start Instruction:   %b = load i32, i32* %1, align 4
; CHECK-NEXT:       End Instruction:   %d = load i32, i32* %3, align 4
; CHECK-NEXT:   Function: turtle, Basic Block: (unnamed)
; CHECK-NEXT:     Start Instruction:   %a = load i32, i32* %0, align 4
; CHECK-NEXT:       End Instruction:   %c = load i32, i32* %2, align 4
; CHECK-NEXT: 2 candidates of length 5.  Found in:
; CHECK-NEXT:   Function: fish, Basic Block: entry
; CHECK-NEXT:     Start Instruction:   store i32 6, i32* %0, align 4
; CHECK-NEXT:       End Instruction:   store i32 4, i32* %4, align 4
; CHECK-NEXT:   Function: fish, Basic Block: entry
; CHECK-NEXT:     Start Instruction:   store i32 1, i32* %1, align 4
; CHECK-NEXT:       End Instruction:   store i32 5, i32* %5, align 4

define linkonce_odr void @fish() {
entry:
  %0 = alloca i32, align 4
  %1 = alloca i32, align 4
  %2 = alloca i32, align 4
  %3 = alloca i32, align 4
  %4 = alloca i32, align 4
  %5 = alloca i32, align 4
  store i32 6, i32* %0, align 4
  store i32 1, i32* %1, align 4
  store i32 2, i32* %2, align 4
  store i32 3, i32* %3, align 4
  store i32 4, i32* %4, align 4
  store i32 5, i32* %5, align 4
  ret void
}

define void @turtle(i32* %0, i32* %1, i32* %2, i32* %3) {
  %a = load i32, i32* %0
  %b = load i32, i32* %1
  %c = load i32, i32* %2
  %d = load i32, i32* %3
  ret void
}