Andres-Salamanca wrote:

@andykaylor @erichkeane @bcardosolopes 
While implementing this simplification, I noticed a difference compared to the 
previous behavior where the folding happened during codegen.

Consider the following test case:

```cpp
void sw7(int a) {
  switch (a) {
  case 0:
  case 1:
  case 2:
    int x;
  case 3:
  case 4:
  case 5:
    break;
  }
}
```
In the [previous 
implementation](https://github.com/llvm/clangir/blob/1fb346d9c05fa676b76f512eded5bba4010b4a74/clang/test/CIR/CodeGen/switch.cpp#L145),
 the codegen phase performed the folding. Variable `x` was **hoisted outside** 
the switch and the generated CIR looked like this:
```
 cir.case(anyof, [#cir.int<0> : !s32i, #cir.int<1> : !s32i, #cir.int<2> : 
!s32i]) {
   cir.yield
 }
 cir.case(anyof, [#cir.int<3> : !s32i, #cir.int<4> : !s32i, #cir.int<5> : 
!s32i]) {
   cir.break
 }
```
Now, without codegen folding and before applying the new pass, the output is:

```mlir
%1 = cir.alloca !s32i, !cir.ptr<!s32i>, ["x"] {alignment = 4 : i64} // x 
hoisted out as before
%2 = cir.load %0 : !cir.ptr<!s32i>, !s32i
cir.switch (%2 : !s32i) {
  cir.case(equal, [#cir.int<0> : !s32i]) {
    cir.yield
  }
  cir.case(equal, [#cir.int<1> : !s32i]) {
    cir.yield
  }
  cir.case(equal, [#cir.int<2> : !s32i]) {
    cir.yield
  }
  cir.case(equal, [#cir.int<3> : !s32i]) {
    cir.yield
  }
  cir.case(equal, [#cir.int<4> : !s32i]) {
    cir.yield
  }
  cir.case(equal, [#cir.int<5> : !s32i]) {
    cir.break
  }
  cir.yield
}
```
After applying the new CIR simplify pass, the output is:

```mlir
cir.case(anyof, [#cir.int<0> : !s32i, #cir.int<1> : !s32i, #cir.int<2> : !s32i, 
#cir.int<3> : !s32i, #cir.int<4> : !s32i, #cir.int<5> : !s32i]) {
   cir.break
}
```

https://github.com/llvm/llvm-project/pull/140649
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to