File: one-shot-bufferize-allow-return-allocs-no-deallocs.mlir

package info (click to toggle)
llvm-toolchain-18 1%3A18.1.8-18
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 1,908,340 kB
  • sloc: cpp: 6,667,937; ansic: 1,440,452; asm: 883,619; python: 230,549; objc: 76,880; f90: 74,238; lisp: 35,989; pascal: 16,571; sh: 10,229; perl: 7,459; ml: 5,047; awk: 3,523; makefile: 2,987; javascript: 2,149; xml: 892; fortran: 649; cs: 573
file content (17 lines) | stat: -rw-r--r-- 613 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// RUN: mlir-opt %s -one-shot-bufferize=allow-return-allocs-from-loops -split-input-file | FileCheck %s --dump-input=always

// A regression test to check that different before and after argument types are
// bufferized successfully.
func.func @different_before_after_args() -> tensor<f32> {
  %true = arith.constant true
  %cst = arith.constant dense<0.0> : tensor<f32>
  %0 = scf.while (%arg4 = %true) : (i1) -> (tensor<f32>) {
    scf.condition(%true) %cst : tensor<f32>
  } do {
  ^bb0(%arg4: tensor<f32>):
    scf.yield %true : i1
  }
  return %0 : tensor<f32>
}

// CHECK-LABEL: @different_before_after_args