FastNewClosureStub failed to load the cached literals array.

Also, less efficient code was generated because of negative keyed load
offsets. I changed this to benefit from HLoadKeyed dehoisting.

BUG=v8:3185
LOG=N
R=yangguo@chromium.org

Review URL: https://codereview.chromium.org/184103004

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@19846 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent b6996007
This diff is collapsed.
...@@ -5924,18 +5924,6 @@ class HObjectAccess V8_FINAL { ...@@ -5924,18 +5924,6 @@ class HObjectAccess V8_FINAL {
return HObjectAccess(kInobject, SharedFunctionInfo::kCodeOffset); return HObjectAccess(kInobject, SharedFunctionInfo::kCodeOffset);
} }
static HObjectAccess ForFirstCodeSlot() {
return HObjectAccess(kInobject, SharedFunctionInfo::kFirstCodeSlot);
}
static HObjectAccess ForFirstContextSlot() {
return HObjectAccess(kInobject, SharedFunctionInfo::kFirstContextSlot);
}
static HObjectAccess ForFirstOsrAstIdSlot() {
return HObjectAccess(kInobject, SharedFunctionInfo::kFirstOsrAstIdSlot);
}
static HObjectAccess ForOptimizedCodeMap() { static HObjectAccess ForOptimizedCodeMap() {
return HObjectAccess(kInobject, return HObjectAccess(kInobject,
SharedFunctionInfo::kOptimizedCodeMapOffset); SharedFunctionInfo::kOptimizedCodeMapOffset);
......
...@@ -6696,13 +6696,6 @@ class SharedFunctionInfo: public HeapObject { ...@@ -6696,13 +6696,6 @@ class SharedFunctionInfo: public HeapObject {
static const int kLiteralsOffset = 2; static const int kLiteralsOffset = 2;
static const int kOsrAstIdOffset = 3; static const int kOsrAstIdOffset = 3;
static const int kEntryLength = 4; static const int kEntryLength = 4;
static const int kFirstContextSlot = FixedArray::kHeaderSize +
(kEntriesStart + kContextOffset) * kPointerSize;
static const int kFirstCodeSlot = FixedArray::kHeaderSize +
(kEntriesStart + kCachedCodeOffset) * kPointerSize;
static const int kFirstOsrAstIdSlot = FixedArray::kHeaderSize +
(kEntriesStart + kOsrAstIdOffset) * kPointerSize;
static const int kSecondEntryIndex = kEntryLength + kEntriesStart;
static const int kInitialLength = kEntriesStart + kEntryLength; static const int kInitialLength = kEntriesStart + kEntryLength;
// [scope_info]: Scope info. // [scope_info]: Scope info.
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment