Index: Source/core/dom/Text.cpp |
diff --git a/Source/core/dom/Text.cpp b/Source/core/dom/Text.cpp |
index c983fbd9874729c34dc3b92ddc3c86b7b47abf15..9db26bb8de3df3b6c77c654958f9fa5f0c32f1d2 100644 |
--- a/Source/core/dom/Text.cpp |
+++ b/Source/core/dom/Text.cpp |
@@ -42,13 +42,48 @@ |
namespace blink { |
+#if ENABLE(OILPAN) |
+namespace { |
+// If the external string kept by a Text node exceed this threshold length, |
haraken
2015/02/19 23:47:43
exceeds
|
+// Oilpan is informed. External allocation amounts owned by heap objects are |
+// taken into account when scheduling urgent Oilpan GCs. |
+// |
+// FIXME: having only Text nodes with strings above an ad-hoc local threshold |
+// influence Oilpan's GC behavior isn't a satisfactory long-term solution. |
+// But code that allocates a lot of Text nodes in tight loops, and not much more, |
+// we do have to trigger Oilpan GCs to avoid PartitionAlloc OOMs. The accounting |
+// does add overhead on the allocation of every Text node however, so for now, only |
+// register those above the given threshold. TBC. |
+const size_t stringLengthThreshold = 256; |
+ |
+enum RegistrationMode { AsNew, AsAlive }; |
+ |
+void registerExternalAllocation(size_t length, RegistrationMode mode) |
+{ |
+ if (length > stringLengthThreshold) { |
haraken
2015/02/19 23:47:43
Does it really make sense to have the threshold?
sof
2015/02/20 09:33:48
I added it to prevent having e.g. all smaller Text
haraken
2015/02/23 08:42:27
Mostly convinced but let me ask one more question:
sof
2015/02/23 09:13:37
The latter would entail an atomicAdd() which will
haraken
2015/02/23 09:26:34
Thanks, the current code looks reasonable to me.
|
+ if (mode == AsNew) |
+ Heap::increaseExternallyAllocatedBytes(length); |
+ else |
+ Heap::increaseExternallyAllocatedBytesAlive(length); |
+ } |
+} |
+ |
+} // namespace |
+#endif |
+ |
PassRefPtrWillBeRawPtr<Text> Text::create(Document& document, const String& data) |
{ |
+#if ENABLE(OILPAN) |
+ registerExternalAllocation(data.length(), AsNew); |
+#endif |
return adoptRefWillBeNoop(new Text(document, data, CreateText)); |
} |
PassRefPtrWillBeRawPtr<Text> Text::createEditingText(Document& document, const String& data) |
{ |
+#if ENABLE(OILPAN) |
+ registerExternalAllocation(data.length(), AsNew); |
+#endif |
return adoptRefWillBeNoop(new Text(document, data, CreateEditingText)); |
} |
@@ -408,6 +443,14 @@ PassRefPtrWillBeRawPtr<Text> Text::cloneWithData(const String& data) |
return create(document(), data); |
} |
+#if ENABLE(OILPAN) |
+void Text::trace(Visitor* visitor) |
+{ |
+ registerExternalAllocation(m_data.length(), AsAlive); |
+ CharacterData::trace(visitor); |
+} |
+#endif |
+ |
#ifndef NDEBUG |
void Text::formatForDebugger(char *buffer, unsigned length) const |
{ |