File: misched-critical-path.ll

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 1,998,492 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (35 lines) | stat: -rw-r--r-- 1,038 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
; RUN: llc < %s -mtriple=x86_64-apple-darwin8 -misched-print-dags -o - 2>&1 > /dev/null | FileCheck %s
; REQUIRES: asserts

@sc = common global i8 0
@uc = common global i8 0
@ui = common global i32 0

; Regression Test for PR92368.
;
; CHECK: SU(8):   CMP8rr %4:gr8, %3:gr8, implicit-def $eflags
; CHECK:   Predecessors:
; CHECK-NEXT:    SU(6): Data Latency=0 Reg=%4
; CHECK-NEXT:    SU(7): Out  Latency=0
; CHECK-NEXT:    SU(5): Out  Latency=0
; CHECK-NEXT:    SU(3): Data Latency=4 Reg=%3
define void @misched_bug() nounwind {
entry:
  %v0 = load i8, ptr @sc, align 1
  %v1 = zext i8 %v0 to i32
  %v2 = load i8, ptr @uc, align 1
  %v3 = zext i8 %v2 to i32
  %v4 = trunc i32 %v3 to i8
  %v5 = trunc i32 %v1 to i8
  %pair74 = cmpxchg ptr @sc, i8 %v4, i8 %v5 monotonic monotonic
  %v6 = extractvalue { i8, i1 } %pair74, 0
  %v7 = icmp eq i8 %v6, %v4
  %v8 = zext i1 %v7 to i8
  %v9 = zext i8 %v8 to i32
  store i32 %v9, ptr @ui, align 4
  br label %return

return:                                           ; preds = %ventry
  ret void
}