-
Notifications
You must be signed in to change notification settings - Fork 13k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[NLL] false edges on infinite loops #46036
Comments
So @mikhail-m1 added the notion of "false edges" in #45384. This seems to be roughly what is needed here. We would want to edit the code that generates a rust/src/librustc_mir/build/expr/into.rs Lines 149 to 204 in 3e49ada
and modify the graph in the case where condition is rust/src/librustc_mir/build/expr/into.rs Line 191 in 3e49ada
so that we create a FalseEdges that "breaks out". |
Added some mentoring instructions to this NLL issue. Can elaborate as needed! cc nll folks: @davidtwco |
I am trying to fix this one. I have already a kind of patch ready, need to dump MIR and see if it's doing the right thing. |
@Pulkit07 nice :) |
This might take some time, I getting |
@Pulkit07 woah, core dumped?! When do you get the error, when bootstrapping? |
@nikomatsakis I am getting this error when running tests like src/test/run-pass/auto-loop.rs, src/test/run-pass/break.rs and many others. |
@Pulkit07 even if you don't have time to continue working, it'd be helpful if you could post the diff somewhere of how far you got |
From gitter, here is the diff https://bpaste.net/show/ac4eab0ead8e |
So playing with implementing this I've run in to a stumbling block. It seems like fn oh_no1() -> i32 {
loop {
return 1;
}
// we abort here since the fake edge means MIR typeck tries to assert that () == i32
// even though the only way we can get here is if we're unwinding and at that point the
// return value doesn't matter
} |
@bobtwinkles Ah, very good point! You are correct that this control flow is supposed to be like a "false unwind". My instructions were wrong in this respect. We want the false edge not to "break out" but rather to go to an unwinding target. Basically, where we would unwind to, if we were unwinding. The method to get such a block is rust/src/librustc_mir/build/scope.rs Lines 715 to 722 in 3e49ada
I'm not sure whether we will have to further modify |
Here is a test case that @bobtwinkles and I discussed on IRC: https://play.rust-lang.org/?gist=f9b57ba12faa3e9bc8e4a4d523d58736&version=nightly Right now, it ICEs, but it also ought to be reporting an error if this is all working correctly. |
[NLL] Add false edges out of infinite loops Resolves #46036 by adding a `cleanup` member to the `FalseEdges` terminator kind. There's also a small doc fix to one of the other comments in `into.rs` which I can pull out in to another PR if desired =) This PR should pass CI but the test suite has been relatively unstable on my system so I'm not 100% sure. r? @nikomatsakis
…chenkov Move some tests to more reasonable directories - 3 cc rust-lang#73494 r? `@petrochenkov` /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56202.rs <sup>/~https://github.com/rust-lang/rust/issues/56202</sup>: traits 1.008 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-69841.rs <sup>/~https://github.com/rust-lang/rust/issues/69841</sup>: for-loop-while 1.014 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-10763.rs <sup>/~https://github.com/rust-lang/rust/issues/10763</sup>: extern 1.016 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-50599.rs <sup>/~https://github.com/rust-lang/rust/issues/50599</sup>: resolve 1.018 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-6128.rs <sup>/~https://github.com/rust-lang/rust/issues/6128</sup>: traits 1.043 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-20616-8.rs <sup>/~https://github.com/rust-lang/rust/issues/20616</sup>: parser 1.045 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-46553.rs <sup>/~https://github.com/rust-lang/rust/issues/46553</sup>: consts 1.081 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33140-hack-boundaries.rs <sup>/~https://github.com/rust-lang/rust/issues/33140</sup>: traits 1.101 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-25826.rs <sup>/~https://github.com/rust-lang/rust/issues/25826</sup>: consts 1.108 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56488.rs <sup>/~https://github.com/rust-lang/rust/issues/56488</sup>: traits 1.110 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-58856-1.rs <sup>/~https://github.com/rust-lang/rust/issues/58856</sup>: parser 1.133 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57819.rs <sup>/~https://github.com/rust-lang/rust/issues/57819</sup>: parser 1.138 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-54348.rs <sup>/~https://github.com/rust-lang/rust/issues/54348</sup>: consts 1.155 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-14309.rs <sup>/~https://github.com/rust-lang/rust/issues/14309</sup>: lint 1.160 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-4446.rs <sup>/~https://github.com/rust-lang/rust/issues/4446</sup>: threads-sendsync 1.203 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-53675-a-test-called-panic.rs <sup>/~https://github.com/rust-lang/rust/issues/53675</sup>: test-attrs 1.211 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-40231-2.rs <sup>/~https://github.com/rust-lang/rust/issues/40231</sup>: consts 1.213 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-22037.rs <sup>/~https://github.com/rust-lang/rust/issues/22037</sup>: associated-types 1.214 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-59029-2.rs <sup>/~https://github.com/rust-lang/rust/issues/59029</sup>: traits 1.219 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-18425.rs <sup>/~https://github.com/rust-lang/rust/issues/18425</sup>: consts 1.237 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-6157.rs <sup>/~https://github.com/rust-lang/rust/issues/6157</sup>: regions 1.238 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33819.rs <sup>/~https://github.com/rust-lang/rust/issues/33819</sup>: borrowck 1.280 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-3683.rs <sup>/~https://github.com/rust-lang/rust/issues/3683</sup>: traits 1.283 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-8709.rs <sup>/~https://github.com/rust-lang/rust/issues/8709</sup>: macros 1.291 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-20616-9.rs <sup>/~https://github.com/rust-lang/rust/issues/20616</sup>: parser 1.293 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-64732.rs <sup>/~https://github.com/rust-lang/rust/issues/64732</sup>: parser 1.296 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-18655.rs <sup>/~https://github.com/rust-lang/rust/issues/18655</sup>: associated-types 1.305 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-32947.rs <sup>/~https://github.com/rust-lang/rust/issues/32947</sup>: simd 1.322 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57198.rs <sup>/~https://github.com/rust-lang/rust/issues/57198</sup>: parser 1.342 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-10764-rpass.rs <sup>/~https://github.com/rust-lang/rust/issues/10764</sup>: extern 1.392 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-73541-2.rs <sup>/~https://github.com/rust-lang/rust/issues/73541</sup>: async-await 1.422 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-7970b.rs <sup>/~https://github.com/rust-lang/rust/issues/7970</sup>: parser 1.439 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57684.rs <sup>/~https://github.com/rust-lang/rust/issues/57684</sup>: parser 1.512 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33264.rs <sup>/~https://github.com/rust-lang/rust/issues/33264</sup>: llvm-asm 1.523 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-65284-suggest-generic-trait-bound.rs <sup>/~https://github.com/rust-lang/rust/issues/65284</sup>: suggestions 1.647 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-17458.rs <sup>/~https://github.com/rust-lang/rust/issues/17458</sup>: consts 1.711 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56762.rs <sup>/~https://github.com/rust-lang/rust/issues/56762</sup>: consts 1.787 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-2216.rs <sup>/~https://github.com/rust-lang/rust/issues/2216</sup>: for-loop-while 1.856 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-45696-scribble-on-boxed-borrow.rs <sup>/~https://github.com/rust-lang/rust/issues/45696</sup>: nll 2.009 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-46036.rs <sup>/~https://github.com/rust-lang/rust/issues/46036</sup>: nll 2.059 `@petrochenkov` Can you put a place holder (like `N/A`) for tests without GitHub issues? It is a lot easier to parse fixed sized rows.
…chenkov Move some tests to more reasonable directories - 3 cc rust-lang#73494 r? ``@petrochenkov`` /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56202.rs <sup>/~https://github.com/rust-lang/rust/issues/56202</sup>: traits 1.008 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-69841.rs <sup>/~https://github.com/rust-lang/rust/issues/69841</sup>: for-loop-while 1.014 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-10763.rs <sup>/~https://github.com/rust-lang/rust/issues/10763</sup>: extern 1.016 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-50599.rs <sup>/~https://github.com/rust-lang/rust/issues/50599</sup>: resolve 1.018 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-6128.rs <sup>/~https://github.com/rust-lang/rust/issues/6128</sup>: traits 1.043 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-20616-8.rs <sup>/~https://github.com/rust-lang/rust/issues/20616</sup>: parser 1.045 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-46553.rs <sup>/~https://github.com/rust-lang/rust/issues/46553</sup>: consts 1.081 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33140-hack-boundaries.rs <sup>/~https://github.com/rust-lang/rust/issues/33140</sup>: traits 1.101 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-25826.rs <sup>/~https://github.com/rust-lang/rust/issues/25826</sup>: consts 1.108 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56488.rs <sup>/~https://github.com/rust-lang/rust/issues/56488</sup>: traits 1.110 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-58856-1.rs <sup>/~https://github.com/rust-lang/rust/issues/58856</sup>: parser 1.133 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57819.rs <sup>/~https://github.com/rust-lang/rust/issues/57819</sup>: parser 1.138 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-54348.rs <sup>/~https://github.com/rust-lang/rust/issues/54348</sup>: consts 1.155 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-14309.rs <sup>/~https://github.com/rust-lang/rust/issues/14309</sup>: lint 1.160 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-4446.rs <sup>/~https://github.com/rust-lang/rust/issues/4446</sup>: threads-sendsync 1.203 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-53675-a-test-called-panic.rs <sup>/~https://github.com/rust-lang/rust/issues/53675</sup>: test-attrs 1.211 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-40231-2.rs <sup>/~https://github.com/rust-lang/rust/issues/40231</sup>: consts 1.213 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-22037.rs <sup>/~https://github.com/rust-lang/rust/issues/22037</sup>: associated-types 1.214 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-59029-2.rs <sup>/~https://github.com/rust-lang/rust/issues/59029</sup>: traits 1.219 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-18425.rs <sup>/~https://github.com/rust-lang/rust/issues/18425</sup>: consts 1.237 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-6157.rs <sup>/~https://github.com/rust-lang/rust/issues/6157</sup>: regions 1.238 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33819.rs <sup>/~https://github.com/rust-lang/rust/issues/33819</sup>: borrowck 1.280 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-3683.rs <sup>/~https://github.com/rust-lang/rust/issues/3683</sup>: traits 1.283 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-8709.rs <sup>/~https://github.com/rust-lang/rust/issues/8709</sup>: macros 1.291 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-20616-9.rs <sup>/~https://github.com/rust-lang/rust/issues/20616</sup>: parser 1.293 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-64732.rs <sup>/~https://github.com/rust-lang/rust/issues/64732</sup>: parser 1.296 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-18655.rs <sup>/~https://github.com/rust-lang/rust/issues/18655</sup>: associated-types 1.305 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-32947.rs <sup>/~https://github.com/rust-lang/rust/issues/32947</sup>: simd 1.322 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57198.rs <sup>/~https://github.com/rust-lang/rust/issues/57198</sup>: parser 1.342 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-10764-rpass.rs <sup>/~https://github.com/rust-lang/rust/issues/10764</sup>: extern 1.392 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-73541-2.rs <sup>/~https://github.com/rust-lang/rust/issues/73541</sup>: async-await 1.422 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-7970b.rs <sup>/~https://github.com/rust-lang/rust/issues/7970</sup>: parser 1.439 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-57684.rs <sup>/~https://github.com/rust-lang/rust/issues/57684</sup>: parser 1.512 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-33264.rs <sup>/~https://github.com/rust-lang/rust/issues/33264</sup>: llvm-asm 1.523 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-65284-suggest-generic-trait-bound.rs <sup>/~https://github.com/rust-lang/rust/issues/65284</sup>: suggestions 1.647 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-17458.rs <sup>/~https://github.com/rust-lang/rust/issues/17458</sup>: consts 1.711 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-56762.rs <sup>/~https://github.com/rust-lang/rust/issues/56762</sup>: consts 1.787 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-2216.rs <sup>/~https://github.com/rust-lang/rust/issues/2216</sup>: for-loop-while 1.856 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-45696-scribble-on-boxed-borrow.rs <sup>/~https://github.com/rust-lang/rust/issues/45696</sup>: nll 2.009 /~https://github.com/rust-lang/rust/blob/master/src/test/ui/issues/issue-46036.rs <sup>/~https://github.com/rust-lang/rust/issues/46036</sup>: nll 2.059 ``@petrochenkov`` Can you put a place holder (like `N/A`) for tests without GitHub issues? It is a lot easier to parse fixed sized rows.
The NLL RFC specifies false edges on infinite loops, so that we get errors in some cases. This is a somewhat disputed clause (see nikomatsakis/nll-rfc#35) that we may change, but it makes sense for now. I'm filing this so we don't forget about it.
The text was updated successfully, but these errors were encountered: