Bug 144465

Summary: Object allocation not sinking properly through CheckStructure
Product: WebKit Reporter: Basile Clement <basile_clement>
Component: JavaScriptCoreAssignee: Basile Clement <basile_clement>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, fpizlo, ggaren, mark.lam, msaboff
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Example of the bug
none
Good old NaN not being equal to itself
none
Patch
none
Patch
none
Patch for landing none

Basile Clement
Reported 2015-04-30 12:23:48 PDT
Created attachment 252079 [details] Example of the bug When sinking allocations through CheckStructure node, we are just ignoring them, which may cause code that should have been guarded by the CheckStructure to execute unchecked and produce wrong results.
Attachments
Example of the bug (333 bytes, application/x-javascript)
2015-04-30 12:23 PDT, Basile Clement
no flags
Good old NaN not being equal to itself (342 bytes, application/x-javascript)
2015-04-30 12:44 PDT, Basile Clement
no flags
Patch (5.46 KB, patch)
2015-04-30 17:24 PDT, Basile Clement
no flags
Patch (7.23 KB, patch)
2015-05-01 16:58 PDT, Basile Clement
no flags
Patch for landing (7.28 KB, patch)
2015-05-04 11:05 PDT, Basile Clement
no flags
Basile Clement
Comment 1 2015-04-30 12:28:15 PDT
According to Filip, the CheckStructureImmediate node was here for that case, I am trying to put up a fix once I understand how it is supposed to work.
Basile Clement
Comment 2 2015-04-30 12:44:36 PDT
Created attachment 252080 [details] Good old NaN not being equal to itself The test would have been failing even w/o the bug.
Basile Clement
Comment 3 2015-04-30 17:24:08 PDT
Filip Pizlo
Comment 4 2015-05-01 15:25:30 PDT
Comment on attachment 252119 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=252119&action=review > Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:4974 > - LValue structureID = lowCell(m_node->child1()); > + LValue structure = lowCell(m_node->child1()); > + LValue structureID = m_out.load32(structure, m_heaps.Structure_structureID); We should do something to eliminate this load. Can we make checkStructure() have a mode where it checks structure pointers instead of IDs?
Basile Clement
Comment 5 2015-05-01 16:58:37 PDT
WebKit Commit Bot
Comment 6 2015-05-01 17:00:44 PDT
Attachment 252200 [details] did not pass style-queue: ERROR: Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:1881: Place brace on its own line for function definitions. [whitespace/braces] [4] ERROR: Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:4980: Place brace on its own line for function definitions. [whitespace/braces] [4] Total errors found: 2 in 5 files If any of these errors are false positives, please file a bug against check-webkit-style.
Filip Pizlo
Comment 7 2015-05-01 19:04:33 PDT
Comment on attachment 252200 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=252200&action=review > Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:5324 > - LValue structureID, const FormattedValue& formattedValue, ExitKind exitKind, > - const StructureSet& set) > + LValue structureDiscriminant, const FormattedValue& formattedValue, ExitKind exitKind, > + const StructureSet& set, std::function<LValue(Structure*)>&& weakStructureDiscriminant) We usually use a functor instead of std::function. Something like: template<typename Functor> void checkStrcuture(..., const Functor& weakStructureDiscriminant) { ... } In all other ways, it'll work the same as what you have. r=me anyways, it's not a big deal.
Basile Clement
Comment 8 2015-05-04 10:38:52 PDT
(In reply to comment #7) > Comment on attachment 252200 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=252200&action=review > > > Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:5324 > > - LValue structureID, const FormattedValue& formattedValue, ExitKind exitKind, > > - const StructureSet& set) > > + LValue structureDiscriminant, const FormattedValue& formattedValue, ExitKind exitKind, > > + const StructureSet& set, std::function<LValue(Structure*)>&& weakStructureDiscriminant) > > We usually use a functor instead of std::function. Something like: > > template<typename Functor> > void checkStrcuture(..., const Functor& weakStructureDiscriminant) { ... } > > In all other ways, it'll work the same as what you have. > > r=me anyways, it's not a big deal. I used std::function due to the habit of writing more precise types ; I will change that to a functor before landing, if only for the sake of consistency.
Basile Clement
Comment 9 2015-05-04 11:05:43 PDT
Created attachment 252321 [details] Patch for landing
WebKit Commit Bot
Comment 10 2015-05-04 11:09:40 PDT
Attachment 252321 [details] did not pass style-queue: ERROR: Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:1887: Place brace on its own line for function definitions. [whitespace/braces] [4] ERROR: Source/JavaScriptCore/ftl/FTLLowerDFGToLLVM.cpp:5099: Place brace on its own line for function definitions. [whitespace/braces] [4] Total errors found: 2 in 5 files If any of these errors are false positives, please file a bug against check-webkit-style.
WebKit Commit Bot
Comment 11 2015-05-04 11:39:18 PDT
Comment on attachment 252321 [details] Patch for landing Clearing flags on attachment: 252321 Committed r183752: <http://trac.webkit.org/changeset/183752>
WebKit Commit Bot
Comment 12 2015-05-04 11:39:22 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.