File: machine-combiner-eor.mir

package info (click to toggle)
llvm-toolchain-16 1%3A16.0.6-15~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 1,634,792 kB
  • sloc: cpp: 6,179,261; ansic: 1,216,205; asm: 741,319; python: 196,614; objc: 75,325; f90: 49,640; lisp: 32,396; pascal: 12,286; sh: 9,394; perl: 7,442; ml: 5,494; awk: 3,523; makefile: 2,723; javascript: 1,206; xml: 886; fortran: 581; cs: 573
file content (85 lines) | stat: -rw-r--r-- 3,168 bytes parent folder | download | duplicates (12)
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
# NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
# RUN: llc -mtriple=aarch64-none-linux-gnu -mcpu=neoverse-n2 -run-pass machine-combiner \
# RUN:     -verify-machineinstrs  -o - %s | FileCheck %s

# Most machine-combiner reassociation tests are put in machine-combiner.ll.
# However, we cannot test reassociation of SVE EORs in machine-combiner.ll
# because isel combines two EORs to one EOR3. So SVE EOR-specific test is put
# in this file.

---

name:            reassociate_xors_sve_1
registers:
  - { id: 0, class: zpr, preferred-register: '' }
  - { id: 1, class: zpr, preferred-register: '' }
  - { id: 2, class: zpr, preferred-register: '' }
  - { id: 3, class: zpr, preferred-register: '' }
  - { id: 4, class: zpr, preferred-register: '' }
  - { id: 5, class: zpr, preferred-register: '' }
  - { id: 6, class: zpr, preferred-register: '' }
body:             |
  bb.0:
    liveins: $z0, $z1, $z2, $z3

    ; CHECK-LABEL: name: reassociate_xors_sve_1
    ; CHECK: liveins: $z0, $z1, $z2, $z3
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: [[COPY:%[0-9]+]]:zpr = COPY $z3
    ; CHECK-NEXT: [[COPY1:%[0-9]+]]:zpr = COPY $z2
    ; CHECK-NEXT: [[COPY2:%[0-9]+]]:zpr = COPY $z1
    ; CHECK-NEXT: [[COPY3:%[0-9]+]]:zpr = COPY $z0
    ; CHECK-NEXT: [[EOR_ZZZ:%[0-9]+]]:zpr = EOR_ZZZ [[COPY3]], [[COPY2]]
    ; CHECK-NEXT: [[EOR_ZZZ1:%[0-9]+]]:zpr = EOR_ZZZ [[COPY1]], [[COPY]]
    ; CHECK-NEXT: [[EOR_ZZZ2:%[0-9]+]]:zpr = EOR_ZZZ killed [[EOR_ZZZ]], killed [[EOR_ZZZ1]]
    ; CHECK-NEXT: $z0 = COPY [[EOR_ZZZ2]]
    ; CHECK-NEXT: RET_ReallyLR implicit $z0
    %3:zpr = COPY $z3
    %2:zpr = COPY $z2
    %1:zpr = COPY $z1
    %0:zpr = COPY $z0
    %4:zpr = EOR_ZZZ %0, %1
    %5:zpr = EOR_ZZZ killed %4, %2
    %6:zpr = EOR_ZZZ killed %5, %3
    $z0 = COPY %6
    RET_ReallyLR implicit $z0

...
---

name:            reassociate_xors_sve_2
registers:
  - { id: 0, class: zpr, preferred-register: '' }
  - { id: 1, class: zpr, preferred-register: '' }
  - { id: 2, class: zpr, preferred-register: '' }
  - { id: 3, class: zpr, preferred-register: '' }
  - { id: 4, class: zpr, preferred-register: '' }
  - { id: 5, class: zpr, preferred-register: '' }
  - { id: 6, class: zpr, preferred-register: '' }
body:             |
  bb.0:
    liveins: $z0, $z1, $z2, $z3

    ; CHECK-LABEL: name: reassociate_xors_sve_2
    ; CHECK: liveins: $z0, $z1, $z2, $z3
    ; CHECK-NEXT: {{  $}}
    ; CHECK-NEXT: [[COPY:%[0-9]+]]:zpr = COPY $z3
    ; CHECK-NEXT: [[COPY1:%[0-9]+]]:zpr = COPY $z2
    ; CHECK-NEXT: [[COPY2:%[0-9]+]]:zpr = COPY $z1
    ; CHECK-NEXT: [[COPY3:%[0-9]+]]:zpr = COPY $z0
    ; CHECK-NEXT: [[AND_ZZZ:%[0-9]+]]:zpr = AND_ZZZ [[COPY3]], [[COPY2]]
    ; CHECK-NEXT: [[EOR_ZZZ:%[0-9]+]]:zpr = EOR_ZZZ [[COPY1]], [[COPY]]
    ; CHECK-NEXT: [[EOR_ZZZ1:%[0-9]+]]:zpr = EOR_ZZZ killed [[AND_ZZZ]], killed [[EOR_ZZZ]]
    ; CHECK-NEXT: $z0 = COPY [[EOR_ZZZ1]]
    ; CHECK-NEXT: RET_ReallyLR implicit $z0
    %3:zpr = COPY $z3
    %2:zpr = COPY $z2
    %1:zpr = COPY $z1
    %0:zpr = COPY $z0
    %4:zpr = AND_ZZZ %0, %1
    %5:zpr = EOR_ZZZ killed %4, %2
    %6:zpr = EOR_ZZZ killed %5, %3
    $z0 = COPY %6
    RET_ReallyLR implicit $z0

...