Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009, 2010 Google Inc. All rights reserved. | 2 * Copyright (C) 2009, 2010 Google Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions are | 5 * modification, are permitted provided that the following conditions are |
| 6 * met: | 6 * met: |
| 7 * | 7 * |
| 8 * * Redistributions of source code must retain the above copyright | 8 * * Redistributions of source code must retain the above copyright |
| 9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
| 10 * * Redistributions in binary form must reproduce the above | 10 * * Redistributions in binary form must reproduce the above |
| (...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 121 static std::unique_ptr<ArrayBufferContentsArray> transferArrayBufferContents( | 121 static std::unique_ptr<ArrayBufferContentsArray> transferArrayBufferContents( |
| 122 v8::Isolate*, | 122 v8::Isolate*, |
| 123 const ArrayBufferArray&, | 123 const ArrayBufferArray&, |
| 124 ExceptionState&); | 124 ExceptionState&); |
| 125 | 125 |
| 126 static std::unique_ptr<ImageBitmapContentsArray> transferImageBitmapContents( | 126 static std::unique_ptr<ImageBitmapContentsArray> transferImageBitmapContents( |
| 127 v8::Isolate*, | 127 v8::Isolate*, |
| 128 const ImageBitmapArray&, | 128 const ImageBitmapArray&, |
| 129 ExceptionState&); | 129 ExceptionState&); |
| 130 | 130 |
| 131 // Informs the V8 about external memory allocated and owned by this object. | 131 // Informs V8 about external memory allocated and owned by this object. |
| 132 // Large values should contribute to GC counters to eventually trigger a GC, | 132 // Large values should contribute to GC counters to eventually trigger a GC, |
| 133 // otherwise flood of postMessage() can cause OOM. | 133 // otherwise flood of postMessage() can cause OOM. |
| 134 // Ok to invoke multiple times (only adds memory once). | 134 // Ok to invoke multiple times (only adds memory once). |
| 135 // The memory registration is revoked automatically in destructor. | 135 // The memory registration is revoked automatically in destructor. |
| 136 void registerMemoryAllocatedWithCurrentScriptContext(); | 136 void registerMemoryAllocatedWithCurrentScriptContext(); |
| 137 | 137 |
| 138 // Upon passing a serialized value from one context to another (via a | |
| 139 // postMessage()), the allocation amounts it has registered with the | |
| 140 // 'origining' context must be discharged, as the 'target' context will assume | |
| 141 // ownership of value. This method takes care of the first part of the | |
| 142 // external allocation bookkeeping, the above registration method the other | |
| 143 // half. | |
| 144 void unregisterMemoryAllocatedByCurrentScriptContext(); | |
|
jbroman
2017/03/07 18:00:04
Can you clarify why this is needed now? It looks l
sof
2017/03/07 19:14:03
- transferables (arraybuffers) will be accounted w
jbroman
2017/03/07 19:29:05
Ah, it wasn't obvious to me that this was intended
sof
2017/03/08 07:07:17
Added a method on ArrayBufferContents to handle th
| |
| 145 | |
| 138 const uint8_t* data() const { return m_dataBuffer.get(); } | 146 const uint8_t* data() const { return m_dataBuffer.get(); } |
| 139 size_t dataLengthInBytes() const { return m_dataBufferSize; } | 147 size_t dataLengthInBytes() const { return m_dataBufferSize; } |
| 140 | 148 |
| 141 BlobDataHandleMap& blobDataHandles() { return m_blobDataHandles; } | 149 BlobDataHandleMap& blobDataHandles() { return m_blobDataHandles; } |
| 142 ArrayBufferContentsArray* getArrayBufferContentsArray() { | 150 ArrayBufferContentsArray* getArrayBufferContentsArray() { |
| 143 return m_arrayBufferContentsArray.get(); | 151 return m_arrayBufferContentsArray.get(); |
| 144 } | 152 } |
| 145 ImageBitmapContentsArray* getImageBitmapContentsArray() { | 153 ImageBitmapContentsArray* getImageBitmapContentsArray() { |
| 146 return m_imageBitmapContentsArray.get(); | 154 return m_imageBitmapContentsArray.get(); |
| 147 } | 155 } |
| (...skipping 30 matching lines...) Expand all Loading... | |
| 178 | 186 |
| 179 std::unique_ptr<ArrayBufferContentsArray> m_arrayBufferContentsArray; | 187 std::unique_ptr<ArrayBufferContentsArray> m_arrayBufferContentsArray; |
| 180 std::unique_ptr<ImageBitmapContentsArray> m_imageBitmapContentsArray; | 188 std::unique_ptr<ImageBitmapContentsArray> m_imageBitmapContentsArray; |
| 181 BlobDataHandleMap m_blobDataHandles; | 189 BlobDataHandleMap m_blobDataHandles; |
| 182 intptr_t m_externallyAllocatedMemory; | 190 intptr_t m_externallyAllocatedMemory; |
| 183 }; | 191 }; |
| 184 | 192 |
| 185 } // namespace blink | 193 } // namespace blink |
| 186 | 194 |
| 187 #endif // SerializedScriptValue_h | 195 #endif // SerializedScriptValue_h |
| OLD | NEW |