summaryrefslogtreecommitdiffstats
path: root/src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch
diff options
context:
space:
mode:
authorAaron Kennedy <aaron.kennedy@nokia.com>2011-10-11 14:27:48 +1000
committerQt by Nokia <qt-info@nokia.com>2011-10-11 07:02:14 +0200
commit27833629c6099fea4b7d59eb283748a12cb0d1da (patch)
treedc9ac17ff4e93129d784ce21d301ad9a5acd2fd3 /src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch
parent1fb5600c5eb2ee2af8a766dea5b325aee6dd43b4 (diff)
Update V8
Change-Id: I359ec3f57a120ebd02d03c56d0944397b5407ed8 Reviewed-on: http://codereview.qt-project.org/6386 Reviewed-by: Aaron Kennedy <aaron.kennedy@nokia.com> Sanity-Review: Aaron Kennedy <aaron.kennedy@nokia.com> Sanity-Review: Qt Sanity Bot <qt_sanity_bot@ovi.com>
Diffstat (limited to 'src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch')
-rw-r--r--src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch61
1 files changed, 61 insertions, 0 deletions
diff --git a/src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch b/src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch
new file mode 100644
index 0000000000..b6dde1e024
--- /dev/null
+++ b/src/v8/0016-Move-external-resource-to-the-last-hidden-field.patch
@@ -0,0 +1,61 @@
+From 8f15248619bb3bf49473dc3ede8a4e631bd5d199 Mon Sep 17 00:00:00 2001
+From: Aaron Kennedy <aaron.kennedy@nokia.com>
+Date: Tue, 4 Oct 2011 14:22:54 +1000
+Subject: [PATCH 16/16] Move external resource to the last hidden field
+
+---
+ src/objects-inl.h | 10 +++++-----
+ 1 files changed, 5 insertions(+), 5 deletions(-)
+
+diff --git a/src/objects-inl.h b/src/objects-inl.h
+index 1765441..c02e037 100644
+--- a/src/objects-inl.h
++++ b/src/objects-inl.h
+@@ -1398,7 +1398,7 @@ int JSObject::GetInternalFieldCount() {
+
+ int JSObject::GetInternalFieldOffset(int index) {
+ ASSERT(index < GetInternalFieldCount() && index >= 0);
+- return GetHeaderSize() + (kPointerSize * (index + map()->has_external_resource()?1:0));
++ return GetHeaderSize() + (kPointerSize * index);
+ }
+
+
+@@ -1407,7 +1407,7 @@ Object* JSObject::GetInternalField(int index) {
+ // Internal objects do follow immediately after the header, whereas in-object
+ // properties are at the end of the object. Therefore there is no need
+ // to adjust the index here.
+- return READ_FIELD(this, GetHeaderSize() + (kPointerSize * (index + map()->has_external_resource()?1:0)));
++ return READ_FIELD(this, GetHeaderSize() + (kPointerSize * index));
+ }
+
+
+@@ -1416,7 +1416,7 @@ void JSObject::SetInternalField(int index, Object* value) {
+ // Internal objects do follow immediately after the header, whereas in-object
+ // properties are at the end of the object. Therefore there is no need
+ // to adjust the index here.
+- int offset = GetHeaderSize() + (kPointerSize * (index + map()->has_external_resource()?1:0));
++ int offset = GetHeaderSize() + (kPointerSize * index);
+ WRITE_FIELD(this, offset, value);
+ WRITE_BARRIER(this, offset);
+ }
+@@ -1424,7 +1424,7 @@ void JSObject::SetInternalField(int index, Object* value) {
+
+ void JSObject::SetExternalResourceObject(Object *value) {
+ ASSERT(map()->has_external_resource());
+- int offset = GetHeaderSize();
++ int offset = GetHeaderSize() + kPointerSize * GetInternalFieldCount();
+ WRITE_FIELD(this, offset, value);
+ WRITE_BARRIER(this, offset);
+ }
+@@ -1432,7 +1432,7 @@ void JSObject::SetExternalResourceObject(Object *value) {
+
+ Object *JSObject::GetExternalResourceObject() {
+ if (map()->has_external_resource()) {
+- return READ_FIELD(this, GetHeaderSize());
++ return READ_FIELD(this, GetHeaderSize() + kPointerSize * GetInternalFieldCount());
+ } else {
+ return GetHeap()->undefined_value();
+ }
+--
+1.7.4.4
+