Closed Bug 773587 Opened 12 years ago Closed 12 years ago

IonMonkey: Assertion failure: isInt32(), at ../../jsapi.h:450

Categories

(Core :: JavaScript Engine, defect)

Other Branch
x86
Linux
defect
Not set
major

Tracking

()

RESOLVED FIXED

People

(Reporter: decoder, Assigned: jandem)

References

Details

(Keywords: assertion, testcase, Whiteboard: [jsbugmon:update])

Attachments

(1 file)

The following testcase asserts on ionmonkey revision a29f6c635516 (run with --ion -n -m --ion-eager): StrictEquality( true, new Boolean(true), false ); function StrictEquality( x, y, expect ) { result = ( x === y ); StrictEquality(y.environment !== Set.environment, true); }
Jan, it looks like the bug is that we're feeding a constant boolean into ToInt32(). It feels like handling that isn't a good fix though. The TypePolicy logic and lowering is kind of squirrelly and I kind of want to just refactor and separate out int32 from boolean specialization. Thoughts?
Attached patch Proposed fix (deleted) — Splinter Review
If TI knows a comparison is like bool === bool we will use specialization Int32 and lower to LCompare. If it's a strict comparison and we know one side is boolean, we use specialization Bool and lower to CompareB (Value === bool). Due to inlining etc, the MIR type may be more precise than what TI tells us, so if we have a Bool specialization we may still get two bool inputs and we want to switch the specialization to Int32 to match the first case (known bool === bool). The bug is that we don't want to return early in this case but want to insert MToInt32.
Assignee: general → jdemooij
Status: NEW → ASSIGNED
Attachment #643290 - Flags: review?(dvander)
Attachment #643290 - Flags: review?(dvander) → review+
Status: ASSIGNED → RESOLVED
Closed: 12 years ago
Resolution: --- → FIXED
A testcase for this bug was automatically identified at js/src/jit-test/tests/ion/bug773587.js.
Flags: in-testsuite+
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: