# RUN: llc -mtriple=s390x-linux-gnu -mcpu=z15 -O3 -run-pass=machine-sink %s -o - \ # RUN: -verify-machineinstrs | FileCheck %s # # Test that the AGHIK can be sunk into %bb.4. It has a def of CC, but it is dead. --- | define void @fun() { ret void } ... # CHECK-LABEL: bb.4: # CHECK: %1:gr64bit = nsw AGHIK %0, -4, implicit-def dead $cc # CHECK-NEXT: CGHI %1, 0, implicit-def $cc # CHECK-NEXT: BRC 14, 6, %bb.1, implicit $cc # CHECK-NEXT: J %bb.5 --- name: fun alignment: 16 tracksRegLiveness: true registers: - { id: 0, class: gr64bit } - { id: 1, class: gr64bit } - { id: 2, class: grx32bit } - { id: 3, class: gr64bit } frameInfo: maxAlignment: 1 machineFunctionInfo: {} body: | bb.0: %2:grx32bit = LHIMux 0 %3:gr64bit = IMPLICIT_DEF bb.1: %0:gr64bit = PHI %3, %bb.0, %1, %bb.4 bb.2: %1:gr64bit = nsw AGHIK %0, -4, implicit-def dead $cc CHIMux %2, 0, implicit-def $cc BRC 14, 6, %bb.4, implicit $cc J %bb.3 bb.3: bb.4: CGHI %1, 0, implicit-def $cc BRC 14, 6, %bb.1, implicit $cc J %bb.5 bb.5: Return ...