yamt wrote:

> > Given that we don't need `setjmpTableSize` anymore and `setjmpTable` 
> > doesn't change, we don't need the whole block here from line 1463 ~ line 
> > 1503 doing SSA updates anymore:
> 
> i get errors like the following if i simply put the SSA update things in 
> `!EnableWasmAltSjLj` block. i need to investigate.
> 
> ```
> spacetanuki% /Volumes/PortableSSD/llvm/build/bin/clang --sysroot 
> /opt/wasi-sdk-21.0/share/wasi-sysroot -resource-dir 
> /Volumes/PortableSSD/llvm/llvm/lib/clang/17 --target=wasm32-wasi -Os -c 
> -mllvm -wasm-enable-sjlj -mllvm -experimental-wasm-enable-alt-sjlj a.c  
> Instruction does not dominate all uses!
>   %val = load i32, ptr %val_gep, align 4
>   %setjmp.ret = phi i32 [ 0, %entry.split ], [ %val, %setjmp.dispatch ]
> in function f
> fatal error: error in backend: Broken function found, compilation aborted!
> PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ 
> and include the crash backtrace, preprocessed source, and associated run 
> script.
> Stack dump:
> 0.      Program arguments: /Volumes/PortableSSD/llvm/build/bin/clang 
> --sysroot /opt/wasi-sdk-21.0/share/wasi-sysroot -resource-dir 
> /Volumes/PortableSSD/llvm/llvm/lib/clang/17 --target=wasm32-wasi -Os -c 
> -mllvm -wasm-enable-sjlj -mllvm -experimental-wasm-enable-alt-sjlj a.c
> 1.      <eof> parser at end of file
> 2.      Code generation
> 3.      Running pass 'Function Pass Manager' on module 'a.c'.
> 4.      Running pass 'Module Verifier' on function '@f'
> ```

i think i found the cause. rebuildSSA is still necessary to propagate "val".


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

Reply via email to