Skip to content
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

Don't enqueue onto a disabled dep_graph. #36973

Merged
merged 1 commit into from
Oct 20, 2016
Merged

Conversation

nnethercote
Copy link
Contributor

This commit guards all calls to DepGraphThreadData::enqueue with a
check to make sure it is enabled. This avoids some useless allocation
and vector manipulations when it is disabled (i.e. when incremental
compilation is off) which improves speed by 1--2% on most of the
rustc-benchmarks.

This commit has an observable functional change: when the dep_graph is
disabled its shadow_graph will no longer receive messages. This should
be ok because these message are only used when debug assertions are
enabled.

r? @nikomatsakis

@nikomatsakis
Copy link
Contributor

This should be ok because these message are only used when debug assertions are
enabled.

I used to have this setup, but I changed it to the current one specifically so that the shadow graph was active even if incremental is disabled. This is because it detects common errors that are otherwise overlooked (at least until people are using incremental by default).

Perhaps we could do this setup, but only if debug-assertions are not enabled?

@michaelwoerister
Copy link
Member

FYI: As far as I know, debug assertions are always enabled on the build bots.

@TimNN
Copy link
Contributor

TimNN commented Oct 5, 2016

@michaelwoerister: I think it's the exact opposite (at least on the stable/beta/nightly build bots): debug_assertions are never enabled (which is why DEBUG logging does not work in these builds)

@michaelwoerister
Copy link
Member

@TimNN I might not be using the right terminology. What I meant was that the tests that gate whether a PR gets merged are run using a compiler where debug assertions are enabled.

@TimNN
Copy link
Contributor

TimNN commented Oct 5, 2016

Ah well, I suppose those are build bots as well. (Not sure if there is an "official" terminology).

(And I just checked, debug_assertions are indeed enabled on the test bots (or whatever you want to call them): https://github.com/rust-lang/rust-buildbot/blob/master/master/master.cfg#L1775)

@michaelwoerister
Copy link
Member

@TimNN Thanks for making facts out of my speculations :)

@nnethercote
Copy link
Contributor Author

Ok, I will update the code to still push the messages if debug assertions are enabled.

@nnethercote
Copy link
Contributor Author

r? @nikomatsakis

@@ -19,15 +19,21 @@ pub struct DepTask<'graph> {

impl<'graph> DepTask<'graph> {
pub fn new(data: &'graph DepGraphThreadData, key: DepNode<DefId>)
-> DepTask<'graph> {
data.enqueue(DepMessage::PushTask(key.clone()));
Copy link
Contributor

@nikomatsakis nikomatsakis Oct 11, 2016

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you measured the impact of this on the perf also when construction is enabled? When I first wrote the code, I went to some lengths to make it straightline and cheap when the graph was enabled, and the overhead I measured was quite low. The idea was that copying into the buffer without a branch could actually be cheaper than not copying at all. I did measure and I recall finding this to be the case (I think I tested libsyntax), but a lot has changed since then, and for all I know my measurements at the time were flawed. =) We have a better setup now.

(After all, we do expect "incremental enabled" to be the common case, right? I would think that incr will always be on, unless you are building a final release artifact, in which case you are already asking for a lot of time to be spent on optimization.)

@nnethercote
Copy link
Contributor Author

The only measurement of incremental compilation I did is of syntex-incr in rustc-benchmarks. Its speed was unaffected by the patch. Perfectly predictable branches tend to be cheap :)

@nikomatsakis
Copy link
Contributor

Seems good.

@bors r+

@bors
Copy link
Contributor

bors commented Oct 11, 2016

📌 Commit d54b044 has been approved by nikomatsakis

bors added a commit that referenced this pull request Oct 12, 2016
@alexcrichton
Copy link
Member

@bors: r-

Unfortunately I think this caused this failure, specifically:

Building stage1 std artifacts (x86_64-pc-windows-msvc -> x86_64-pc-windows-msvc)
    Finished release [optimized] target(s) in 656.99 secs
   Compiling build_helper v0.1.0 (file:///C:/bot/slave/auto-win-msvc-64-cargotest/build/src/build_helper)
   Compiling core v0.0.0 (file:///C:/bot/slave/auto-win-msvc-64-cargotest/build/src/libcore)
   Compiling gcc v0.3.35
   Compiling unwind v0.0.0 (file:///C:/bot/slave/auto-win-msvc-64-cargotest/build/src/libunwind)
   Compiling libc v0.0.0 (file:///C:/bot/slave/auto-win-msvc-64-cargotest/build/src/rustc/libc_shim)
Build failed, waiting for other jobs to finish...
error: internal compiler error: unexpected panic

note: the compiler unexpectedly panicked. this is a bug.

note: we would appreciate a bug report: https://github.com/rust-lang/rust/blob/master/CONTRIBUTING.md#bug-reports

thread 'rustc' panicked at 'should never swap if not fully enabled', C:\bot\slave\auto-win-msvc-64-cargotest\build\src\librustc\dep_graph\thread.rs:108
note: Run with `RUST_BACKTRACE=1` for a backtrace.

This happened on MSVC for me but not on Linux, and I had to take it out of a rollup as a result.

This commit guards all calls to `DepGraphThreadData::enqueue` with a
check to make sure it is enabled. This requires distinguishing between a
"fully enabled" and an "enqueue-enabled" graph.

This change avoids some useless allocation and vector manipulations when
the graph is disabled (i.e. when incremental compilation is off) which
improves speed by ~1% on some of the rustc-benchmarks.
@nnethercote
Copy link
Contributor Author

I've fixed the problem and pushed an updated commit. The problem was that I mistakenly removed the the enabled check in enqueue (right at the end of the diff). It's back now.

r? @nikomatsakis

@nikomatsakis
Copy link
Contributor

@bors r+

@bors
Copy link
Contributor

bors commented Oct 19, 2016

📌 Commit cde42cd has been approved by nikomatsakis

@bors
Copy link
Contributor

bors commented Oct 20, 2016

⌛ Testing commit cde42cd with merge eb38d42...

bors added a commit that referenced this pull request Oct 20, 2016
Don't enqueue onto a disabled dep_graph.

This commit guards all calls to `DepGraphThreadData::enqueue` with a
check to make sure it is enabled. This avoids some useless allocation
and vector manipulations when it is disabled (i.e. when incremental
compilation is off) which improves speed by 1--2% on most of the
rustc-benchmarks.

This commit has an observable functional change: when the dep_graph is
disabled its `shadow_graph` will no longer receive messages. This should
be ok because these message are only used when debug assertions are
enabled.

r? @nikomatsakis
@bors bors merged commit cde42cd into rust-lang:master Oct 20, 2016
@nnethercote nnethercote deleted the dep_graph branch October 21, 2016 03:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants