|  | ; REQUIRES: asserts | 
|  | ; RUN: llc -mtriple=riscv32 -debug-only=machine-scheduler < %s \ | 
|  | ; RUN:   -o /dev/null 2>&1 | FileCheck %s | 
|  | ; RUN: llc -mtriple=riscv64 -debug-only=machine-scheduler < %s \ | 
|  | ; RUN:   -o /dev/null 2>&1 | FileCheck %s | 
|  |  | 
|  | ; This test exercises the areMemAccessesTriviallyDisjoint hook. | 
|  | ; Test that the two stores are disjoint memory accesses. If the corresponding | 
|  | ; store machine instructions don't depend on each other, the second store should | 
|  | ; not appear in the successors list of the first one and the first one should | 
|  | ; not appear on the predecessors list of the second one. | 
|  | define i32 @test_disjoint(ptr %P, i32 %v) { | 
|  | entry: | 
|  | ; CHECK: ********** MI Scheduling ********** | 
|  | ; CHECK-LABEL: test_disjoint:%bb.0 | 
|  | ; CHECK:SU(2):   SW %1:gpr, %0:gpr, 12 :: (store (s32) into %ir.arrayidx) | 
|  | ; CHECK-NOT: Successors: | 
|  | ; CHECK:SU(3):   SW %1:gpr, %0:gpr, 8 :: (store (s32) into %ir.arrayidx1) | 
|  | ; CHECK: Predecessors: | 
|  | ; CHECK-NOT:    SU(2): Ord  Latency=0 Memory | 
|  | %arrayidx = getelementptr inbounds i32, ptr %P, i32 3 | 
|  | store i32 %v, ptr %arrayidx | 
|  | %arrayidx1 = getelementptr inbounds i32, ptr %P, i32 2 | 
|  | store i32 %v, ptr %arrayidx1 | 
|  | ret i32 %v | 
|  | } |