Closed
Bug 977810
Opened 11 years ago
Closed 11 years ago
Poison Baseline/Ion code in release builds
Categories
(Core :: JavaScript Engine: JIT, defect)
Core
JavaScript Engine: JIT
Tracking
()
RESOLVED
FIXED
mozilla30
People
(Reporter: cpeterson, Assigned: cpeterson)
References
Details
(Keywords: sec-want, Whiteboard: [js:p1])
Attachments
(1 file, 1 obsolete file)
1.82 KB,
patch
|
jandem
:
review+
|
Details | Diff | Splinter Review |
Ion code is only poisoned in debug builds. Consider poisoning in release builds or #ifdef JS_CRASH_DIAGNOSTICS (Nightly and Aurora).
https://hg.mozilla.org/mozilla-central/file/4cfb6c61b137/js/src/jit/Ion.cpp#l676
Note that JS_POISON is already #ifdef JS_CRASH_DIAGNOSTICS-only, so we shouldn't need any special checking for nightly/aurora.
Assignee | ||
Comment 2•11 years ago
|
||
Poison freed Ion code in nightly builds.
As of bug 860254, jemalloc now poisons freed memory in both debug and release builds. bsmedberg suggested [1] poisoning freed JIT code, too. I replaced with #ifdef DEBUG with #ifdef JS_CRASH_DIAGNOSTICS, so it only affects Nightly and Aurora release builds. How much would this poison affect JS performance if it was enabled in release builds on all channels?
[1] https://groups.google.com/forum/#!topic/mozilla.dev.tech.js-engine.internals/dUlUxYsFz5Q
Assignee | ||
Comment 3•11 years ago
|
||
Also null out JitCode's code_ and pool_ pointers.
Attachment #8388161 -
Attachment is obsolete: true
Attachment #8388161 -
Flags: review?(jdemooij)
Attachment #8388162 -
Flags: review?(jdemooij)
Comment 4•11 years ago
|
||
Comment on attachment 8388162 [details] [diff] [review]
poison-ion-code.patch
Review of attachment 8388162 [details] [diff] [review]:
-----------------------------------------------------------------
Thanks for doing this!
::: js/src/jit/Ion.cpp
@@ +690,5 @@
> + // Horrible hack: if we are using perf integration, we don't
> + // want to reuse code addresses, so we just leak the memory instead.
> + if (!PerfEnabled()) {
> + pool_->release();
> + }
Nit: no {}
Attachment #8388162 -
Flags: review?(jdemooij) → review+
Comment 5•11 years ago
|
||
(In reply to Chris Peterson (:cpeterson) from comment #2)
> How much would this poison affect
> JS performance if it was enabled in release builds on all channels?
I just tested this on Octane in the shell, and I don't see a slowdown if I enable the poisoning in an opt build. So I'm fine with removing "#ifdef JS_CRASH_DIAGNOSTICS", as long as you keep an eye on AWFY/Talos after it lands.
Assignee | ||
Comment 6•11 years ago
|
||
(In reply to Jan de Mooij [:jandem] from comment #5)
> I just tested this on Octane in the shell, and I don't see a slowdown if I
> enable the poisoning in an opt build. So I'm fine with removing "#ifdef
> JS_CRASH_DIAGNOSTICS", as long as you keep an eye on AWFY/Talos after it
> lands.
JS_POISON itself is #ifdef JS_CRASH_DIAGNOSTICS so that JS_POISON call would need to be replaced with a memset().
Comment 7•11 years ago
|
||
(In reply to Chris Peterson (:cpeterson) from comment #6)
> JS_POISON itself is #ifdef JS_CRASH_DIAGNOSTICS so that JS_POISON call would
> need to be replaced with a memset().
Ah, indeed. I have to run, but I just tried again with a memset there and perf still looks fine in the shell.
Comment 8•11 years ago
|
||
Or we could (should!) define the real JS_POISON in all builds... can we try that?
Assignee | ||
Comment 9•11 years ago
|
||
Assignee | ||
Comment 10•11 years ago
|
||
I filed a new bug 981991 to continue the investigation of defining JS_POISON in release builds.
Comment 11•11 years ago
|
||
Status: ASSIGNED → RESOLVED
Closed: 11 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla30
Updated•11 years ago
|
Summary: Poison Ion code in release builds → Poison Baseline/Ion code in release builds
You need to log in
before you can comment on or make changes to this bug.
Description
•