rust/src/test
Alex Crichton 1c07096a45 rustc: Fill out remaining parts of C-unwind ABI
This commit intends to fill out some of the remaining pieces of the
C-unwind ABI. This has a number of other changes with it though to move
this design space forward a bit. Notably contained within here is:

* On `panic=unwind`, the `extern "C"` ABI is now considered as "may
  unwind". This fixes a longstanding soundness issue where if you
  `panic!()` in an `extern "C"` function defined in Rust that's actually
  UB because the LLVM representation for the function has the `nounwind`
  attribute, but then you unwind.

* Whether or not a function unwinds now mainly considers the ABI of the
  function instead of first checking the panic strategy. This fixes a
  miscompile of `extern "C-unwind"` with `panic=abort` because that ABI
  can still unwind.

* The aborting stub for non-unwinding ABIs with `panic=unwind` has been
  reimplemented. Previously this was done as a small tweak during MIR
  generation, but this has been moved to a separate and dedicated MIR
  pass. This new pass will, for appropriate functions and function
  calls, insert a `cleanup` landing pad for any function call that may
  unwind within a function that is itself not allowed to unwind. Note
  that this subtly changes some behavior from before where previously on
  an unwind which was caught-to-abort it would run active destructors in
  the function, and now it simply immediately aborts the process.

* The `#[unwind]` attribute has been removed and all users in tests and
  such are now using `C-unwind` and `#![feature(c_unwind)]`.

I think this is largely the last piece of the RFC to implement.
Unfortunately I believe this is still not stabilizable as-is because
activating the feature gate changes the behavior of the existing `extern
"C"` ABI in a way that has no replacement. My thinking for how to enable
this is that we add support for the `C-unwind` ABI on stable Rust first,
and then after it hits stable we change the behavior of the `C` ABI.
That way anyone straddling stable/beta/nightly can switch to `C-unwind`
safely.
2021-08-03 07:06:19 -07:00
..
assembly Re-Annotate the tests with needs-llvm-components 2021-06-24 23:13:08 +03:00
auxiliary
codegen rustc: Fill out remaining parts of C-unwind ABI 2021-08-03 07:06:19 -07:00
codegen-units
debuginfo Fix failing test 2021-07-25 20:34:08 +02:00
incremental Make type_implements_trait not a query 2021-07-06 14:38:10 -04:00
mir-opt Update tests 2021-07-27 16:26:50 -04:00
pretty Auto merge of #83491 - jyn514:remove-pretty, r=pnkfelix 2021-07-27 03:12:40 +00:00
run-make rfc3052: Remove authors field from Cargo manifests 2021-07-29 14:56:05 -07:00
run-make-fulldeps rustc: Fill out remaining parts of C-unwind ABI 2021-08-03 07:06:19 -07:00
run-pass-valgrind
rustdoc Rollup merge of #87451 - GuillaumeGomez:tuple-struct-field-doc, r=jyn514 2021-07-29 06:11:45 +09:00
rustdoc-gui Auto merge of #87390 - notriddle:notriddle/rustdoc-headers-patch, r=GuillaumeGomez 2021-07-25 21:41:57 +00:00
rustdoc-js fix(rustdoc): generics search 2021-07-01 06:40:27 -07:00
rustdoc-js-std fix(rustdoc): generics search 2021-07-01 06:40:27 -07:00
rustdoc-json
rustdoc-ui Auto merge of #87285 - GuillaumeGomez:intra-doc-span, r=estebank 2021-07-29 23:33:18 +00:00
rustfix
ui rustc: Fill out remaining parts of C-unwind ABI 2021-08-03 07:06:19 -07:00
ui-fulldeps Add long explanation for E0498 2021-07-27 18:06:34 +01:00
COMPILER_TESTS.md