2020-03-31 04:12:47 +08:00
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=1,2,0" | FileCheck %s --check-prefix=CHECK-120
|
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=1,0,2" | FileCheck %s --check-prefix=CHECK-102
|
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=0,1,2" | FileCheck %s --check-prefix=CHECK-012
|
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=0,2,1" | FileCheck %s --check-prefix=CHECK-021
|
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=2,0,1" | FileCheck %s --check-prefix=CHECK-201
|
|
|
|
// RUN: mlir-opt -allow-unregistered-dialect %s -test-loop-permutation="permutation-map=2,1,0" | FileCheck %s --check-prefix=CHECK-210
|
2020-03-29 02:49:09 +08:00
|
|
|
|
|
|
|
// CHECK-120-LABEL: func @permute
|
|
|
|
func @permute(%U0 : index, %U1 : index, %U2 : index) {
|
|
|
|
"abc"() : () -> ()
|
|
|
|
affine.for %arg0 = 0 to %U0 {
|
|
|
|
affine.for %arg1 = 0 to %U1 {
|
|
|
|
affine.for %arg2 = 0 to %U2 {
|
|
|
|
"foo"(%arg0, %arg1) : (index, index) -> ()
|
|
|
|
"bar"(%arg2) : (index) -> ()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
"xyz"() : () -> ()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// CHECK-120: "abc"
|
|
|
|
// CHECK-120-NEXT: affine.for
|
|
|
|
// CHECK-120-NEXT: affine.for
|
|
|
|
// CHECK-120-NEXT: affine.for
|
|
|
|
// CHECK-120-NEXT: "foo"(%arg4, %arg5)
|
|
|
|
// CHECK-120-NEXT: "bar"(%arg3)
|
|
|
|
// CHECK-120-NEXT: }
|
|
|
|
// CHECK-120-NEXT: }
|
|
|
|
// CHECK-120-NEXT: }
|
|
|
|
// CHECK-120-NEXT: "xyz"
|
|
|
|
// CHECK-120-NEXT: return
|
|
|
|
|
|
|
|
// CHECK-102: "foo"(%arg4, %arg3)
|
|
|
|
// CHECK-102-NEXT: "bar"(%arg5)
|
|
|
|
|
|
|
|
// CHECK-012: "foo"(%arg3, %arg4)
|
|
|
|
// CHECK-012-NEXT: "bar"(%arg5)
|
|
|
|
|
|
|
|
// CHECK-021: "foo"(%arg3, %arg5)
|
|
|
|
// CHECK-021-NEXT: "bar"(%arg4)
|
|
|
|
|
|
|
|
// CHECK-210: "foo"(%arg5, %arg4)
|
|
|
|
// CHECK-210-NEXT: "bar"(%arg3)
|
|
|
|
|
|
|
|
// CHECK-201: "foo"(%arg5, %arg3)
|
|
|
|
// CHECK-201-NEXT: "bar"(%arg4)
|