hablich [Sun, 17 May 2015 06:08:31 +0000 (23:08 -0700)]
Update version to 4.5
BUG=
TBR=machenbach@chromium.org
NOTRY=true
Review URL: https://codereview.chromium.org/
1123393006
Cr-Commit-Position: refs/heads/master@{#28435}
v8-autoroll [Sun, 17 May 2015 03:24:58 +0000 (20:24 -0700)]
Update V8 DEPS.
Rolling v8/tools/clang to
ec43def7c912c4a6bfadaf9e500bfb05da263f6f
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1139293002
Cr-Commit-Position: refs/heads/master@{#28434}
v8-autoroll [Sat, 16 May 2015 03:26:39 +0000 (20:26 -0700)]
Update V8 DEPS.
Rolling v8/third_party/icu to
5788e2736b3bc642994b6351a6096124895afa01
Rolling v8/tools/clang to
e11ef3ee3eecde207b8a38916b34fde40352f466
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1138003006
Cr-Commit-Position: refs/heads/master@{#28433}
yangguo [Fri, 15 May 2015 22:51:08 +0000 (15:51 -0700)]
Debugger: preserve stepping state after evaluating breakpoint condition.
R=ulan@chromium.org, yurys@chromium.org
BUG=chromium:467180
LOG=N
Review URL: https://codereview.chromium.org/
1132643004
Cr-Commit-Position: refs/heads/master@{#28432}
mbrandy [Fri, 15 May 2015 17:41:08 +0000 (10:41 -0700)]
PPC: Now that vector ics are established for load, keyed load and call ics, let's remove dead code behind the flag.
Port
323ced9e272e234d19db13d407b5bb9da266681d
R=mvstanton@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1132513007
Cr-Commit-Position: refs/heads/master@{#28431}
hpayer [Fri, 15 May 2015 17:04:48 +0000 (10:04 -0700)]
Clean-up aligned allocation logic.
BUG=
Review URL: https://codereview.chromium.org/
1138643005
Cr-Commit-Position: refs/heads/master@{#28430}
hpayer [Fri, 15 May 2015 16:08:47 +0000 (09:08 -0700)]
Shrink active semi-space and uncommit other semi-space only in idle memory mode.
BUG=chromium:483147
LOG=n
Review URL: https://codereview.chromium.org/
1140693003
Cr-Commit-Position: refs/heads/master@{#28429}
hpayer [Fri, 15 May 2015 16:06:21 +0000 (09:06 -0700)]
Make sure that idle scavenges are just performed when enough objects are allocated in new space.
BUG=
Review URL: https://codereview.chromium.org/
1138643003
Cr-Commit-Position: refs/heads/master@{#28428}
domenic [Fri, 15 May 2015 15:32:54 +0000 (08:32 -0700)]
Fix V8 extras js2c pipeline
570fca61 introduced a regression that caused minification etc. to be
applied to V8 extras.
R=yangguo@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1125103003
Cr-Commit-Position: refs/heads/master@{#28427}
arv [Fri, 15 May 2015 15:09:46 +0000 (08:09 -0700)]
[es6] Iterators and generators should "extend" %IteratorPrototype%
All the builtin iterators as well as the generator objects have an
object called %IteratorPrototype% in the spec between them and
%ObjectPrototype%.
BUG=v8:3568
LOG=N
Review URL: https://codereview.chromium.org/
1128233008
Cr-Commit-Position: refs/heads/master@{#28426}
erikcorry [Fri, 15 May 2015 14:48:17 +0000 (07:48 -0700)]
Remove release-mode assert that has out-stayed its welcome
R=hpayer@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1127333004
Cr-Commit-Position: refs/heads/master@{#28425}
yangguo [Fri, 15 May 2015 13:57:36 +0000 (06:57 -0700)]
Add regression test for resolving "this" in debug evaluate.
R=hablich@chromium.org
BUG=chromium:487289
LOG=N
Review URL: https://codereview.chromium.org/
1137293002
Cr-Commit-Position: refs/heads/master@{#28424}
yangguo [Fri, 15 May 2015 13:32:32 +0000 (06:32 -0700)]
Migrate error messages, part 11.
R=mvstanton@chromium.org
Review URL: https://codereview.chromium.org/
1140053002
Cr-Commit-Position: refs/heads/master@{#28423}
mvstanton [Fri, 15 May 2015 13:25:25 +0000 (06:25 -0700)]
Now that vector ics are established for load, keyed load and call ics, let's remove dead code behind the flag.
BUG=
Review URL: https://codereview.chromium.org/
1129853002
Cr-Commit-Position: refs/heads/master@{#28422}
mvstanton [Fri, 15 May 2015 13:05:08 +0000 (06:05 -0700)]
Bug: Runtime_GrowArrayElements provoked unnecessary lazy deopt.
Unnecessary, and unhandled as well.
BUG=488398
R=jarin@chromium.org
LOG=N
Review URL: https://codereview.chromium.org/
1141163004
Cr-Commit-Position: refs/heads/master@{#28421}
yangguo [Fri, 15 May 2015 13:00:31 +0000 (06:00 -0700)]
Store fewer arrays in the context snapshot.
This slightly reduces the initial context size.
R=ishell@chromium.org
Review URL: https://codereview.chromium.org/
1146523002
Cr-Commit-Position: refs/heads/master@{#28420}
bmeurer [Fri, 15 May 2015 12:17:15 +0000 (05:17 -0700)]
[turbofan] Pass closure as node to FrameState.
First step towards support for inlining based on SharedFunctionInfo
instead of JSFunction.
R=jarin@chromium.org
Review URL: https://codereview.chromium.org/
1134713004
Cr-Commit-Position: refs/heads/master@{#28419}
ishell [Fri, 15 May 2015 10:40:04 +0000 (03:40 -0700)]
Map::ReconfigureProperty() should mark map as unstable when there is an element kind transition somewhere in the middle of the transition tree.
BUG=chromium:485548
LOG=N
Review URL: https://codereview.chromium.org/
1128043005
Cr-Commit-Position: refs/heads/master@{#28418}
dslomov [Fri, 15 May 2015 09:56:31 +0000 (02:56 -0700)]
[destructuring] Adapting PatternRewriter to work in C-style for-statements.
BUG=v8:811
LOG=N
Review URL: https://codereview.chromium.org/
1128043006
Cr-Commit-Position: refs/heads/master@{#28417}
hpayer [Fri, 15 May 2015 07:48:16 +0000 (00:48 -0700)]
When context disposal rate is high and we cannot perform a full GC, we do nothing until the context disposal rate becomes lower.
BUG=chromium:473351
LOG=n
Review URL: https://codereview.chromium.org/
1118303004
Cr-Commit-Position: refs/heads/master@{#28416}
yangguo [Fri, 15 May 2015 07:42:40 +0000 (00:42 -0700)]
Reland "Prevent stack overflow in the serializer/deserializer."
TBR=mvstanton@chromium.org
Review URL: https://codereview.chromium.org/
1124403006
Cr-Commit-Position: refs/heads/master@{#28415}
jochen [Fri, 15 May 2015 07:37:15 +0000 (00:37 -0700)]
Remove static logging of memory allocations
We want to move to a world where there's no Isolate::Current but we
always knows which isolate we're in. There's no way we can teach this
info to the C++ allocator.
BUG=none
R=hpayer@chromium.org
LOG=n
Review URL: https://codereview.chromium.org/
1128023005
Cr-Commit-Position: refs/heads/master@{#28414}
paul.lind [Fri, 15 May 2015 06:49:46 +0000 (23:49 -0700)]
Fix Heap::AllocateFillerObject() to use double alignment param.
This is called from Runtime, and was dropping the requested alignment
for doubles. Needed for upcoming MIPS CL to remove some more
workarounds for load/store doubles.
BUG=
Review URL: https://codereview.chromium.org/
1131123003
Cr-Commit-Position: refs/heads/master@{#28413}
martyn.capewell [Fri, 15 May 2015 05:13:15 +0000 (22:13 -0700)]
ARM64: Enable shorten-64-to-32 warning
Enable clang's shorten-64-to-32 warning flag on ARM64, and fix the warnings
that arise.
BUG=
Review URL: https://codereview.chromium.org/
1131573006
Cr-Commit-Position: refs/heads/master@{#28412}
v8-autoroll [Fri, 15 May 2015 03:25:10 +0000 (20:25 -0700)]
Update V8 DEPS.
Rolling v8/tools/clang to
50042056ee1589e57bdb6ecba4609a7da51c7ec4
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1136353003
Cr-Commit-Position: refs/heads/master@{#28411}
jochen [Fri, 15 May 2015 02:08:58 +0000 (19:08 -0700)]
Remove Isolate::Current() call from jsregexp
BUG=none
R=vogelheim@chromium.org
LOG=n
Review URL: https://codereview.chromium.org/
1143583002
Cr-Commit-Position: refs/heads/master@{#28410}
dehrenberg [Fri, 15 May 2015 02:03:47 +0000 (19:03 -0700)]
Test that TypedArray methods don't read length
ES6 specifies that methods on TypedArrays reference an internal length
slot, rather than their length property. This patch tests that for the
TypedArray methods that exist currently.
R=arv@chromium.org
BUG=v8:3578
LOG=Y
Review URL: https://codereview.chromium.org/
1130413010
Cr-Commit-Position: refs/heads/master@{#28409}
jochen [Fri, 15 May 2015 01:49:33 +0000 (18:49 -0700)]
Remove unnecessary Isolate::Current calls from hydrogen-instructions
BUG=none
R=vogelheim@chromium.org
LOG=n
Review URL: https://codereview.chromium.org/
1144523004
Cr-Commit-Position: refs/heads/master@{#28408}
jochen [Fri, 15 May 2015 01:48:25 +0000 (18:48 -0700)]
Fix deprecation declarations in headers
BUG=none
R=ulan@chromium.org
LOG=n
Review URL: https://codereview.chromium.org/
1127963005
Cr-Commit-Position: refs/heads/master@{#28407}
jochen [Fri, 15 May 2015 01:47:15 +0000 (18:47 -0700)]
Remove unnecessary call to Isolate::Current in parser-shell
R=vogelheim@chromium.org
BUG=none
LOG=n
Review URL: https://codereview.chromium.org/
1123203003
Cr-Commit-Position: refs/heads/master@{#28406}
caitpotter88 [Thu, 14 May 2015 22:59:22 +0000 (15:59 -0700)]
[es6] support spread-calling Super-accessing properties
BUG=v8:4105, v8:3018
LOG=N
R=arv@chromium.org
Review URL: https://codereview.chromium.org/
1132933003
Cr-Commit-Position: refs/heads/master@{#28405}
paul.lind [Thu, 14 May 2015 18:44:46 +0000 (11:44 -0700)]
Revert of MIPS: Add float instructions and test coverage, part one
Reason for revert:
Simulator test failures in RunChangeFloat64ToInt.., RunChangeTaggedToInt32,
div-mul-minus-one
Original issue's description:
> Implement assembler, disassembler tests for all instructions for mips32
> and mips64. Additionally, add missing single precision float instructions
> for r2 and r6 architecture variants in assembler, simulator and disassembler
> with corresponding tests.
BUG=
Review URL: https://codereview.chromium.org/
1143473003
Cr-Commit-Position: refs/heads/master@{#28404}
machenbach [Thu, 14 May 2015 14:59:30 +0000 (07:59 -0700)]
Revert of Prevent stack overflow in the serializer/deserializer. (patchset #6 id:100001 of https://codereview.chromium.org/
1125073004/)
Reason for revert:
[Sheriff] Breaks msan:
http://build.chromium.org/p/client.v8/builders/V8%20Linux%20-%20arm64%20-%20sim%20-%20MSAN/builds/2266
Original issue's description:
> Prevent stack overflow in the serializer/deserializer.
>
> We keep an eye on the recursion depth. Once it exceeds a limit, we serialize
> only the object header and size, but defer serializing the object body for
> after we have unwound the stack.
>
> R=mvstanton@chromium.org
>
> Committed: https://crrev.com/
36b4a498d6614243454d5a182e4946b0dad24f0a
> Cr-Commit-Position: refs/heads/master@{#28385}
TBR=mvstanton@chromium.org,yangguo@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Review URL: https://codereview.chromium.org/
1139113002
Cr-Commit-Position: refs/heads/master@{#28403}
Djordje.Pesic [Thu, 14 May 2015 14:02:40 +0000 (07:02 -0700)]
MIPS: Add float instructions and test coverage, part one
Implement assembler, disassembler tests for all instructions for mips32 and mips64. Additionally, add missing single precision float instructions for r2 and r6 architecture variants in assembler, simulator and disassembler with corresponding tests.
Review URL: https://codereview.chromium.org/
1119203003
Cr-Commit-Position: refs/heads/master@{#28402}
chunyang.dai [Thu, 14 May 2015 09:22:57 +0000 (02:22 -0700)]
Revert "X87: Resolve references to "this" the same way as normal variables"
This reverts commit
6eea252463648d81cf3ae128e6f0d5f815a108bb.
revert reason:
original patch is reverted.
BUG=
Review URL: https://codereview.chromium.org/
1130853007
Cr-Commit-Position: refs/heads/master@{#28401}
v8-autoroll [Thu, 14 May 2015 03:26:16 +0000 (20:26 -0700)]
Update V8 DEPS.
Rolling v8/testing/gtest to
23574bf2333f834ff665f894c97bef8a5b33a0a9
Rolling v8/tools/clang to
17e168207560f2dfdf95e50c5eb79e6d3ac1eaf6
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1136913007
Cr-Commit-Position: refs/heads/master@{#28400}
titzer [Wed, 13 May 2015 16:08:03 +0000 (09:08 -0700)]
[turbofan] Treat uninitialized source positions as unknown.
R=mstarzinger@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1109763002
Cr-Commit-Position: refs/heads/master@{#28399}
titzer [Wed, 13 May 2015 13:50:41 +0000 (06:50 -0700)]
[turbofan] Reenable feedback for LoadNamed.
R=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1140943003
Cr-Commit-Position: refs/heads/master@{#28398}
wingo [Wed, 13 May 2015 13:32:27 +0000 (06:32 -0700)]
Rely on ExpressionClassifier to match valid arrow function formals
R=dslomov@chromium.org
LOG=N
BUG=
Review URL: https://codereview.chromium.org/
1123383005
Cr-Commit-Position: refs/heads/master@{#28397}
rossberg [Wed, 13 May 2015 13:31:19 +0000 (06:31 -0700)]
[strong] Introduce strong bit
Only set on strong functions so far to test basic operation.
R=dslomov@chromium.org
BUG=v8:3956
LOG=N
Review URL: https://codereview.chromium.org/
1138243002
Cr-Commit-Position: refs/heads/master@{#28396}
yangguo [Wed, 13 May 2015 13:30:06 +0000 (06:30 -0700)]
Revert "Resolve references to "this" the same way as normal variables"
... and the following two
"PPC: Resolve references to "this" the same way as normal variables"
"Remove Scope::scope_uses_this_ flag"
R=hablich@chromium.org
BUG=chromium:487289
LOG=N
Review URL: https://codereview.chromium.org/
1134003003
Cr-Commit-Position: refs/heads/master@{#28395}
Ben L. Titzer [Wed, 13 May 2015 13:08:25 +0000 (15:08 +0200)]
[turbofan] Turn off type feedback in turbo mode until StoreNamed issue is resolved.
TBR=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1130073006
Cr-Commit-Position: refs/heads/master@{#28394}
bmeurer [Wed, 13 May 2015 12:53:54 +0000 (05:53 -0700)]
[turbofan] Lower more number operations to integer operations.
If the typer was able to prove that a NumberAdd/Sub/Mul/Div/Mod always
produces a Signed32/Unsigned32 value, and the inputs are
Signed32/Unsigned32, we can lower the node to the corresponding integer
operation instead, no matter what the uses are.
R=jarin@chromium.org
Review URL: https://codereview.chromium.org/
1140933002
Cr-Commit-Position: refs/heads/master@{#28393}
titzer [Wed, 13 May 2015 12:29:38 +0000 (05:29 -0700)]
[turbofan] Add FrameStates before all property accesses.
R=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1133303006
Cr-Commit-Position: refs/heads/master@{#28392}
wingo [Wed, 13 May 2015 11:45:04 +0000 (04:45 -0700)]
Use ExpressionClassifier to identify valid arrow function formals
R=dslomov@chromium.org
LOG=N
BUG=
Review URL: https://codereview.chromium.org/
1138153003
Cr-Commit-Position: refs/heads/master@{#28391}
chunyang.dai [Wed, 13 May 2015 11:18:41 +0000 (04:18 -0700)]
X87: Resolve references to "this" the same way as normal variables
port
bd56d279b612f92d2d1d25f92d32fe7f42a455ca (R28340).
original commit message:
Make the parser handle references to "this" as unresolved variables, so the
same logic as for the rest of function parameters is used for the receiver.
Minor additions to the code generation handle copying the receiver to the
context, along with the rest of the function parameters.
Based on work by Adrian Perez de Castro <aperez@igalia.com>.
BUG=
Review URL: https://codereview.chromium.org/
1136953010
Cr-Commit-Position: refs/heads/master@{#28390}
bmeurer [Wed, 13 May 2015 11:17:31 +0000 (04:17 -0700)]
[turbofan] Use frame state before for shift operations as well.
This was already done for other binary operations, so it's basically
copying the existing functionality to shift left and shift right
logical/arithmetic.
R=jarin@chromium.org
Review URL: https://codereview.chromium.org/
1140883003
Cr-Commit-Position: refs/heads/master@{#28389}
chunyang.dai [Wed, 13 May 2015 11:16:25 +0000 (04:16 -0700)]
X87: New hydrogen instruction to reduce cost of growing an array on keyed stores.
port
3bce9c3afbe792167a54db49b16679289e0aea8f (r28359).
original commit message:
HMaybeGrowElements moves the situation where you actually have to grow
into deferred code. This means crankshaft doesn't have to spill registers
just to make the bounds comparison to see if it'll need to grow or not.
It makes the growing case a bit more expensive, but reduces the cost of
the general case.
BUG=
Review URL: https://codereview.chromium.org/
1124093008
Cr-Commit-Position: refs/heads/master@{#28388}
chunyang.dai [Wed, 13 May 2015 11:15:42 +0000 (04:15 -0700)]
X87: [strong] Check arity of functions
port
3226e980200035f37c86fef4b11fb307e17764a2 (28346).
original commit message:
[strong] Check arity of functions
In strong mode it is an error to call a function with too few
arguments.
This is enforced inside the ArgumentsAdaptorTrampoline.
This does not yet handle rest parameter
BUG=
Review URL: https://codereview.chromium.org/
1139913007
Cr-Commit-Position: refs/heads/master@{#28387}
chunyang.dai [Wed, 13 May 2015 11:14:35 +0000 (04:14 -0700)]
X87: Add a MathFloor stub generated with TurboFan
port
abc35080b33cc31e47b9913e64ac99ec687c6b65 (r28339)
original commit message:
This stub will be used as the basis of a Math.floor-specific CallIC to
detect and track calls to floor that return -0.
Along the way:
- Create a TurboFanCodeStub super class from which the StringLength and
MathRound TF stubs derive.
- Fix the ugly hack that passes the first stub parameter as the "this"
pointer in the the TF-compiled JS function.
- Fix bugs in the ia32/x64 disassembler.
BUG=
Review URL: https://codereview.chromium.org/
1134323002
Cr-Commit-Position: refs/heads/master@{#28386}
yangguo [Wed, 13 May 2015 10:18:35 +0000 (03:18 -0700)]
Prevent stack overflow in the serializer/deserializer.
We keep an eye on the recursion depth. Once it exceeds a limit, we serialize
only the object header and size, but defer serializing the object body for
after we have unwound the stack.
R=mvstanton@chromium.org
Review URL: https://codereview.chromium.org/
1125073004
Cr-Commit-Position: refs/heads/master@{#28385}
machenbach [Wed, 13 May 2015 10:00:43 +0000 (03:00 -0700)]
[test] Make perf runner able to pass extra flags to d8.
TEST=tools/run_perf.py --arch x64 --extra-flags="--turbo --turbo-verify-allocation --turbo-greedy-regalloc" /path/to/SunSpider.json
BUG=484208
LOG=n
TBR=tandrii@chromium.org
NOTRY=true
Review URL: https://codereview.chromium.org/
1128933007
Cr-Commit-Position: refs/heads/master@{#28384}
bmeurer [Wed, 13 May 2015 07:38:42 +0000 (00:38 -0700)]
[turbofan] Add frame state before JavaScript comparisons.
Use these check points to optimize comparisons where we already know
that one side cannot be a String (or turn into a string via
ToPrimitive).
Also remove bunch of useless DoNotCrash tests for the scheduler that are
painful to maintain and add almost no value.
R=jarin@chromium.org
Review URL: https://codereview.chromium.org/
1140583004
Cr-Commit-Position: refs/heads/master@{#28383}
dehrenberg [Wed, 13 May 2015 04:32:12 +0000 (21:32 -0700)]
Implement %TypedArray%.{fill,find,findIndex}
This patch adds three methods to TypedArrays which are already
implemented for arrays. The implementations are made by calling
out to the underlying code used by Arrays.
R=adamk@chromium.org
BUG=v8:3578
LOG=Y
Review URL: https://codereview.chromium.org/
1136663005
Cr-Commit-Position: refs/heads/master@{#28382}
dehrenberg [Tue, 12 May 2015 19:20:58 +0000 (12:20 -0700)]
TypedArray.prototype.copyWithin method
This patch adds the copyWithin method to TypedArrays. For the first
pass, the internals of Array.copyWithin are used. Eventually, a more
efficient form based on memcpy could be used instead.
BUG=v8:3578
LOG=Y
R=adamk@chromium.org, arv@chromium.org, caitpotter88@gmail.com
Review URL: https://codereview.chromium.org/
1131113002
Cr-Commit-Position: refs/heads/master@{#28381}
dslomov [Tue, 12 May 2015 18:12:56 +0000 (11:12 -0700)]
Fix test formatting
TBR=arv@chromium.org
Review URL: https://codereview.chromium.org/
1129713004
Cr-Commit-Position: refs/heads/master@{#28380}
arv [Tue, 12 May 2015 17:37:34 +0000 (10:37 -0700)]
[strong] Add more function arity tests
This is a follow up to https://codereview.chromium.org/
1115263004/
BUG=v8:3956
LOG=N
R=rossberg@chromium.org
Review URL: https://codereview.chromium.org/
1141603002
Cr-Commit-Position: refs/heads/master@{#28379}
ulan [Tue, 12 May 2015 17:25:04 +0000 (10:25 -0700)]
Make transition to reduce memory mode more conservative in idle time handler.
BUG=chromium:486005
LOG=NO
Review URL: https://codereview.chromium.org/
1131943004
Cr-Commit-Position: refs/heads/master@{#28378}
dslomov [Tue, 12 May 2015 17:13:12 +0000 (10:13 -0700)]
Fix the behavior of 'super.foo' assignment when receiver is not an object.
R=arv@chromium.org,verwaest@chromium.org
BUG=v8:4097
LOG=N
Review URL: https://codereview.chromium.org/
1132203005
Cr-Commit-Position: refs/heads/master@{#28377}
mvstanton [Tue, 12 May 2015 16:51:14 +0000 (09:51 -0700)]
Make LoadFastElementStub a HandlerStub.
BUG=
Review URL: https://codereview.chromium.org/
1132493006
Cr-Commit-Position: refs/heads/master@{#28376}
mbrandy [Tue, 12 May 2015 16:48:16 +0000 (09:48 -0700)]
PPC: Fix '[strong] Disallow implicit conversions for comparison'
Do not trash type register in kIsNotStringMask test.
R=conradw@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1124333013
Cr-Commit-Position: refs/heads/master@{#28375}
mbrandy [Tue, 12 May 2015 16:43:24 +0000 (09:43 -0700)]
PPC: Fix '[strong] Disallow implicit conversions for comparison'
Fix build break.
R=conradw@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1130603004
Cr-Commit-Position: refs/heads/master@{#28374}
hpayer [Tue, 12 May 2015 15:48:04 +0000 (08:48 -0700)]
Get more debugging data when crashing in Deoptimizer::GetOutputInfo.
BUG=
Review URL: https://codereview.chromium.org/
1138493004
Cr-Commit-Position: refs/heads/master@{#28373}
mbrandy [Tue, 12 May 2015 15:42:39 +0000 (08:42 -0700)]
PPC: New hydrogen instruction to reduce cost of growing an array on keyed stores.
Port
3bce9c3afbe792167a54db49b16679289e0aea8f
Original commit message:
HMaybeGrowElements moves the situation where you actually have to grow
into deferred code. This means crankshaft doesn't have to spill registers
just to make the bounds comparison to see if it'll need to grow or not.
It makes the growing case a bit more expensive, but reduces the cost of
the general case.
R=mvstanton@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1132743004
Cr-Commit-Position: refs/heads/master@{#28372}
yurys [Tue, 12 May 2015 15:40:31 +0000 (08:40 -0700)]
Provide accessor for object internal properties that doesn't require debugger to be active
Some of the DevTools' clients need to inspect JS objects without enabling debugger. This CL allows to inspect object's internal properties without enabling debugger and instantiating debug context.
Note that now debug context can be created lazily if v8::Debug::GetDebugContext is called when there is no debug listener. This is fragile and has already resulted in some subtle error. I'm going to fix that in a separate CL.
BUG=chromium:481845
LOG=Y
Review URL: https://codereview.chromium.org/
1134193002
Cr-Commit-Position: refs/heads/master@{#28371}
conradw [Tue, 12 May 2015 15:23:53 +0000 (08:23 -0700)]
[strong] Disallow implicit conversions for comparison
Implements the strong mode proposal's restrictions on implicit conversions
for the binary >, >=, <, and <= operators.
BUG=v8:3956
LOG=N
Review URL: https://codereview.chromium.org/
1130283002
Cr-Commit-Position: refs/heads/master@{#28370}
verwaest [Tue, 12 May 2015 15:11:18 +0000 (08:11 -0700)]
Mark internal AccessorInfo properties as "special data properties" to ensure correct strict-mode handling.
BUG=
Review URL: https://codereview.chromium.org/
1123163005
Cr-Commit-Position: refs/heads/master@{#28369}
yangguo [Tue, 12 May 2015 14:28:40 +0000 (07:28 -0700)]
Fix test-heap/BootstrapperExports on no-snap builds
NOTRY=true
NOTREECHECKS=true
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1137143003
Cr-Commit-Position: refs/heads/master@{#28368}
yangguo [Tue, 12 May 2015 14:00:47 +0000 (07:00 -0700)]
Reland "Use function wrapper argument to expose internal arrays to native scripts."
Review URL: https://codereview.chromium.org/
1138173002
Cr-Commit-Position: refs/heads/master@{#28367}
yangguo [Tue, 12 May 2015 13:52:26 +0000 (06:52 -0700)]
Migrate error messages, part 10.
R=mvstanton@chromium.org
Committed: https://crrev.com/
8608e619afe2b4514b0577bfb73a153b1550d41f
Cr-Commit-Position: refs/heads/master@{#28357}
Review URL: https://codereview.chromium.org/
1126043004
Cr-Commit-Position: refs/heads/master@{#28366}
yangguo [Tue, 12 May 2015 13:03:59 +0000 (06:03 -0700)]
Revert of Provide accessor for object internal properties that doesn't require debugger to be active (patchset #3 id:40001 of https://codereview.chromium.org/
1126103006/)
Reason for revert:
GC mole issues: https://chromegw.corp.google.com/i/client.v8/builders/V8%20Linux%20-%20gcmole/builds/1950/steps/GCMole%20ia32/logs/stdio
Original issue's description:
> Provide accessor for object internal properties that doesn't require debugger to be active
>
> Some of the DevTools' clients need to inspect JS objects without enabling debugger. This CL allows to inspect object's internal properties without enabling debugger and instantiating debug context.
>
> Note that now debug context can be created lazily if v8::Debug::GetDebugContext is called when there is no debug listener. This is fragile and has already resulted in some subtle error. I'm going to fix that in a separate CL.
>
> BUG=chromium:481845
> LOG=Y
>
> Committed: https://crrev.com/
bdeb0de88c8cf5f2c78f261b45314138f525110d
> Cr-Commit-Position: refs/heads/master@{#28362}
TBR=pfeldman@chromium.org,kozyatinskiy@chromium.org,yurys@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=chromium:481845
Review URL: https://codereview.chromium.org/
1133243002
Cr-Commit-Position: refs/heads/master@{#28365}
titzer [Tue, 12 May 2015 12:57:32 +0000 (05:57 -0700)]
[turbofan] Correctify FrameState before operations in JSTypeFeedbackSpecializer.
Handle missing or improper FrameStates more gracefully.
Uses the operator properties to determine if the node contains a FrameState
before, then checks if a valid bailout id exists.
R=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1135243002
Cr-Commit-Position: refs/heads/master@{#28364}
titzer [Tue, 12 May 2015 12:41:41 +0000 (05:41 -0700)]
[turbofan] Add AdvancedReducer::ReplaceWithValue() method and convert JSInlining to an AdvancedReducer.
Note that this is just a duplication for now. We'll want to get rid of the
NodeProperties::ReplaceWithValue() method in the long run.
R=bmeurer@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1135483004
Cr-Commit-Position: refs/heads/master@{#28363}
yurys [Tue, 12 May 2015 12:38:17 +0000 (05:38 -0700)]
Provide accessor for object internal properties that doesn't require debugger to be active
Some of the DevTools' clients need to inspect JS objects without enabling debugger. This CL allows to inspect object's internal properties without enabling debugger and instantiating debug context.
Note that now debug context can be created lazily if v8::Debug::GetDebugContext is called when there is no debug listener. This is fragile and has already resulted in some subtle error. I'm going to fix that in a separate CL.
BUG=chromium:481845
LOG=Y
Review URL: https://codereview.chromium.org/
1126103006
Cr-Commit-Position: refs/heads/master@{#28362}
titzer [Tue, 12 May 2015 12:30:27 +0000 (05:30 -0700)]
[turbofan] Use FrameStatesBeforeAndAfter to simplify handling of before/after frame states in AstGraphBuilder.
R=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1128193005
Cr-Commit-Position: refs/heads/master@{#28361}
hpayer [Tue, 12 May 2015 11:44:46 +0000 (04:44 -0700)]
Implement unaligned allocate and allocate heap numbers in runtime double unaligned.
In follow-up CLs the scavenger and the MC collector should also respect the unalignment of heap numbers.
BUG=
Review URL: https://codereview.chromium.org/
1141523002
Cr-Commit-Position: refs/heads/master@{#28360}
mvstanton [Tue, 12 May 2015 08:47:15 +0000 (01:47 -0700)]
New hydrogen instruction to reduce cost of growing an array on keyed stores.
HMaybeGrowElements moves the situation where you actually have to grow
into deferred code. This means crankshaft doesn't have to spill registers
just to make the bounds comparison to see if it'll need to grow or not.
It makes the growing case a bit more expensive, but reduces the cost of
the general case.
BUG=chromium:484025
LOG=N
Review URL: https://codereview.chromium.org/
1124443004
Cr-Commit-Position: refs/heads/master@{#28359}
yangguo [Tue, 12 May 2015 08:33:27 +0000 (01:33 -0700)]
Revert of Migrate error messages, part 10. (patchset #2 id:20001 of https://codereview.chromium.org/
1126043004/)
Reason for revert:
patch didn't apply correctly.
Original issue's description:
> Migrate error messages, part 10.
>
> R=mvstanton@chromium.org
>
> Committed: https://crrev.com/
8608e619afe2b4514b0577bfb73a153b1550d41f
> Cr-Commit-Position: refs/heads/master@{#28357}
TBR=mvstanton@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Review URL: https://codereview.chromium.org/
1130073005
Cr-Commit-Position: refs/heads/master@{#28358}
yangguo [Tue, 12 May 2015 08:16:55 +0000 (01:16 -0700)]
Migrate error messages, part 10.
R=mvstanton@chromium.org
Review URL: https://codereview.chromium.org/
1126043004
Cr-Commit-Position: refs/heads/master@{#28357}
yurys [Tue, 12 May 2015 07:33:21 +0000 (00:33 -0700)]
Don't create debug context if debug listener is not set
If there had been no debug listener v8::Debug::GetDebugContext would have created new context and wouln't have kept reference to it. This way we may well end up with several debug contexts and disabled debugger.
As a side effect this change allows to efficiently distinguish debug context from blink contexts by simply comparing handles.
BUG=chromium:482290
LOG=Y
Review URL: https://codereview.chromium.org/
1136733002
Cr-Commit-Position: refs/heads/master@{#28356}
yangguo [Tue, 12 May 2015 07:26:05 +0000 (00:26 -0700)]
Revert of Use function wrapper argument to expose internal arrays to native scripts. (patchset #2 id:20001 of https://codereview.chromium.org/
1127983003/)
Reason for revert:
custom snapshot builder failing.
Original issue's description:
> Use function wrapper argument to expose internal arrays to native scripts.
>
> R=jkummerow@chromium.org
>
> Committed: https://crrev.com/
a9b5a1795449d94387218d25baed2c2b3c4fbadc
> Cr-Commit-Position: refs/heads/master@{#28354}
TBR=jkummerow@chromium.org
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
Review URL: https://codereview.chromium.org/
1123353008
Cr-Commit-Position: refs/heads/master@{#28355}
yangguo [Tue, 12 May 2015 06:14:17 +0000 (23:14 -0700)]
Use function wrapper argument to expose internal arrays to native scripts.
R=jkummerow@chromium.org
Review URL: https://codereview.chromium.org/
1127983003
Cr-Commit-Position: refs/heads/master@{#28354}
jochen [Tue, 12 May 2015 04:59:46 +0000 (21:59 -0700)]
Deprecate Isolate::New
Embedders need to always pass CreateParams now
BUG=none
LOG=y
R=vogelheim@chromium.org
Review URL: https://codereview.chromium.org/
1133723004
Cr-Commit-Position: refs/heads/master@{#28353}
v8-autoroll [Tue, 12 May 2015 03:24:43 +0000 (20:24 -0700)]
Update V8 DEPS.
Rolling v8/buildtools to
b73e5f70d7ac6be98fb2555461f631afc90216ce
Rolling v8/third_party/icu to
ce41627e388fb46ab49671bd16a5db81dcd75a71
Rolling v8/tools/clang to
6e259b4afbbd784a775e47f37379e57f002bf0c2
TBR=machenbach@chromium.org
Review URL: https://codereview.chromium.org/
1124083005
Cr-Commit-Position: refs/heads/master@{#28352}
dehrenberg [Tue, 12 May 2015 01:32:26 +0000 (18:32 -0700)]
Factor out core of Array.forEach and .every, for use in TypedArrays
The idea is to make this the model for future TypedArray methods.
A possible downside could be lower array method performance
if everything gets polymorhpic (but if enough inlining happens, it
should still be fast), but on the upside, this change means that
the TypedArray methods won't create as much code size bloat.
BUG=v8:3578
LOG=Y
R=adamk@chromium.org
CC=arv@chromium.org, caitpotter88@gmail.com
Review URL: https://codereview.chromium.org/
1133503003
Cr-Commit-Position: refs/heads/master@{#28351}
akos.palfi [Mon, 11 May 2015 23:07:43 +0000 (16:07 -0700)]
MIPS64: Improve '[strong] Check arity of functions'
Port
3226e980200035f37c86fef4b11fb307e17764a2
BUG=
Review URL: https://codereview.chromium.org/
1129323007
Cr-Commit-Position: refs/heads/master@{#28350}
caitpotter88 [Mon, 11 May 2015 22:53:41 +0000 (15:53 -0700)]
[es6] stage Object.assign() / --harmony-object
BUG=v8:4007
LOG=N
R=
Review URL: https://codereview.chromium.org/
1128873006
Cr-Commit-Position: refs/heads/master@{#28349}
mbrandy [Mon, 11 May 2015 19:08:49 +0000 (12:08 -0700)]
PPC: [strong] Check arity of functions
Port
3226e980200035f37c86fef4b11fb307e17764a2
Original commit message:
In strong mode it is an error to call a function with too few
arguments.
This is enforced inside the ArgumentsAdaptorTrampoline.
This does not yet handle rest parameters
R=arv@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1132153003
Cr-Commit-Position: refs/heads/master@{#28348}
paul.lind [Mon, 11 May 2015 18:49:54 +0000 (11:49 -0700)]
MIPS: Fix Add a MathFloor stub generated with TurboFan.
Port
abc35080b33cc31e47b9913e64ac99ec687c6b65
BUG=
Review URL: https://codereview.chromium.org/
1133103003
Cr-Commit-Position: refs/heads/master@{#28347}
arv [Mon, 11 May 2015 17:20:43 +0000 (10:20 -0700)]
[strong] Check arity of functions
In strong mode it is an error to call a function with too few
arguments.
This is enforced inside the ArgumentsAdaptorTrampoline.
This does not yet handle rest parameters
BUG=v8:3956
LOG=N
R=rossberg@chromium.org, dslomov@chromium.org
Review URL: https://codereview.chromium.org/
1115263004
Cr-Commit-Position: refs/heads/master@{#28346}
dslomov [Mon, 11 May 2015 16:28:28 +0000 (09:28 -0700)]
[destructuring] Implement basic binding destructuring infrastructure
This patch:
- Refactors Parser::ParseVariableDeclarations
- Introduces Parser::PatternMatcher class
- Implements matching a single variable pattern
- Implements rudimentary matching against object literal pattern
as a proof of concept
R=arv@chromium.org,rossberg@chromium.org
BUG=v8:811
LOG=N
Review URL: https://codereview.chromium.org/
1130623004
Cr-Commit-Position: refs/heads/master@{#28345}
titzer [Mon, 11 May 2015 15:56:07 +0000 (08:56 -0700)]
Add a bailout id just before every variable load in fullcode.
R=jarin@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1139733002
Cr-Commit-Position: refs/heads/master@{#28344}
wingo [Mon, 11 May 2015 15:42:19 +0000 (08:42 -0700)]
Remove Scope::scope_uses_this_ flag
R=rossberg@chromium.org
LOG=N
BUG=
Review URL: https://codereview.chromium.org/
1128963005
Cr-Commit-Position: refs/heads/master@{#28343}
mbrandy [Mon, 11 May 2015 14:34:31 +0000 (07:34 -0700)]
PPC: Resolve references to "this" the same way as normal variables
Port
bd56d279b612f92d2d1d25f92d32fe7f42a455ca
Original commit message:
Make the parser handle references to "this" as unresolved variables, so the
same logic as for the rest of function parameters is used for the receiver.
Minor additions to the code generation handle copying the receiver to the
context, along with the rest of the function parameters.
Based on work by Adrian Perez de Castro <aperez@igalia.com>.
This is a reapplication of https://codereview.chromium.org/
1130733003.
R=wingo@igalia.com, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1134073003
Cr-Commit-Position: refs/heads/master@{#28342}
mbrandy [Mon, 11 May 2015 14:33:27 +0000 (07:33 -0700)]
PPC: Add a MathFloor stub generated with TurboFan
Port
abc35080b33cc31e47b9913e64ac99ec687c6b65
Original commit message:
This stub will be used as the basis of a Math.floor-specific CallIC to
detect and track calls to floor that return -0.
Along the way:
- Create a TurboFanCodeStub super class from which the StringLength and
MathRound TF stubs derive.
- Fix the ugly hack that passes the first stub parameter as the "this"
pointer in the the TF-compiled JS function.
- Fix bugs in the ia32/x64 disassembler.
R=danno@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=
Review URL: https://codereview.chromium.org/
1137033002
Cr-Commit-Position: refs/heads/master@{#28341}
wingo [Mon, 11 May 2015 11:49:48 +0000 (04:49 -0700)]
Resolve references to "this" the same way as normal variables
Make the parser handle references to "this" as unresolved variables, so the
same logic as for the rest of function parameters is used for the receiver.
Minor additions to the code generation handle copying the receiver to the
context, along with the rest of the function parameters.
Based on work by Adrian Perez de Castro <aperez@igalia.com>.
This is a reapplication of https://codereview.chromium.org/
1130733003.
R=rossberg@chromium.org
BUG=v8:2700
LOG=N
Review URL: https://codereview.chromium.org/
1136073002
Cr-Commit-Position: refs/heads/master@{#28340}
danno [Mon, 11 May 2015 11:45:02 +0000 (04:45 -0700)]
Add a MathFloor stub generated with TurboFan
This stub will be used as the basis of a Math.floor-specific CallIC to
detect and track calls to floor that return -0.
Along the way:
- Create a TurboFanCodeStub super class from which the StringLength and
MathRound TF stubs derive.
- Fix the ugly hack that passes the first stub parameter as the "this"
pointer in the the TF-compiled JS function.
- Fix bugs in the ia32/x64 disassembler.
Review URL: https://codereview.chromium.org/
1137703002
Cr-Commit-Position: refs/heads/master@{#28339}
titzer [Mon, 11 May 2015 11:28:50 +0000 (04:28 -0700)]
Add %GetUndetectable() test intrinsic and add tests for undetectables.
R=verwaest@chromium.org
BUG=
Review URL: https://codereview.chromium.org/
1132303003
Cr-Commit-Position: refs/heads/master@{#28338}
wingo [Mon, 11 May 2015 11:07:12 +0000 (04:07 -0700)]
Fix more -Werror=sign-compare bugs with GCC 4.9.2
R=svenpanne@chromium.org
LOG=N
BUG=
Review URL: https://codereview.chromium.org/
1128043002
Cr-Commit-Position: refs/heads/master@{#28337}
machenbach [Mon, 11 May 2015 11:03:50 +0000 (04:03 -0700)]
[test] Skip Slimming Paint layout tests.
Also make the expectation lint check happy.
TBR=jochen@chromium.org
NOTRY=true
Review URL: https://codereview.chromium.org/
1137993003
Cr-Commit-Position: refs/heads/master@{#28336}